From 55c7c2f48e51214dfa9eaf15742a8494370e6a6b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 7 Feb 2024 01:44:57 -0800 Subject: [PATCH 001/338] CMake: Remove leftover debug print --- src/platform/qt/CMakeLists.txt | 1 - 1 file changed, 1 deletion(-) diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index 610fa362dbf..cb224b0a67b 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -335,7 +335,6 @@ if(BUILD_GL OR BUILD_GLES2 OR BUILD_EPOXY) install(DIRECTORY ${PROJECT_SOURCE_DIR}/res/shaders DESTINATION ${DATADIR} COMPONENT ${BINARY_NAME}-qt) else() file(GLOB SHADERS ${PROJECT_SOURCE_DIR}/res/shaders/*.shader) - message(STATUS ${SHADERS}) file(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/shaders) foreach(SHADER_DIR ${SHADERS}) get_filename_component(SHADER ${SHADER_DIR} NAME) From c917a71ef8ac653bde6a9dfaf6bd09f2a5c70cb6 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 7 Feb 2024 03:38:07 -0800 Subject: [PATCH 002/338] Qt: Improve OpenGLES support and cleanup ifdef maze --- src/platform/qt/Display.cpp | 48 ++++++++++++----------------------- src/platform/qt/DisplayGL.cpp | 47 ++++++++++++++++++++++++++++++++++ src/platform/qt/DisplayGL.h | 1 + 3 files changed, 64 insertions(+), 32 deletions(-) diff --git a/src/platform/qt/Display.cpp b/src/platform/qt/Display.cpp index 8bec92f284b..2cc7df66ec1 100644 --- a/src/platform/qt/Display.cpp +++ b/src/platform/qt/Display.cpp @@ -33,49 +33,33 @@ QGBA::Display* QGBA::Display::create(QWidget* parent) { switch (s_driver) { #if defined(BUILD_GL) || defined(BUILD_GLES2) || defined(BUILD_GLES3) || defined(USE_EPOXY) case Driver::OPENGL: -#if defined(BUILD_GLES2) || defined(BUILD_GLES3) || defined(USE_EPOXY) - if (QOpenGLContext::openGLModuleType() == QOpenGLContext::LibGLES) { - format.setVersion(2, 0); - } else { - format.setVersion(3, 3); - } - format.setProfile(QSurfaceFormat::CoreProfile); - if (DisplayGL::supportsFormat(format)) { - QSurfaceFormat::setDefaultFormat(format); - } else { -#ifdef BUILD_GL - LOG(QT, WARN) << ("Failed to create an OpenGL Core context, trying old-style..."); - format.setVersion(1, 4); - format.setOption(QSurfaceFormat::DeprecatedFunctions); - if (!DisplayGL::supportsFormat(format)) { - return nullptr; - } -#else - return nullptr; -#endif + default: + if (DisplayGL::highestCompatible(format)) { + return new DisplayGL(format, parent); } - return new DisplayGL(format, parent); -#endif + break; #endif #ifdef BUILD_GL case Driver::OPENGL1: - format.setVersion(1, 4); - if (!DisplayGL::supportsFormat(format)) { - return nullptr; + if (QOpenGLContext::openGLModuleType() == QOpenGLContext::LibGL) { + format.setVersion(1, 4); + } else { + format.setVersion(1, 1); + } + if (DisplayGL::supportsFormat(format)) { + return new DisplayGL(format, parent); } - return new DisplayGL(format, parent); + break; #endif case Driver::QT: - return new DisplayQt(parent); - +#if !defined(BUILD_GL) && !defined(BUILD_GLES2) && !defined(BUILD_GLES3) && !defined(USE_EPOXY) default: -#if defined(BUILD_GL) || defined(BUILD_GLES2) || defined(BUILD_GLES3) || defined(USE_EPOXY) - return new DisplayGL(format, parent); -#else - return new DisplayQt(parent); #endif + return new DisplayQt(parent); + } + return nullptr; } QGBA::Display::Display(QWidget* parent) diff --git a/src/platform/qt/DisplayGL.cpp b/src/platform/qt/DisplayGL.cpp index e31437cad9e..3a4c3ffdd2d 100644 --- a/src/platform/qt/DisplayGL.cpp +++ b/src/platform/qt/DisplayGL.cpp @@ -53,6 +53,12 @@ typedef struct _XDisplay Display; #define OVERHEAD_NSEC 300000 #endif +// Legacy define from X11/X.h +#ifdef Unsorted +#undef Unsorted +#endif + +#include "LogController.h" #include "OpenGLBug.h" #include "utils.h" @@ -277,6 +283,47 @@ void DisplayGL::startDrawing(std::shared_ptr controller) { QTimer::singleShot(8, this, &DisplayGL::updateContentSize); } +bool DisplayGL::highestCompatible(QSurfaceFormat& format) { +#if defined(BUILD_GLES2) || defined(BUILD_GLES3) || defined(USE_EPOXY) + if (QOpenGLContext::openGLModuleType() == QOpenGLContext::LibGL) { + format.setVersion(3, 3); + format.setProfile(QSurfaceFormat::CoreProfile); + if (DisplayGL::supportsFormat(format)) { + return true; + } + } else { +#if defined(BUILD_GLES3) || defined(USE_EPOXY) + format.setVersion(3, 1); + if (DisplayGL::supportsFormat(format)) { + return true; + } +#endif +#if defined(BUILD_GLES2) || defined(USE_EPOXY) + format.setVersion(2, 0); + if (DisplayGL::supportsFormat(format)) { + return true; + } +#endif + } +#endif + +#ifdef BUILD_GL +#if defined(BUILD_GLES2) || defined(BUILD_GLES3) || defined(USE_EPOXY) + LOG(QT, WARN) << tr("Failed to create an OpenGL 3 context, trying old-style..."); +#endif + if (QOpenGLContext::openGLModuleType() == QOpenGLContext::LibGL) { + format.setVersion(1, 4); + } else { + format.setVersion(1, 1); + } + format.setOption(QSurfaceFormat::DeprecatedFunctions); + if (DisplayGL::supportsFormat(format)) { + return true; + } +#endif + return false; +} + bool DisplayGL::supportsFormat(const QSurfaceFormat& format) { if (!s_supports.contains(format)) { QOpenGLContext context; diff --git a/src/platform/qt/DisplayGL.h b/src/platform/qt/DisplayGL.h index d94a68621b2..71e2de5974f 100644 --- a/src/platform/qt/DisplayGL.h +++ b/src/platform/qt/DisplayGL.h @@ -96,6 +96,7 @@ Q_OBJECT int framebufferHandle() override; QSize contentSize() const override { return m_cachedContentSize; } + static bool highestCompatible(QSurfaceFormat&); static bool supportsFormat(const QSurfaceFormat&); public slots: From 49d9b70e6f2015165b6719a6da8ea842e996fde0 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 8 Feb 2024 17:15:18 -0800 Subject: [PATCH 003/338] Core: Move rewind state coalescing into mCoreRewindRestore --- include/mgba/core/rewind.h | 2 +- src/core/rewind.c | 46 ++++++++++++++++-------------- src/core/thread.c | 2 +- src/platform/qt/CoreController.cpp | 6 +--- 4 files changed, 28 insertions(+), 28 deletions(-) diff --git a/include/mgba/core/rewind.h b/include/mgba/core/rewind.h index 9d259555746..2f33886cad3 100644 --- a/include/mgba/core/rewind.h +++ b/include/mgba/core/rewind.h @@ -40,7 +40,7 @@ void mCoreRewindContextDeinit(struct mCoreRewindContext*); struct mCore; void mCoreRewindAppend(struct mCoreRewindContext*, struct mCore*); -bool mCoreRewindRestore(struct mCoreRewindContext*, struct mCore*); +bool mCoreRewindRestore(struct mCoreRewindContext*, struct mCore*, unsigned count); CXX_GUARD_END diff --git a/src/core/rewind.c b/src/core/rewind.c index 21120ec2154..b8ba752dd7f 100644 --- a/src/core/rewind.c +++ b/src/core/rewind.c @@ -115,7 +115,7 @@ void _rewindDiff(struct mCoreRewindContext* context) { context->currentState->unmap(context->currentState, next, size); } -bool mCoreRewindRestore(struct mCoreRewindContext* context, struct mCore* core) { +bool mCoreRewindRestore(struct mCoreRewindContext* context, struct mCore* core, unsigned count) { #ifndef DISABLE_THREADING if (context->onThread) { MutexLock(&context->mutex); @@ -129,30 +129,34 @@ bool mCoreRewindRestore(struct mCoreRewindContext* context, struct mCore* core) #endif return false; } - --context->size; - mCoreLoadStateNamed(core, context->previousState, SAVESTATE_SAVEDATA | SAVESTATE_RTC); - if (context->current == 0) { - context->current = mCoreRewindPatchesSize(&context->patchMemory); - } - --context->current; + for (; count && context->size; --count, --context->size) { + if (context->current == 0) { + context->current = mCoreRewindPatchesSize(&context->patchMemory); + } + --context->current; - if (context->size) { - struct PatchFast* patch = mCoreRewindPatchesGetPointer(&context->patchMemory, context->current); - size_t size2 = context->previousState->size(context->previousState); - size_t size = context->currentState->size(context->currentState); - if (size2 < size) { - size = size2; + if (context->size > 1) { + struct PatchFast* patch = mCoreRewindPatchesGetPointer(&context->patchMemory, context->current); + size_t size2 = context->previousState->size(context->previousState); + size_t size = context->currentState->size(context->currentState); + if (size2 < size) { + size = size2; + } + void* current = context->currentState->map(context->currentState, size, MAP_READ); + void* previous = context->previousState->map(context->previousState, size, MAP_WRITE); + patch->d.applyPatch(&patch->d, previous, size, current, size); + context->currentState->unmap(context->currentState, current, size); + context->previousState->unmap(context->previousState, previous, size); } - void* current = context->currentState->map(context->currentState, size, MAP_READ); - void* previous = context->previousState->map(context->previousState, size, MAP_WRITE); - patch->d.applyPatch(&patch->d, previous, size, current, size); - context->currentState->unmap(context->currentState, current, size); - context->previousState->unmap(context->previousState, previous, size); + struct VFile* nextState = context->previousState; + context->previousState = context->currentState; + context->currentState = nextState; } - struct VFile* nextState = context->previousState; - context->previousState = context->currentState; - context->currentState = nextState; + + mCoreLoadStateNamed(core, context->currentState, SAVESTATE_SAVEDATA | SAVESTATE_RTC); + + #ifndef DISABLE_THREADING if (context->onThread) { MutexUnlock(&context->mutex); diff --git a/src/core/thread.c b/src/core/thread.c index 903d4b8446a..b458f5e123c 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -153,7 +153,7 @@ void _frameStarted(void* context) { return; } if (thread->core->opts.rewindEnable && thread->core->opts.rewindBufferCapacity > 0) { - if (!thread->impl->rewinding || !mCoreRewindRestore(&thread->impl->rewind, thread->core)) { + if (!thread->impl->rewinding || !mCoreRewindRestore(&thread->impl->rewind, thread->core, 1)) { if (thread->impl->rewind.rewindFrameCounter == 0) { mCoreRewindAppend(&thread->impl->rewind, thread->core); thread->impl->rewind.rewindFrameCounter = thread->core->opts.rewindBufferInterval; diff --git a/src/platform/qt/CoreController.cpp b/src/platform/qt/CoreController.cpp index 2e2bd5fed7c..dd74cce7882 100644 --- a/src/platform/qt/CoreController.cpp +++ b/src/platform/qt/CoreController.cpp @@ -556,11 +556,7 @@ void CoreController::rewind(int states) { if (!states) { states = INT_MAX; } - for (int i = 0; i < states; ++i) { - if (!mCoreRewindRestore(&m_threadContext.impl->rewind, m_threadContext.core)) { - break; - } - } + mCoreRewindRestore(&m_threadContext.impl->rewind, m_threadContext.core, states); interrupter.resume(); emit frameAvailable(); emit rewound(); From cf54ddd864291a873dff0d5bb9583f27f1011ad0 Mon Sep 17 00:00:00 2001 From: oltolm Date: Sun, 7 Jan 2024 12:13:26 +0100 Subject: [PATCH 004/338] CMake: make compile with mingw-w64 and Qt6 --- .gitignore | 4 ++++ CMakeLists.txt | 4 +++- CMakePresets.json | 21 +++++++++++++++++++++ src/platform/sdl/CMakeLists.txt | 1 + 4 files changed, 29 insertions(+), 1 deletion(-) create mode 100644 CMakePresets.json diff --git a/.gitignore b/.gitignore index 999fdd67311..fedbc461f46 100644 --- a/.gitignore +++ b/.gitignore @@ -20,6 +20,10 @@ CMakeCache.txt CMakeFiles CMakeSettings.json +CMakeUserPresets.json +compile_commands.json +/.cache +/.vscode cmake_install.cmake hle-bios.bin version.c diff --git a/CMakeLists.txt b/CMakeLists.txt index a1e730e0430..4bf16066526 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -217,13 +217,15 @@ endif() # Platform support if(WIN32) set(WIN32_VERSION "${LIB_VERSION_MAJOR},${LIB_VERSION_MINOR},${LIB_VERSION_PATCH}") - add_definitions(-D_WIN32_WINNT=0x0600) set(CMAKE_WINDOWS_EXPORT_ALL_SYMBOLS TRUE) if(MSVC) add_definitions(-DNOMINMAX -DWIN32_LEAN_AND_MEAN) add_definitions(-D_UNICODE -DUNICODE) else() add_definitions(-D_GNU_SOURCE) + if(CMAKE_SIZEOF_VOID_P EQUAL 8) + add_compile_definitions(_FILE_OFFSET_BITS=64) + endif() endif() list(APPEND OS_LIB ws2_32 shlwapi) list(APPEND CORE_VFS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/windows/vfs-w32.c) diff --git a/CMakePresets.json b/CMakePresets.json new file mode 100644 index 00000000000..584b1987dae --- /dev/null +++ b/CMakePresets.json @@ -0,0 +1,21 @@ +{ + "version": 3, + "configurePresets": [ + { + "name": "clang", + "generator": "Ninja", + "cacheVariables": { + "CMAKE_BUILD_TYPE": "Debug", + "CMAKE_EXPORT_COMPILE_COMMANDS": "ON" + } + }, + { + "name": "gcc", + "generator": "Ninja", + "cacheVariables": { + "CMAKE_BUILD_TYPE": "Debug", + "CMAKE_EXPORT_COMPILE_COMMANDS": "ON" + } + } + ] +} \ No newline at end of file diff --git a/src/platform/sdl/CMakeLists.txt b/src/platform/sdl/CMakeLists.txt index ca1919da9a3..07c773fb286 100644 --- a/src/platform/sdl/CMakeLists.txt +++ b/src/platform/sdl/CMakeLists.txt @@ -125,6 +125,7 @@ target_link_libraries(${BINARY_NAME}-sdl ${BINARY_NAME} ${PLATFORM_LIBRARY} ${OP if(NOT WIN32) set_target_properties(${BINARY_NAME}-sdl PROPERTIES OUTPUT_NAME ${BINARY_NAME}) else() + target_compile_definitions(${BINARY_NAME}-sdl PRIVATE _WIN32_WINNT=0x0600) set_target_properties(${BINARY_NAME}-sdl PROPERTIES RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}") endif() install(TARGETS ${BINARY_NAME}-sdl DESTINATION ${CMAKE_INSTALL_BINDIR} COMPONENT ${BINARY_NAME}-sdl) From 3571b112dc821d3612e5073afb8b6be41a35dc55 Mon Sep 17 00:00:00 2001 From: oltolm Date: Sun, 7 Jan 2024 12:16:52 +0100 Subject: [PATCH 005/338] fix compilation warnings --- include/mgba-util/common.h | 4 ---- include/mgba-util/platform/windows/threading.h | 2 +- src/core/thread.c | 16 ++++++++-------- src/platform/qt/AudioProcessorSDL.h | 1 + src/platform/qt/ColorPicker.cpp | 4 +--- src/platform/qt/ForwarderController.cpp | 4 ++-- src/platform/qt/ForwarderGenerator3DS.h | 2 +- src/platform/qt/GBAKeyEditor.cpp | 1 + src/platform/qt/SettingsView.cpp | 1 + src/platform/qt/ShortcutController.cpp | 8 ++++---- src/platform/qt/input/SDLInputDriver.h | 2 ++ src/platform/qt/main.cpp | 10 ++++++---- .../qt/scripting/ScriptingController.cpp | 16 ++++++++-------- src/platform/qt/scripting/ScriptingController.h | 2 +- src/platform/sdl/main.c | 1 + 15 files changed, 38 insertions(+), 36 deletions(-) diff --git a/include/mgba-util/common.h b/include/mgba-util/common.h index 0fc10be58e5..4a4054c9efd 100644 --- a/include/mgba-util/common.h +++ b/include/mgba-util/common.h @@ -14,10 +14,6 @@ #define CXX_GUARD_END #endif -#ifdef __MINGW32__ -#define __USE_MINGW_ANSI_STDIO 1 -#endif - CXX_GUARD_START #include diff --git a/include/mgba-util/platform/windows/threading.h b/include/mgba-util/platform/windows/threading.h index 3f5de5a773d..df1e902050b 100644 --- a/include/mgba-util/platform/windows/threading.h +++ b/include/mgba-util/platform/windows/threading.h @@ -8,7 +8,7 @@ #include -#define _WIN32_WINNT 0x0600 +#define WIN32_LEAN_AND_MEAN #include #define THREAD_ENTRY DWORD WINAPI typedef THREAD_ENTRY ThreadEntry(LPVOID); diff --git a/src/core/thread.c b/src/core/thread.c index b458f5e123c..63b8e0d568a 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -218,17 +218,17 @@ ADD_CALLBACK(savedataUpdated) ADD_CALLBACK(alarm) #undef ADD_CALLBACK -#define CALLBACK(NAME) _script_ ## NAME +#define SCRIPT(NAME) _script_ ## NAME static void _mCoreThreadAddCallbacks(struct mCoreThread* threadContext) { struct mCoreCallbacks callbacks = { - .videoFrameEnded = CALLBACK(frame), - .coreCrashed = CALLBACK(crashed), - .sleep = CALLBACK(sleep), - .shutdown = CALLBACK(stop), - .keysRead = CALLBACK(keysRead), - .savedataUpdated = CALLBACK(savedataUpdated), - .alarm = CALLBACK(alarm), + .videoFrameEnded = SCRIPT(frame), + .coreCrashed = SCRIPT(crashed), + .sleep = SCRIPT(sleep), + .shutdown = SCRIPT(stop), + .keysRead = SCRIPT(keysRead), + .savedataUpdated = SCRIPT(savedataUpdated), + .alarm = SCRIPT(alarm), .context = threadContext }; threadContext->core->addCoreCallbacks(threadContext->core, &callbacks); diff --git a/src/platform/qt/AudioProcessorSDL.h b/src/platform/qt/AudioProcessorSDL.h index c2d5d0ee1e7..2f86c0e166a 100644 --- a/src/platform/qt/AudioProcessorSDL.h +++ b/src/platform/qt/AudioProcessorSDL.h @@ -9,6 +9,7 @@ #ifdef BUILD_SDL +#define SDL_MAIN_HANDLED #include "platform/sdl/sdl-audio.h" namespace QGBA { diff --git a/src/platform/qt/ColorPicker.cpp b/src/platform/qt/ColorPicker.cpp index 22d995c0f3d..8cebab5207a 100644 --- a/src/platform/qt/ColorPicker.cpp +++ b/src/platform/qt/ColorPicker.cpp @@ -44,13 +44,11 @@ bool ColorPicker::eventFilter(QObject* obj, QEvent* event) { return false; } - QWidget* swatch = static_cast(obj); - QColorDialog* colorPicker = new QColorDialog; colorPicker->setAttribute(Qt::WA_DeleteOnClose); colorPicker->setCurrentColor(m_defaultColor); colorPicker->open(); - connect(colorPicker, &QColorDialog::colorSelected, [this, swatch](const QColor& color) { + connect(colorPicker, &QColorDialog::colorSelected, [this](const QColor& color) { setColor(color); emit colorChanged(color); }); diff --git a/src/platform/qt/ForwarderController.cpp b/src/platform/qt/ForwarderController.cpp index 56e20201970..0934f1c69b2 100644 --- a/src/platform/qt/ForwarderController.cpp +++ b/src/platform/qt/ForwarderController.cpp @@ -232,9 +232,9 @@ bool ForwarderController::toolInstalled(const QString& tool) { void ForwarderController::connectReply(QNetworkReply* reply, Download download, void (ForwarderController::*next)(QNetworkReply*)) { #if (QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)) - connect(reply, &QNetworkReply::errorOccurred, this, [this, reply]() { + connect(reply, &QNetworkReply::errorOccurred, this, [this]() { #else - connect(reply, qOverload<>(&QNetworkReply::error), this, [this, reply]() { + connect(reply, qOverload<>(&QNetworkReply::error), this, [this]() { #endif emit buildFailed(); }); diff --git a/src/platform/qt/ForwarderGenerator3DS.h b/src/platform/qt/ForwarderGenerator3DS.h index b2258506341..8713be1bf51 100644 --- a/src/platform/qt/ForwarderGenerator3DS.h +++ b/src/platform/qt/ForwarderGenerator3DS.h @@ -23,7 +23,7 @@ Q_OBJECT System system() const override { return System::N3DS; } QString extension() const override { return QLatin1String("cia"); } - virtual QStringList externalTools() const { return {"bannertool", "3dstool", "ctrtool", "makerom"}; } + virtual QStringList externalTools() const override { return {"bannertool", "3dstool", "ctrtool", "makerom"}; } void rebuild(const QString& source, const QString& target) override; diff --git a/src/platform/qt/GBAKeyEditor.cpp b/src/platform/qt/GBAKeyEditor.cpp index 88963afa294..4536bda2ad2 100644 --- a/src/platform/qt/GBAKeyEditor.cpp +++ b/src/platform/qt/GBAKeyEditor.cpp @@ -18,6 +18,7 @@ #include "KeyEditor.h" #ifdef BUILD_SDL +#define SDL_MAIN_HANDLED #include "platform/sdl/sdl-events.h" #endif diff --git a/src/platform/qt/SettingsView.cpp b/src/platform/qt/SettingsView.cpp index 7f0fef53f99..04d7d16497d 100644 --- a/src/platform/qt/SettingsView.cpp +++ b/src/platform/qt/SettingsView.cpp @@ -26,6 +26,7 @@ #include #ifdef BUILD_SDL +#define SDL_MAIN_HANDLED #include "platform/sdl/sdl-events.h" #endif diff --git a/src/platform/qt/ShortcutController.cpp b/src/platform/qt/ShortcutController.cpp index d1165a9ba79..db7f27e6a92 100644 --- a/src/platform/qt/ShortcutController.cpp +++ b/src/platform/qt/ShortcutController.cpp @@ -143,7 +143,7 @@ bool ShortcutController::eventFilter(QObject* obj, QEvent* event) { QKeyEvent* keyEvent = static_cast(event); #ifdef ENABLE_SCRIPTING if (m_scripting) { - m_scripting->event(obj, event); + m_scripting->scriptingEvent(obj, event); } #endif if (keyEvent->isAutoRepeat()) { @@ -165,7 +165,7 @@ bool ShortcutController::eventFilter(QObject* obj, QEvent* event) { if (event->type() == GamepadButtonEvent::Down()) { #ifdef ENABLE_SCRIPTING if (m_scripting) { - m_scripting->event(obj, event); + m_scripting->scriptingEvent(obj, event); } #endif auto item = m_buttons.find(static_cast(event)->value()); @@ -186,7 +186,7 @@ bool ShortcutController::eventFilter(QObject* obj, QEvent* event) { if (event->type() == GamepadButtonEvent::Up()) { #ifdef ENABLE_SCRIPTING if (m_scripting) { - m_scripting->event(obj, event); + m_scripting->scriptingEvent(obj, event); } #endif auto item = m_buttons.find(static_cast(event)->value()); @@ -224,7 +224,7 @@ bool ShortcutController::eventFilter(QObject* obj, QEvent* event) { #ifdef ENABLE_SCRIPTING if (event->type() == GamepadHatEvent::Type()) { if (m_scripting) { - m_scripting->event(obj, event); + m_scripting->scriptingEvent(obj, event); } } #endif diff --git a/src/platform/qt/input/SDLInputDriver.h b/src/platform/qt/input/SDLInputDriver.h index 61f1e6238e0..4a4916ad39d 100644 --- a/src/platform/qt/input/SDLInputDriver.h +++ b/src/platform/qt/input/SDLInputDriver.h @@ -8,6 +8,8 @@ #include "input/Gamepad.h" #include "input/InputDriver.h" +#define SDL_MAIN_HANDLED + #include "platform/sdl/sdl-events.h" #include diff --git a/src/platform/qt/main.cpp b/src/platform/qt/main.cpp index c245cff5316..62967bf1a07 100644 --- a/src/platform/qt/main.cpp +++ b/src/platform/qt/main.cpp @@ -109,8 +109,9 @@ int main(int argc, char* argv[]) { #endif QTranslator qtTranslator; - qtTranslator.load(locale, "qt", "_", QLibraryInfo::location(QLibraryInfo::TranslationsPath)); - application.installTranslator(&qtTranslator); + if (qtTranslator.load(locale, "qt", "_", QLibraryInfo::location(QLibraryInfo::TranslationsPath))) { + application.installTranslator(&qtTranslator); + } #ifdef QT_STATIC QTranslator qtStaticTranslator; @@ -119,8 +120,9 @@ int main(int argc, char* argv[]) { #endif QTranslator langTranslator; - langTranslator.load(locale, binaryName, "-", ":/translations/"); - application.installTranslator(&langTranslator); + if (langTranslator.load(locale, binaryName, "-", ":/translations/")) { + application.installTranslator(&langTranslator); + } Window* w = application.newWindow(); w->loadConfig(); diff --git a/src/platform/qt/scripting/ScriptingController.cpp b/src/platform/qt/scripting/ScriptingController.cpp index 065754bf183..06adafdf59e 100644 --- a/src/platform/qt/scripting/ScriptingController.cpp +++ b/src/platform/qt/scripting/ScriptingController.cpp @@ -170,11 +170,11 @@ void ScriptingController::flushStorage() { } bool ScriptingController::eventFilter(QObject* obj, QEvent* ev) { - event(obj, ev); + scriptingEvent(obj, ev); return false; } -void ScriptingController::event(QObject* obj, QEvent* event) { +void ScriptingController::scriptingEvent(QObject* obj, QEvent* event) { if (!m_controller) { return; } @@ -188,7 +188,7 @@ void ScriptingController::event(QObject* obj, QEvent* event) { return; case QEvent::KeyPress: case QEvent::KeyRelease: { - struct mScriptKeyEvent ev{mSCRIPT_EV_TYPE_KEY}; + struct mScriptKeyEvent ev{{mSCRIPT_EV_TYPE_KEY}}; auto keyEvent = static_cast(event); ev.state = event->type() == QEvent::KeyRelease ? mSCRIPT_INPUT_STATE_UP : static_cast(event)->isAutoRepeat() ? mSCRIPT_INPUT_STATE_HELD : mSCRIPT_INPUT_STATE_DOWN; @@ -199,7 +199,7 @@ void ScriptingController::event(QObject* obj, QEvent* event) { } case QEvent::MouseButtonPress: case QEvent::MouseButtonRelease: { - struct mScriptMouseButtonEvent ev{mSCRIPT_EV_TYPE_MOUSE_BUTTON}; + struct mScriptMouseButtonEvent ev{{mSCRIPT_EV_TYPE_MOUSE_BUTTON}}; auto mouseEvent = static_cast(event); ev.mouse = 0; ev.state = event->type() == QEvent::MouseButtonPress ? mSCRIPT_INPUT_STATE_DOWN : mSCRIPT_INPUT_STATE_UP; @@ -208,7 +208,7 @@ void ScriptingController::event(QObject* obj, QEvent* event) { return; } case QEvent::MouseMove: { - struct mScriptMouseMoveEvent ev{mSCRIPT_EV_TYPE_MOUSE_MOVE}; + struct mScriptMouseMoveEvent ev{{mSCRIPT_EV_TYPE_MOUSE_MOVE}}; auto mouseEvent = static_cast(event); QPoint pos = mouseEvent->pos(); pos = static_cast(obj)->normalizedPoint(m_controller.get(), pos); @@ -219,7 +219,7 @@ void ScriptingController::event(QObject* obj, QEvent* event) { return; } case QEvent::Wheel: { - struct mScriptMouseWheelEvent ev{mSCRIPT_EV_TYPE_MOUSE_WHEEL}; + struct mScriptMouseWheelEvent ev{{mSCRIPT_EV_TYPE_MOUSE_WHEEL}}; auto wheelEvent = static_cast(event); QPoint adelta = wheelEvent->angleDelta(); QPoint pdelta = wheelEvent->pixelDelta(); @@ -240,7 +240,7 @@ void ScriptingController::event(QObject* obj, QEvent* event) { auto type = event->type(); if (type == GamepadButtonEvent::Down() || type == GamepadButtonEvent::Up()) { - struct mScriptGamepadButtonEvent ev{mSCRIPT_EV_TYPE_GAMEPAD_BUTTON}; + struct mScriptGamepadButtonEvent ev{{mSCRIPT_EV_TYPE_GAMEPAD_BUTTON}}; auto gamepadEvent = static_cast(event); ev.pad = 0; ev.state = event->type() == GamepadButtonEvent::Down() ? mSCRIPT_INPUT_STATE_DOWN : mSCRIPT_INPUT_STATE_UP; @@ -248,7 +248,7 @@ void ScriptingController::event(QObject* obj, QEvent* event) { mScriptContextFireEvent(&m_scriptContext, &ev.d); } if (type == GamepadHatEvent::Type()) { - struct mScriptGamepadHatEvent ev{mSCRIPT_EV_TYPE_GAMEPAD_HAT}; + struct mScriptGamepadHatEvent ev{{mSCRIPT_EV_TYPE_GAMEPAD_HAT}}; updateGamepad(); auto gamepadEvent = static_cast(event); ev.pad = 0; diff --git a/src/platform/qt/scripting/ScriptingController.h b/src/platform/qt/scripting/ScriptingController.h index a44e52b2eae..9e5b3f6b570 100644 --- a/src/platform/qt/scripting/ScriptingController.h +++ b/src/platform/qt/scripting/ScriptingController.h @@ -43,7 +43,7 @@ Q_OBJECT bool loadFile(const QString& path); bool load(VFileDevice& vf, const QString& name); - void event(QObject* obj, QEvent* ev); + void scriptingEvent(QObject* obj, QEvent* ev); mScriptContext* context() { return &m_scriptContext; } ScriptingTextBufferModel* textBufferModel() const { return m_bufferModel; } diff --git a/src/platform/sdl/main.c b/src/platform/sdl/main.c index f71f1cfc52c..d6a41f6117a 100644 --- a/src/platform/sdl/main.c +++ b/src/platform/sdl/main.c @@ -47,6 +47,7 @@ static void _loadState(struct mCoreThread* thread) { int main(int argc, char** argv) { #ifdef _WIN32 AttachConsole(ATTACH_PARENT_PROCESS); + freopen("CONOUT$", "w", stdout); #endif struct mSDLRenderer renderer = {0}; From c541a79e9564310d7a81d9668f41317acf30dda1 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 4 Mar 2024 21:52:25 -0800 Subject: [PATCH 006/338] Windows: Fix compilation woes from last commit --- include/mgba-util/common.h | 18 +++++++++++++----- include/mgba-util/platform/windows/threading.h | 2 -- src/platform/sdl/CMakeLists.txt | 1 - 3 files changed, 13 insertions(+), 8 deletions(-) diff --git a/include/mgba-util/common.h b/include/mgba-util/common.h index 4a4054c9efd..d91a6557c4f 100644 --- a/include/mgba-util/common.h +++ b/include/mgba-util/common.h @@ -16,6 +16,19 @@ CXX_GUARD_START +#ifdef _WIN32 +#define WIN32_LEAN_AND_MEAN +// Require Windows 7 or newer +#ifndef _WIN32_WINNT +#define _WIN32_WINNT 0x0601 +#elif _WIN32_WINNT < 0x0601 +#undef _WIN32_WINNT +#define _WIN32_WINNT 0x0601 +#endif +// WinSock2 gets very angry if it's included too late +#include +#endif + #include #include #include @@ -31,11 +44,6 @@ CXX_GUARD_START #include #include -#ifdef _WIN32 -// WinSock2 gets very angry if it's included too late -#include -#endif - #if defined(_MSC_VER) || defined(__cplusplus) #define restrict __restrict #endif diff --git a/include/mgba-util/platform/windows/threading.h b/include/mgba-util/platform/windows/threading.h index df1e902050b..7b1589075d2 100644 --- a/include/mgba-util/platform/windows/threading.h +++ b/include/mgba-util/platform/windows/threading.h @@ -8,8 +8,6 @@ #include -#define WIN32_LEAN_AND_MEAN -#include #define THREAD_ENTRY DWORD WINAPI typedef THREAD_ENTRY ThreadEntry(LPVOID); #define THREAD_EXIT(RES) return RES diff --git a/src/platform/sdl/CMakeLists.txt b/src/platform/sdl/CMakeLists.txt index 07c773fb286..ca1919da9a3 100644 --- a/src/platform/sdl/CMakeLists.txt +++ b/src/platform/sdl/CMakeLists.txt @@ -125,7 +125,6 @@ target_link_libraries(${BINARY_NAME}-sdl ${BINARY_NAME} ${PLATFORM_LIBRARY} ${OP if(NOT WIN32) set_target_properties(${BINARY_NAME}-sdl PROPERTIES OUTPUT_NAME ${BINARY_NAME}) else() - target_compile_definitions(${BINARY_NAME}-sdl PRIVATE _WIN32_WINNT=0x0600) set_target_properties(${BINARY_NAME}-sdl PROPERTIES RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}") endif() install(TARGETS ${BINARY_NAME}-sdl DESTINATION ${CMAKE_INSTALL_BINDIR} COMPONENT ${BINARY_NAME}-sdl) From 4ee633925c5389e214307b3dd64c7e575ff47efb Mon Sep 17 00:00:00 2001 From: TuxSH <1922548+TuxSH@users.noreply.github.com> Date: Sat, 12 Aug 2023 00:17:04 +0200 Subject: [PATCH 007/338] 3DS: Implement 3x sharp bilinear scaling and make it the default - Old method was 2x. 3x looks quite a bit sharper in aspect-fit mode on non-O2DS as the width is an integer number of half-width pixels. Since resulting upscaling ratio is 3x:1.5x, this gives very good results, althought it might be too sharp for your liking (YMMV). Not as much of a difference in screen-fit mode - Remove duplicate rendertarget as it was not necessary --- src/platform/3ds/main.c | 97 +++++++++++++++++++++-------------------- 1 file changed, 50 insertions(+), 47 deletions(-) diff --git a/src/platform/3ds/main.c b/src/platform/3ds/main.c index 470c50db7d2..0f7bb27b93d 100644 --- a/src/platform/3ds/main.c +++ b/src/platform/3ds/main.c @@ -47,8 +47,9 @@ static enum FilterMode { FM_NEAREST, FM_LINEAR_1x, FM_LINEAR_2x, + FM_LINEAR_3x, FM_MAX -} filterMode = FM_LINEAR_2x; +} filterMode = FM_LINEAR_3x; static enum DarkenMode { DM_NATIVE, @@ -97,9 +98,8 @@ static int bufferId = 0; static bool frameLimiter = true; static u32 frameCounter; -static C3D_RenderTarget* topScreen[2]; -static C3D_RenderTarget* bottomScreen[2]; -static int doubleBuffer = 0; +static C3D_RenderTarget* topScreen; +static C3D_RenderTarget* bottomScreen; static bool frameStarted = false; static C3D_RenderTarget* upscaleBuffer; @@ -115,28 +115,26 @@ static bool _initGpu(void) { } if (gfxIsWide()) { - topScreen[0] = C3D_RenderTargetCreate(240, 800, GPU_RB_RGB8, 0); - topScreen[1] = C3D_RenderTargetCreate(240, 800, GPU_RB_RGB8, 0); + topScreen = C3D_RenderTargetCreate(240, 800, GPU_RB_RGB8, 0); } else { - topScreen[0] = C3D_RenderTargetCreate(240, 400, GPU_RB_RGB8, 0); - topScreen[1] = C3D_RenderTargetCreate(240, 400, GPU_RB_RGB8, 0); + topScreen = C3D_RenderTargetCreate(240, 400, GPU_RB_RGB8, 0); } - bottomScreen[0] = C3D_RenderTargetCreate(240, 320, GPU_RB_RGB8, 0); - bottomScreen[1] = C3D_RenderTargetCreate(240, 320, GPU_RB_RGB8, 0); - if (!topScreen[0] || !topScreen[1] || !bottomScreen[0] || !bottomScreen[1]) { + bottomScreen = C3D_RenderTargetCreate(240, 320, GPU_RB_RGB8, 0); + if (!topScreen || !bottomScreen) { return false; } C3D_FrameBegin(0); - C3D_FrameDrawOn(bottomScreen[0]); - C3D_RenderTargetClear(bottomScreen[0], C3D_CLEAR_COLOR, 0, 0); - C3D_FrameDrawOn(topScreen[0]); - C3D_RenderTargetClear(topScreen[0], C3D_CLEAR_COLOR, 0, 0); - C3D_RenderTargetSetOutput(topScreen[0], GFX_TOP, GFX_LEFT, GX_TRANSFER_IN_FORMAT(GX_TRANSFER_FMT_RGB8) | GX_TRANSFER_OUT_FORMAT(GX_TRANSFER_FMT_RGB8)); - C3D_RenderTargetSetOutput(bottomScreen[0], GFX_BOTTOM, GFX_LEFT, GX_TRANSFER_IN_FORMAT(GX_TRANSFER_FMT_RGB8) | GX_TRANSFER_OUT_FORMAT(GX_TRANSFER_FMT_RGB8)); + C3D_FrameDrawOn(bottomScreen); + C3D_RenderTargetClear(bottomScreen, C3D_CLEAR_COLOR, 0, 0); + C3D_FrameDrawOn(topScreen); + C3D_RenderTargetClear(topScreen, C3D_CLEAR_COLOR, 0, 0); + C3D_RenderTargetSetOutput(topScreen, GFX_TOP, GFX_LEFT, GX_TRANSFER_IN_FORMAT(GX_TRANSFER_FMT_RGB8) | GX_TRANSFER_OUT_FORMAT(GX_TRANSFER_FMT_RGB8)); + C3D_RenderTargetSetOutput(bottomScreen, GFX_BOTTOM, GFX_LEFT, GX_TRANSFER_IN_FORMAT(GX_TRANSFER_FMT_RGB8) | GX_TRANSFER_OUT_FORMAT(GX_TRANSFER_FMT_RGB8)); C3D_FrameEnd(0); - if (!C3D_TexInitVRAM(&upscaleBufferTex, 512, 512, GPU_RGB8)) { + if (!C3D_TexInitVRAM(&upscaleBufferTex, 1024, 512, GPU_RGB8)) { + __builtin_trap(); return false; } upscaleBuffer = C3D_RenderTargetCreateFromTex(&upscaleBufferTex, GPU_TEXFACE_2D, 0, 0); @@ -164,10 +162,8 @@ static void _cleanup(void) { screenshotBuffer = NULL; } - C3D_RenderTargetDelete(topScreen[0]); - C3D_RenderTargetDelete(topScreen[1]); - C3D_RenderTargetDelete(bottomScreen[0]); - C3D_RenderTargetDelete(bottomScreen[1]); + C3D_RenderTargetDelete(topScreen); + C3D_RenderTargetDelete(bottomScreen); C3D_RenderTargetDelete(upscaleBuffer); C3D_TexDelete(&upscaleBufferTex); C3D_TexDelete(&outputTexture[0]); @@ -216,10 +212,10 @@ static void _drawStart(void) { C3D_FrameBegin(0); ctrStartFrame(); - C3D_FrameDrawOn(bottomScreen[doubleBuffer]); - C3D_RenderTargetClear(bottomScreen[doubleBuffer], C3D_CLEAR_COLOR, 0, 0); - C3D_FrameDrawOn(topScreen[doubleBuffer]); - C3D_RenderTargetClear(topScreen[doubleBuffer], C3D_CLEAR_COLOR, 0, 0); + C3D_FrameDrawOn(bottomScreen); + C3D_RenderTargetClear(bottomScreen, C3D_CLEAR_COLOR, 0, 0); + C3D_FrameDrawOn(topScreen); + C3D_RenderTargetClear(topScreen, C3D_CLEAR_COLOR, 0, 0); } static void _drawEnd(void) { @@ -227,12 +223,10 @@ static void _drawEnd(void) { return; } ctrEndFrame(); - C3D_RenderTargetSetOutput(topScreen[doubleBuffer], GFX_TOP, GFX_LEFT, GX_TRANSFER_IN_FORMAT(GX_TRANSFER_FMT_RGB8) | GX_TRANSFER_OUT_FORMAT(GX_TRANSFER_FMT_RGB8)); - C3D_RenderTargetSetOutput(bottomScreen[doubleBuffer], GFX_BOTTOM, GFX_LEFT, GX_TRANSFER_IN_FORMAT(GX_TRANSFER_FMT_RGB8) | GX_TRANSFER_OUT_FORMAT(GX_TRANSFER_FMT_RGB8)); + C3D_RenderTargetSetOutput(topScreen, GFX_TOP, GFX_LEFT, GX_TRANSFER_IN_FORMAT(GX_TRANSFER_FMT_RGB8) | GX_TRANSFER_OUT_FORMAT(GX_TRANSFER_FMT_RGB8)); + C3D_RenderTargetSetOutput(bottomScreen, GFX_BOTTOM, GFX_LEFT, GX_TRANSFER_IN_FORMAT(GX_TRANSFER_FMT_RGB8) | GX_TRANSFER_OUT_FORMAT(GX_TRANSFER_FMT_RGB8)); C3D_FrameEnd(0); frameStarted = false; - - doubleBuffer ^= 1; } static int _batteryState(void) { @@ -256,7 +250,7 @@ static int _batteryState(void) { } static void _guiPrepare(void) { - C3D_FrameDrawOn(bottomScreen[doubleBuffer]); + C3D_FrameDrawOn(bottomScreen); ctrSetViewportSize(320, 240, true); } @@ -476,21 +470,33 @@ static u32 _setupTex(int out, bool faded) { static void _drawTex(struct mCore* core, bool faded, bool both) { unsigned screen_w, screen_h; bool isWide = screenMode >= SM_PA_TOP && gfxIsWide(); + + if (filterMode < FM_LINEAR_1x || filterMode > FM_LINEAR_3x) { + // Out-of-range filtering modes are not supported + filterMode = FM_LINEAR_3x; + } + int mult = 1 + filterMode - FM_LINEAR_1x; + switch (screenMode) { case SM_PA_BOTTOM: - C3D_FrameDrawOn(bottomScreen[doubleBuffer]); + C3D_FrameDrawOn(bottomScreen); screen_w = 320; screen_h = 240; break; case SM_PA_TOP: - C3D_FrameDrawOn(topScreen[doubleBuffer]); + C3D_FrameDrawOn(topScreen); screen_w = isWide ? 800 : 400; screen_h = 240; break; default: C3D_FrameDrawOn(upscaleBuffer); - screen_w = 512; - screen_h = 512; + // PICA200 erratum: if viewport X coord exceeds 1023, entire polygon + // is not rendered. If viewport Y coord exceeds 1016, GPU hangs. + // This can not be mitigated by scissor testing. + // C3D_FrameDrawOn sets the viewport dims to the texture's dims, + // thus we must re-set the viewport ourselves. + screen_w = 256 * mult; + screen_h = 256 * mult; break; } int wide = isWide ? 2 : 1; @@ -523,17 +529,13 @@ static void _drawTex(struct mCore* core, bool faded, bool both) { case SM_AF_BOTTOM: case SM_SF_TOP: case SM_SF_BOTTOM: - default: - if (filterMode == FM_LINEAR_1x) { - w = corew; - h = coreh; - } else { - w = corew * 2; - h = coreh * 2; - } + default: { + w = corew * mult; + h = coreh * mult; ctrSetViewportSize(screen_w, screen_h, false); break; } + } uint32_t color = _setupTex(activeOutputTexture, faded); ctrAddRectEx(color, x, y, w, h, 0, 0, corew, coreh, 0); @@ -549,10 +551,10 @@ static void _drawTex(struct mCore* core, bool faded, bool both) { coreh = h; screen_h = 240; if (screenMode < SM_PA_TOP) { - C3D_FrameDrawOn(bottomScreen[doubleBuffer]); + C3D_FrameDrawOn(bottomScreen); screen_w = 320; } else { - C3D_FrameDrawOn(topScreen[doubleBuffer]); + C3D_FrameDrawOn(topScreen); screen_w = isWide ? 800 : 400; } ctrSetViewportSize(screen_w, screen_h, true); @@ -979,13 +981,14 @@ int main(int argc, char* argv[]) { .title = "Filtering", .data = GUI_V_S("filterMode"), .submenu = 0, - .state = FM_LINEAR_2x, + .state = FM_LINEAR_3x, .validStates = (const char*[]) { NULL, // Disable choosing nearest neighbor; it always looks bad "Bilinear (smoother)", "Bilinear (pixelated)", + "Bilinear (ultrasharp)", }, - .nStates = 3 + .nStates = 4 }, { .title = "Screen darkening", From 369e6a03f4b09b3585a4923dd682faa34e0bbf67 Mon Sep 17 00:00:00 2001 From: TuxSH <1922548+TuxSH@users.noreply.github.com> Date: Sun, 17 Sep 2023 18:20:47 +0200 Subject: [PATCH 008/338] Fix menu bug that allowed the selection of invalid states when wrap=true --- src/util/gui/menu.c | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/src/util/gui/menu.c b/src/util/gui/menu.c index 584f2d0d5e0..f0c624f1715 100644 --- a/src/util/gui/menu.c +++ b/src/util/gui/menu.c @@ -18,30 +18,33 @@ DEFINE_VECTOR(GUIMenuItemList, struct GUIMenuItem); DEFINE_VECTOR(GUIMenuSavedList, struct GUIMenuSavedState); void _itemNext(struct GUIMenuItem* item, bool wrap) { - if (item->state < item->nStates - 1) { + if (wrap || item->state < item->nStates - 1) { unsigned oldState = item->state; do { ++item->state; + if (item->state >= item->nStates) { + item->state -= item->nStates; + } } while (!item->validStates[item->state] && item->state < item->nStates - 1); if (!item->validStates[item->state]) { item->state = oldState; } - } else if (wrap) { - item->state = 0; } } void _itemPrev(struct GUIMenuItem* item, bool wrap) { - if (item->state > 0) { + if (wrap || item->state > 0) { unsigned oldState = item->state; do { - --item->state; + if (item->state > 0) { + --item->state; + } else { + item->state = item->nStates - 1; + } } while (!item->validStates[item->state] && item->state > 0); if (!item->validStates[item->state]) { item->state = oldState; } - } else if (wrap) { - item->state = item->nStates - 1; } } From d8ab5529a700cdf2ec5dd09cab580180d53fe717 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 11 Mar 2024 21:39:45 -0700 Subject: [PATCH 009/338] GB: Fix type coercion --- src/gb/gb.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/gb/gb.c b/src/gb/gb.c index 9583125244b..b3bb62a8021 100644 --- a/src/gb/gb.c +++ b/src/gb/gb.c @@ -106,7 +106,7 @@ static void GBDeinit(struct mCPUComponent* component) { bool GBLoadGBX(struct GBXMetadata* metadata, struct VFile* vf) { uint8_t footer[16]; - if (vf->seek(vf, -sizeof(footer), SEEK_END) < 0) { + if (vf->seek(vf, -(off_t) sizeof(footer), SEEK_END) < 0) { return false; } if (vf->read(vf, footer, sizeof(footer)) < (ssize_t) sizeof(footer)) { @@ -1100,7 +1100,7 @@ bool GBIsROM(struct VFile* vf) { } uint8_t footer[16]; - vf->seek(vf, -sizeof(footer), SEEK_END); + vf->seek(vf, -(off_t) sizeof(footer), SEEK_END); if (vf->read(vf, footer, sizeof(footer)) < (ssize_t) sizeof(footer)) { return false; } From c8c9fcb665271054e8ed9a87f555c7b37d64e39c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 12 Mar 2024 17:46:25 -0700 Subject: [PATCH 010/338] SDL: Use SDL_GameControllerRumble instead of SDL_JoystickRumble if available --- src/platform/sdl/sdl-events.c | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/src/platform/sdl/sdl-events.c b/src/platform/sdl/sdl-events.c index a675ff2c093..41783b3c3c0 100644 --- a/src/platform/sdl/sdl-events.c +++ b/src/platform/sdl/sdl-events.c @@ -665,13 +665,22 @@ void mSDLHandleEvent(struct mCoreThread* context, struct mSDLPlayer* sdlContext, #if SDL_VERSION_ATLEAST(2, 0, 0) static void _mSDLSetRumble(struct mRumble* rumble, int enable) { struct mSDLRumble* sdlRumble = (struct mSDLRumble*) rumble; - if (!sdlRumble->p->joystick + if (!sdlRumble->p->joystick) { + return; + } + #if !SDL_VERSION_ATLEAST(2, 0, 9) - || !sdlRumble->p->joystick->haptic || !SDL_HapticRumbleSupported(sdlRumble->p->joystick->haptic) + if (!sdlRumble->p->joystick->haptic || !SDL_HapticRumbleSupported(sdlRumble->p->joystick->haptic)) { + return; + } #endif - ) { + +#if SDL_VERSION_ATLEAST(2, 0, 18) + if (!sdlRumble->p->joystick->controller || !SDL_GameControllerHasRumble(sdlRumble->p->joystick->controller)) { return; } +#endif + int8_t originalLevel = sdlRumble->level; sdlRumble->level += enable; if (CircleBufferSize(&sdlRumble->history) == RUMBLE_PWM) { @@ -689,7 +698,11 @@ static void _mSDLSetRumble(struct mRumble* rumble, int enable) { } sdlRumble->activeLevel = activeLevel; #if SDL_VERSION_ATLEAST(2, 0, 9) - SDL_JoystickRumble(sdlRumble->p->joystick->joystick, activeLevel * 0xFFFF, activeLevel * 0xFFFF, 500); + if (sdlRumble->p->joystick->controller) { + SDL_GameControllerRumble(sdlRumble->p->joystick->controller, activeLevel * 0xFFFF, activeLevel * 0xFFFF, 500); + } else { + SDL_JoystickRumble(sdlRumble->p->joystick->joystick, activeLevel * 0xFFFF, activeLevel * 0xFFFF, 500); + } #else if (sdlRumble->activeLevel > 0.5 / RUMBLE_STEPS) { SDL_HapticRumbleStop(sdlRumble->p->joystick->haptic); From 4fdadc585d2f5d7e389b8b23f737ef13f1c99852 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 17 Mar 2024 19:53:41 -0700 Subject: [PATCH 011/338] GB Audio: Fix audio envelope timing resetting too often (fixes #3164) --- CHANGES | 1 + .../nrx2_speed_change/xbaseline_0000.png | Bin 1388 -> 1193 bytes .../nrx2_speed_change/xbaseline_0000.png | Bin 1402 -> 1201 bytes src/gb/audio.c | 27 +++++++++++------- 4 files changed, 17 insertions(+), 11 deletions(-) diff --git a/CHANGES b/CHANGES index d850f2002ed..efb7d494e1c 100644 --- a/CHANGES +++ b/CHANGES @@ -6,6 +6,7 @@ Features: - New unlicensed GB mappers: NT (older types 1 and 2), Li Cheng, GGB-81 - Debugger: Add range watchpoints Emulation fixes: + - GB Audio: Fix audio envelope timing resetting too often (fixes mgba.io/i/3164) - GB I/O: Fix STAT writing IRQ trigger conditions (fixes mgba.io/i/2501) - GB Serialize: Add missing Pocket Cam state to savestates - GB Video: Implement DMG-style sprite ordering diff --git a/cinema/gb/samesuite/apu/channel_1/nrx2_speed_change/xbaseline_0000.png b/cinema/gb/samesuite/apu/channel_1/nrx2_speed_change/xbaseline_0000.png index 0032b919f1aaef5acc9573be68705c0633b9bf45..e541e5c0ba570a3e33559ffc29e4b643a51c3c73 100644 GIT binary patch literal 1193 zcmeAS@N?(olHy`uVBq!ia0vp^3xIe62NRHFxc>b*0|QHer;B4q#hkZu1B)Ij2)I1G zGVen9ly#nVD`bV)QW`sX=YF>fQeM_O;kJNUk!CbU;{ETsKrC?RK-v6W&HF{`wjT?4 zR9gGGBJHw!(&@(r*}r;kL~XjUea`E*lbkxQe_i`{rmwuyjqiW!_Ag%<&GE2ocVxe2 z=5OtdU(?zRzvX6gD=@k_tG|2QecN)a`yNj#ka0iLoAv$Xj8D4BU#~^%`PAQ&zWTqA&HMZNpTzvXaFb`-OXmlm^fa>{Pd3f2l3rn7yvU^Puyt*q{iO$= zeXqHv`2_w9DZa?iy*+pL{rCP~3x93id@;IoE1S{rT(LatkxJ7T@-=UUhfVw&UHJ_l?5l@0=k3FN~9eE`1C0%@xR;^KVZP z;|uFA`gisAgzn3~{iW#3{#EbIf4G)Ev@N-IaK~<*hsC7@AFo^f+F11}q4d!6R}WPG z32oVP&!(gE;YQvQ$G7VIYW(%b&}*Oac~M@ULno|e{61(rNq4Pg=I-lrwx`S$f2=xf z$JMVu@3OpuyY9+C?U!epXGqB1Zm5Yly-0q=az3%;|0^$kJ3Y0kJZsZZQ`Ox3t8l%x zr3Uxs#&sUhi;D7>UBhP_5tA=>8o1K7c~bc2O{ZLZnw_ox3pkUTl<+LSGO zLnoKU^-Pa=6m~tBeYNlnS5UAVeOcpoEv(AO>io%Bf%(Q3YU_?H{Ip`tBD<-ng}U8! zOYY4s&x@#v$T{+0HTVS|N)4j)_h&}7~}l3@QPfcfnQP!Z(m>gTe~DWM4f DU*lx* literal 1388 zcmdUv?N<^86vk;4^a8lrI-w4A&6m^4Nz+I{GZQu6h}2Wl&}4W{h%|J)fRRXyEmKOQQc@iFPQo!3MuI2}|BQXO&pr2kxaapgA8rK>8v|MAwhjOQ zKw|e{lAOK4SygL3b1FbRuLb~C2gYI|QVKY;H&ul#UZ0o!afI7X4WbrB_ni-OKXwiv zSog{nuux6Jt2W37gD6^iwg&%1n60JBJKp{CIR7tNKs6O-hXL|jMED8Z0j$LnG4b^sdS4Ef+3rd3q;+xBd{d$V(ICH&Wtxge|ueP zAdsD_diOxqL+7hf+;G7)O~u@E}wyB zfb2EmKeyxaS zZM#Z26=Ay4+06r`<&;MoDi5GjqG$2BSS6~1v{=2v6LRTeA#a&enRPn=yfvhl@D|nK zo8*Dv%0i}M5}Q|ySwH2&L)kL;X3SIpv;0hyBW?+59A$QVBSp#)B_JTB9h=s#P|URq zE~7Z_f|~5I%CjNM`ET^%s(b&I3lN7QOdjIKI>YqArGW{N%AVPb8!Em7%^464zPL3o zgj{%5d*wnD&21=Ca_#PJHTvrAj3{;04}aUarBZZ)OkblJQ{GtF&=sjm2CaW2MQ0Cl7UC^SKyE&JB$5PA zpz>tlhd_S1KE7z+J~X=9IVj(UQcg<>+Nrf7;vVr$W3v|LS#p_)ZQ`q{BHCN&F*J_^ z4*GpvE7?1){^$L_T&hb~qG0eV_R!kGZWN5maD9%ldPr8KUtC)c(iie|8ZRZ?=wi(^ z7$I1LT^f+4#iyDw%3jPJ?HeUnLWry`9(0<-BmJ4TDeR8cbLN#3#BbMJ>$sV`=t}2r zcKHaM6N2}N@+7a_4Yp7iC)u;^a=qPr=HFj2qQNSJ_D%)UPm??{o~2&4khckPmjnl6 z_4CIbecEN{m#Vt_P6kOIfC-)`fp(d1)1EkH4Hu---+XSi}S?G3TQZVo{`lh^CaO~>;2Ucf4UI`8oG4x^`n*p{CA)Q9yH zM6i76==L8KeCc=I6OnY;Z?e(;%u~k^!9lRE+`v!>upCJL|E>GNckJxus7M#&%U?7$ L3X2i!%`E*7PTjq& diff --git a/cinema/gb/samesuite/apu/channel_2/nrx2_speed_change/xbaseline_0000.png b/cinema/gb/samesuite/apu/channel_2/nrx2_speed_change/xbaseline_0000.png index 2804b6f3a5f9ecfc563b1f9f493e383099380a35..5173a31fdeba2b6065b2a4d660eecb5cf72d6bd5 100644 GIT binary patch literal 1201 zcmeAS@N?(olHy`uVBq!ia0vp^3xIe62NRHFxc>b*0|QHir;B4q#hkZuFHU--AmCb< zwf{oBPu=9&1>3q?8yqBBUt9X;7CU!@PnZ`W`FyW^-(gpo;}7@FpK(6gIe4BYN0S$S z`Io(qBYovL)=qt0+WEpf>9k7Wyq$X)h+lg}(>=pIk1x=O^1egYw;0?=S5>vF6ssx~s7zwR2v-zQ4Kq+r_$9LHEB4 zw!QsPcy8|VpB)zGjklaV^?dC@&GUCI&R%fo@a*G{|NTFe{oY>Y(z^9u^NlUyI-VUn z>6HX@_~Q7reBW|Qv*vhSd-&~R$d{D|PclkN#$1nyO9=nZ{LAHA(I2;hs;;_a2fzAW zlTPz-4K`eJk>RxU^Lgi=d)Lm`xA*VywZZr1m%e@wSNn3s&R>lmpC7#Q?{(Fy2ak5o z>1O{`zh_Nw{+IiQ`iu2+)|yF0XQn@0d-Yod*lEY#FXLUX&b+XDU%AcCUzXedyV;g* zu&R5ZA6)4hbm{i#4Uaim9x0wbvS9vVbABghZyD*A%6eZn8g+WFeUbi3I5|#g+8oYi z@$1WXzYr^$ofzrH)7JarmDLaJ4}W*RIPK?ERlW1nx=*LS?2lvLELSsa;_rin!FR&{ z)_qW#|6={++dO={x`w46{C*voF}+PS{m_G>UyWZs_;r@;2M@FH4%Nveb&~mp%w^Yu z*;hYa*}U}Ym4mN%&OBIGGpF+3Z^5WPo4#T`;gc=bt|_sHbk3ouQiAx$jwC z%X9WKdqndRq(Iiwd}ar0vo-pi{`Ib&L{T# z+WEA}zxUnYkDHj1+1vSf@2n-CPgiuS=9PnV%!}Q!Wu8^UoP*C(cK)9~_1>cRC&GVA zt7acuxKQ<5t9xqftK>+b=}{NYUwQuQDsOjuoSI>U=3ft4nQL*U?$}DqIJlHqdlt|* z$ql>f{#Zt;CC}euQupOQ<8$K~RuzsQxBp4jDg3cq=25~13ke-Qw(jPGLz8(f{=hE# UH?f-xJwQc~r>mdKI;Vst0G@ehoB#j- literal 1402 zcmdUv`BTyf0L9tb$lR2*3u8hmrghycz|>qt%_}nvODanikIalvL|YM9(2{1WwLFHz z`^Yj+OhnyAGa`?~V@<@PG+{HZ(2(ORNgiu|#{Tf$n|VKd=Kb*Qp2m5b7{iP~AdrdA z3D1D_EM8Z-(S~&g4eN(NpiOQ*o^EI9`SS&0nsV<}PoKW8?rV>P%A=ZHlyk|)%)Z}) z&1o({8}*n&;bo*dn9pA=wk@*LFs9YRd~a^eUChbe#%O86Xyc_*MsAR>d)XaXH#+Xn z>IK@O9j+&e>eoiJ#CfyL4N7p-=l}ft0dn~Ay&Ti zqBAkB6Ibk{>Y2RE_}QD@YbEmOxFYi}OQ~b!A|q+XLais~0L>VzGD; z>1Ye9M)fenxQ)7==oJB*Fj2<$H=#(CPiDcxU6HV{SdUxBH}Y)gqm8;_HNa^GHA>GncBMS1yolbu#EsF`|e@KLs6%?lis zw!=xiGHj+Hj6ua;grMviYyc#XgRvs9tDe|DUfWQPC{al`nlZZh|Ml4c(E;` zY{pKf&N%apNk$tlXD-Dyz_nIPwc@IIFmKCj96!@=llcMyo-R%6y`o|-xzN4pyvZkn zQ}o;B{F$^QYQ$iSii diff --git a/src/gb/audio.c b/src/gb/audio.c index 996fce66d14..cf5445e1570 100644 --- a/src/gb/audio.c +++ b/src/gb/audio.c @@ -33,10 +33,10 @@ static void _writeDuty(struct GBAudioEnvelope* envelope, uint8_t value); static bool _writeEnvelope(struct GBAudioEnvelope* envelope, uint8_t value, enum GBAudioStyle style); static void _resetSweep(struct GBAudioSweep* sweep); -static bool _resetEnvelope(struct GBAudioEnvelope* sweep); +static bool _resetEnvelope(struct GBAudioEnvelope* sweep, enum GBAudioStyle style); static void _updateEnvelope(struct GBAudioEnvelope* envelope); -static void _updateEnvelopeDead(struct GBAudioEnvelope* envelope); +static void _updateEnvelopeDead(struct GBAudioEnvelope* envelope, enum GBAudioStyle style); static bool _updateSweep(struct GBAudioSquareChannel* sweep, bool initial); static void _updateSquareSample(struct GBAudioSquareChannel* ch); @@ -192,7 +192,7 @@ void GBAudioWriteNR14(struct GBAudio* audio, uint8_t value) { } } if (GBAudioRegisterControlIsRestart(value << 8)) { - audio->playingCh1 = _resetEnvelope(&audio->ch1.envelope); + audio->playingCh1 = _resetEnvelope(&audio->ch1.envelope, audio->style); audio->ch1.sweep.realFrequency = audio->ch1.control.frequency; _resetSweep(&audio->ch1.sweep); if (audio->playingCh1 && audio->ch1.sweep.shift) { @@ -243,7 +243,7 @@ void GBAudioWriteNR24(struct GBAudio* audio, uint8_t value) { } } if (GBAudioRegisterControlIsRestart(value << 8)) { - audio->playingCh2 = _resetEnvelope(&audio->ch2.envelope); + audio->playingCh2 = _resetEnvelope(&audio->ch2.envelope, audio->style); if (!audio->ch2.control.length) { audio->ch2.control.length = 64; @@ -383,7 +383,7 @@ void GBAudioWriteNR44(struct GBAudio* audio, uint8_t value) { } } if (GBAudioRegisterNoiseControlIsRestart(value)) { - audio->playingCh4 = _resetEnvelope(&audio->ch4.envelope); + audio->playingCh4 = _resetEnvelope(&audio->ch4.envelope, audio->style); audio->ch4.lfsr = 0; if (!audio->ch4.length) { @@ -877,9 +877,10 @@ static void _sample(struct mTiming* timing, void* user, uint32_t cyclesLate) { mTimingSchedule(timing, &audio->sampleEvent, audio->sampleInterval * audio->timingFactor - cyclesLate); } -bool _resetEnvelope(struct GBAudioEnvelope* envelope) { +bool _resetEnvelope(struct GBAudioEnvelope* envelope, enum GBAudioStyle style) { envelope->currentVolume = envelope->initialVolume; - _updateEnvelopeDead(envelope); + envelope->nextStep = envelope->stepTime; + _updateEnvelopeDead(envelope, style); return envelope->initialVolume || envelope->direction; } @@ -932,7 +933,7 @@ bool _writeEnvelope(struct GBAudioEnvelope* envelope, uint8_t value, enum GBAudi } envelope->currentVolume &= 0xF; } - _updateEnvelopeDead(envelope); + _updateEnvelopeDead(envelope, style); return envelope->initialVolume || envelope->direction; } @@ -968,16 +969,20 @@ static void _updateEnvelope(struct GBAudioEnvelope* envelope) { } } -static void _updateEnvelopeDead(struct GBAudioEnvelope* envelope) { +static void _updateEnvelopeDead(struct GBAudioEnvelope* envelope, enum GBAudioStyle style) { if (!envelope->stepTime) { envelope->dead = envelope->currentVolume ? 1 : 2; } else if (!envelope->direction && !envelope->currentVolume) { envelope->dead = 2; } else if (envelope->direction && envelope->currentVolume == 0xF) { envelope->dead = 1; - } else { + } else if (envelope->dead) { + // TODO: Figure out if this happens on DMG/CGB or just AGB + // TODO: Figure out the exact circumstances that lead to reloading the step + if (style == GB_AUDIO_GBA) { + envelope->nextStep = envelope->stepTime; + } envelope->dead = 0; - envelope->nextStep = envelope->stepTime; } } From 776d52a2c6000bb690fc2f81bbb86a5958c2b9d3 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 18 Mar 2024 23:17:42 -0700 Subject: [PATCH 012/338] Scripting: Export new image masking function --- include/mgba-util/image.h | 1 + res/scripts/color-mask.lua | 34 +++++++++++++ res/scripts/logo-bg.png | Bin 0 -> 1268 bytes res/scripts/logo-bounce.lua | 39 ++++++++++----- res/scripts/logo-fg.png | Bin 0 -> 888 bytes res/scripts/wheel.png | Bin 0 -> 6931 bytes src/script/image.c | 8 ++++ src/util/image.c | 90 ++++++++++++++++++++++++++++++---- src/util/test/image.c | 93 ++++++++++++++++++++++++++++++++++++ 9 files changed, 246 insertions(+), 19 deletions(-) create mode 100644 res/scripts/color-mask.lua create mode 100644 res/scripts/logo-bg.png create mode 100644 res/scripts/logo-fg.png create mode 100644 res/scripts/wheel.png diff --git a/include/mgba-util/image.h b/include/mgba-util/image.h index 31514687d9c..b86b2135a4b 100644 --- a/include/mgba-util/image.h +++ b/include/mgba-util/image.h @@ -138,6 +138,7 @@ void mPainterInit(struct mPainter*, struct mImage* backing); void mPainterDrawRectangle(struct mPainter*, int x, int y, int width, int height); void mPainterDrawLine(struct mPainter*, int x1, int y1, int x2, int y2); void mPainterDrawCircle(struct mPainter*, int x, int y, int diameter); +void mPainterDrawMask(struct mPainter*, const struct mImage* mask, int x, int y); uint32_t mColorConvert(uint32_t color, enum mColorFormat from, enum mColorFormat to); uint32_t mImageColorConvert(uint32_t color, const struct mImage* from, enum mColorFormat to); diff --git a/res/scripts/color-mask.lua b/res/scripts/color-mask.lua new file mode 100644 index 00000000000..25a51f8052b --- /dev/null +++ b/res/scripts/color-mask.lua @@ -0,0 +1,34 @@ +local state = {} +state.wheel = image.load(script.dir .. "/wheel.png") +state.overlay = canvas:newLayer(state.wheel.width, state.wheel.height) +state.painter = image.newPainter(state.overlay.image) +state.phase = 0 +state.speed = 0.01 +state.painter:setFill(true) +state.painter:setStrokeWidth(0) + +function state.update() + local r = math.fmod(state.phase * 3, math.pi * 2) + local g = math.fmod(state.phase * 5, math.pi * 2) + local b = math.fmod(state.phase * 7, math.pi * 2) + local color = 0xFF000000 + color = color | math.floor((math.sin(r) + 1) * 127.5) << 16 + color = color | math.floor((math.sin(g) + 1) * 127.5) << 8 + color = color | math.floor((math.sin(b) + 1) * 127.5) + + -- Clear image + state.painter:setBlend(false) + state.painter:setFillColor(0) + state.painter:drawRectangle(0, 0, state.wheel.width, state.wheel.height) + -- Draw mask + state.painter:setBlend(true) + state.painter:setFillColor(color | 0xFF000000) + state.painter:drawMask(state.wheel, 0, 0) + + state.overlay:update() + state.phase = math.fmod(state.phase + state.speed, math.pi * 2 * 3 * 5 * 7) +end + +callbacks:add("frame", state.update) + + diff --git a/res/scripts/logo-bg.png b/res/scripts/logo-bg.png new file mode 100644 index 0000000000000000000000000000000000000000..908e410d972802b97a3819d83beddf167b1279ef GIT binary patch literal 1268 zcmV*Aei51Z+QvjE8`~)(hwY+{q2LXAWMze3{P9PD)ElsjaPL z$BrG;)YRbj`!lB+Kt<9%PV+xbgY5@?0e-UsXh?bs=*b+2Mx*%ser9H705DAx(=?f# zoyF~TQ(axn-o1MX1OfyC0g8%>R=ejPz>mNf@EwWF=a!^8Wl>L0kBW*UFkx^d%%!r^eXCDYZNY!@W`B&kV~TN0Uu zr2W}exN_x+3JVJrkH?qz!{M;Hy1LZT(xSS$I_2l*F9I8eA|&lS=mDVE_IlJsT@@Nl-MBS(%1(CFx>Ex>FF27@XnC|GIA14#oJzBx$^ z4iXh&nI-f4*+Or%#{a zcDorJ9evT%-N5VockNX=fN-{%(P(r@yB?)Jc5G~HHPceU~1 z?b;Rhdc86XaYWtvezzMy7c{_Lx*NIZQ8W#AmuX4 zvUL6WbvuAVl7ediOqnYb3N^L0wG9LUfw*a!vMej-ziL^QB9Vw4z)4A;8d~~rU#m(d zCnuY3-@g4>C={yc@9#H;hliP-p2p+xP*G7qYilce_Uu{hdgCOXzvUYRn65J51K>ko zKVYt5jb0M(^iN&}V7l^wcY*hTcSyXO4PXwK23}3}( canvas:screenWidth() - state.logo.width then - state.x = (canvas:screenWidth() - state.logo.width) * 2 - state.x + if state.x > canvas:screenWidth() - state.logo_fg.width then + state.x = (canvas:screenWidth() - state.logo_fg.width) * 2 - state.x state.direction = state.direction ~ 1 + state.recolor() end else state.x = state.x - 1 if state.x < 0 then state.x = -state.x state.direction = state.direction ~ 1 + state.recolor() end end if state.direction & 2 == 2 then state.y = state.y + 1 - if state.y > canvas:screenHeight() - state.logo.height then - state.y = (canvas:screenHeight() - state.logo.height) * 2 - state.y + if state.y > canvas:screenHeight() - state.logo_fg.height then + state.y = (canvas:screenHeight() - state.logo_fg.height) * 2 - state.y state.direction = state.direction ~ 2 + state.recolor() end else state.y = state.y - 1 if state.y < 0 then state.y = -state.y state.direction = state.direction ~ 2 + state.recolor() end end state.overlay:setPosition(math.floor(state.x), math.floor(state.y)) end +state.recolor() callbacks:add("frame", state.update) diff --git a/res/scripts/logo-fg.png b/res/scripts/logo-fg.png new file mode 100644 index 0000000000000000000000000000000000000000..c401fb0112f85b8018412906cd23cc7f2abf03ae GIT binary patch literal 888 zcmV-;1Bd*HP)zp&^&OQBManId*?R9=fV|_W9tO0wQ=ft^+E>Z2SosT)UVXp>Vhc1y$0c8 z8?FAF0l8Bhl?Qk$YIsilNc~H_ULqjsfgu1>eXB0a0_;@Min z1ndCL181s){03nLcSeo_<*@;9yH5XQ09D}k42McXI8WEb-sEjy7!JW zQODMz?p6m9r+?M<5&>@}aUYsrq^NFB6LqXUU>jkRbP@9731C-AuRFb8Ga=vQ>3%$* zR;PhCfK!BYvyJe<^mc=QLsjirx(ht@ifgT6D8o9UsXwo-HPn9fyxuVmmUczd?htD* z&z2gBigbNmQ$JCs792mj4meGUmys;=Hg%8M9R>SN{Y+i1KASP_V4Z-iYUX!w5w#H3 zhz35ocXI%59;yj)}r7PS}Dt?FrqPaj2eB#qt33})$hU=`3# zNLSAAqq&1B-!`z^e@AzB|CU#9Dz#gxq);*hl!V2jD;ITEqaeo}m%| O0000tXP)c^ONwML97T5Exv@z}rAsLsJF%=pp1t0!}1g79q!LXeJWSO@KoHiCIBp$`brO@V05Feh>Z=;Qto9 zKSI||5E`iUz!5ks8-?hd3X%L0-~yFF;LIfCbOJs|z)S)r5#SISfQjZxCWuV=P4HHO z{|NXGf%goQcPW^BpauvWelQBr-iAmn(%Qz=58MadVk#kL5O5A5vk2&IfDvYZCVp-Z zM5Pvh@^*m#H28Oew;a~5g=4gKl7NT9w?`q`8xYCAjli=NhcYt>nWy2I)@Y)_j2b8D z{UC@+8DJ_!?4c%@0Dm2L_kh0?cp7@D>NBY|)3u`z4F^Q>T3{7$BG3)I$#H}%AmBVg z4$cIQ4Vw75Y8;}H0VJE2^5Vy@gLgOhH$(qZFhRmNU=I#|KMK)MK_qX`aG+l+97@PV z1kBextpRw#0^r17tF8s0k_DiW4Wjz%7VwsW_wUfPR;gBW6SruehsbTK02Tui^>cwP z;Ip{ghs)Inrr@GFL2gQRbdDZJvlaj77fdEF~O7uPaGtxf;GY98lXwaB7U>eL3|IyQgBXC|6f9K z3zFMMA!-?(pMYG_&^`i(3lQ9e;6eoD#xqC*$fS|n6egT3FlB{DB;1^cf98QZ7sOrQ zEC8pZnmvK!$D<^aF2x07zs3CLw$EjzK+|pz$&k%mc*XAbtSu+4cXC zJTVGU1E6Q941jqbvi0gn?A{96Mc&r&hHg!fsX5*eE_BUD*5kj-%RGJxb6YK{kZhk*Az@aCxZ zYmltj$2HNwK=u)MEN(PmnPr-@QfKvO=k{1<@d;(A4W^ng==d=3ZUpZ=a2((vd1>E- zNUm@Af_m}z79OVJgpBQ33j6uNBn%>o)t)p1(0vuex!^nrWgNyO%YCHGCzACC z3SETUN{tH#0ThKN2_PFtae(6R>;~2W&!JX-yxs01cL4_j?*O)~Qh5Sb>hnbfba z7=A7w?g#N{aCSfmhw{jUD3l=f0PtCA+)R~n6GUm+C`}VZbDuu{BJhNUC>ZLZd%&T< zNvJWexK{EFAf>h6)?PzZ%}bKs1*p=47kdOFVp3Ya1h)p1ITVk-#-nVsf08tO{CjCF zfzYkY85+bFhXWuq;V%I@fxpz+Nsv6l(K8g<&k2|>z*`7iGbCNglpAS=^>#VXldig4 zBt2#}$&JB+U0$32hl)6b%b)c4{sncYcw9vxS z3SbuS9(_J~17FqJX~@%|S_^rRb3z;3Cj-5)8&B)8nR5+66*p=o?jOKc`oMF5jUBFy z8W6oA6)?qx2M30ZR_H*r-o#~rDSB=Ua5OL}<*qK! zEz6LlKL@^;@|_7^@WX>S0Z+YPSU;Sf0h&q?Jy0j9d}OBaqx zoBP)|R|BVN=;}x5tDz!)^k%%X@%uY~jk?74uDwK1!=)DUgw%A7 z9_##C4L$<=p$~XBPUm*<-yV3@X9O@U&tlX;OmuNI!)Lw^y}dALlFAb%K&fQ- z@{z!0w7yEp1-g-xsNxae4lc6=po$%+?m)G%9Xs2|`Hch#Juckq!iVzAN;WOFsgGuq zVqTb*(`_22Dhig9PlnmE;n-tg$`mN;fy_z;Hg1H~tKqT7VC72KRG+_dy>7~irD%U4 z+Lx%s4Cw?Tx{+n`@o%Lvu(!Ui16wrb*XpKcy6~_A2P8q{kZ*xa9i*}Cf@lZuwJEUw zJeYUBf~Q=z|0W3F`RC!M%V5ci@bZncV@xH~9mbI6@#vbNHzo}bMP7GGHG25ishtSX z!|J9#@4)R2IB|&bhCQes_h?T`@z^y&^`>@T4Lv8c_J?bB!*yd|nQm7KB#D{}w>t%( zEE-4-K3)Xe@SzTb$So=LJS)i1D>Ka<)+Z1g5wC z7u_21J_|_w>EJ~DMSdqkG%d-fu4I6xlF*dZoz<My#OWyD3$6dWKDECuR*@q+@q(*j8B>dVW;QZk${U=d#(^~AMb;kh81CIfuLpv3s$+jje zNHL`2!s{+{J0}Cj4qxeyq|m&jo{Ta{lBEHpj_sXIw1tY!;v1@Kp-SPd{p@1hrrf2c zwei?US3fk^MYdj=MHBUQDn#S*`iS}sMs--o9`c7*3pE^(t#>C&)c3eaZq~8@6oYAO zM?w^Wm!%m?b2iqy_pSSf#^|2eFsFl1(}h~ZJ~U{de$u_ymF6B=M|!NCYa~0surS`I7522Pnn&gsK4&RV_Zx6bbA^JuF zM6Hei_5&+W1C)6rA%TfZ;&vWk+Au@(rw#C_Iq=H*e7#DkJy{=5WdayZMlBva z|4$tVksCnOH2pQJlQC)&wQ5-Rv71e79CiV0*#f(Ev~Cksv3so3#?WH2uhD_Y4Pa-U zX|T2)T7CcDR#Jrut64ql0(kB@*tM%TL|MnsQo8uNIu)XACV&F+4S56w{X~!P7{Ty_ z1W`?~RI_M{_=y5b?<}p0p8(SKPK9W5UQJ}vMnyc6if1D;)_@ z2x|k7X`4MKspzDkkD{aaOIX61VF(<)VFTQ9OY6U{motkN%CWKb+D_F(F9gt+bs9*T z*P4P&+RMDmbzDbZ(?P;eMXKybh}Oo9>nvUUibZfm zXErWl8Q&Ry6&Fz=?_KcSXZdbk$Yxc7dq0uD1R9ESf0Kn3>M61$5@V4eke(7W#db9$MC^vXbHxI<~Qmg)HPo zZlqFlv6ybc?zjUkzBsZdwm{e3$*F}hEE!r;RS~;852AaOT7Dv=^)>iIweD;yTlqR) z=Muiki>zQA_MT_8)ONs*o&Fju=BlkA{TP#Azs=f{ln&xVFejC7>d785{pd{^? z*U(QtxAJ2?&Kj;mMJUcPHXu>qu)hPG`7(U>N5z`3dJ>KMN}ha{Wtbx&?+##9r-t2g zbO3>IHCQg;RNLBd(^_*=ob>iZN4)^J9q8gv)Qr|sQS-?TiZq=SU<;~?^BC|5+QMDYgk4wXP_3;7VMJA5>!1E z&?~L^${2R9KZIY5DJZ4A3el5JquF^Tgr~CxxiSG&#YHw&W!0lxjcw7)J_h(o`${|C z$YXjMql=;=z)4?4(XGRjW=LBirmYTOWk*L!12{}|&36TGcgBE~O@a$?k&V3;l7cpl z%Xw=86|DTQ_LcTPQ~;N}Qw_$VLN>-@fBGOj75vn;OgaUmd-uQ_eZbS5Hy>>PqCe_d z5Ww;f*2OmqvgIlcwMG=|B!J5LsZA!|jQGDTo?*~4c@}2Rh=>Pj+-z6YH1X4iNZLWYZn05wmN1tM@qf-MS-JBtn zaea5fUKCVuG(2e=eE134ss1_vwYkS+!!1ogg_RjX1@8ctV2%nhN#Eim()TN|Y|bc! z+FU0|mH|9ig%u-Vr=bQ!n;iA#ZK#HDvu>|-p;gnBefy@As!A_v-Tm~0j_sHA6CC0+ z4Y)LRc?T6{>J-%CIWI#|GVEF8ncF>e|hJwFAQtNYO#hR5wz zLv5EXQPKUTl5M+J(>AZRq7L4GaWP|gM*1T|3t@C4OHXSF#)4Q1Vy-#ld6Fiwfn(Y; ztQ>Jn9?8J)YN@>?4j34veGzy|pNkK}+vaVgX`-Y^=}HUziYn(Jc~dRaYZm{A+0tB< zrbjBjXOe4D9w( zpOE3GES-U7s<9(7DrCo7+U(lJKs2r_Q99cPQI#rJQsR2{=xc2sIS`o#j-4I)iMW7R z0^TilZPQ9l(rQWCPHG~yYBjPMctg{%M?I;k@=vf`Yn=Mmw(9dW!(~j$RHWQ`zGD9b zkDD5%-u6y+FJ^@Zz}cc}dZ_~5HQ+teEM<`al%)5<0#tm4PJ9;;hvwZeB5$Lmb1i=* zEZn96B{Bo_I38Eyvl|E4GO_?lhX^7~hPMU8BJh6Ky5>m&DbL(MCzfL^vXhYGGr&x< z$4q?%ksF$5UW>;S_-ts~eBq9S$XTZ)@<+h`1Bgq(d%0P%NmW^-Xc>_cBqsr;1dy=6 zKL?< zliXdf0hFal%i_^6*PE>f7UA(gV*%dtBNL$P5CJ&9i%8yE4&GN4NH(e3B%P#rlAtna zA4`AJF>vR$8K~rXvlYQYN-S#><98z$pnMPkI8R0;c@KDB0kJMks;xC$Y0X#yP)-JI zYyBp)eckX)t0XUHXzb-9`J#G18zCIqreDD{7cSQ53zHRDY3Hw~_ zghAY@NZ%96G_X3bgvC72s$O3uWHBK(%Wv^!L~ilTCik>Uj-3RN#N1gf2-82z0PiyJ z&j)XR^XPsnF!{|81uej1Ti>HzcM$S30=^@!;h9MBWNPvEk>)HZ#A0{5E+DyP4U{ei zcP_X~K)jVJUWRqN%+k$I>-J}HKDz8g@SnJxi^rE^0F9=ICYlHh)m%^eqb5AY3E-au-p9b71O9aI$K_t*7KJE#-c7(-LRJv)3qn@PPw__1BJ5T9 zjY8A})Pobjn*shT@MeL3EcjCtRK9P8DIKDakevj)M!*^ZRuQm@kk#^|g|!$8z6ERm|b6=Jrion#1s}k$+wc_cSWvc`<@f|zhDR;8m{uD`T9(s7n6~c za-wWb6Qz`7$aAEWw@Y)nT}nAS_M0pz>38kA)*VvHv!s-hbv{d5kl^>GQV8 z$ZgqVXOk|8nQWVVx#hlbntL9#6UM4|SzmVYtpg4D1y$iRN7$_t&q5Wi(Wwlk=C?g|mBR7pLm0&U2B!L8$KSf6W*(9woS!vHE7ta1^hY_4f4Yx+b*4La{3K$ zHELMpz1r5iI>83~yg^2%N1n&&Ii5#u8JQqD3^o2UF_!CwSbst-xlkK?GiZ(-{6mW` zBrPRfYZh=3Dl}C^*SbBZRrfY0;#-EM@hw{03A!6NAmRK07NhkrEu*7T%-8MXR6^2?}&Zm5j-F|wvPDP7Gh{-~_U*1evtbJp`|_m<^eWD9Z{+k#u5UC$%8 zjPf|dk{ng1WpDt_$>{V-%W2n=Qp&$cxmI^hp9#YRQIebv*AB%zziG$w$StGj^w=zZ zgQRJnj&9%mm}|biWxTZbF!Ii~NxD}3dV37*yy;qb&)b@`ZiAeXdQBhIZjCoG$f*_C zw)1&pI`4F1P^At^Ne~@{ijFa21n-VM=OIl=+U!pw37}C;G(2g@7D0?cv~Q(WZNQF5 Z{}1R4%vk=CZo2>g002ovPDHLkV1f&Z^~L}I literal 0 HcmV?d00001 diff --git a/src/script/image.c b/src/script/image.c index f056c7d4938..7705ebd9a8c 100644 --- a/src/script/image.c +++ b/src/script/image.c @@ -141,6 +141,7 @@ mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mPainter, setStrokeColor, _mPainterSetStrokeC mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mPainter, drawRectangle, mPainterDrawRectangle, 4, S32, x, S32, y, S32, width, S32, height); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mPainter, drawLine, mPainterDrawLine, 4, S32, x1, S32, y1, S32, x2, S32, y2); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mPainter, drawCircle, mPainterDrawCircle, 3, S32, x, S32, y, S32, diameter); +mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mPainter, drawMask, mPainterDrawMask, 3, CS(mImage), mask, S32, x, S32, y); mSCRIPT_DEFINE_STRUCT(mPainter) mSCRIPT_DEFINE_CLASS_DOCSTRING( @@ -162,6 +163,13 @@ mSCRIPT_DEFINE_STRUCT(mPainter) mSCRIPT_DEFINE_STRUCT_METHOD(mPainter, drawLine) mSCRIPT_DEFINE_DOCSTRING("Draw a circle with the specified diameter with the given origin at the top-left corner of the bounding box") mSCRIPT_DEFINE_STRUCT_METHOD(mPainter, drawCircle) + mSCRIPT_DEFINE_DOCSTRING( + "Draw a mask image with each color channel multiplied by the current fill color. This can " + "be useful for displaying graphics with dynamic colors. By making a grayscale template " + "image on a transparent background in advance, a script can set the fill color to a desired " + "target color and use this function to draw it into a destination image." + ) + mSCRIPT_DEFINE_STRUCT_METHOD(mPainter, drawMask) mSCRIPT_DEFINE_END; mSCRIPT_DECLARE_STRUCT_METHOD(mScriptPainter, W(mPainter), _get, _mScriptPainterGet, 1, CHARP, name); diff --git a/src/util/image.c b/src/util/image.c index a0fefafe799..f1f1a0fef47 100644 --- a/src/util/image.c +++ b/src/util/image.c @@ -42,6 +42,53 @@ memcpy((void*) (DST), &_color, (DEPTH)); \ } while (0); +static uint32_t _mColorMultiply(uint32_t colorA, uint32_t colorB) { + uint32_t color = 0; + + uint32_t a, b; + a = colorA & 0xFF; + b = colorB & 0xFF; + b = a * b; + b /= 0xFF; + if (b > 0xFF) { + color |= 0xFF; + } else { + color |= b; + } + + a = (colorA >> 8) & 0xFF; + b = (colorB >> 8) & 0xFF; + b = a * b; + b /= 0xFF; + if (b > 0xFF) { + color |= 0xFF00; + } else { + color |= b << 8; + } + + a = (colorA >> 16) & 0xFF; + b = (colorB >> 16) & 0xFF; + b = a * b; + b /= 0xFF; + if (b > 0xFF) { + color |= 0xFF0000; + } else { + color |= b << 16; + } + + a = (colorA >> 24) & 0xFF; + b = (colorB >> 24) & 0xFF; + b = a * b; + b /= 0xFF; + if (b > 0xFF) { + color |= 0xFF000000; + } else { + color |= b << 24; + } + + return color; +} + struct mImage* mImageCreate(unsigned width, unsigned height, enum mColorFormat format) { return mImageCreateWithStride(width, height, width, format); } @@ -395,18 +442,18 @@ void mImageSetPaletteEntry(struct mImage* image, unsigned index, uint32_t color) image->palette[index] = color; } -#define COMPOSITE_BOUNDS_INIT \ +#define COMPOSITE_BOUNDS_INIT(SOURCE, DEST) \ struct mRectangle dstRect = { \ .x = 0, \ .y = 0, \ - .width = image->width, \ - .height = image->height \ + .width = (DEST)->width, \ + .height = (DEST)->height \ }; \ struct mRectangle srcRect = { \ .x = x, \ .y = y, \ - .width = source->width, \ - .height = source->height \ + .width = (SOURCE)->width, \ + .height = (SOURCE)->height \ }; \ if (!mRectangleIntersection(&srcRect, &dstRect)) { \ return; \ @@ -436,7 +483,7 @@ void mImageBlit(struct mImage* image, const struct mImage* source, int x, int y) return; } - COMPOSITE_BOUNDS_INIT; + COMPOSITE_BOUNDS_INIT(source, image); for (y = 0; y < srcRect.height; ++y) { uintptr_t srcPixel = (uintptr_t) PIXEL(source, srcStartX, srcStartY + y); @@ -461,7 +508,7 @@ void mImageComposite(struct mImage* image, const struct mImage* source, int x, i return; } - COMPOSITE_BOUNDS_INIT; + COMPOSITE_BOUNDS_INIT(source, image); for (y = 0; y < srcRect.height; ++y) { uintptr_t srcPixel = (uintptr_t) PIXEL(source, srcStartX, srcStartY + y); @@ -498,7 +545,7 @@ void mImageCompositeWithAlpha(struct mImage* image, const struct mImage* source, alpha = 256; } - COMPOSITE_BOUNDS_INIT; + COMPOSITE_BOUNDS_INIT(source, image); int fixedAlpha = alpha * 0x200; @@ -821,6 +868,33 @@ void mPainterDrawCircle(struct mPainter* painter, int x, int y, int diameter) { } } +void mPainterDrawMask(struct mPainter* painter, const struct mImage* mask, int x, int y) { + if (!painter->fill) { + return; + } + + COMPOSITE_BOUNDS_INIT(mask, painter->backing); + + for (y = 0; y < srcRect.height; ++y) { + uintptr_t dstPixel = (uintptr_t) PIXEL(painter->backing, dstStartX, dstStartY + y); + uintptr_t maskPixel = (uintptr_t) PIXEL(mask, srcStartX, srcStartY + y); + for (x = 0; x < srcRect.width; ++x, dstPixel += painter->backing->depth, maskPixel += mask->depth) { + uint32_t color; + GET_PIXEL(color, maskPixel, mask->depth); + color = mColorConvert(color, mask->format, mCOLOR_ARGB8); + color = _mColorMultiply(painter->fillColor, color); + if (painter->blend || painter->fillColor < 0xFF000000) { + uint32_t current; + GET_PIXEL(current, dstPixel, painter->backing->depth); + current = mColorConvert(current, painter->backing->format, mCOLOR_ARGB8); + color = mColorMixARGB8(color, current); + } + color = mColorConvert(color, mCOLOR_ARGB8, painter->backing->format); + PUT_PIXEL(color, dstPixel, painter->backing->depth); + } + } +} + uint32_t mColorConvert(uint32_t color, enum mColorFormat from, enum mColorFormat to) { if (from == to) { return color; diff --git a/src/util/test/image.c b/src/util/test/image.c index a27e53d5c36..e3ea16e2451 100644 --- a/src/util/test/image.c +++ b/src/util/test/image.c @@ -2038,6 +2038,97 @@ M_TEST_DEFINE(painterDrawCircleInvalid) { mImageDestroy(image); } +M_TEST_DEFINE(painterDrawMask) { + struct mImage* image; + struct mImage* mask; + struct mPainter painter; + + image = mImageCreate(4, 4, mCOLOR_XRGB8); + mPainterInit(&painter, image); + painter.blend = false; + painter.fill = true; + + mask = mImageCreate(2, 2, mCOLOR_XRGB8); + mImageSetPixel(mask, 0, 0, 0xFFFFFFFF); + mImageSetPixel(mask, 1, 0, 0xFFFF0000); + mImageSetPixel(mask, 0, 1, 0xFF00FF00); + mImageSetPixel(mask, 1, 1, 0xFF0000FF); + + painter.fillColor = 0xFFFFFFFF; + mPainterDrawMask(&painter, mask, 0, 0); + painter.fillColor = 0xFFFF0000; + mPainterDrawMask(&painter, mask, 2, 0); + painter.fillColor = 0xFF00FF00; + mPainterDrawMask(&painter, mask, 0, 2); + painter.fillColor = 0xFF0000FF; + mPainterDrawMask(&painter, mask, 2, 2); + + COMPARE4X(0xFFFFFF, 0xFF0000, 0xFF0000, 0xFF0000, + 0x00FF00, 0x0000FF, 0x000000, 0x000000, + 0x00FF00, 0x000000, 0x0000FF, 0x000000, + 0x00FF00, 0x000000, 0x000000, 0x0000FF); + + painter.fillColor = 0xFF808080; + mPainterDrawMask(&painter, mask, 0, 0); + painter.fillColor = 0xFFFFFF00; + mPainterDrawMask(&painter, mask, 2, 0); + painter.fillColor = 0xFF00FFFF; + mPainterDrawMask(&painter, mask, 0, 2); + painter.fillColor = 0xFFFF00FF; + mPainterDrawMask(&painter, mask, 2, 2); + + COMPARE4X(0x808080, 0x800000, 0xFFFF00, 0xFF0000, + 0x008000, 0x000080, 0x00FF00, 0x000000, + 0x00FFFF, 0x000000, 0xFF00FF, 0xFF0000, + 0x00FF00, 0x0000FF, 0x000000, 0x0000FF); + + painter.fillColor = 0xFFFFFFFF; + mPainterDrawMask(&painter, mask, -1, -1); + mPainterDrawMask(&painter, mask, 3, 3); + assert_int_equal(0xFF0000FF, mImageGetPixel(image, 0, 0)); + assert_int_equal(0xFFFFFFFF, mImageGetPixel(image, 3, 3)); + + mImageDestroy(image); + mImageDestroy(mask); +} + +M_TEST_DEFINE(painterDrawMaskBlend) { + struct mImage* image; + struct mImage* mask; + struct mPainter painter; + const uint8_t lut[4] = { 0x00, 0x55, 0xAA, 0xFF }; + int x, y; + + image = mImageCreate(4, 4, mCOLOR_XRGB8); + mPainterInit(&painter, image); + painter.blend = true; + painter.fill = true; + painter.fillColor = 0xFFFF8000; + + for (y = 0; y < 4; ++y) { + for (x = 0; x < 4; ++x) { + mImageSetPixel(image, x, y, 0xFF808080); + } + } + + mask = mImageCreate(4, 4, mCOLOR_ARGB8); + for (y = 0; y < 4; ++y) { + for (x = 0; x < 4; ++x) { + mImageSetPixel(mask, x, y, (lut[x] << 24) | (lut[y] * 0x010101)); + } + } + + mPainterDrawMask(&painter, mask, 0, 0); + + COMPARE4X(0x808080, 0x555555, 0x2A2A2A, 0x000000, + 0x808080, 0x716355, 0x63462A, 0x552A00, + 0x808080, 0x8E7155, 0x9C632A, 0xAA5500, + 0x808080, 0xAA8055, 0xD4802A, 0xFF8000); + + mImageDestroy(image); + mImageDestroy(mask); +} + #undef COMPARE3X #undef COMPARE3 #undef COMPARE4X @@ -2083,4 +2174,6 @@ M_TEST_SUITE_DEFINE(Image, cmocka_unit_test(painterDrawCircleOffset), cmocka_unit_test(painterDrawCircleBlend), cmocka_unit_test(painterDrawCircleInvalid), + cmocka_unit_test(painterDrawMask), + cmocka_unit_test(painterDrawMaskBlend), ) From c80f3afd7708e2e7d2f0f5175ba21fa2b70a424c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 18 Mar 2024 23:26:01 -0700 Subject: [PATCH 013/338] Qt: Reattach video backend when resetting scripts (fixes #3167) --- src/platform/qt/scripting/ScriptingController.cpp | 2 ++ src/platform/qt/scripting/ScriptingController.h | 1 + 2 files changed, 3 insertions(+) diff --git a/src/platform/qt/scripting/ScriptingController.cpp b/src/platform/qt/scripting/ScriptingController.cpp index 06adafdf59e..79b46e9d09f 100644 --- a/src/platform/qt/scripting/ScriptingController.cpp +++ b/src/platform/qt/scripting/ScriptingController.cpp @@ -92,6 +92,7 @@ void ScriptingController::setInputController(InputController* input) { } void ScriptingController::setVideoBackend(VideoBackend* backend) { + m_videoBackend = backend; mScriptCanvasUpdateBackend(&m_scriptContext, backend); } @@ -339,6 +340,7 @@ void ScriptingController::init() { mScriptContextAttachLogger(&m_scriptContext, &m_logger); m_bufferModel->attachToContext(&m_scriptContext); + mScriptCanvasUpdateBackend(&m_scriptContext, m_videoBackend); HashTableEnumerate(&m_scriptContext.engines, [](const char* key, void* engine, void* context) { ScriptingController* self = static_cast(context); diff --git a/src/platform/qt/scripting/ScriptingController.h b/src/platform/qt/scripting/ScriptingController.h index 9e5b3f6b570..5c579a7682f 100644 --- a/src/platform/qt/scripting/ScriptingController.h +++ b/src/platform/qt/scripting/ScriptingController.h @@ -87,6 +87,7 @@ private slots: mScriptEngineContext* m_activeEngine = nullptr; QHash m_engines; ScriptingTextBufferModel* m_bufferModel; + VideoBackend* m_videoBackend = nullptr; mScriptGamepad m_gamepad; From aa7b9349f843da4bc9427e0c20b71b7c0097123a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 19 Mar 2024 21:30:47 -0700 Subject: [PATCH 014/338] Core: Clean up thread state mutex usage --- src/core/thread.c | 32 ++++++++++++++++++++------------ 1 file changed, 20 insertions(+), 12 deletions(-) diff --git a/src/core/thread.c b/src/core/thread.c index 63b8e0d568a..4b470777d57 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -42,13 +42,9 @@ static BOOL CALLBACK _createTLS(PINIT_ONCE once, PVOID param, PVOID* context) { static void _mCoreLog(struct mLogger* logger, int category, enum mLogLevel level, const char* format, va_list args); -static void _changeState(struct mCoreThreadInternal* threadContext, enum mCoreThreadState newState, bool broadcast) { - MutexLock(&threadContext->stateMutex); +static void _changeState(struct mCoreThreadInternal* threadContext, enum mCoreThreadState newState) { threadContext->state = newState; - if (broadcast) { - ConditionWake(&threadContext->stateCond); - } - MutexUnlock(&threadContext->stateMutex); + ConditionWake(&threadContext->stateCond); } static void _waitOnInterrupt(struct mCoreThreadInternal* threadContext) { @@ -178,7 +174,9 @@ void _crashed(void* context) { if (!thread) { return; } - _changeState(thread->impl, mTHREAD_CRASHED, true); + MutexLock(&thread->impl->stateMutex); + _changeState(thread->impl, mTHREAD_CRASHED); + MutexUnlock(&thread->impl->stateMutex); } void _coreSleep(void* context) { @@ -196,7 +194,9 @@ void _coreShutdown(void* context) { if (!thread) { return; } - _changeState(thread->impl, mTHREAD_EXITING, true); + MutexLock(&thread->impl->stateMutex); + _changeState(thread->impl, mTHREAD_EXITING); + MutexUnlock(&thread->impl->stateMutex); } #ifdef ENABLE_SCRIPTING @@ -303,7 +303,9 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { core->reset(core); threadContext->impl->core = core; - _changeState(threadContext->impl, mTHREAD_RUNNING, true); + MutexLock(&threadContext->impl->stateMutex); + _changeState(threadContext->impl, mTHREAD_RUNNING); + MutexUnlock(&threadContext->impl->stateMutex); if (threadContext->resetCallback) { threadContext->resetCallback(threadContext); @@ -326,23 +328,27 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { bool wasPaused = false; int pendingRequests = 0; + MutexLock(&impl->stateMutex); while (impl->state < mTHREAD_EXITING) { #ifdef USE_DEBUGGERS struct mDebugger* debugger = core->debugger; if (debugger) { + MutexUnlock(&impl->stateMutex); mDebuggerRun(debugger); + MutexLock(&impl->stateMutex); if (debugger->state == DEBUGGER_SHUTDOWN) { - _changeState(impl, mTHREAD_EXITING, false); + impl->state = mTHREAD_EXITING; } } else #endif { while (impl->state == mTHREAD_RUNNING) { + MutexUnlock(&impl->stateMutex); core->runLoop(core); + MutexLock(&impl->stateMutex); } } - MutexLock(&impl->stateMutex); while (impl->state >= mTHREAD_MIN_WAITING && impl->state < mTHREAD_EXITING) { if (impl->state == mTHREAD_INTERRUPTING) { impl->state = mTHREAD_INTERRUPTED; @@ -430,7 +436,9 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { } while (impl->state < mTHREAD_SHUTDOWN) { - _changeState(impl, mTHREAD_SHUTDOWN, false); + MutexLock(&impl->stateMutex); + impl->state = mTHREAD_SHUTDOWN; + MutexUnlock(&impl->stateMutex); } if (core->opts.rewindEnable) { From a2587cb8cff265d9f327a9413b4f2c5e607850fb Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 19 Mar 2024 21:40:38 -0700 Subject: [PATCH 015/338] Util: Code cleanup to remove unreachable code --- src/util/string.c | 14 +++++--------- 1 file changed, 5 insertions(+), 9 deletions(-) diff --git a/src/util/string.c b/src/util/string.c index 1a2ffe7a49a..b2bf376c6e5 100644 --- a/src/util/string.c +++ b/src/util/string.c @@ -177,16 +177,12 @@ size_t toUtf8(uint32_t unichar, char* buffer) { buffer[2] = (unichar & 0x3F) | 0x80; return 3; } - if (unichar < 0x200000) { - buffer[0] = (unichar >> 18) | 0xF0; - buffer[1] = ((unichar >> 12) & 0x3F) | 0x80; - buffer[2] = ((unichar >> 6) & 0x3F) | 0x80; - buffer[3] = (unichar & 0x3F) | 0x80; - return 4; - } - // This shouldn't be possible - return 0; + buffer[0] = (unichar >> 18) | 0xF0; + buffer[1] = ((unichar >> 12) & 0x3F) | 0x80; + buffer[2] = ((unichar >> 6) & 0x3F) | 0x80; + buffer[3] = (unichar & 0x3F) | 0x80; + return 4; } size_t toUtf16(uint32_t unichar, uint16_t* buffer) { From cf0d8fdc28f9b451fb2c86357db035e195a923b1 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 24 Mar 2024 14:46:34 -0700 Subject: [PATCH 016/338] Qt: Get InputController compiling with Qt6 Cameras still don't work though --- src/platform/qt/InputController.cpp | 49 +++++++++++++++++++++++++++-- src/platform/qt/InputController.h | 9 ++++-- 2 files changed, 53 insertions(+), 5 deletions(-) diff --git a/src/platform/qt/InputController.cpp b/src/platform/qt/InputController.cpp index 337e7df6b2b..e195505a44a 100644 --- a/src/platform/qt/InputController.cpp +++ b/src/platform/qt/InputController.cpp @@ -16,8 +16,13 @@ #include #include #ifdef BUILD_QT_MULTIMEDIA +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) #include #include +#else +#include +#include +#endif #endif #include @@ -50,7 +55,9 @@ InputController::InputController(QWidget* topLevel, QObject* parent) m_gamepadTimer.start(); #ifdef BUILD_QT_MULTIMEDIA +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) connect(&m_videoDumper, &VideoDumper::imageAvailable, this, &InputController::setCamImage); +#endif #endif mInputBindKey(&m_inputMap, KEYBOARD, Qt::Key_X, GBA_KEY_A); @@ -90,10 +97,20 @@ InputController::InputController(QWidget* topLevel, QObject* parent) #ifdef BUILD_QT_MULTIMEDIA image->p->m_cameraActive = true; QByteArray camera = image->p->m_config->getQtOption("camera").toByteArray(); +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (!camera.isNull()) { image->p->m_cameraDevice = camera; } QMetaObject::invokeMethod(image->p, "setupCam"); +#else + if (!camera.isNull()) { + for (const auto& cam : QMediaDevices::videoInputs()) { + if (cam.id() == camera) { + image->p->m_cameraDevice = cam; + } + } + } +#endif #endif }; @@ -595,9 +612,13 @@ void InputController::setCamImage(const QImage& image) { QList> InputController::listCameras() const { QList> out; #ifdef BUILD_QT_MULTIMEDIA - QList cams = QCameraInfo::availableCameras(); - for (const auto& cam : cams) { +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) + for (const auto& cam : QCameraInfo::availableCameras()) { out.append(qMakePair(cam.deviceName().toLatin1(), cam.description())); +#else + for (const auto& cam : QMediaDevices::videoInputs()) { + out.append(qMakePair(cam.id(), cam.description())); +#endif } #endif return out; @@ -639,6 +660,7 @@ void InputController::setupCam() { return; } +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (!m_camera) { m_camera = std::make_unique(m_cameraDevice); connect(m_camera.get(), &QCamera::statusChanged, this, &InputController::prepareCamSettings, Qt::QueuedConnection); @@ -650,10 +672,16 @@ void InputController::setupCam() { m_camera->setCaptureMode(QCamera::CaptureVideo); m_camera->setViewfinder(&m_videoDumper); m_camera->load(); +#else + if (!m_camera) { + m_camera = std::make_unique(m_cameraDevice); + m_captureSession.setCamera(m_camera.get()); + } +#endif #endif } -#ifdef BUILD_QT_MULTIMEDIA +#if defined(BUILD_QT_MULTIMEDIA) && (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) void InputController::prepareCamSettings(QCamera::Status status) { if (status != QCamera::LoadedStatus || m_camera->state() == QCamera::ActiveState) { return; @@ -697,7 +725,11 @@ void InputController::prepareCamSettings(QCamera::Status status) { void InputController::teardownCam() { #ifdef BUILD_QT_MULTIMEDIA if (m_camera) { +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) m_camera->unload(); +#else + m_captureSession.setCamera(nullptr); +#endif m_camera.reset(); } #endif @@ -705,6 +737,7 @@ void InputController::teardownCam() { void InputController::setCamera(const QByteArray& name) { #ifdef BUILD_QT_MULTIMEDIA +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (m_cameraDevice == name) { return; } @@ -715,5 +748,15 @@ void InputController::setCamera(const QByteArray& name) { if (m_cameraActive) { setupCam(); } +#else + if (m_cameraDevice.id() == name) { + return; + } + for (const auto& cam : QMediaDevices::videoInputs()) { + if (cam.id() == name) { + m_cameraDevice = cam; + } + } +#endif #endif } diff --git a/src/platform/qt/InputController.h b/src/platform/qt/InputController.h index 06871ff1ee5..51be333ede1 100644 --- a/src/platform/qt/InputController.h +++ b/src/platform/qt/InputController.h @@ -27,6 +27,8 @@ #ifdef BUILD_QT_MULTIMEDIA #if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) #include "VideoDumper.h" +#else +#include #endif #include #endif @@ -126,7 +128,7 @@ public slots: void setCamera(const QByteArray& id); private slots: -#ifdef BUILD_QT_MULTIMEDIA +#if defined(BUILD_QT_MULTIMEDIA) && (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) void prepareCamSettings(QCamera::Status); #endif void setupCam(); @@ -168,10 +170,13 @@ private slots: #ifdef BUILD_QT_MULTIMEDIA bool m_cameraActive = false; - QByteArray m_cameraDevice; std::unique_ptr m_camera; #if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) + QByteArray m_cameraDevice; VideoDumper m_videoDumper; +#else + QCameraDevice m_cameraDevice; + QMediaCaptureSession m_captureSession; #endif #endif From 3f21de2b7caaf148cd0b3a279f07c3f3a0eb9781 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 24 Mar 2024 15:55:39 -0700 Subject: [PATCH 017/338] Qt: Port AudioProcessorQt to Qt6 --- src/platform/qt/AudioProcessorQt.cpp | 33 +++++++++++++++++++++------- src/platform/qt/AudioProcessorQt.h | 12 +++++++++- src/platform/qt/Window.cpp | 4 +++- 3 files changed, 39 insertions(+), 10 deletions(-) diff --git a/src/platform/qt/AudioProcessorQt.cpp b/src/platform/qt/AudioProcessorQt.cpp index 8d12cd935b8..4b53c7bb7fc 100644 --- a/src/platform/qt/AudioProcessorQt.cpp +++ b/src/platform/qt/AudioProcessorQt.cpp @@ -9,6 +9,9 @@ #include "LogController.h" #include +#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) +#include +#endif #include #include @@ -31,10 +34,13 @@ void AudioProcessorQt::setInput(std::shared_ptr controller) { } void AudioProcessorQt::stop() { + if (m_audioOutput) { + m_audioOutput->stop(); + m_audioOutput.reset(); + } if (m_device) { m_device.reset(); } - pause(); AudioProcessor::stop(); } @@ -52,25 +58,36 @@ bool AudioProcessorQt::start() { QAudioFormat format; format.setSampleRate(m_sampleRate); format.setChannelCount(2); +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) format.setSampleSize(16); format.setCodec("audio/pcm"); format.setByteOrder(QAudioFormat::Endian(QSysInfo::ByteOrder)); format.setSampleType(QAudioFormat::SignedInt); - m_audioOutput = new QAudioOutput(format, this); + m_audioOutput = std::make_unique(format); m_audioOutput->setCategory("game"); - } +#else + format.setSampleFormat(QAudioFormat::Int16); - m_device->setInput(input()); - m_device->setFormat(m_audioOutput->format()); + QAudioDevice device(QMediaDevices::defaultAudioOutput()); + m_audioOutput = std::make_unique(device, format); + LOG(QT, INFO) << "Audio outputting to " << device.description(); +#endif + } - m_audioOutput->start(m_device.get()); - return m_audioOutput->state() == QAudio::ActiveState; + if (m_audioOutput->state() == QAudio::SuspendedState) { + m_audioOutput->resume(); + } else { + m_device->setInput(input()); + m_device->setFormat(m_audioOutput->format()); + m_audioOutput->start(m_device.get()); + } + return m_audioOutput->state() == QAudio::ActiveState && m_audioOutput->error() == QAudio::NoError; } void AudioProcessorQt::pause() { if (m_audioOutput) { - m_audioOutput->stop(); + m_audioOutput->suspend(); } } diff --git a/src/platform/qt/AudioProcessorQt.h b/src/platform/qt/AudioProcessorQt.h index 0e56907e106..1648b967fce 100644 --- a/src/platform/qt/AudioProcessorQt.h +++ b/src/platform/qt/AudioProcessorQt.h @@ -7,6 +7,12 @@ #include "AudioProcessor.h" +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) +#include +#else +#include +#endif + class QAudioOutput; namespace QGBA { @@ -33,7 +39,11 @@ public slots: virtual void requestSampleRate(unsigned) override; private: - QAudioOutput* m_audioOutput = nullptr; +#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) + std::unique_ptr m_audioOutput; +#else + std::unique_ptr m_audioOutput; +#endif std::unique_ptr m_device; unsigned m_sampleRate = 44100; }; diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index 6b77a1ef393..cc439f60f07 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -1093,7 +1093,9 @@ void Window::reloadAudioDriver() { m_audioProcessor = std::unique_ptr(AudioProcessor::create()); m_audioProcessor->setInput(m_controller); m_audioProcessor->configure(m_config); - m_audioProcessor->start(); + if (!m_audioProcessor->start()) { + LOG(QT, WARN) << "Failed to start audio processor"; + } } void Window::changeRenderer() { From 06448e844577601167577b644bfb60f6c493d65a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 24 Mar 2024 19:51:09 -0700 Subject: [PATCH 018/338] Qt: Get VideoDumper compiling with Qt6 Cameras still don't work though --- src/platform/qt/CMakeLists.txt | 7 +- src/platform/qt/VideoDumper.cpp | 126 ++++++++++++++++++++++---------- src/platform/qt/VideoDumper.h | 34 ++++++++- 3 files changed, 121 insertions(+), 46 deletions(-) diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index cb224b0a67b..19d4293d099 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -225,11 +225,8 @@ endif() if(${QT}Multimedia_FOUND) list(APPEND AUDIO_SRC AudioProcessorQt.cpp - AudioDevice.cpp) - if(QT_V LESS 6) - list(APPEND SOURCE_FILES - VideoDumper.cpp) - endif() + AudioDevice.cpp + VideoDumper.cpp) if (WIN32 AND QT_STATIC) list(APPEND QT_LIBRARIES ${QT}::QWindowsAudioPlugin ${QT}::DSServicePlugin ${QT}::QWindowsVistaStylePlugin ${QT}::QJpegPlugin strmiids mfuuid mfplat mf ksguid dxva2 evr d3d9) diff --git a/src/platform/qt/VideoDumper.cpp b/src/platform/qt/VideoDumper.cpp index 7fdb433bb18..1f1185200d3 100644 --- a/src/platform/qt/VideoDumper.cpp +++ b/src/platform/qt/VideoDumper.cpp @@ -5,59 +5,69 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include "VideoDumper.h" +#include "VideoProcessor.h" + #include -#include using namespace QGBA; VideoDumper::VideoDumper(QObject* parent) +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) : QAbstractVideoSurface(parent) +#else + : QObject(parent) +#endif { } bool VideoDumper::present(const QVideoFrame& frame) { QVideoFrame mappedFrame(frame); +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (!mappedFrame.map(QAbstractVideoBuffer::ReadOnly)) { return false; } - QVideoFrame::PixelFormat vFormat = mappedFrame.pixelFormat(); - QImage::Format format = QVideoFrame::imageFormatFromPixelFormat(vFormat); +#else + if (!mappedFrame.map(QVideoFrame::ReadOnly)) { + return false; + } +#endif + PixelFormat vFormat = mappedFrame.pixelFormat(); + QImage::Format format = imageFormatFromPixelFormat(vFormat); bool swap = false; #ifdef USE_FFMPEG bool useScaler = false; #endif if (format == QImage::Format_Invalid) { +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (vFormat < QVideoFrame::Format_BGRA5658_Premultiplied) { vFormat = static_cast(vFormat - QVideoFrame::Format_BGRA32 + QVideoFrame::Format_ARGB32); - format = QVideoFrame::imageFormatFromPixelFormat(vFormat); - if (format == QImage::Format_ARGB32) { - format = QImage::Format_RGBA8888; - } else if (format == QImage::Format_ARGB32_Premultiplied) { - format = QImage::Format_RGBA8888_Premultiplied; - } +#else + if (vFormat < PixelFormat::Format_AYUV) { +#endif + format = imageFormatFromPixelFormat(vFormat); swap = true; } else { #ifdef USE_FFMPEG enum AVPixelFormat pixelFormat; switch (vFormat) { - case QVideoFrame::Format_YUV420P: + case VideoDumper::PixelFormat::Format_YUV420P: pixelFormat = AV_PIX_FMT_YUV420P; break; #if (QT_VERSION >= QT_VERSION_CHECK(5, 14, 0)) - case QVideoFrame::Format_YUV422P: + case VideoDumper::PixelFormat::Format_YUV422P: pixelFormat = AV_PIX_FMT_YUV422P; break; #endif - case QVideoFrame::Format_YUYV: + case VideoDumper::PixelFormat::Format_YUYV: pixelFormat = AV_PIX_FMT_YUYV422; break; - case QVideoFrame::Format_UYVY: + case VideoDumper::PixelFormat::Format_UYVY: pixelFormat = AV_PIX_FMT_UYVY422; break; - case QVideoFrame::Format_NV12: + case VideoDumper::PixelFormat::Format_NV12: pixelFormat = AV_PIX_FMT_NV12; break; - case QVideoFrame::Format_NV21: + case VideoDumper::PixelFormat::Format_NV21: pixelFormat = AV_PIX_FMT_NV12; break; default: @@ -80,11 +90,15 @@ bool VideoDumper::present(const QVideoFrame& frame) { #endif } } - uchar* bits = mappedFrame.bits(); +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) + Direction direction = surfaceFormat().scanLineDirection(); +#else + Direction direction = mappedFrame.surfaceFormat().scanLineDirection(); +#endif #ifdef USE_FFMPEG QImage image; if (!useScaler) { - image = QImage(bits, mappedFrame.width(), mappedFrame.height(), mappedFrame.bytesPerLine(), format); + image = QImage(mappedFrame.bits(0), mappedFrame.width(), mappedFrame.height(), mappedFrame.bytesPerLine(0), format); } if (useScaler) { image = QImage(mappedFrame.width(), mappedFrame.height(), format); @@ -99,14 +113,14 @@ bool VideoDumper::present(const QVideoFrame& frame) { sws_scale(m_scaler, planes, strides, 0, mappedFrame.height(), &outBits, &outStride); } else #else - QImage image(bits, mappedFrame.width(), mappedFrame.height(), mappedFrame.bytesPerLine(), format); + QImage image(mappedFrame.bits(0), mappedFrame.width(), mappedFrame.height(), mappedFrame.bytesPerLine(0), format); #endif if (swap) { image = image.rgbSwapped(); - } else if (surfaceFormat().scanLineDirection() != QVideoSurfaceFormat::BottomToTop) { + } else if (direction != Direction::BottomToTop) { image = image.copy(); // Create a deep copy of the bits } - if (surfaceFormat().scanLineDirection() == QVideoSurfaceFormat::BottomToTop) { + if (direction == Direction::BottomToTop) { image = image.mirrored(); } mappedFrame.unmap(); @@ -114,29 +128,63 @@ bool VideoDumper::present(const QVideoFrame& frame) { return true; } +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) QList VideoDumper::supportedPixelFormats(QAbstractVideoBuffer::HandleType) const { - QList list; - list.append(QVideoFrame::Format_RGB32); - list.append(QVideoFrame::Format_ARGB32); - list.append(QVideoFrame::Format_RGB24); - list.append(QVideoFrame::Format_ARGB32_Premultiplied); - list.append(QVideoFrame::Format_RGB565); - list.append(QVideoFrame::Format_RGB555); - list.append(QVideoFrame::Format_BGR32); - list.append(QVideoFrame::Format_BGRA32); - list.append(QVideoFrame::Format_BGR24); - list.append(QVideoFrame::Format_BGRA32_Premultiplied); - list.append(QVideoFrame::Format_BGR565); - list.append(QVideoFrame::Format_BGR555); + return VideoDumper::supportedPixelFormats(); +} +#endif + +QList VideoDumper::supportedPixelFormats() { + QList list{{ +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) + VideoDumper::PixelFormat::Format_RGB32, + VideoDumper::PixelFormat::Format_ARGB32, + VideoDumper::PixelFormat::Format_RGB24, + VideoDumper::PixelFormat::Format_ARGB32_Premultiplied, + VideoDumper::PixelFormat::Format_RGB565, + VideoDumper::PixelFormat::Format_RGB555, + VideoDumper::PixelFormat::Format_BGR32, + VideoDumper::PixelFormat::Format_BGRA32, + VideoDumper::PixelFormat::Format_BGR24, + VideoDumper::PixelFormat::Format_BGRA32_Premultiplied, + VideoDumper::PixelFormat::Format_BGR565, + VideoDumper::PixelFormat::Format_BGR555, +#else + VideoDumper::PixelFormat::Format_XRGB8888, + VideoDumper::PixelFormat::Format_ARGB8888, + VideoDumper::PixelFormat::Format_ARGB8888_Premultiplied, + VideoDumper::PixelFormat::Format_RGBX8888, + VideoDumper::PixelFormat::Format_RGBA8888, + VideoDumper::PixelFormat::Format_XBGR8888, + VideoDumper::PixelFormat::Format_ABGR8888, + VideoDumper::PixelFormat::Format_BGRX8888, + VideoDumper::PixelFormat::Format_BGRA8888, + VideoDumper::PixelFormat::Format_BGRA8888_Premultiplied, +#endif #ifdef USE_FFMPEG - list.append(QVideoFrame::Format_YUYV); - list.append(QVideoFrame::Format_UYVY); + VideoDumper::PixelFormat::Format_YUYV, + VideoDumper::PixelFormat::Format_UYVY, #if (QT_VERSION >= QT_VERSION_CHECK(5, 14, 0)) - list.append(QVideoFrame::Format_YUV422P); + VideoDumper::PixelFormat::Format_YUV422P, #endif - list.append(QVideoFrame::Format_YUV420P); - list.append(QVideoFrame::Format_NV12); - list.append(QVideoFrame::Format_NV21); + VideoDumper::PixelFormat::Format_YUV420P, + VideoDumper::PixelFormat::Format_NV12, + VideoDumper::PixelFormat::Format_NV21, #endif + }}; return list; } + +QImage::Format VideoDumper::imageFormatFromPixelFormat(VideoDumper::PixelFormat vFormat) { +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) + QImage::Format format = QVideoFrame::imageFormatFromPixelFormat(vFormat); +#else + QImage::Format format = QVideoFrameFormat::imageFormatFromPixelFormat(vFormat); +#endif + if (format == QImage::Format_ARGB32) { + format = QImage::Format_RGBA8888; + } else if (format == QImage::Format_ARGB32_Premultiplied) { + format = QImage::Format_RGBA8888_Premultiplied; + } + return format; +} diff --git a/src/platform/qt/VideoDumper.h b/src/platform/qt/VideoDumper.h index c22688c2b08..65433462cb8 100644 --- a/src/platform/qt/VideoDumper.h +++ b/src/platform/qt/VideoDumper.h @@ -5,7 +5,13 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #pragma once +#include +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) #include +#include +#else +#include +#endif #ifdef USE_FFMPEG extern "C" { @@ -15,14 +21,38 @@ extern "C" { namespace QGBA { -class VideoDumper : public QAbstractVideoSurface { +class VideoDumper : public +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) +QAbstractVideoSurface +#else +QObject +#endif +{ Q_OBJECT public: +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) + using PixelFormat = QVideoFrame::PixelFormat; + using Direction = QVideoSurfaceFormat::Direction; +#else + using PixelFormat = QVideoFrameFormat::PixelFormat; + using Direction = QVideoFrameFormat::Direction; +#endif + VideoDumper(QObject* parent = nullptr); +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) + QList supportedPixelFormats(QAbstractVideoBuffer::HandleType type) const override; +#endif + static QList supportedPixelFormats(); + static QImage::Format imageFormatFromPixelFormat(PixelFormat); + +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) bool present(const QVideoFrame& frame) override; - QList supportedPixelFormats(QAbstractVideoBuffer::HandleType type = QAbstractVideoBuffer::NoHandle) const override; +#else +public slots: + bool present(const QVideoFrame& frame); +#endif signals: void imageAvailable(const QImage& image); From dc29af82624b9791e58c8b3cd937c5663311e563 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 24 Mar 2024 21:18:41 -0700 Subject: [PATCH 019/338] Qt: Hook up cameras in Qt6 --- src/platform/qt/InputController.cpp | 47 +++++++++++++++++++++++------ src/platform/qt/InputController.h | 14 ++++++--- 2 files changed, 47 insertions(+), 14 deletions(-) diff --git a/src/platform/qt/InputController.cpp b/src/platform/qt/InputController.cpp index e195505a44a..4a02361996d 100644 --- a/src/platform/qt/InputController.cpp +++ b/src/platform/qt/InputController.cpp @@ -54,11 +54,11 @@ InputController::InputController(QWidget* topLevel, QObject* parent) m_gamepadTimer.setInterval(15); m_gamepadTimer.start(); -#ifdef BUILD_QT_MULTIMEDIA -#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) - connect(&m_videoDumper, &VideoDumper::imageAvailable, this, &InputController::setCamImage); -#endif +#if defined(BUILD_QT_MULTIMEDIA) && (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) + m_captureSession.setVideoSink(&m_videoSink); + connect(&m_videoSink, &QVideoSink::videoFrameChanged, &m_videoDumper, &VideoDumper::present); #endif + connect(&m_videoDumper, &VideoDumper::imageAvailable, this, &InputController::setCamImage); mInputBindKey(&m_inputMap, KEYBOARD, Qt::Key_X, GBA_KEY_A); mInputBindKey(&m_inputMap, KEYBOARD, Qt::Key_Z, GBA_KEY_B); @@ -101,7 +101,6 @@ InputController::InputController(QWidget* topLevel, QObject* parent) if (!camera.isNull()) { image->p->m_cameraDevice = camera; } - QMetaObject::invokeMethod(image->p, "setupCam"); #else if (!camera.isNull()) { for (const auto& cam : QMediaDevices::videoInputs()) { @@ -111,6 +110,7 @@ InputController::InputController(QWidget* topLevel, QObject* parent) } } #endif + QMetaObject::invokeMethod(image->p, "setupCam"); #endif }; @@ -677,18 +677,26 @@ void InputController::setupCam() { m_camera = std::make_unique(m_cameraDevice); m_captureSession.setCamera(m_camera.get()); } + prepareCamFormat(); #endif #endif } -#if defined(BUILD_QT_MULTIMEDIA) && (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) +#ifdef BUILD_QT_MULTIMEDIA +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) void InputController::prepareCamSettings(QCamera::Status status) { if (status != QCamera::LoadedStatus || m_camera->state() == QCamera::ActiveState) { return; } + prepareCamFormat(); +} +#endif + +void InputController::prepareCamFormat() { #if (QT_VERSION >= QT_VERSION_CHECK(5, 5, 0)) - QCameraViewfinderSettings settings; QSize size(1280, 720); +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) + QCameraViewfinderSettings settings; auto cameraRes = m_camera->supportedViewfinderResolutions(settings); for (auto& cameraSize : cameraRes) { if (cameraSize.width() < m_image.w || cameraSize.height() < m_image.h) { @@ -717,6 +725,25 @@ void InputController::prepareCamSettings(QCamera::Status status) { } } m_camera->setViewfinderSettings(settings); +#else + bool goodFormatFound = false; + auto goodFormats = m_videoDumper.supportedPixelFormats(); + QCameraFormat bestFormat; + for (const auto& format : m_cameraDevice.videoFormats()) { + if (!goodFormats.contains(format.pixelFormat())) { + continue; + } + if (format.resolution().width() <= size.width() && format.resolution().height() <= size.height()) { + size = format.resolution(); + bestFormat = format; + goodFormatFound = true; + } + } + if (!goodFormatFound) { + LOG(QT, WARN) << "Could not find a valid camera format!"; + } + m_camera->setCameraFormat(bestFormat); +#endif #endif m_camera->start(); } @@ -745,9 +772,6 @@ void InputController::setCamera(const QByteArray& name) { if (m_camera && m_camera->state() == QCamera::ActiveState) { teardownCam(); } - if (m_cameraActive) { - setupCam(); - } #else if (m_cameraDevice.id() == name) { return; @@ -758,5 +782,8 @@ void InputController::setCamera(const QByteArray& name) { } } #endif + if (m_cameraActive) { + setupCam(); + } #endif } diff --git a/src/platform/qt/InputController.h b/src/platform/qt/InputController.h index 51be333ede1..07e752fd7c5 100644 --- a/src/platform/qt/InputController.h +++ b/src/platform/qt/InputController.h @@ -25,12 +25,13 @@ #include #ifdef BUILD_QT_MULTIMEDIA -#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) #include "VideoDumper.h" -#else + +#include +#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) #include +#include #endif -#include #endif struct mRotationSource; @@ -152,6 +153,10 @@ private slots: QSet> activeGamepadAxes(uint32_t type); QSet> activeGamepadHats(uint32_t type); +#if defined(BUILD_QT_MULTIMEDIA) + void prepareCamFormat(); +#endif + struct InputControllerLux : GBALuminanceSource { InputController* p; uint8_t value; @@ -171,12 +176,13 @@ private slots: #ifdef BUILD_QT_MULTIMEDIA bool m_cameraActive = false; std::unique_ptr m_camera; + VideoDumper m_videoDumper; #if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) QByteArray m_cameraDevice; - VideoDumper m_videoDumper; #else QCameraDevice m_cameraDevice; QMediaCaptureSession m_captureSession; + QVideoSink m_videoSink; #endif #endif From 04bbcdfdd1f3c2352eb3f2f7b25980deb6055066 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 24 Mar 2024 21:31:53 -0700 Subject: [PATCH 020/338] Qt: Fix build --- src/platform/qt/VideoDumper.cpp | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/platform/qt/VideoDumper.cpp b/src/platform/qt/VideoDumper.cpp index 1f1185200d3..913406a70ee 100644 --- a/src/platform/qt/VideoDumper.cpp +++ b/src/platform/qt/VideoDumper.cpp @@ -5,8 +5,6 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include "VideoDumper.h" -#include "VideoProcessor.h" - #include using namespace QGBA; From 6940b424df95ba22dec250f828d44df2834d3cf9 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 24 Mar 2024 22:07:31 -0700 Subject: [PATCH 021/338] Qt: Fix non-Multimedia build --- src/platform/qt/InputController.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/src/platform/qt/InputController.cpp b/src/platform/qt/InputController.cpp index 4a02361996d..d5e799b5a90 100644 --- a/src/platform/qt/InputController.cpp +++ b/src/platform/qt/InputController.cpp @@ -54,11 +54,13 @@ InputController::InputController(QWidget* topLevel, QObject* parent) m_gamepadTimer.setInterval(15); m_gamepadTimer.start(); -#if defined(BUILD_QT_MULTIMEDIA) && (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) +#ifdef BUILD_QT_MULTIMEDIA +#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) m_captureSession.setVideoSink(&m_videoSink); connect(&m_videoSink, &QVideoSink::videoFrameChanged, &m_videoDumper, &VideoDumper::present); #endif connect(&m_videoDumper, &VideoDumper::imageAvailable, this, &InputController::setCamImage); +#endif mInputBindKey(&m_inputMap, KEYBOARD, Qt::Key_X, GBA_KEY_A); mInputBindKey(&m_inputMap, KEYBOARD, Qt::Key_Z, GBA_KEY_B); @@ -115,10 +117,12 @@ InputController::InputController(QWidget* topLevel, QObject* parent) }; m_image.stopRequestImage = [](mImageSource* context) { - InputControllerImage* image = static_cast(context); #ifdef BUILD_QT_MULTIMEDIA + InputControllerImage* image = static_cast(context); image->p->m_cameraActive = false; QMetaObject::invokeMethod(image->p, "teardownCam"); +#else + UNUSED(context); #endif }; @@ -785,5 +789,7 @@ void InputController::setCamera(const QByteArray& name) { if (m_cameraActive) { setupCam(); } +#else + UNUSED(name); #endif } From ea5339304a8923f31853cba98863d3b87bb6dd9e Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 24 Mar 2024 22:57:51 -0700 Subject: [PATCH 022/338] GBA Savedata: Prefix SavedataType constants and type name --- include/mgba/internal/gba/overrides.h | 2 +- include/mgba/internal/gba/savedata.h | 22 +-- src/gba/core.c | 14 +- src/gba/dma.c | 6 +- src/gba/gba.c | 4 +- src/gba/memory.c | 28 +-- src/gba/overrides.c | 260 +++++++++++++------------- src/gba/savedata.c | 128 ++++++------- src/gba/sharkport.c | 10 +- src/platform/libretro/libretro.c | 2 +- src/platform/qt/OverrideView.cpp | 4 +- src/platform/qt/SaveConverter.cpp | 56 +++--- src/platform/qt/SaveConverter.h | 4 +- 13 files changed, 270 insertions(+), 270 deletions(-) diff --git a/include/mgba/internal/gba/overrides.h b/include/mgba/internal/gba/overrides.h index c835a62a13a..83a63f0a428 100644 --- a/include/mgba/internal/gba/overrides.h +++ b/include/mgba/internal/gba/overrides.h @@ -16,7 +16,7 @@ CXX_GUARD_START struct GBACartridgeOverride { char id[4]; - enum SavedataType savetype; + enum GBASavedataType savetype; int hardware; uint32_t idleLoop; bool mirroring; diff --git a/include/mgba/internal/gba/savedata.h b/include/mgba/internal/gba/savedata.h index 102c2304138..a03f2960cdc 100644 --- a/include/mgba/internal/gba/savedata.h +++ b/include/mgba/internal/gba/savedata.h @@ -17,15 +17,15 @@ mLOG_DECLARE_CATEGORY(GBA_SAVE); struct VFile; -enum SavedataType { - SAVEDATA_AUTODETECT = -1, - SAVEDATA_FORCE_NONE = 0, - SAVEDATA_SRAM = 1, - SAVEDATA_FLASH512 = 2, - SAVEDATA_FLASH1M = 3, - SAVEDATA_EEPROM = 4, - SAVEDATA_EEPROM512 = 5, - SAVEDATA_SRAM512 = 6, +enum GBASavedataType { + GBA_SAVEDATA_AUTODETECT = -1, + GBA_SAVEDATA_FORCE_NONE = 0, + GBA_SAVEDATA_SRAM = 1, + GBA_SAVEDATA_FLASH512 = 2, + GBA_SAVEDATA_FLASH1M = 3, + GBA_SAVEDATA_EEPROM = 4, + GBA_SAVEDATA_EEPROM512 = 5, + GBA_SAVEDATA_SRAM512 = 6, }; enum SavedataCommand { @@ -68,7 +68,7 @@ enum { }; struct GBASavedata { - enum SavedataType type; + enum GBASavedataType type; uint8_t* data; enum SavedataCommand command; struct VFile* vf; @@ -108,7 +108,7 @@ void GBASavedataUnmask(struct GBASavedata* savedata); size_t GBASavedataSize(const struct GBASavedata* savedata); bool GBASavedataClone(struct GBASavedata* savedata, struct VFile* out); bool GBASavedataLoad(struct GBASavedata* savedata, struct VFile* in); -void GBASavedataForceType(struct GBASavedata* savedata, enum SavedataType type); +void GBASavedataForceType(struct GBASavedata* savedata, enum GBASavedataType type); void GBASavedataInitFlash(struct GBASavedata* savedata); void GBASavedataInitEEPROM(struct GBASavedata* savedata); diff --git a/src/gba/core.c b/src/gba/core.c index 46ad70f088c..89bcaafc6b4 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -1004,27 +1004,27 @@ size_t _GBACoreListMemoryBlocks(const struct mCore* core, const struct mCoreMemo if (gbacore->memoryBlockType != gba->memory.savedata.type) { switch (gba->memory.savedata.type) { - case SAVEDATA_SRAM: + case GBA_SAVEDATA_SRAM: memcpy(gbacore->memoryBlocks, _GBAMemoryBlocksSRAM, sizeof(_GBAMemoryBlocksSRAM)); gbacore->nMemoryBlocks = sizeof(_GBAMemoryBlocksSRAM) / sizeof(*_GBAMemoryBlocksSRAM); break; - case SAVEDATA_SRAM512: + case GBA_SAVEDATA_SRAM512: memcpy(gbacore->memoryBlocks, _GBAMemoryBlocksSRAM512, sizeof(_GBAMemoryBlocksSRAM512)); gbacore->nMemoryBlocks = sizeof(_GBAMemoryBlocksSRAM512) / sizeof(*_GBAMemoryBlocksSRAM512); break; - case SAVEDATA_FLASH512: + case GBA_SAVEDATA_FLASH512: memcpy(gbacore->memoryBlocks, _GBAMemoryBlocksFlash512, sizeof(_GBAMemoryBlocksFlash512)); gbacore->nMemoryBlocks = sizeof(_GBAMemoryBlocksFlash512) / sizeof(*_GBAMemoryBlocksFlash512); break; - case SAVEDATA_FLASH1M: + case GBA_SAVEDATA_FLASH1M: memcpy(gbacore->memoryBlocks, _GBAMemoryBlocksFlash1M, sizeof(_GBAMemoryBlocksFlash1M)); gbacore->nMemoryBlocks = sizeof(_GBAMemoryBlocksFlash1M) / sizeof(*_GBAMemoryBlocksFlash1M); break; - case SAVEDATA_EEPROM: + case GBA_SAVEDATA_EEPROM: memcpy(gbacore->memoryBlocks, _GBAMemoryBlocksEEPROM, sizeof(_GBAMemoryBlocksEEPROM)); gbacore->nMemoryBlocks = sizeof(_GBAMemoryBlocksEEPROM) / sizeof(*_GBAMemoryBlocksEEPROM); break; - case SAVEDATA_EEPROM512: + case GBA_SAVEDATA_EEPROM512: memcpy(gbacore->memoryBlocks, _GBAMemoryBlocksEEPROM512, sizeof(_GBAMemoryBlocksEEPROM512)); gbacore->nMemoryBlocks = sizeof(_GBAMemoryBlocksEEPROM512) / sizeof(*_GBAMemoryBlocksEEPROM512); break; @@ -1076,7 +1076,7 @@ void* _GBACoreGetMemoryBlock(struct mCore* core, size_t id, size_t* sizeOut) { *sizeOut = gba->memory.romSize; return gba->memory.rom; case GBA_REGION_SRAM: - if (gba->memory.savedata.type == SAVEDATA_FLASH1M) { + if (gba->memory.savedata.type == GBA_SAVEDATA_FLASH1M) { *sizeOut = GBA_SIZE_FLASH1M; return gba->memory.savedata.currentBank; } diff --git a/src/gba/dma.c b/src/gba/dma.c index 7c75184eafd..29034136147 100644 --- a/src/gba/dma.c +++ b/src/gba/dma.c @@ -274,7 +274,7 @@ void GBADMAService(struct GBA* gba, int number, struct GBADMA* info) { } cpu->memory.store32(cpu, dest, memory->dmaTransferRegister, 0); } else { - if (sourceRegion == GBA_REGION_ROM2_EX && (memory->savedata.type == SAVEDATA_EEPROM || memory->savedata.type == SAVEDATA_EEPROM512)) { + if (sourceRegion == GBA_REGION_ROM2_EX && (memory->savedata.type == GBA_SAVEDATA_EEPROM || memory->savedata.type == GBA_SAVEDATA_EEPROM512)) { memory->dmaTransferRegister = GBASavedataReadEEPROM(&memory->savedata); memory->dmaTransferRegister |= memory->dmaTransferRegister << 16; } else if (source) { @@ -282,11 +282,11 @@ void GBADMAService(struct GBA* gba, int number, struct GBADMA* info) { memory->dmaTransferRegister |= memory->dmaTransferRegister << 16; } if (destRegion == GBA_REGION_ROM2_EX) { - if (memory->savedata.type == SAVEDATA_AUTODETECT) { + if (memory->savedata.type == GBA_SAVEDATA_AUTODETECT) { mLOG(GBA_MEM, INFO, "Detected EEPROM savegame"); GBASavedataInitEEPROM(&memory->savedata); } - if (memory->savedata.type == SAVEDATA_EEPROM512 || memory->savedata.type == SAVEDATA_EEPROM) { + if (memory->savedata.type == GBA_SAVEDATA_EEPROM512 || memory->savedata.type == GBA_SAVEDATA_EEPROM) { GBASavedataWriteEEPROM(&memory->savedata, memory->dmaTransferRegister, info->nextCount); } } else { diff --git a/src/gba/gba.c b/src/gba/gba.c index 7586ae66c06..409bd2b3ab3 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -469,10 +469,10 @@ bool GBALoadROM(struct GBA* gba, struct VFile* vf) { } bool GBALoadSave(struct GBA* gba, struct VFile* sav) { - enum SavedataType type = gba->memory.savedata.type; + enum GBASavedataType type = gba->memory.savedata.type; GBASavedataDeinit(&gba->memory.savedata); GBASavedataInit(&gba->memory.savedata, sav); - if (type != SAVEDATA_AUTODETECT) { + if (type != GBA_SAVEDATA_AUTODETECT) { GBASavedataForceType(&gba->memory.savedata, type); } return sav; diff --git a/src/gba/memory.c b/src/gba/memory.c index 9418a2706bd..455c70bdb6c 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -595,7 +595,7 @@ uint32_t GBALoad16(struct ARMCore* cpu, uint32_t address, int* cycleCounter) { break; case GBA_REGION_ROM2_EX: wait = memory->waitstatesNonseq16[address >> BASE_OFFSET]; - if (memory->savedata.type == SAVEDATA_EEPROM || memory->savedata.type == SAVEDATA_EEPROM512) { + if (memory->savedata.type == GBA_SAVEDATA_EEPROM || memory->savedata.type == GBA_SAVEDATA_EEPROM512) { value = GBASavedataReadEEPROM(&memory->savedata); } else if ((address & 0x0DFC0000) >= 0x0DF80000 && memory->hw.devices & HW_EREADER) { value = GBACartEReaderRead(&memory->ereader, address); @@ -702,7 +702,7 @@ uint32_t GBALoad8(struct ARMCore* cpu, uint32_t address, int* cycleCounter) { case GBA_REGION_SRAM: case GBA_REGION_SRAM_MIRROR: wait = memory->waitstatesNonseq16[address >> BASE_OFFSET]; - if (memory->savedata.type == SAVEDATA_AUTODETECT) { + if (memory->savedata.type == GBA_SAVEDATA_AUTODETECT) { mLOG(GBA_MEM, INFO, "Detected SRAM savegame"); GBASavedataInitSRAM(&memory->savedata); } @@ -711,13 +711,13 @@ uint32_t GBALoad8(struct ARMCore* cpu, uint32_t address, int* cycleCounter) { } if (memory->hw.devices & HW_EREADER && (address & 0xE00FF80) >= 0xE00FF80) { value = GBACartEReaderReadFlash(&memory->ereader, address); - } else if (memory->savedata.type == SAVEDATA_SRAM) { + } else if (memory->savedata.type == GBA_SAVEDATA_SRAM) { value = memory->savedata.data[address & (GBA_SIZE_SRAM - 1)]; - } else if (memory->savedata.type == SAVEDATA_FLASH512 || memory->savedata.type == SAVEDATA_FLASH1M) { + } else if (memory->savedata.type == GBA_SAVEDATA_FLASH512 || memory->savedata.type == GBA_SAVEDATA_FLASH1M) { value = GBASavedataReadFlash(&memory->savedata, address); } else if (memory->hw.devices & HW_TILT) { value = GBAHardwareTiltRead(&memory->hw, address & OFFSET_MASK); - } else if (memory->savedata.type == SAVEDATA_SRAM512) { + } else if (memory->savedata.type == GBA_SAVEDATA_SRAM512) { value = memory->savedata.data[address & (GBA_SIZE_SRAM512 - 1)]; } else { mLOG(GBA_MEM, GAME_ERROR, "Reading from non-existent SRAM: 0x%08X", address); @@ -975,11 +975,11 @@ void GBAStore16(struct ARMCore* cpu, uint32_t address, int16_t value, int* cycle if ((address & 0x0DFC0000) >= 0x0DF80000 && memory->hw.devices & HW_EREADER) { GBACartEReaderWrite(&memory->ereader, address, value); break; - } else if (memory->savedata.type == SAVEDATA_AUTODETECT) { + } else if (memory->savedata.type == GBA_SAVEDATA_AUTODETECT) { mLOG(GBA_MEM, INFO, "Detected EEPROM savegame"); GBASavedataInitEEPROM(&memory->savedata); } - if (memory->savedata.type == SAVEDATA_EEPROM512 || memory->savedata.type == SAVEDATA_EEPROM) { + if (memory->savedata.type == GBA_SAVEDATA_EEPROM512 || memory->savedata.type == GBA_SAVEDATA_EEPROM) { GBASavedataWriteEEPROM(&memory->savedata, value, 1); break; } @@ -1050,7 +1050,7 @@ void GBAStore8(struct ARMCore* cpu, uint32_t address, int8_t value, int* cycleCo break; case GBA_REGION_SRAM: case GBA_REGION_SRAM_MIRROR: - if (memory->savedata.type == SAVEDATA_AUTODETECT) { + if (memory->savedata.type == GBA_SAVEDATA_AUTODETECT) { if (address == SAVEDATA_FLASH_BASE) { mLOG(GBA_MEM, INFO, "Detected Flash savegame"); GBASavedataInitFlash(&memory->savedata); @@ -1061,9 +1061,9 @@ void GBAStore8(struct ARMCore* cpu, uint32_t address, int8_t value, int* cycleCo } if (memory->hw.devices & HW_EREADER && (address & 0xE00FF80) >= 0xE00FF80) { GBACartEReaderWriteFlash(&memory->ereader, address, value); - } else if (memory->savedata.type == SAVEDATA_FLASH512 || memory->savedata.type == SAVEDATA_FLASH1M) { + } else if (memory->savedata.type == GBA_SAVEDATA_FLASH512 || memory->savedata.type == GBA_SAVEDATA_FLASH1M) { GBASavedataWriteFlash(&memory->savedata, address, value); - } else if (memory->savedata.type == SAVEDATA_SRAM) { + } else if (memory->savedata.type == GBA_SAVEDATA_SRAM) { if (memory->vfame.cartType) { GBAVFameSramWrite(&memory->vfame, address, value, memory->savedata.data); } else { @@ -1072,7 +1072,7 @@ void GBAStore8(struct ARMCore* cpu, uint32_t address, int8_t value, int* cycleCo memory->savedata.dirty |= mSAVEDATA_DIRT_NEW; } else if (memory->hw.devices & HW_TILT) { GBAHardwareTiltWrite(&memory->hw, address & OFFSET_MASK, value); - } else if (memory->savedata.type == SAVEDATA_SRAM512) { + } else if (memory->savedata.type == GBA_SAVEDATA_SRAM512) { memory->savedata.data[address & (GBA_SIZE_SRAM512 - 1)] = value; memory->savedata.dirty |= mSAVEDATA_DIRT_NEW; } else { @@ -1263,7 +1263,7 @@ void GBAPatch32(struct ARMCore* cpu, uint32_t address, int32_t value, int32_t* o break; case GBA_REGION_SRAM: case GBA_REGION_SRAM_MIRROR: - if (memory->savedata.type == SAVEDATA_SRAM) { + if (memory->savedata.type == GBA_SAVEDATA_SRAM) { LOAD_32(oldValue, address & (GBA_SIZE_SRAM - 4), memory->savedata.data); STORE_32(value, address & (GBA_SIZE_SRAM - 4), memory->savedata.data); } else { @@ -1333,7 +1333,7 @@ void GBAPatch16(struct ARMCore* cpu, uint32_t address, int16_t value, int16_t* o break; case GBA_REGION_SRAM: case GBA_REGION_SRAM_MIRROR: - if (memory->savedata.type == SAVEDATA_SRAM) { + if (memory->savedata.type == GBA_SAVEDATA_SRAM) { LOAD_16(oldValue, address & (GBA_SIZE_SRAM - 2), memory->savedata.data); STORE_16(value, address & (GBA_SIZE_SRAM - 2), memory->savedata.data); } else { @@ -1391,7 +1391,7 @@ void GBAPatch8(struct ARMCore* cpu, uint32_t address, int8_t value, int8_t* old) break; case GBA_REGION_SRAM: case GBA_REGION_SRAM_MIRROR: - if (memory->savedata.type == SAVEDATA_SRAM) { + if (memory->savedata.type == GBA_SAVEDATA_SRAM) { oldValue = ((int8_t*) memory->savedata.data)[address & (GBA_SIZE_SRAM - 1)]; ((int8_t*) memory->savedata.data)[address & (GBA_SIZE_SRAM - 1)] = value; } else { diff --git a/src/gba/overrides.c b/src/gba/overrides.c index ccc871e62e9..44a47efb58e 100644 --- a/src/gba/overrides.c +++ b/src/gba/overrides.c @@ -13,210 +13,210 @@ static const struct GBACartridgeOverride _overrides[] = { // Advance Wars - { "AWRE", SAVEDATA_FLASH512, HW_NONE, 0x8038810, false }, - { "AWRP", SAVEDATA_FLASH512, HW_NONE, 0x8038810, false }, + { "AWRE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8038810, false }, + { "AWRP", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8038810, false }, // Advance Wars 2: Black Hole Rising - { "AW2E", SAVEDATA_FLASH512, HW_NONE, 0x8036E08, false }, - { "AW2P", SAVEDATA_FLASH512, HW_NONE, 0x803719C, false }, + { "AW2E", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8036E08, false }, + { "AW2P", GBA_SAVEDATA_FLASH512, HW_NONE, 0x803719C, false }, // Boktai: The Sun is in Your Hand - { "U3IJ", SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, - { "U3IE", SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, - { "U3IP", SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, + { "U3IJ", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, + { "U3IE", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, + { "U3IP", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, // Boktai 2: Solar Boy Django - { "U32J", SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, - { "U32E", SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, - { "U32P", SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, + { "U32J", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, + { "U32E", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, + { "U32P", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, // Crash Bandicoot 2 - N-Tranced - { "AC8J", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "AC8E", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "AC8P", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "AC8J", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "AC8E", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "AC8P", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, // DigiCommunication Nyo - Datou! Black Gemagema Dan - { "BDKJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "BDKJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, // Dragon Ball Z - The Legacy of Goku - { "ALGP", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "ALGP", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, // Dragon Ball Z - The Legacy of Goku II - { "ALFJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "ALFE", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "ALFP", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "ALFJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "ALFE", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "ALFP", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, // Dragon Ball Z - Taiketsu - { "BDBE", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "BDBP", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "BDBE", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "BDBP", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, // Drill Dozer - { "V49J", SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, - { "V49E", SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, - { "V49P", SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, + { "V49J", GBA_SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, + { "V49E", GBA_SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, + { "V49P", GBA_SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, // e-Reader - { "PEAJ", SAVEDATA_FLASH1M, HW_EREADER, IDLE_LOOP_NONE }, - { "PSAJ", SAVEDATA_FLASH1M, HW_EREADER, IDLE_LOOP_NONE }, - { "PSAE", SAVEDATA_FLASH1M, HW_EREADER, IDLE_LOOP_NONE }, + { "PEAJ", GBA_SAVEDATA_FLASH1M, HW_EREADER, IDLE_LOOP_NONE }, + { "PSAJ", GBA_SAVEDATA_FLASH1M, HW_EREADER, IDLE_LOOP_NONE }, + { "PSAE", GBA_SAVEDATA_FLASH1M, HW_EREADER, IDLE_LOOP_NONE }, // Final Fantasy Tactics Advance - { "AFXE", SAVEDATA_FLASH512, HW_NONE, 0x8000428, false }, + { "AFXE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8000428, false }, // F-Zero - Climax - { "BFTJ", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BFTJ", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, // Goodboy Galaxy - { "2GBP", SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, + { "2GBP", GBA_SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, // Iridion II - { "AI2E", SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, - { "AI2P", SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, + { "AI2E", GBA_SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, + { "AI2P", GBA_SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, // Game Boy Wars Advance 1+2 - { "BGWJ", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BGWJ", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, // Golden Sun: The Lost Age - { "AGFE", SAVEDATA_FLASH512, HW_NONE, 0x801353A, false }, + { "AGFE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x801353A, false }, // Koro Koro Puzzle - Happy Panechu! - { "KHPJ", SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, + { "KHPJ", GBA_SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, // Legendz - Yomigaeru Shiren no Shima - { "BLJJ", SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, - { "BLJK", SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, + { "BLJJ", GBA_SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, + { "BLJK", GBA_SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, // Legendz - Sign of Nekuromu - { "BLVJ", SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, + { "BLVJ", GBA_SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, // Mega Man Battle Network - { "AREE", SAVEDATA_SRAM, HW_NONE, 0x800032E, false }, + { "AREE", GBA_SAVEDATA_SRAM, HW_NONE, 0x800032E, false }, // Mega Man Zero - { "AZCE", SAVEDATA_SRAM, HW_NONE, 0x80004E8, false }, + { "AZCE", GBA_SAVEDATA_SRAM, HW_NONE, 0x80004E8, false }, // Metal Slug Advance - { "BSME", SAVEDATA_EEPROM, HW_NONE, 0x8000290, false }, + { "BSME", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8000290, false }, // Pokemon Ruby - { "AXVJ", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVE", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVP", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVI", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVS", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVD", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVF", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXVJ", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXVE", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXVP", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXVI", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXVS", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXVD", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXVF", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, // Pokemon Sapphire - { "AXPJ", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPE", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPP", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPI", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPS", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPD", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPF", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXPJ", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXPE", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXPP", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXPI", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXPS", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXPD", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXPF", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, // Pokemon Emerald - { "BPEJ", SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPEE", SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPEP", SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPEI", SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPES", SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPED", SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPEF", SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, + { "BPEJ", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, + { "BPEE", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, + { "BPEP", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, + { "BPEI", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, + { "BPES", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, + { "BPED", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, + { "BPEF", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, // Pokemon Mystery Dungeon - { "B24E", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "B24P", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "B24E", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "B24P", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, // Pokemon FireRed - { "BPRJ", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRE", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRP", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRI", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRS", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRD", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRF", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPRJ", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPRE", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPRP", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPRI", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPRS", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPRD", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPRF", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, // Pokemon LeafGreen - { "BPGJ", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGE", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGP", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGI", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGS", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGD", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGF", SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPGJ", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPGE", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPGP", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPGI", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPGS", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPGD", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPGF", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, // RockMan EXE 4.5 - Real Operation - { "BR4J", SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, + { "BR4J", GBA_SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, // Rocky - { "AR8E", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "AROP", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "AR8E", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "AROP", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, // Sennen Kazoku - { "BKAJ", SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "BKAJ", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, // Shin Bokura no Taiyou: Gyakushuu no Sabata - { "U33J", SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, + { "U33J", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, // Stuart Little 2 - { "ASLE", SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, - { "ASLF", SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, + { "ASLE", GBA_SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, + { "ASLF", GBA_SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, // Super Mario Advance 2 - { "AA2J", SAVEDATA_EEPROM, HW_NONE, 0x800052E, false }, - { "AA2E", SAVEDATA_EEPROM, HW_NONE, 0x800052E, false }, - { "AA2P", SAVEDATA_AUTODETECT, HW_NONE, 0x800052E, false }, + { "AA2J", GBA_SAVEDATA_EEPROM, HW_NONE, 0x800052E, false }, + { "AA2E", GBA_SAVEDATA_EEPROM, HW_NONE, 0x800052E, false }, + { "AA2P", GBA_SAVEDATA_AUTODETECT, HW_NONE, 0x800052E, false }, // Super Mario Advance 3 - { "A3AJ", SAVEDATA_EEPROM, HW_NONE, 0x8002B9C, false }, - { "A3AE", SAVEDATA_EEPROM, HW_NONE, 0x8002B9C, false }, - { "A3AP", SAVEDATA_EEPROM, HW_NONE, 0x8002B9C, false }, + { "A3AJ", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8002B9C, false }, + { "A3AE", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8002B9C, false }, + { "A3AP", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8002B9C, false }, // Super Mario Advance 4 - { "AX4J", SAVEDATA_FLASH1M, HW_NONE, 0x800072A, false }, - { "AX4E", SAVEDATA_FLASH1M, HW_NONE, 0x800072A, false }, - { "AX4P", SAVEDATA_FLASH1M, HW_NONE, 0x800072A, false }, + { "AX4J", GBA_SAVEDATA_FLASH1M, HW_NONE, 0x800072A, false }, + { "AX4E", GBA_SAVEDATA_FLASH1M, HW_NONE, 0x800072A, false }, + { "AX4P", GBA_SAVEDATA_FLASH1M, HW_NONE, 0x800072A, false }, // Super Monkey Ball Jr. - { "ALUE", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "ALUP", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "ALUE", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "ALUP", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, // Top Gun - Combat Zones - { "A2YE", SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, + { "A2YE", GBA_SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, // Ueki no Housoku - Jingi Sakuretsu! Nouryokusha Battle - { "BUHJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "BUHJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, // Wario Ware Twisted - { "RZWJ", SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, IDLE_LOOP_NONE, false }, - { "RZWE", SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, IDLE_LOOP_NONE, false }, - { "RZWP", SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, IDLE_LOOP_NONE, false }, + { "RZWJ", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, IDLE_LOOP_NONE, false }, + { "RZWE", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, IDLE_LOOP_NONE, false }, + { "RZWP", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, IDLE_LOOP_NONE, false }, // Yoshi's Universal Gravitation - { "KYGJ", SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, - { "KYGE", SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, - { "KYGP", SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, + { "KYGJ", GBA_SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, + { "KYGE", GBA_SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, + { "KYGP", GBA_SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, // Aging cartridge - { "TCHK", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "TCHK", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, // Famicom Mini series 3 (FDS), some aren't mirrored (22 - 28) // See https://forum.no-intro.org/viewtopic.php?f=2&t=4221 for discussion - { "FNMJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FMRJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FPTJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FLBJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FFMJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FTKJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FTUJ", SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "FNMJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "FMRJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "FPTJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "FLBJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "FFMJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "FTKJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "FTUJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, { { 0, 0, 0, 0 }, 0, 0, IDLE_LOOP_NONE, false } }; bool GBAOverrideFind(const struct Configuration* config, struct GBACartridgeOverride* override) { - override->savetype = SAVEDATA_AUTODETECT; + override->savetype = GBA_SAVEDATA_AUTODETECT; override->hardware = HW_NONE; override->idleLoop = IDLE_LOOP_NONE; override->mirroring = false; @@ -233,7 +233,7 @@ bool GBAOverrideFind(const struct Configuration* config, struct GBACartridgeOver } if (!found && override->id[0] == 'F') { // Classic NES Series - override->savetype = SAVEDATA_EEPROM; + override->savetype = GBA_SAVEDATA_EEPROM; found = true; } @@ -247,25 +247,25 @@ bool GBAOverrideFind(const struct Configuration* config, struct GBACartridgeOver if (savetype) { if (strcasecmp(savetype, "SRAM") == 0) { found = true; - override->savetype = SAVEDATA_SRAM; + override->savetype = GBA_SAVEDATA_SRAM; } else if (strcasecmp(savetype, "SRAM512") == 0) { found = true; - override->savetype = SAVEDATA_SRAM512; + override->savetype = GBA_SAVEDATA_SRAM512; } else if (strcasecmp(savetype, "EEPROM") == 0) { found = true; - override->savetype = SAVEDATA_EEPROM; + override->savetype = GBA_SAVEDATA_EEPROM; } else if (strcasecmp(savetype, "EEPROM512") == 0) { found = true; - override->savetype = SAVEDATA_EEPROM512; + override->savetype = GBA_SAVEDATA_EEPROM512; } else if (strcasecmp(savetype, "FLASH512") == 0) { found = true; - override->savetype = SAVEDATA_FLASH512; + override->savetype = GBA_SAVEDATA_FLASH512; } else if (strcasecmp(savetype, "FLASH1M") == 0) { found = true; - override->savetype = SAVEDATA_FLASH1M; + override->savetype = GBA_SAVEDATA_FLASH1M; } else if (strcasecmp(savetype, "NONE") == 0) { found = true; - override->savetype = SAVEDATA_FORCE_NONE; + override->savetype = GBA_SAVEDATA_FORCE_NONE; } } @@ -295,28 +295,28 @@ void GBAOverrideSave(struct Configuration* config, const struct GBACartridgeOver snprintf(sectionName, sizeof(sectionName), "override.%c%c%c%c", override->id[0], override->id[1], override->id[2], override->id[3]); const char* savetype = 0; switch (override->savetype) { - case SAVEDATA_SRAM: + case GBA_SAVEDATA_SRAM: savetype = "SRAM"; break; - case SAVEDATA_SRAM512: + case GBA_SAVEDATA_SRAM512: savetype = "SRAM512"; break; - case SAVEDATA_EEPROM: + case GBA_SAVEDATA_EEPROM: savetype = "EEPROM"; break; - case SAVEDATA_EEPROM512: + case GBA_SAVEDATA_EEPROM512: savetype = "EEPROM512"; break; - case SAVEDATA_FLASH512: + case GBA_SAVEDATA_FLASH512: savetype = "FLASH512"; break; - case SAVEDATA_FLASH1M: + case GBA_SAVEDATA_FLASH1M: savetype = "FLASH1M"; break; - case SAVEDATA_FORCE_NONE: + case GBA_SAVEDATA_FORCE_NONE: savetype = "NONE"; break; - case SAVEDATA_AUTODETECT: + case GBA_SAVEDATA_AUTODETECT: break; } ConfigurationSetValue(config, sectionName, "savetype", savetype); @@ -335,7 +335,7 @@ void GBAOverrideSave(struct Configuration* config, const struct GBACartridgeOver } void GBAOverrideApply(struct GBA* gba, const struct GBACartridgeOverride* override) { - if (override->savetype != SAVEDATA_AUTODETECT) { + if (override->savetype != GBA_SAVEDATA_AUTODETECT) { GBASavedataForceType(&gba->memory.savedata, override->savetype); } @@ -429,7 +429,7 @@ void GBAOverrideApplyDefaults(struct GBA* gba, const struct Configuration* overr if (isPokemon && !isKnownPokemon) { // Enable FLASH1M and RTC on Pokémon ROM hacks - override.savetype = SAVEDATA_FLASH1M; + override.savetype = GBA_SAVEDATA_FLASH1M; override.hardware = HW_RTC; override.vbaBugCompat = true; GBAOverrideApply(gba, &override); diff --git a/src/gba/savedata.c b/src/gba/savedata.c index e7176650b72..11be3e0abfa 100644 --- a/src/gba/savedata.c +++ b/src/gba/savedata.c @@ -44,7 +44,7 @@ static void _ashesToAshes(struct mTiming* timing, void* user, uint32_t cyclesLat } void GBASavedataInit(struct GBASavedata* savedata, struct VFile* vf) { - savedata->type = SAVEDATA_AUTODETECT; + savedata->type = GBA_SAVEDATA_AUTODETECT; savedata->data = 0; savedata->command = EEPROM_COMMAND_NULL; savedata->flashState = FLASH_STATE_RAW; @@ -72,35 +72,35 @@ void GBASavedataDeinit(struct GBASavedata* savedata) { savedata->vf = NULL; } else { switch (savedata->type) { - case SAVEDATA_SRAM: + case GBA_SAVEDATA_SRAM: mappedMemoryFree(savedata->data, GBA_SIZE_SRAM); break; - case SAVEDATA_SRAM512: + case GBA_SAVEDATA_SRAM512: mappedMemoryFree(savedata->data, GBA_SIZE_SRAM512); break; - case SAVEDATA_FLASH512: + case GBA_SAVEDATA_FLASH512: mappedMemoryFree(savedata->data, GBA_SIZE_FLASH512); break; - case SAVEDATA_FLASH1M: + case GBA_SAVEDATA_FLASH1M: mappedMemoryFree(savedata->data, GBA_SIZE_FLASH1M); break; - case SAVEDATA_EEPROM: + case GBA_SAVEDATA_EEPROM: mappedMemoryFree(savedata->data, GBA_SIZE_EEPROM); break; - case SAVEDATA_EEPROM512: + case GBA_SAVEDATA_EEPROM512: mappedMemoryFree(savedata->data, GBA_SIZE_EEPROM512); break; - case SAVEDATA_FORCE_NONE: - case SAVEDATA_AUTODETECT: + case GBA_SAVEDATA_FORCE_NONE: + case GBA_SAVEDATA_AUTODETECT: break; } } savedata->data = 0; - savedata->type = SAVEDATA_AUTODETECT; + savedata->type = GBA_SAVEDATA_AUTODETECT; } void GBASavedataMask(struct GBASavedata* savedata, struct VFile* vf, bool writeback) { - enum SavedataType type = savedata->type; + enum GBASavedataType type = savedata->type; struct VFile* oldVf = savedata->vf; GBASavedataDeinit(savedata); if (oldVf && oldVf != savedata->realVf) { @@ -116,7 +116,7 @@ void GBASavedataUnmask(struct GBASavedata* savedata) { if (!savedata->realVf || savedata->vf == savedata->realVf) { return; } - enum SavedataType type = savedata->type; + enum GBASavedataType type = savedata->type; struct VFile* vf = savedata->vf; GBASavedataDeinit(savedata); savedata->vf = savedata->realVf; @@ -132,20 +132,20 @@ void GBASavedataUnmask(struct GBASavedata* savedata) { bool GBASavedataClone(struct GBASavedata* savedata, struct VFile* out) { if (savedata->data) { switch (savedata->type) { - case SAVEDATA_SRAM: + case GBA_SAVEDATA_SRAM: return out->write(out, savedata->data, GBA_SIZE_SRAM) == GBA_SIZE_SRAM; - case SAVEDATA_SRAM512: + case GBA_SAVEDATA_SRAM512: return out->write(out, savedata->data, GBA_SIZE_SRAM512) == GBA_SIZE_SRAM512; - case SAVEDATA_FLASH512: + case GBA_SAVEDATA_FLASH512: return out->write(out, savedata->data, GBA_SIZE_FLASH512) == GBA_SIZE_FLASH512; - case SAVEDATA_FLASH1M: + case GBA_SAVEDATA_FLASH1M: return out->write(out, savedata->data, GBA_SIZE_FLASH1M) == GBA_SIZE_FLASH1M; - case SAVEDATA_EEPROM: + case GBA_SAVEDATA_EEPROM: return out->write(out, savedata->data, GBA_SIZE_EEPROM) == GBA_SIZE_EEPROM; - case SAVEDATA_EEPROM512: + case GBA_SAVEDATA_EEPROM512: return out->write(out, savedata->data, GBA_SIZE_EEPROM512) == GBA_SIZE_EEPROM512; - case SAVEDATA_AUTODETECT: - case SAVEDATA_FORCE_NONE: + case GBA_SAVEDATA_AUTODETECT: + case GBA_SAVEDATA_FORCE_NONE: return true; } } else if (savedata->vf) { @@ -163,21 +163,21 @@ bool GBASavedataClone(struct GBASavedata* savedata, struct VFile* out) { size_t GBASavedataSize(const struct GBASavedata* savedata) { switch (savedata->type) { - case SAVEDATA_SRAM: + case GBA_SAVEDATA_SRAM: return GBA_SIZE_SRAM; - case SAVEDATA_SRAM512: + case GBA_SAVEDATA_SRAM512: return GBA_SIZE_SRAM512; - case SAVEDATA_FLASH512: + case GBA_SAVEDATA_FLASH512: return GBA_SIZE_FLASH512; - case SAVEDATA_FLASH1M: + case GBA_SAVEDATA_FLASH1M: return GBA_SIZE_FLASH1M; - case SAVEDATA_EEPROM: + case GBA_SAVEDATA_EEPROM: return GBA_SIZE_EEPROM; - case SAVEDATA_EEPROM512: + case GBA_SAVEDATA_EEPROM512: return GBA_SIZE_EEPROM512; - case SAVEDATA_FORCE_NONE: + case GBA_SAVEDATA_FORCE_NONE: return 0; - case SAVEDATA_AUTODETECT: + case GBA_SAVEDATA_AUTODETECT: default: if (savedata->vf) { return savedata->vf->size(savedata->vf); @@ -188,7 +188,7 @@ size_t GBASavedataSize(const struct GBASavedata* savedata) { bool GBASavedataLoad(struct GBASavedata* savedata, struct VFile* in) { if (savedata->data) { - if (!in || savedata->type == SAVEDATA_FORCE_NONE) { + if (!in || savedata->type == GBA_SAVEDATA_FORCE_NONE) { return false; } ssize_t size = GBASavedataSize(savedata); @@ -220,11 +220,11 @@ bool GBASavedataLoad(struct GBASavedata* savedata, struct VFile* in) { return true; } -void GBASavedataForceType(struct GBASavedata* savedata, enum SavedataType type) { +void GBASavedataForceType(struct GBASavedata* savedata, enum GBASavedataType type) { if (savedata->type == type) { return; } - if (savedata->type != SAVEDATA_AUTODETECT) { + if (savedata->type != GBA_SAVEDATA_AUTODETECT) { struct VFile* vf = savedata->vf; int mapMode = savedata->mapMode; bool maskWriteback = savedata->maskWriteback; @@ -234,40 +234,40 @@ void GBASavedataForceType(struct GBASavedata* savedata, enum SavedataType type) savedata->maskWriteback = maskWriteback; } switch (type) { - case SAVEDATA_FLASH512: - case SAVEDATA_FLASH1M: + case GBA_SAVEDATA_FLASH512: + case GBA_SAVEDATA_FLASH1M: savedata->type = type; GBASavedataInitFlash(savedata); break; - case SAVEDATA_EEPROM: - case SAVEDATA_EEPROM512: + case GBA_SAVEDATA_EEPROM: + case GBA_SAVEDATA_EEPROM512: savedata->type = type; GBASavedataInitEEPROM(savedata); break; - case SAVEDATA_SRAM: + case GBA_SAVEDATA_SRAM: GBASavedataInitSRAM(savedata); break; - case SAVEDATA_SRAM512: + case GBA_SAVEDATA_SRAM512: GBASavedataInitSRAM512(savedata); break; - case SAVEDATA_FORCE_NONE: - savedata->type = SAVEDATA_FORCE_NONE; + case GBA_SAVEDATA_FORCE_NONE: + savedata->type = GBA_SAVEDATA_FORCE_NONE; break; - case SAVEDATA_AUTODETECT: + case GBA_SAVEDATA_AUTODETECT: break; } } void GBASavedataInitFlash(struct GBASavedata* savedata) { - if (savedata->type == SAVEDATA_AUTODETECT) { - savedata->type = SAVEDATA_FLASH512; + if (savedata->type == GBA_SAVEDATA_AUTODETECT) { + savedata->type = GBA_SAVEDATA_FLASH512; } - if (savedata->type != SAVEDATA_FLASH512 && savedata->type != SAVEDATA_FLASH1M) { + if (savedata->type != GBA_SAVEDATA_FLASH512 && savedata->type != GBA_SAVEDATA_FLASH1M) { mLOG(GBA_SAVE, WARN, "Can't re-initialize savedata"); return; } int32_t flashSize = GBA_SIZE_FLASH512; - if (savedata->type == SAVEDATA_FLASH1M) { + if (savedata->type == GBA_SAVEDATA_FLASH1M) { flashSize = GBA_SIZE_FLASH1M; } off_t end; @@ -289,14 +289,14 @@ void GBASavedataInitFlash(struct GBASavedata* savedata) { } void GBASavedataInitEEPROM(struct GBASavedata* savedata) { - if (savedata->type == SAVEDATA_AUTODETECT) { - savedata->type = SAVEDATA_EEPROM512; - } else if (savedata->type != SAVEDATA_EEPROM512 && savedata->type != SAVEDATA_EEPROM) { + if (savedata->type == GBA_SAVEDATA_AUTODETECT) { + savedata->type = GBA_SAVEDATA_EEPROM512; + } else if (savedata->type != GBA_SAVEDATA_EEPROM512 && savedata->type != GBA_SAVEDATA_EEPROM) { mLOG(GBA_SAVE, WARN, "Can't re-initialize savedata"); return; } int32_t eepromSize = GBA_SIZE_EEPROM512; - if (savedata->type == SAVEDATA_EEPROM) { + if (savedata->type == GBA_SAVEDATA_EEPROM) { eepromSize = GBA_SIZE_EEPROM; } off_t end; @@ -316,8 +316,8 @@ void GBASavedataInitEEPROM(struct GBASavedata* savedata) { } void GBASavedataInitSRAM(struct GBASavedata* savedata) { - if (savedata->type == SAVEDATA_AUTODETECT) { - savedata->type = SAVEDATA_SRAM; + if (savedata->type == GBA_SAVEDATA_AUTODETECT) { + savedata->type = GBA_SAVEDATA_SRAM; } else { mLOG(GBA_SAVE, WARN, "Can't re-initialize savedata"); return; @@ -340,8 +340,8 @@ void GBASavedataInitSRAM(struct GBASavedata* savedata) { } void GBASavedataInitSRAM512(struct GBASavedata* savedata) { - if (savedata->type == SAVEDATA_AUTODETECT) { - savedata->type = SAVEDATA_SRAM512; + if (savedata->type == GBA_SAVEDATA_AUTODETECT) { + savedata->type = GBA_SAVEDATA_SRAM512; } else { mLOG(GBA_SAVE, WARN, "Can't re-initialize savedata"); return; @@ -365,11 +365,11 @@ void GBASavedataInitSRAM512(struct GBASavedata* savedata) { uint8_t GBASavedataReadFlash(struct GBASavedata* savedata, uint16_t address) { if (savedata->command == FLASH_COMMAND_ID) { - if (savedata->type == SAVEDATA_FLASH512) { + if (savedata->type == GBA_SAVEDATA_FLASH512) { if (address < 2) { return FLASH_MFG_PANASONIC >> (address * 8); } - } else if (savedata->type == SAVEDATA_FLASH1M) { + } else if (savedata->type == GBA_SAVEDATA_FLASH1M) { if (address < 2) { return FLASH_MFG_SANYO >> (address * 8); } @@ -472,10 +472,10 @@ static void _ensureEeprom(struct GBASavedata* savedata, uint32_t size) { if (size < GBA_SIZE_EEPROM512) { return; } - if (savedata->type == SAVEDATA_EEPROM) { + if (savedata->type == GBA_SAVEDATA_EEPROM) { return; } - savedata->type = SAVEDATA_EEPROM; + savedata->type = GBA_SAVEDATA_EEPROM; if (!savedata->vf) { return; } @@ -605,7 +605,7 @@ void GBASavedataRTCWrite(struct GBASavedata* savedata) { int bank = 0; if ((savedata->vf->size(savedata->vf) & 0xFF) != sizeof(buffer)) { // Writing past the end of the file can invalidate the file mapping - if (savedata->type == SAVEDATA_FLASH1M) { + if (savedata->type == GBA_SAVEDATA_FLASH1M) { bank = savedata->currentBank == &savedata->data[0x10000]; } savedata->vf->unmap(savedata->vf, savedata->data, size); @@ -614,9 +614,9 @@ void GBASavedataRTCWrite(struct GBASavedata* savedata) { savedata->vf->write(savedata->vf, &buffer, sizeof(buffer)); if (!savedata->data) { savedata->data = savedata->vf->map(savedata->vf, size, MAP_WRITE); - if (savedata->type == SAVEDATA_FLASH1M) { + if (savedata->type == GBA_SAVEDATA_FLASH1M) { savedata->currentBank = &savedata->data[bank << 16]; - } else if (savedata->type == SAVEDATA_FLASH512) { + } else if (savedata->type == GBA_SAVEDATA_FLASH512) { savedata->currentBank = savedata->data; } } @@ -730,7 +730,7 @@ void GBASavedataDeserialize(struct GBASavedata* savedata, const struct GBASerial LOAD_32(savedata->writeAddress, 0, &state->savedata.writeAddress); LOAD_16(savedata->settling, 0, &state->savedata.settlingSector); - if (savedata->type == SAVEDATA_FLASH1M) { + if (savedata->type == GBA_SAVEDATA_FLASH1M) { _flashSwitchBank(savedata, GBASerializedSavedataFlagsGetFlashBank(flags)); } @@ -743,9 +743,9 @@ void GBASavedataDeserialize(struct GBASavedata* savedata, const struct GBASerial void _flashSwitchBank(struct GBASavedata* savedata, int bank) { mLOG(GBA_SAVE, DEBUG, "Performing flash bank switch to bank %i", bank); - if (bank > 0 && savedata->type == SAVEDATA_FLASH512) { + if (bank > 0 && savedata->type == GBA_SAVEDATA_FLASH512) { mLOG(GBA_SAVE, INFO, "Updating flash chip from 512kb to 1Mb"); - savedata->type = SAVEDATA_FLASH1M; + savedata->type = GBA_SAVEDATA_FLASH1M; if (savedata->vf) { savedata->vf->unmap(savedata->vf, savedata->data, GBA_SIZE_FLASH512); if (savedata->vf->size(savedata->vf) < GBA_SIZE_FLASH1M) { @@ -764,7 +764,7 @@ void _flashErase(struct GBASavedata* savedata) { mLOG(GBA_SAVE, DEBUG, "Performing flash chip erase"); savedata->dirty |= mSAVEDATA_DIRT_NEW; size_t size = GBA_SIZE_FLASH512; - if (savedata->type == SAVEDATA_FLASH1M) { + if (savedata->type == GBA_SAVEDATA_FLASH1M) { size = GBA_SIZE_FLASH1M; } memset(savedata->data, 0xFF, size); @@ -774,7 +774,7 @@ void _flashEraseSector(struct GBASavedata* savedata, uint16_t sectorStart) { mLOG(GBA_SAVE, DEBUG, "Performing flash sector erase at 0x%04x", sectorStart); savedata->dirty |= mSAVEDATA_DIRT_NEW; size_t size = 0x1000; - if (savedata->type == SAVEDATA_FLASH1M) { + if (savedata->type == GBA_SAVEDATA_FLASH1M) { mLOG(GBA_SAVE, DEBUG, "Performing unknown sector-size erase at 0x%04x", sectorStart); } savedata->settling = sectorStart >> 12; diff --git a/src/gba/sharkport.c b/src/gba/sharkport.c index 9e1e645181d..2f33e3d41a9 100644 --- a/src/gba/sharkport.c +++ b/src/gba/sharkport.c @@ -18,9 +18,9 @@ static const int GSV_PAYLOAD_OFFSET = 0x430; static bool _importSavedata(struct GBA* gba, void* payload, size_t size) { bool success = false; switch (gba->memory.savedata.type) { - case SAVEDATA_FLASH512: + case GBA_SAVEDATA_FLASH512: if (size > GBA_SIZE_FLASH512) { - GBASavedataForceType(&gba->memory.savedata, SAVEDATA_FLASH1M); + GBASavedataForceType(&gba->memory.savedata, GBA_SAVEDATA_FLASH1M); } // Fall through default: @@ -28,8 +28,8 @@ static bool _importSavedata(struct GBA* gba, void* payload, size_t size) { size = GBASavedataSize(&gba->memory.savedata); } break; - case SAVEDATA_FORCE_NONE: - case SAVEDATA_AUTODETECT: + case GBA_SAVEDATA_FORCE_NONE: + case GBA_SAVEDATA_AUTODETECT: goto cleanup; } @@ -276,7 +276,7 @@ bool GBASavedataExportSharkPort(const struct GBA* gba, struct VFile* vf) { checksum += buffer.c[i] << (checksum % 24); } - if (gba->memory.savedata.type == SAVEDATA_EEPROM) { + if (gba->memory.savedata.type == GBA_SAVEDATA_EEPROM) { for (i = 0; i < size; ++i) { char byte = gba->memory.savedata.data[i ^ 7]; checksum += byte << (checksum % 24); diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index 8c08e7bb621..bea9f62731f 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -1156,7 +1156,7 @@ size_t retro_get_memory_size(unsigned id) { #ifdef M_CORE_GBA case mPLATFORM_GBA: switch (((struct GBA*) core->board)->memory.savedata.type) { - case SAVEDATA_AUTODETECT: + case GBA_SAVEDATA_AUTODETECT: return GBA_SIZE_FLASH1M; default: return GBASavedataSize(&((struct GBA*) core->board)->memory.savedata); diff --git a/src/platform/qt/OverrideView.cpp b/src/platform/qt/OverrideView.cpp index 07e114c1c11..9e51fab4a9e 100644 --- a/src/platform/qt/OverrideView.cpp +++ b/src/platform/qt/OverrideView.cpp @@ -153,14 +153,14 @@ void OverrideView::updateOverrides() { if (m_ui.tabWidget->currentWidget() == m_ui.tabGBA) { auto gba = std::make_unique(); memset(gba->override.id, 0, 4); - gba->override.savetype = static_cast(m_ui.savetype->currentIndex() - 1); + gba->override.savetype = static_cast(m_ui.savetype->currentIndex() - 1); gba->override.hardware = HW_NO_OVERRIDE; gba->override.idleLoop = IDLE_LOOP_NONE; gba->override.mirroring = false; gba->override.vbaBugCompat = false; gba->vbaBugCompatSet = false; - if (gba->override.savetype != SAVEDATA_AUTODETECT) { + if (gba->override.savetype != GBA_SAVEDATA_AUTODETECT) { hasOverride = true; } if (!m_ui.hwAutodetect->isChecked()) { diff --git a/src/platform/qt/SaveConverter.cpp b/src/platform/qt/SaveConverter.cpp index 44e061c8f48..d16eeeea4f5 100644 --- a/src/platform/qt/SaveConverter.cpp +++ b/src/platform/qt/SaveConverter.cpp @@ -170,8 +170,8 @@ void SaveConverter::detectFromSavestate(VFile* vf) { switch (platform) { #ifdef M_CORE_GBA case mPLATFORM_GBA: - save.gba.type = static_cast(state.at(offsetof(GBASerializedState, savedata.type))); - if (save.gba.type == SAVEDATA_EEPROM || save.gba.type == SAVEDATA_EEPROM512) { + save.gba.type = static_cast(state.at(offsetof(GBASerializedState, savedata.type))); + if (save.gba.type == GBA_SAVEDATA_EEPROM || save.gba.type == GBA_SAVEDATA_EEPROM512) { save.endianness = Endian::LITTLE; } break; @@ -198,25 +198,25 @@ void SaveConverter::detectFromSize(std::shared_ptr vf) { switch (vf->size()) { case GBA_SIZE_SRAM: case GBA_SIZE_SRAM + 16: - m_validSaves.append(AnnotatedSave{SAVEDATA_SRAM, vf}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_SRAM, vf}); break; case GBA_SIZE_FLASH512: case GBA_SIZE_FLASH512 + 16: - m_validSaves.append(AnnotatedSave{SAVEDATA_FLASH512, vf}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_FLASH512, vf}); break; case GBA_SIZE_FLASH1M: case GBA_SIZE_FLASH1M + 16: - m_validSaves.append(AnnotatedSave{SAVEDATA_FLASH1M, vf}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_FLASH1M, vf}); break; case GBA_SIZE_EEPROM: case GBA_SIZE_EEPROM + 16: - m_validSaves.append(AnnotatedSave{SAVEDATA_EEPROM, vf, Endian::LITTLE}); - m_validSaves.append(AnnotatedSave{SAVEDATA_EEPROM, vf, Endian::BIG}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_EEPROM, vf, Endian::LITTLE}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_EEPROM, vf, Endian::BIG}); break; case GBA_SIZE_EEPROM512: case GBA_SIZE_EEPROM512 + 16: - m_validSaves.append(AnnotatedSave{SAVEDATA_EEPROM512, vf, Endian::LITTLE}); - m_validSaves.append(AnnotatedSave{SAVEDATA_EEPROM512, vf, Endian::BIG}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_EEPROM512, vf, Endian::LITTLE}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_EEPROM512, vf, Endian::BIG}); break; } #endif @@ -272,12 +272,12 @@ void SaveConverter::detectFromHeaders(std::shared_ptr vf) { QByteArray bytes = QByteArray::fromRawData(static_cast(data), size); bytes.data(); // Trigger a deep copy before we delete the backing if (size == GBA_SIZE_FLASH1M) { - m_validSaves.append(AnnotatedSave{SAVEDATA_FLASH1M, std::make_shared(bytes), Endian::NONE, Container::SHARKPORT}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_FLASH1M, std::make_shared(bytes), Endian::NONE, Container::SHARKPORT}); } else { - m_validSaves.append(AnnotatedSave{SAVEDATA_SRAM, std::make_shared(bytes.left(GBA_SIZE_SRAM)), Endian::NONE, Container::SHARKPORT}); - m_validSaves.append(AnnotatedSave{SAVEDATA_FLASH512, std::make_shared(bytes.left(GBA_SIZE_FLASH512)), Endian::NONE, Container::SHARKPORT}); - m_validSaves.append(AnnotatedSave{SAVEDATA_EEPROM, std::make_shared(bytes.left(GBA_SIZE_EEPROM)), Endian::BIG, Container::SHARKPORT}); - m_validSaves.append(AnnotatedSave{SAVEDATA_EEPROM512, std::make_shared(bytes.left(GBA_SIZE_EEPROM512)), Endian::BIG, Container::SHARKPORT}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_SRAM, std::make_shared(bytes.left(GBA_SIZE_SRAM)), Endian::NONE, Container::SHARKPORT}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_FLASH512, std::make_shared(bytes.left(GBA_SIZE_FLASH512)), Endian::NONE, Container::SHARKPORT}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_EEPROM, std::make_shared(bytes.left(GBA_SIZE_EEPROM)), Endian::BIG, Container::SHARKPORT}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_EEPROM512, std::make_shared(bytes.left(GBA_SIZE_EEPROM512)), Endian::BIG, Container::SHARKPORT}); } free(data); } @@ -289,20 +289,20 @@ void SaveConverter::detectFromHeaders(std::shared_ptr vf) { bytes.data(); // Trigger a deep copy before we delete the backing switch (size) { case GBA_SIZE_FLASH1M: - m_validSaves.append(AnnotatedSave{SAVEDATA_FLASH1M, std::make_shared(bytes), Endian::NONE, Container::GSV}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_FLASH1M, std::make_shared(bytes), Endian::NONE, Container::GSV}); break; case GBA_SIZE_FLASH512: - m_validSaves.append(AnnotatedSave{SAVEDATA_FLASH512, std::make_shared(bytes), Endian::NONE, Container::GSV}); - m_validSaves.append(AnnotatedSave{SAVEDATA_FLASH1M, std::make_shared(bytes), Endian::NONE, Container::GSV}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_FLASH512, std::make_shared(bytes), Endian::NONE, Container::GSV}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_FLASH1M, std::make_shared(bytes), Endian::NONE, Container::GSV}); break; case GBA_SIZE_SRAM: - m_validSaves.append(AnnotatedSave{SAVEDATA_SRAM, std::make_shared(bytes.left(GBA_SIZE_SRAM)), Endian::NONE, Container::GSV}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_SRAM, std::make_shared(bytes.left(GBA_SIZE_SRAM)), Endian::NONE, Container::GSV}); break; case GBA_SIZE_EEPROM: - m_validSaves.append(AnnotatedSave{SAVEDATA_EEPROM, std::make_shared(bytes.left(GBA_SIZE_EEPROM)), Endian::BIG, Container::GSV}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_EEPROM, std::make_shared(bytes.left(GBA_SIZE_EEPROM)), Endian::BIG, Container::GSV}); break; case GBA_SIZE_EEPROM512: - m_validSaves.append(AnnotatedSave{SAVEDATA_EEPROM512, std::make_shared(bytes.left(GBA_SIZE_EEPROM512)), Endian::BIG, Container::GSV}); + m_validSaves.append(AnnotatedSave{GBA_SAVEDATA_EEPROM512, std::make_shared(bytes.left(GBA_SIZE_EEPROM512)), Endian::BIG, Container::GSV}); break; } free(data); @@ -401,7 +401,7 @@ SaveConverter::AnnotatedSave::AnnotatedSave(mPlatform platform, std::shared_ptr< } #ifdef M_CORE_GBA -SaveConverter::AnnotatedSave::AnnotatedSave(SavedataType type, std::shared_ptr vf, Endian endianness, Container container) +SaveConverter::AnnotatedSave::AnnotatedSave(GBASavedataType type, std::shared_ptr vf, Endian endianness, Container container) : container(container) , platform(mPLATFORM_GBA) , size(vf->size()) @@ -468,15 +468,15 @@ SaveConverter::AnnotatedSave::operator QString() const { #ifdef M_CORE_GBA case mPLATFORM_GBA: switch (gba.type) { - case SAVEDATA_SRAM: + case GBA_SAVEDATA_SRAM: typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "SRAM"); break; - case SAVEDATA_FLASH512: - case SAVEDATA_FLASH1M: + case GBA_SAVEDATA_FLASH512: + case GBA_SAVEDATA_FLASH1M: typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "%1 flash"); break; - case SAVEDATA_EEPROM: - case SAVEDATA_EEPROM512: + case GBA_SAVEDATA_EEPROM: + case GBA_SAVEDATA_EEPROM512: typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "%1 EEPROM"); break; default: @@ -664,8 +664,8 @@ QByteArray SaveConverter::AnnotatedSave::convertTo(const SaveConverter::Annotate #ifdef M_CORE_GBA case mPLATFORM_GBA: switch (gba.type) { - case SAVEDATA_EEPROM: - case SAVEDATA_EEPROM512: + case GBA_SAVEDATA_EEPROM: + case GBA_SAVEDATA_EEPROM512: if (endianness == target.endianness) { break; } diff --git a/src/platform/qt/SaveConverter.h b/src/platform/qt/SaveConverter.h index 2fa13307176..764e13d9c17 100644 --- a/src/platform/qt/SaveConverter.h +++ b/src/platform/qt/SaveConverter.h @@ -48,7 +48,7 @@ private slots: private: #ifdef M_CORE_GBA struct GBASave { - SavedataType type; + GBASavedataType type; }; #endif #ifdef M_CORE_GB @@ -66,7 +66,7 @@ private slots: AnnotatedSave(); AnnotatedSave(mPlatform, std::shared_ptr, Endian = Endian::NONE, Container = Container::NONE); #ifdef M_CORE_GBA - AnnotatedSave(SavedataType, std::shared_ptr, Endian = Endian::NONE, Container = Container::NONE); + AnnotatedSave(GBASavedataType, std::shared_ptr, Endian = Endian::NONE, Container = Container::NONE); #endif #ifdef M_CORE_GB AnnotatedSave(GBMemoryBankControllerType, std::shared_ptr, Endian = Endian::NONE, Container = Container::NONE); From e48acb6b97fa59b8f317eff55f59a21b0fc6bd1c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 24 Mar 2024 23:03:59 -0700 Subject: [PATCH 023/338] GB, GBA: Move override structs to public API --- include/mgba/gb/interface.h | 15 +++ include/mgba/gba/interface.h | 22 +++ include/mgba/internal/gb/overrides.h | 15 --- include/mgba/internal/gba/overrides.h | 13 +- include/mgba/internal/gba/savedata.h | 12 +- src/gba/core.c | 2 +- src/gba/overrides.c | 184 +++++++++++++------------- src/platform/qt/OverrideView.cpp | 4 +- 8 files changed, 134 insertions(+), 133 deletions(-) diff --git a/include/mgba/gb/interface.h b/include/mgba/gb/interface.h index ecd99e2f994..485111b4165 100644 --- a/include/mgba/gb/interface.h +++ b/include/mgba/gb/interface.h @@ -58,6 +58,13 @@ enum GBVideoLayer { GB_LAYER_OBJ }; +enum GBColorLookup { + GB_COLORS_NONE = 0, + GB_COLORS_CGB = 1, + GB_COLORS_SGB = 2, + GB_COLORS_SGB_CGB_FALLBACK = GB_COLORS_CGB | GB_COLORS_SGB +}; + struct GBSIODriver { struct GBSIO* p; @@ -67,6 +74,14 @@ struct GBSIODriver { uint8_t (*writeSC)(struct GBSIODriver* driver, uint8_t value); }; +struct GBCartridgeOverride { + int headerCrc32; + enum GBModel model; + enum GBMemoryBankControllerType mbc; + + uint32_t gbColors[12]; +}; + struct VFile; bool GBIsROM(struct VFile* vf); diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index bf10c59ba31..f2f05064da5 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -13,6 +13,8 @@ CXX_GUARD_START #include #include +#define GBA_IDLE_LOOP_NONE 0xFFFFFFFF + enum { GBA_VIDEO_HORIZONTAL_PIXELS = 240, GBA_VIDEO_VERTICAL_PIXELS = 160, @@ -45,6 +47,17 @@ enum GBAVideoLayer { GBA_LAYER_OBJWIN, }; +enum GBASavedataType { + GBA_SAVEDATA_AUTODETECT = -1, + GBA_SAVEDATA_FORCE_NONE = 0, + GBA_SAVEDATA_SRAM = 1, + GBA_SAVEDATA_FLASH512 = 2, + GBA_SAVEDATA_FLASH1M = 3, + GBA_SAVEDATA_EEPROM = 4, + GBA_SAVEDATA_EEPROM512 = 5, + GBA_SAVEDATA_SRAM512 = 6, +}; + struct GBA; struct GBAAudio; struct GBASIO; @@ -78,6 +91,15 @@ struct GBASIODriver { uint16_t (*writeRegister)(struct GBASIODriver* driver, uint32_t address, uint16_t value); }; +struct GBACartridgeOverride { + char id[4]; + enum GBASavedataType savetype; + int hardware; + uint32_t idleLoop; + bool mirroring; + bool vbaBugCompat; +}; + void GBASIOJOYCreate(struct GBASIODriver* sio); enum GBASIOBattleChipGateFlavor { diff --git a/include/mgba/internal/gb/overrides.h b/include/mgba/internal/gb/overrides.h index 86cac0f9d67..6e683f0deaa 100644 --- a/include/mgba/internal/gb/overrides.h +++ b/include/mgba/internal/gb/overrides.h @@ -12,21 +12,6 @@ CXX_GUARD_START #include -enum GBColorLookup { - GB_COLORS_NONE = 0, - GB_COLORS_CGB = 1, - GB_COLORS_SGB = 2, - GB_COLORS_SGB_CGB_FALLBACK = GB_COLORS_CGB | GB_COLORS_SGB -}; - -struct GBCartridgeOverride { - int headerCrc32; - enum GBModel model; - enum GBMemoryBankControllerType mbc; - - uint32_t gbColors[12]; -}; - struct GBColorPreset { const char* name; uint32_t colors[12]; diff --git a/include/mgba/internal/gba/overrides.h b/include/mgba/internal/gba/overrides.h index 83a63f0a428..b2eba2d7a6f 100644 --- a/include/mgba/internal/gba/overrides.h +++ b/include/mgba/internal/gba/overrides.h @@ -10,18 +10,7 @@ CXX_GUARD_START -#include - -#define IDLE_LOOP_NONE 0xFFFFFFFF - -struct GBACartridgeOverride { - char id[4]; - enum GBASavedataType savetype; - int hardware; - uint32_t idleLoop; - bool mirroring; - bool vbaBugCompat; -}; +#include struct Configuration; bool GBAOverrideFind(const struct Configuration*, struct GBACartridgeOverride* override); diff --git a/include/mgba/internal/gba/savedata.h b/include/mgba/internal/gba/savedata.h index a03f2960cdc..274241a766e 100644 --- a/include/mgba/internal/gba/savedata.h +++ b/include/mgba/internal/gba/savedata.h @@ -12,22 +12,12 @@ CXX_GUARD_START #include #include +#include mLOG_DECLARE_CATEGORY(GBA_SAVE); struct VFile; -enum GBASavedataType { - GBA_SAVEDATA_AUTODETECT = -1, - GBA_SAVEDATA_FORCE_NONE = 0, - GBA_SAVEDATA_SRAM = 1, - GBA_SAVEDATA_FLASH512 = 2, - GBA_SAVEDATA_FLASH1M = 3, - GBA_SAVEDATA_EEPROM = 4, - GBA_SAVEDATA_EEPROM512 = 5, - GBA_SAVEDATA_SRAM512 = 6, -}; - enum SavedataCommand { EEPROM_COMMAND_NULL = 0, EEPROM_COMMAND_PENDING = 1, diff --git a/src/gba/core.c b/src/gba/core.c index 89bcaafc6b4..54c436b3a89 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -374,7 +374,7 @@ static void _GBACoreLoadConfig(struct mCore* core, const struct mCoreConfig* con } else if (strcasecmp(idleOptimization, "remove") == 0) { gba->idleOptimization = IDLE_LOOP_REMOVE; } else if (strcasecmp(idleOptimization, "detect") == 0) { - if (gba->idleLoop == IDLE_LOOP_NONE) { + if (gba->idleLoop == GBA_IDLE_LOOP_NONE) { gba->idleOptimization = IDLE_LOOP_DETECT; } else { gba->idleOptimization = IDLE_LOOP_REMOVE; diff --git a/src/gba/overrides.c b/src/gba/overrides.c index 44a47efb58e..a3583070594 100644 --- a/src/gba/overrides.c +++ b/src/gba/overrides.c @@ -21,73 +21,73 @@ static const struct GBACartridgeOverride _overrides[] = { { "AW2P", GBA_SAVEDATA_FLASH512, HW_NONE, 0x803719C, false }, // Boktai: The Sun is in Your Hand - { "U3IJ", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, - { "U3IE", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, - { "U3IP", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, + { "U3IJ", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, + { "U3IE", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, + { "U3IP", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, // Boktai 2: Solar Boy Django - { "U32J", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, - { "U32E", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, - { "U32P", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, + { "U32J", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, + { "U32E", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, + { "U32P", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, // Crash Bandicoot 2 - N-Tranced - { "AC8J", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "AC8E", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "AC8P", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "AC8J", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "AC8E", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "AC8P", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // DigiCommunication Nyo - Datou! Black Gemagema Dan - { "BDKJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "BDKJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Dragon Ball Z - The Legacy of Goku - { "ALGP", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "ALGP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Dragon Ball Z - The Legacy of Goku II - { "ALFJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "ALFE", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "ALFP", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "ALFJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "ALFE", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "ALFP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Dragon Ball Z - Taiketsu - { "BDBE", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "BDBP", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "BDBE", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BDBP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Drill Dozer - { "V49J", GBA_SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, - { "V49E", GBA_SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, - { "V49P", GBA_SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, + { "V49J", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE, false }, + { "V49E", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE, false }, + { "V49P", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE, false }, // e-Reader - { "PEAJ", GBA_SAVEDATA_FLASH1M, HW_EREADER, IDLE_LOOP_NONE }, - { "PSAJ", GBA_SAVEDATA_FLASH1M, HW_EREADER, IDLE_LOOP_NONE }, - { "PSAE", GBA_SAVEDATA_FLASH1M, HW_EREADER, IDLE_LOOP_NONE }, + { "PEAJ", GBA_SAVEDATA_FLASH1M, HW_EREADER, GBA_IDLE_LOOP_NONE }, + { "PSAJ", GBA_SAVEDATA_FLASH1M, HW_EREADER, GBA_IDLE_LOOP_NONE }, + { "PSAE", GBA_SAVEDATA_FLASH1M, HW_EREADER, GBA_IDLE_LOOP_NONE }, // Final Fantasy Tactics Advance { "AFXE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8000428, false }, // F-Zero - Climax - { "BFTJ", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BFTJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Goodboy Galaxy - { "2GBP", GBA_SAVEDATA_SRAM, HW_RUMBLE, IDLE_LOOP_NONE, false }, + { "2GBP", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE, false }, // Iridion II - { "AI2E", GBA_SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, - { "AI2P", GBA_SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, + { "AI2E", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "AI2P", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Game Boy Wars Advance 1+2 - { "BGWJ", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BGWJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Golden Sun: The Lost Age { "AGFE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x801353A, false }, // Koro Koro Puzzle - Happy Panechu! - { "KHPJ", GBA_SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, + { "KHPJ", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE, false }, // Legendz - Yomigaeru Shiren no Shima - { "BLJJ", GBA_SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, - { "BLJK", GBA_SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, + { "BLJJ", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "BLJK", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE, false }, // Legendz - Sign of Nekuromu - { "BLVJ", GBA_SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, + { "BLVJ", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE, false }, // Mega Man Battle Network { "AREE", GBA_SAVEDATA_SRAM, HW_NONE, 0x800032E, false }, @@ -99,22 +99,22 @@ static const struct GBACartridgeOverride _overrides[] = { { "BSME", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8000290, false }, // Pokemon Ruby - { "AXVJ", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVE", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVP", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVI", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVS", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVD", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXVF", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXVJ", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXVE", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXVP", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXVI", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXVS", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXVD", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXVF", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, // Pokemon Sapphire - { "AXPJ", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPE", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPP", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPI", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPS", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPD", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, - { "AXPF", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "AXPJ", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXPE", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXPP", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXPI", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXPS", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXPD", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXPF", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, // Pokemon Emerald { "BPEJ", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, @@ -126,43 +126,43 @@ static const struct GBACartridgeOverride _overrides[] = { { "BPEF", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, // Pokemon Mystery Dungeon - { "B24E", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "B24P", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "B24E", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "B24P", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Pokemon FireRed - { "BPRJ", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRE", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRP", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRI", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRS", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRD", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPRF", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPRJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPRE", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPRP", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPRI", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPRS", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPRD", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPRF", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Pokemon LeafGreen - { "BPGJ", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGE", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGP", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGI", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGS", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGD", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, - { "BPGF", GBA_SAVEDATA_FLASH1M, HW_NONE, IDLE_LOOP_NONE, false }, + { "BPGJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPGE", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPGP", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPGI", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPGS", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPGD", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPGF", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // RockMan EXE 4.5 - Real Operation - { "BR4J", GBA_SAVEDATA_FLASH512, HW_RTC, IDLE_LOOP_NONE, false }, + { "BR4J", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE, false }, // Rocky - { "AR8E", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "AROP", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "AR8E", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "AROP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Sennen Kazoku - { "BKAJ", GBA_SAVEDATA_FLASH1M, HW_RTC, IDLE_LOOP_NONE, false }, + { "BKAJ", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, // Shin Bokura no Taiyou: Gyakushuu no Sabata - { "U33J", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, IDLE_LOOP_NONE, false }, + { "U33J", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, // Stuart Little 2 - { "ASLE", GBA_SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, - { "ASLF", GBA_SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, + { "ASLE", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "ASLF", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Super Mario Advance 2 { "AA2J", GBA_SAVEDATA_EEPROM, HW_NONE, 0x800052E, false }, @@ -180,45 +180,45 @@ static const struct GBACartridgeOverride _overrides[] = { { "AX4P", GBA_SAVEDATA_FLASH1M, HW_NONE, 0x800072A, false }, // Super Monkey Ball Jr. - { "ALUE", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "ALUP", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "ALUE", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "ALUP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Top Gun - Combat Zones - { "A2YE", GBA_SAVEDATA_FORCE_NONE, HW_NONE, IDLE_LOOP_NONE, false }, + { "A2YE", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Ueki no Housoku - Jingi Sakuretsu! Nouryokusha Battle - { "BUHJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "BUHJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Wario Ware Twisted - { "RZWJ", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, IDLE_LOOP_NONE, false }, - { "RZWE", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, IDLE_LOOP_NONE, false }, - { "RZWP", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, IDLE_LOOP_NONE, false }, + { "RZWJ", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, GBA_IDLE_LOOP_NONE, false }, + { "RZWE", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, GBA_IDLE_LOOP_NONE, false }, + { "RZWP", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, GBA_IDLE_LOOP_NONE, false }, // Yoshi's Universal Gravitation - { "KYGJ", GBA_SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, - { "KYGE", GBA_SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, - { "KYGP", GBA_SAVEDATA_EEPROM, HW_TILT, IDLE_LOOP_NONE, false }, + { "KYGJ", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE, false }, + { "KYGE", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE, false }, + { "KYGP", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE, false }, // Aging cartridge - { "TCHK", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, + { "TCHK", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, // Famicom Mini series 3 (FDS), some aren't mirrored (22 - 28) // See https://forum.no-intro.org/viewtopic.php?f=2&t=4221 for discussion - { "FNMJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FMRJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FPTJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FLBJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FFMJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FTKJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - { "FTUJ", GBA_SAVEDATA_EEPROM, HW_NONE, IDLE_LOOP_NONE, false }, - - { { 0, 0, 0, 0 }, 0, 0, IDLE_LOOP_NONE, false } + { "FNMJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "FMRJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "FPTJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "FLBJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "FFMJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "FTKJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "FTUJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + + { { 0, 0, 0, 0 }, 0, 0, GBA_IDLE_LOOP_NONE, false } }; bool GBAOverrideFind(const struct Configuration* config, struct GBACartridgeOverride* override) { override->savetype = GBA_SAVEDATA_AUTODETECT; override->hardware = HW_NONE; - override->idleLoop = IDLE_LOOP_NONE; + override->idleLoop = GBA_IDLE_LOOP_NONE; override->mirroring = false; override->vbaBugCompat = false; bool found = false; @@ -327,7 +327,7 @@ void GBAOverrideSave(struct Configuration* config, const struct GBACartridgeOver ConfigurationClearValue(config, sectionName, "hardware"); } - if (override->idleLoop != IDLE_LOOP_NONE) { + if (override->idleLoop != GBA_IDLE_LOOP_NONE) { ConfigurationSetUIntValue(config, sectionName, "idleLoop", override->idleLoop); } else { ConfigurationClearValue(config, sectionName, "idleLoop"); @@ -376,7 +376,7 @@ void GBAOverrideApply(struct GBA* gba, const struct GBACartridgeOverride* overri } } - if (override->idleLoop != IDLE_LOOP_NONE) { + if (override->idleLoop != GBA_IDLE_LOOP_NONE) { gba->idleLoop = override->idleLoop; if (gba->idleOptimization == IDLE_LOOP_DETECT) { gba->idleOptimization = IDLE_LOOP_REMOVE; @@ -385,7 +385,7 @@ void GBAOverrideApply(struct GBA* gba, const struct GBACartridgeOverride* overri } void GBAOverrideApplyDefaults(struct GBA* gba, const struct Configuration* overrides) { - struct GBACartridgeOverride override = { .idleLoop = IDLE_LOOP_NONE }; + struct GBACartridgeOverride override = { .idleLoop = GBA_IDLE_LOOP_NONE }; const struct GBACartridge* cart = (const struct GBACartridge*) gba->memory.rom; if (cart) { memcpy(override.id, &cart->id, sizeof(override.id)); diff --git a/src/platform/qt/OverrideView.cpp b/src/platform/qt/OverrideView.cpp index 9e51fab4a9e..1d27375216f 100644 --- a/src/platform/qt/OverrideView.cpp +++ b/src/platform/qt/OverrideView.cpp @@ -155,7 +155,7 @@ void OverrideView::updateOverrides() { memset(gba->override.id, 0, 4); gba->override.savetype = static_cast(m_ui.savetype->currentIndex() - 1); gba->override.hardware = HW_NO_OVERRIDE; - gba->override.idleLoop = IDLE_LOOP_NONE; + gba->override.idleLoop = GBA_IDLE_LOOP_NONE; gba->override.mirroring = false; gba->override.vbaBugCompat = false; gba->vbaBugCompatSet = false; @@ -246,7 +246,7 @@ void OverrideView::gameStarted() { m_ui.hwGBPlayer->setChecked(gba->memory.hw.devices & HW_GB_PLAYER_DETECTION); m_ui.vbaBugCompat->setChecked(gba->vbaBugCompat); - if (gba->idleLoop != IDLE_LOOP_NONE) { + if (gba->idleLoop != GBA_IDLE_LOOP_NONE) { m_ui.idleLoop->setText(QString::number(gba->idleLoop, 16)); } else { m_ui.idleLoop->clear(); From abf484638e751e385abf52f23e8c5118ef2d2f4d Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 25 Mar 2024 01:23:14 -0700 Subject: [PATCH 024/338] GBA: Fix build --- src/gba/gba.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/gba/gba.c b/src/gba/gba.c index 409bd2b3ab3..31008507c37 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -111,7 +111,7 @@ static void GBAInit(void* cpu, struct mCPUComponent* component) { gba->biosChecksum = GBAChecksum(gba->memory.bios, GBA_SIZE_BIOS); gba->idleOptimization = IDLE_LOOP_REMOVE; - gba->idleLoop = IDLE_LOOP_NONE; + gba->idleLoop = GBA_IDLE_LOOP_NONE; gba->vbaBugCompat = false; gba->hardCrash = true; @@ -165,7 +165,7 @@ void GBAUnloadROM(struct GBA* gba) { gba->memory.savedata.realVf->close(gba->memory.savedata.realVf); gba->memory.savedata.realVf = 0; } - gba->idleLoop = IDLE_LOOP_NONE; + gba->idleLoop = GBA_IDLE_LOOP_NONE; } void GBADestroy(struct GBA* gba) { From 4a17ed3b9cae7ce018a4f282b0299f5f58197f2e Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 25 Mar 2024 01:23:39 -0700 Subject: [PATCH 025/338] GBA: Remove legacy "mirroring" field from overrides --- include/mgba/gba/interface.h | 1 - include/mgba/internal/gba/memory.h | 2 - src/gba/overrides.c | 213 ++++++++++++++--------------- src/platform/qt/OverrideView.cpp | 1 - 4 files changed, 101 insertions(+), 116 deletions(-) diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index f2f05064da5..9d19a55c886 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -96,7 +96,6 @@ struct GBACartridgeOverride { enum GBASavedataType savetype; int hardware; uint32_t idleLoop; - bool mirroring; bool vbaBugCompat; }; diff --git a/include/mgba/internal/gba/memory.h b/include/mgba/internal/gba/memory.h index f9e963d7672..c88e1d092c2 100644 --- a/include/mgba/internal/gba/memory.h +++ b/include/mgba/internal/gba/memory.h @@ -138,8 +138,6 @@ struct GBAMemory { struct GBAPrintContext agbPrintCtxBackup; uint32_t agbPrintFuncBackup; uint16_t* agbPrintBufferBackup; - - bool mirroring; }; struct GBA; diff --git a/src/gba/overrides.c b/src/gba/overrides.c index a3583070594..a63616e613b 100644 --- a/src/gba/overrides.c +++ b/src/gba/overrides.c @@ -13,47 +13,47 @@ static const struct GBACartridgeOverride _overrides[] = { // Advance Wars - { "AWRE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8038810, false }, - { "AWRP", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8038810, false }, + { "AWRE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8038810 }, + { "AWRP", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8038810 }, // Advance Wars 2: Black Hole Rising - { "AW2E", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8036E08, false }, - { "AW2P", GBA_SAVEDATA_FLASH512, HW_NONE, 0x803719C, false }, + { "AW2E", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8036E08 }, + { "AW2P", GBA_SAVEDATA_FLASH512, HW_NONE, 0x803719C }, // Boktai: The Sun is in Your Hand - { "U3IJ", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, - { "U3IE", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, - { "U3IP", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, + { "U3IJ", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE }, + { "U3IE", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE }, + { "U3IP", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE }, // Boktai 2: Solar Boy Django - { "U32J", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, - { "U32E", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, - { "U32P", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, + { "U32J", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE }, + { "U32E", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE }, + { "U32P", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE }, // Crash Bandicoot 2 - N-Tranced - { "AC8J", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "AC8E", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "AC8P", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "AC8J", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "AC8E", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "AC8P", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, // DigiCommunication Nyo - Datou! Black Gemagema Dan - { "BDKJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BDKJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, // Dragon Ball Z - The Legacy of Goku - { "ALGP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "ALGP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, // Dragon Ball Z - The Legacy of Goku II - { "ALFJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "ALFE", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "ALFP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "ALFJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "ALFE", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "ALFP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, // Dragon Ball Z - Taiketsu - { "BDBE", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BDBP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BDBE", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BDBP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, // Drill Dozer - { "V49J", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE, false }, - { "V49E", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE, false }, - { "V49P", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE, false }, + { "V49J", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE }, + { "V49E", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE }, + { "V49P", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE }, // e-Reader { "PEAJ", GBA_SAVEDATA_FLASH1M, HW_EREADER, GBA_IDLE_LOOP_NONE }, @@ -61,156 +61,146 @@ static const struct GBACartridgeOverride _overrides[] = { { "PSAE", GBA_SAVEDATA_FLASH1M, HW_EREADER, GBA_IDLE_LOOP_NONE }, // Final Fantasy Tactics Advance - { "AFXE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8000428, false }, + { "AFXE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x8000428 }, // F-Zero - Climax - { "BFTJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BFTJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, // Goodboy Galaxy - { "2GBP", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE, false }, + { "2GBP", GBA_SAVEDATA_SRAM, HW_RUMBLE, GBA_IDLE_LOOP_NONE }, // Iridion II - { "AI2E", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "AI2P", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "AI2E", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "AI2P", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE }, // Game Boy Wars Advance 1+2 - { "BGWJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BGWJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, // Golden Sun: The Lost Age - { "AGFE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x801353A, false }, + { "AGFE", GBA_SAVEDATA_FLASH512, HW_NONE, 0x801353A }, // Koro Koro Puzzle - Happy Panechu! - { "KHPJ", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE, false }, + { "KHPJ", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE }, // Legendz - Yomigaeru Shiren no Shima - { "BLJJ", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "BLJK", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "BLJJ", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "BLJK", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE }, // Legendz - Sign of Nekuromu - { "BLVJ", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "BLVJ", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE }, // Mega Man Battle Network - { "AREE", GBA_SAVEDATA_SRAM, HW_NONE, 0x800032E, false }, + { "AREE", GBA_SAVEDATA_SRAM, HW_NONE, 0x800032E }, // Mega Man Zero - { "AZCE", GBA_SAVEDATA_SRAM, HW_NONE, 0x80004E8, false }, + { "AZCE", GBA_SAVEDATA_SRAM, HW_NONE, 0x80004E8 }, // Metal Slug Advance - { "BSME", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8000290, false }, + { "BSME", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8000290 }, // Pokemon Ruby - { "AXVJ", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXVE", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXVP", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXVI", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXVS", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXVD", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXVF", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXVJ", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXVE", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXVP", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXVI", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXVS", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXVD", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXVF", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, // Pokemon Sapphire - { "AXPJ", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXPE", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXPP", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXPI", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXPS", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXPD", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, - { "AXPF", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "AXPJ", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXPE", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXPP", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXPI", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXPS", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXPD", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, + { "AXPF", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, // Pokemon Emerald - { "BPEJ", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPEE", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPEP", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPEI", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPES", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPED", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, - { "BPEF", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6, false }, + { "BPEJ", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6 }, + { "BPEE", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6 }, + { "BPEP", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6 }, + { "BPEI", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6 }, + { "BPES", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6 }, + { "BPED", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6 }, + { "BPEF", GBA_SAVEDATA_FLASH1M, HW_RTC, 0x80008C6 }, // Pokemon Mystery Dungeon - { "B24E", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "B24P", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "B24E", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "B24P", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, // Pokemon FireRed - { "BPRJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPRE", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPRP", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPRI", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPRS", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPRD", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPRF", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPRJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPRE", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPRP", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPRI", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPRS", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPRD", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPRF", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, // Pokemon LeafGreen - { "BPGJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPGE", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPGP", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPGI", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPGS", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPGD", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "BPGF", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BPGJ", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPGE", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPGP", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPGI", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPGS", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPGD", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "BPGF", GBA_SAVEDATA_FLASH1M, HW_NONE, GBA_IDLE_LOOP_NONE }, // RockMan EXE 4.5 - Real Operation - { "BR4J", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "BR4J", GBA_SAVEDATA_FLASH512, HW_RTC, GBA_IDLE_LOOP_NONE }, // Rocky - { "AR8E", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "AROP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "AR8E", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "AROP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, // Sennen Kazoku - { "BKAJ", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE, false }, + { "BKAJ", GBA_SAVEDATA_FLASH1M, HW_RTC, GBA_IDLE_LOOP_NONE }, // Shin Bokura no Taiyou: Gyakushuu no Sabata - { "U33J", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE, false }, + { "U33J", GBA_SAVEDATA_EEPROM, HW_RTC | HW_LIGHT_SENSOR, GBA_IDLE_LOOP_NONE }, // Stuart Little 2 - { "ASLE", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "ASLF", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "ASLE", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "ASLF", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE }, // Super Mario Advance 2 - { "AA2J", GBA_SAVEDATA_EEPROM, HW_NONE, 0x800052E, false }, - { "AA2E", GBA_SAVEDATA_EEPROM, HW_NONE, 0x800052E, false }, - { "AA2P", GBA_SAVEDATA_AUTODETECT, HW_NONE, 0x800052E, false }, + { "AA2J", GBA_SAVEDATA_EEPROM, HW_NONE, 0x800052E }, + { "AA2E", GBA_SAVEDATA_EEPROM, HW_NONE, 0x800052E }, + { "AA2P", GBA_SAVEDATA_AUTODETECT, HW_NONE, 0x800052E }, // Super Mario Advance 3 - { "A3AJ", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8002B9C, false }, - { "A3AE", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8002B9C, false }, - { "A3AP", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8002B9C, false }, + { "A3AJ", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8002B9C }, + { "A3AE", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8002B9C }, + { "A3AP", GBA_SAVEDATA_EEPROM, HW_NONE, 0x8002B9C }, // Super Mario Advance 4 - { "AX4J", GBA_SAVEDATA_FLASH1M, HW_NONE, 0x800072A, false }, - { "AX4E", GBA_SAVEDATA_FLASH1M, HW_NONE, 0x800072A, false }, - { "AX4P", GBA_SAVEDATA_FLASH1M, HW_NONE, 0x800072A, false }, + { "AX4J", GBA_SAVEDATA_FLASH1M, HW_NONE, 0x800072A }, + { "AX4E", GBA_SAVEDATA_FLASH1M, HW_NONE, 0x800072A }, + { "AX4P", GBA_SAVEDATA_FLASH1M, HW_NONE, 0x800072A }, // Super Monkey Ball Jr. - { "ALUE", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "ALUP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "ALUE", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, + { "ALUP", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, // Top Gun - Combat Zones - { "A2YE", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "A2YE", GBA_SAVEDATA_FORCE_NONE, HW_NONE, GBA_IDLE_LOOP_NONE }, // Ueki no Housoku - Jingi Sakuretsu! Nouryokusha Battle - { "BUHJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "BUHJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE }, // Wario Ware Twisted - { "RZWJ", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, GBA_IDLE_LOOP_NONE, false }, - { "RZWE", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, GBA_IDLE_LOOP_NONE, false }, - { "RZWP", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, GBA_IDLE_LOOP_NONE, false }, + { "RZWJ", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, GBA_IDLE_LOOP_NONE }, + { "RZWE", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, GBA_IDLE_LOOP_NONE }, + { "RZWP", GBA_SAVEDATA_SRAM, HW_RUMBLE | HW_GYRO, GBA_IDLE_LOOP_NONE }, // Yoshi's Universal Gravitation - { "KYGJ", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE, false }, - { "KYGE", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE, false }, - { "KYGP", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE, false }, + { "KYGJ", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE }, + { "KYGE", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE }, + { "KYGP", GBA_SAVEDATA_EEPROM, HW_TILT, GBA_IDLE_LOOP_NONE }, // Aging cartridge - { "TCHK", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - - // Famicom Mini series 3 (FDS), some aren't mirrored (22 - 28) - // See https://forum.no-intro.org/viewtopic.php?f=2&t=4221 for discussion - { "FNMJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "FMRJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "FPTJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "FLBJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "FFMJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "FTKJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, - { "FTUJ", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, false }, + { "TCHK", GBA_SAVEDATA_EEPROM, HW_NONE, GBA_IDLE_LOOP_NONE, }, { { 0, 0, 0, 0 }, 0, 0, GBA_IDLE_LOOP_NONE, false } }; @@ -219,7 +209,6 @@ bool GBAOverrideFind(const struct Configuration* config, struct GBACartridgeOver override->savetype = GBA_SAVEDATA_AUTODETECT; override->hardware = HW_NONE; override->idleLoop = GBA_IDLE_LOOP_NONE; - override->mirroring = false; override->vbaBugCompat = false; bool found = false; diff --git a/src/platform/qt/OverrideView.cpp b/src/platform/qt/OverrideView.cpp index 1d27375216f..bec404a0091 100644 --- a/src/platform/qt/OverrideView.cpp +++ b/src/platform/qt/OverrideView.cpp @@ -156,7 +156,6 @@ void OverrideView::updateOverrides() { gba->override.savetype = static_cast(m_ui.savetype->currentIndex() - 1); gba->override.hardware = HW_NO_OVERRIDE; gba->override.idleLoop = GBA_IDLE_LOOP_NONE; - gba->override.mirroring = false; gba->override.vbaBugCompat = false; gba->vbaBugCompatSet = false; From 318c5d7435ccd45dca1926a75d3b55d8544feaf2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 25 Mar 2024 01:24:50 -0700 Subject: [PATCH 026/338] GBA: Move GBAHardwareDevice to public API --- include/mgba/gba/interface.h | 13 +++++++++++++ include/mgba/internal/gba/cart/gpio.h | 13 ------------- 2 files changed, 13 insertions(+), 13 deletions(-) diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index 9d19a55c886..c54277e832b 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -58,6 +58,19 @@ enum GBASavedataType { GBA_SAVEDATA_SRAM512 = 6, }; +enum GBAHardwareDevice { + HW_NO_OVERRIDE = 0x8000, + HW_NONE = 0, + HW_RTC = 1, + HW_RUMBLE = 2, + HW_LIGHT_SENSOR = 4, + HW_GYRO = 8, + HW_TILT = 16, + HW_GB_PLAYER = 32, + HW_GB_PLAYER_DETECTION = 64, + HW_EREADER = 128 +}; + struct GBA; struct GBAAudio; struct GBASIO; diff --git a/include/mgba/internal/gba/cart/gpio.h b/include/mgba/internal/gba/cart/gpio.h index 86ddc941f73..77785e6122c 100644 --- a/include/mgba/internal/gba/cart/gpio.h +++ b/include/mgba/internal/gba/cart/gpio.h @@ -18,19 +18,6 @@ mLOG_DECLARE_CATEGORY(GBA_HW); #define IS_GPIO_REGISTER(reg) ((reg) == GPIO_REG_DATA || (reg) == GPIO_REG_DIRECTION || (reg) == GPIO_REG_CONTROL) -enum GBAHardwareDevice { - HW_NO_OVERRIDE = 0x8000, - HW_NONE = 0, - HW_RTC = 1, - HW_RUMBLE = 2, - HW_LIGHT_SENSOR = 4, - HW_GYRO = 8, - HW_TILT = 16, - HW_GB_PLAYER = 32, - HW_GB_PLAYER_DETECTION = 64, - HW_EREADER = 128 -}; - enum GPIORegister { GPIO_REG_DATA = 0xC4, GPIO_REG_DIRECTION = 0xC6, From a430f58c15d65d7daa04364fafa140dc486201be Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 25 Mar 2024 01:47:32 -0700 Subject: [PATCH 027/338] GB, GBA: Move more override-adjacent stuff to public API --- include/mgba/gb/interface.h | 12 ++++++++++++ include/mgba/gba/interface.h | 28 +++++++++++++++------------ include/mgba/internal/gb/overrides.h | 12 ------------ include/mgba/internal/gba/overrides.h | 4 ---- src/feature/gui/gui-config.c | 2 +- src/platform/qt/ConfigController.cpp | 2 +- src/platform/qt/GBAOverride.h | 2 +- src/platform/qt/GBOverride.h | 2 +- src/platform/qt/SettingsView.cpp | 2 +- 9 files changed, 33 insertions(+), 33 deletions(-) diff --git a/include/mgba/gb/interface.h b/include/mgba/gb/interface.h index 485111b4165..de26ef73168 100644 --- a/include/mgba/gb/interface.h +++ b/include/mgba/gb/interface.h @@ -82,6 +82,12 @@ struct GBCartridgeOverride { uint32_t gbColors[12]; }; +struct GBColorPreset { + const char* name; + uint32_t colors[12]; +}; + +struct Configuration; struct VFile; bool GBIsROM(struct VFile* vf); @@ -93,6 +99,12 @@ const char* GBModelToName(enum GBModel); int GBValidModels(const uint8_t* bank0); +bool GBOverrideFind(const struct Configuration*, struct GBCartridgeOverride* override); +bool GBOverrideColorFind(struct GBCartridgeOverride* override, enum GBColorLookup); +void GBOverrideSave(struct Configuration*, const struct GBCartridgeOverride* override); + +size_t GBColorPresetList(const struct GBColorPreset** presets); + CXX_GUARD_END #endif diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index c54277e832b..c64d0039119 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -71,7 +71,7 @@ enum GBAHardwareDevice { HW_EREADER = 128 }; -struct GBA; +struct Configuration; struct GBAAudio; struct GBASIO; struct GBAVideoRenderer; @@ -84,9 +84,13 @@ enum { mPERIPH_GBA_BATTLECHIP_GATE, }; -bool GBAIsROM(struct VFile* vf); -bool GBAIsMB(struct VFile* vf); -bool GBAIsBIOS(struct VFile* vf); +struct GBACartridgeOverride { + char id[4]; + enum GBASavedataType savetype; + int hardware; + uint32_t idleLoop; + bool vbaBugCompat; +}; struct GBALuminanceSource { void (*sample)(struct GBALuminanceSource*); @@ -94,6 +98,13 @@ struct GBALuminanceSource { uint8_t (*readLuminance)(struct GBALuminanceSource*); }; +bool GBAIsROM(struct VFile* vf); +bool GBAIsMB(struct VFile* vf); +bool GBAIsBIOS(struct VFile* vf); + +bool GBAOverrideFind(const struct Configuration*, struct GBACartridgeOverride* override); +void GBAOverrideSave(struct Configuration*, const struct GBACartridgeOverride* override); + struct GBASIODriver { struct GBASIO* p; @@ -104,14 +115,6 @@ struct GBASIODriver { uint16_t (*writeRegister)(struct GBASIODriver* driver, uint32_t address, uint16_t value); }; -struct GBACartridgeOverride { - char id[4]; - enum GBASavedataType savetype; - int hardware; - uint32_t idleLoop; - bool vbaBugCompat; -}; - void GBASIOJOYCreate(struct GBASIODriver* sio); enum GBASIOBattleChipGateFlavor { @@ -132,6 +135,7 @@ struct GBASIOBattlechipGate { void GBASIOBattlechipGateCreate(struct GBASIOBattlechipGate*); +struct GBA; void GBACartEReaderQueueCard(struct GBA* gba, const void* data, size_t size); struct EReaderScan; diff --git a/include/mgba/internal/gb/overrides.h b/include/mgba/internal/gb/overrides.h index 6e683f0deaa..9d16ce65c04 100644 --- a/include/mgba/internal/gb/overrides.h +++ b/include/mgba/internal/gb/overrides.h @@ -12,18 +12,6 @@ CXX_GUARD_START #include -struct GBColorPreset { - const char* name; - uint32_t colors[12]; -}; - -struct Configuration; -bool GBOverrideFind(const struct Configuration*, struct GBCartridgeOverride* override); -bool GBOverrideColorFind(struct GBCartridgeOverride* override, enum GBColorLookup); -void GBOverrideSave(struct Configuration*, const struct GBCartridgeOverride* override); - -size_t GBColorPresetList(const struct GBColorPreset** presets); - struct GB; void GBOverrideApply(struct GB*, const struct GBCartridgeOverride*); void GBOverrideApplyDefaults(struct GB*); diff --git a/include/mgba/internal/gba/overrides.h b/include/mgba/internal/gba/overrides.h index b2eba2d7a6f..4bec8bf15d1 100644 --- a/include/mgba/internal/gba/overrides.h +++ b/include/mgba/internal/gba/overrides.h @@ -12,10 +12,6 @@ CXX_GUARD_START #include -struct Configuration; -bool GBAOverrideFind(const struct Configuration*, struct GBACartridgeOverride* override); -void GBAOverrideSave(struct Configuration*, const struct GBACartridgeOverride* override); - struct GBA; void GBAOverrideApply(struct GBA*, const struct GBACartridgeOverride*); void GBAOverrideApplyDefaults(struct GBA*, const struct Configuration*); diff --git a/src/feature/gui/gui-config.c b/src/feature/gui/gui-config.c index 4a6c7987196..e110ef76857 100644 --- a/src/feature/gui/gui-config.c +++ b/src/feature/gui/gui-config.c @@ -12,7 +12,7 @@ #include #ifdef M_CORE_GB #include -#include +#include #endif #include #include diff --git a/src/platform/qt/ConfigController.cpp b/src/platform/qt/ConfigController.cpp index e1bf354086f..91ecf8e7a7b 100644 --- a/src/platform/qt/ConfigController.cpp +++ b/src/platform/qt/ConfigController.cpp @@ -13,7 +13,7 @@ #include #ifdef M_CORE_GB -#include +#include #endif static const mOption s_frontendOptions[] = { diff --git a/src/platform/qt/GBAOverride.h b/src/platform/qt/GBAOverride.h index 477af001423..b93cb1953f3 100644 --- a/src/platform/qt/GBAOverride.h +++ b/src/platform/qt/GBAOverride.h @@ -7,7 +7,7 @@ #include "Override.h" -#include +#include namespace QGBA { diff --git a/src/platform/qt/GBOverride.h b/src/platform/qt/GBOverride.h index e967211def7..fc1a7d2c927 100644 --- a/src/platform/qt/GBOverride.h +++ b/src/platform/qt/GBOverride.h @@ -7,7 +7,7 @@ #include "Override.h" -#include +#include namespace QGBA { diff --git a/src/platform/qt/SettingsView.cpp b/src/platform/qt/SettingsView.cpp index 04d7d16497d..7c41cb4a4e9 100644 --- a/src/platform/qt/SettingsView.cpp +++ b/src/platform/qt/SettingsView.cpp @@ -18,7 +18,7 @@ #ifdef M_CORE_GB #include "GameBoy.h" -#include +#include #endif #include From 1179d218e7094b40ce5666df0a7c2d083cb96504 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 25 Mar 2024 02:35:03 -0700 Subject: [PATCH 028/338] Qt: Fix Qt6 build --- src/platform/qt/VideoDumper.h | 1 + 1 file changed, 1 insertion(+) diff --git a/src/platform/qt/VideoDumper.h b/src/platform/qt/VideoDumper.h index 65433462cb8..2dcceac0f6c 100644 --- a/src/platform/qt/VideoDumper.h +++ b/src/platform/qt/VideoDumper.h @@ -6,6 +6,7 @@ #pragma once #include +#include #if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) #include #include From ae8b88a4a318044a946e1806540a45ec66ae4505 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 25 Mar 2024 21:16:09 -0700 Subject: [PATCH 029/338] Qt: Fix underrun stalling with Qt6 --- src/platform/qt/AudioDevice.cpp | 10 ++++++++++ src/platform/qt/AudioDevice.h | 1 + src/platform/qt/AudioProcessorQt.cpp | 29 ++++++++++++++++++++++++++++ src/platform/qt/AudioProcessorQt.h | 8 +++++++- 4 files changed, 47 insertions(+), 1 deletion(-) diff --git a/src/platform/qt/AudioDevice.cpp b/src/platform/qt/AudioDevice.cpp index 74f86344495..d19fc20d311 100644 --- a/src/platform/qt/AudioDevice.cpp +++ b/src/platform/qt/AudioDevice.cpp @@ -62,3 +62,13 @@ qint64 AudioDevice::writeData(const char*, qint64) { LOG(QT, WARN) << tr("Writing data to read-only audio device"); return 0; } + +bool AudioDevice::atEnd() const { + if (!m_context->core) { + return true; + } + mCoreSyncLockAudio(&m_context->impl->sync); + bool available = blip_samples_avail(m_context->core->getAudioChannel(m_context->core, 0)) == 0; + mCoreSyncUnlockAudio(&m_context->impl->sync); + return available; +} diff --git a/src/platform/qt/AudioDevice.h b/src/platform/qt/AudioDevice.h index 0794b37431d..86c5b17a6bc 100644 --- a/src/platform/qt/AudioDevice.h +++ b/src/platform/qt/AudioDevice.h @@ -20,6 +20,7 @@ Q_OBJECT void setInput(mCoreThread* input); void setFormat(const QAudioFormat& format); + bool atEnd() const override; protected: virtual qint64 readData(char* data, qint64 maxSize) override; diff --git a/src/platform/qt/AudioProcessorQt.cpp b/src/platform/qt/AudioProcessorQt.cpp index 4b53c7bb7fc..3e4c5474ec8 100644 --- a/src/platform/qt/AudioProcessorQt.cpp +++ b/src/platform/qt/AudioProcessorQt.cpp @@ -21,6 +21,10 @@ using namespace QGBA; AudioProcessorQt::AudioProcessorQt(QObject* parent) : AudioProcessor(parent) { +#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) + m_recheckTimer.setInterval(1); + connect(&m_recheckTimer, &QTimer::timeout, this, &AudioProcessorQt::recheckUnderflow); +#endif } void AudioProcessorQt::setInput(std::shared_ptr controller) { @@ -34,6 +38,9 @@ void AudioProcessorQt::setInput(std::shared_ptr controller) { } void AudioProcessorQt::stop() { +#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) + m_recheckTimer.stop(); +#endif if (m_audioOutput) { m_audioOutput->stop(); m_audioOutput.reset(); @@ -72,6 +79,12 @@ bool AudioProcessorQt::start() { QAudioDevice device(QMediaDevices::defaultAudioOutput()); m_audioOutput = std::make_unique(device, format); LOG(QT, INFO) << "Audio outputting to " << device.description(); + connect(m_audioOutput.get(), &QAudioSink::stateChanged, this, [this](QAudio::State state) { + if (state != QAudio::IdleState) { + return; + } + m_recheckTimer.start(); + }); #endif } @@ -86,6 +99,9 @@ bool AudioProcessorQt::start() { } void AudioProcessorQt::pause() { +#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) + m_recheckTimer.stop(); +#endif if (m_audioOutput) { m_audioOutput->suspend(); } @@ -115,3 +131,16 @@ unsigned AudioProcessorQt::sampleRate() const { } return m_audioOutput->format().sampleRate(); } + +#if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) +void AudioProcessorQt::recheckUnderflow() { + if (!m_device) { + m_recheckTimer.stop(); + return; + } + if (!m_device->atEnd()) { + start(); + m_recheckTimer.stop(); + } +} +#endif diff --git a/src/platform/qt/AudioProcessorQt.h b/src/platform/qt/AudioProcessorQt.h index 1648b967fce..bdfa17a7701 100644 --- a/src/platform/qt/AudioProcessorQt.h +++ b/src/platform/qt/AudioProcessorQt.h @@ -11,6 +11,7 @@ #include #else #include +#include #endif class QAudioOutput; @@ -38,10 +39,15 @@ public slots: virtual void requestSampleRate(unsigned) override; -private: #if (QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)) +private slots: + void recheckUnderflow(); + +private: + QTimer m_recheckTimer; std::unique_ptr m_audioOutput; #else +private: std::unique_ptr m_audioOutput; #endif std::unique_ptr m_device; From 86551614d9b0d6c0aeb9c0e03e58d4266acdae2c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 25 Mar 2024 21:27:58 -0700 Subject: [PATCH 030/338] Qt: Enable building against Qt6 by default --- src/platform/qt/CMakeLists.txt | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index 19d4293d099..fe898be1e8b 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -25,12 +25,19 @@ set(CMAKE_INCLUDE_CURRENT_DIR ON) set(QT_LIBRARIES) -set(QT_V 5) -find_package(Qt${QT_V} COMPONENTS Core Widgets Network OPTIONAL_COMPONENTS Multimedia) -if(QT_V GREATER_EQUAL 6) - find_package(Qt${QT_V} COMPONENTS OpenGL OpenGLWidgets) -endif() -set(QT Qt${QT_V}) +set(QT_VERSIONS 6 5) +foreach(V ${QT_VERSIONS}) + set(QT Qt${V}) + set(QT_V ${V}) + message("${V} ${QT} ${QT_V}") + find_package(${QT} COMPONENTS Core Widgets Network OPTIONAL_COMPONENTS Multimedia) + if(QT_V GREATER_EQUAL 6) + find_package(${QT} COMPONENTS OpenGL OpenGLWidgets) + endif() + if(${${QT}Widgets_FOUND}) + break() + endif() +endforeach() if(NOT BUILD_GL AND NOT BUILD_GLES2 AND NOT BUILD_GLES3) message(WARNING "OpenGL is recommended to build the Qt port") From e3edca1f4168c1eee36cd213ef8d5e91fd35e400 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 26 Mar 2024 22:24:14 -0700 Subject: [PATCH 031/338] Scripting: Attempt to shake out single-lua_State requirement --- src/script/engines/lua.c | 270 +++++++++++++++++++-------------------- 1 file changed, 133 insertions(+), 137 deletions(-) diff --git a/src/script/engines/lua.c b/src/script/engines/lua.c index 32ed0d13ef4..f6bdabea2aa 100644 --- a/src/script/engines/lua.c +++ b/src/script/engines/lua.c @@ -40,12 +40,12 @@ static void _freeFrame(struct mScriptList* frame); static void _autofreeFrame(struct mScriptContext* context, struct mScriptList* frame); struct mScriptEngineContextLua; -static bool _luaPushFrame(struct mScriptEngineContextLua*, struct mScriptList*); -static bool _luaPopFrame(struct mScriptEngineContextLua*, struct mScriptList*); +static bool _luaPushFrame(struct mScriptEngineContextLua*, lua_State*, struct mScriptList*); +static bool _luaPopFrame(struct mScriptEngineContextLua*, lua_State*, struct mScriptList*); static bool _luaInvoke(struct mScriptEngineContextLua*, struct mScriptFrame*); -static struct mScriptValue* _luaCoerce(struct mScriptEngineContextLua* luaContext, bool pop); -static bool _luaWrap(struct mScriptEngineContextLua* luaContext, struct mScriptValue*); +static struct mScriptValue* _luaCoerce(struct mScriptEngineContextLua* luaContext, lua_State*, bool pop); +static bool _luaWrap(struct mScriptEngineContextLua* luaContext, lua_State*, struct mScriptValue*); static void _luaDeref(struct mScriptValue*); @@ -516,14 +516,14 @@ bool _luaIsScript(struct mScriptEngineContext* ctx, const char* name, struct VFi struct mScriptValue* _luaGetGlobal(struct mScriptEngineContext* ctx, const char* name) { struct mScriptEngineContextLua* luaContext = (struct mScriptEngineContextLua*) ctx; lua_getglobal(luaContext->lua, name); - return _luaCoerce(luaContext, true); + return _luaCoerce(luaContext, luaContext->lua, true); } bool _luaSetGlobal(struct mScriptEngineContext* ctx, const char* name, struct mScriptValue* value) { struct mScriptEngineContextLua* luaContext = (struct mScriptEngineContextLua*) ctx; if (!value) { lua_pushnil(luaContext->lua); - } else if (!_luaWrap(luaContext, value)) { + } else if (!_luaWrap(luaContext, luaContext->lua, value)) { return false; } lua_setglobal(luaContext->lua, name); @@ -540,7 +540,7 @@ struct mScriptValue* _luaRootScope(struct mScriptEngineContext* ctx) { struct mScriptValue* key; lua_pop(luaContext->lua, 1); - key = _luaCoerce(luaContext, false); + key = _luaCoerce(luaContext, luaContext->lua, false); mScriptValueWrap(key, mScriptListAppend(list->value.list)); mScriptValueRef(key); mScriptContextFillPool(luaContext->d.context, key); @@ -550,60 +550,60 @@ struct mScriptValue* _luaRootScope(struct mScriptEngineContext* ctx) { return list; } -struct mScriptValue* _luaCoerceFunction(struct mScriptEngineContextLua* luaContext) { +struct mScriptValue* _luaCoerceFunction(struct mScriptEngineContextLua* luaContext, lua_State* lua) { struct mScriptValue* value = mScriptValueAlloc(&mSTLuaFunc); struct mScriptFunction* fn = calloc(1, sizeof(*fn)); struct mScriptEngineContextLuaRef* ref = calloc(1, sizeof(*ref)); fn->call = _luaCall; fn->context = ref; ref->context = luaContext; - ref->ref = luaL_ref(luaContext->lua, LUA_REGISTRYINDEX); + ref->ref = luaL_ref(lua, LUA_REGISTRYINDEX); value->value.opaque = fn; return value; } -struct mScriptValue* _luaCoerceTable(struct mScriptEngineContextLua* luaContext, struct Table* markedObjects) { +struct mScriptValue* _luaCoerceTable(struct mScriptEngineContextLua* luaContext, lua_State* lua, struct Table* markedObjects) { struct mScriptValue* table = mScriptValueAlloc(mSCRIPT_TYPE_MS_TABLE); bool isList = true; - lua_pushnil(luaContext->lua); + lua_pushnil(lua); const void* tablePointer; - while (lua_next(luaContext->lua, -2) != 0) { + while (lua_next(lua, -2) != 0) { struct mScriptValue* value = NULL; - int type = lua_type(luaContext->lua, -1); + int type = lua_type(lua, -1); switch (type) { case LUA_TNUMBER: case LUA_TBOOLEAN: case LUA_TSTRING: case LUA_TFUNCTION: - value = _luaCoerce(luaContext, true); + value = _luaCoerce(luaContext, lua, true); break; case LUA_TTABLE: - tablePointer = lua_topointer(luaContext->lua, -1); + tablePointer = lua_topointer(lua, -1); // Ensure this table doesn't contain any cycles if (!HashTableLookupBinary(markedObjects, &tablePointer, sizeof(tablePointer))) { HashTableInsertBinary(markedObjects, &tablePointer, sizeof(tablePointer), (void*) tablePointer); - value = _luaCoerceTable(luaContext, markedObjects); + value = _luaCoerceTable(luaContext, lua, markedObjects); } default: break; } if (!value) { - lua_pop(luaContext->lua, type == LUA_TTABLE ? 2 : 3); + lua_pop(lua, type == LUA_TTABLE ? 2 : 3); mScriptValueDeref(table); return NULL; } struct mScriptValue* key = NULL; - type = lua_type(luaContext->lua, -1); + type = lua_type(lua, -1); switch (type) { case LUA_TBOOLEAN: case LUA_TSTRING: isList = false; // Fall through case LUA_TNUMBER: - key = _luaCoerce(luaContext, false); + key = _luaCoerce(luaContext, lua, false); break; default: // Limit keys to hashable types @@ -611,7 +611,7 @@ struct mScriptValue* _luaCoerceTable(struct mScriptEngineContextLua* luaContext, } if (!key) { - lua_pop(luaContext->lua, 2); + lua_pop(lua, 2); mScriptValueDeref(table); return false; } @@ -619,7 +619,7 @@ struct mScriptValue* _luaCoerceTable(struct mScriptEngineContextLua* luaContext, mScriptValueDeref(key); mScriptValueDeref(value); } - lua_pop(luaContext->lua, 1); + lua_pop(lua, 1); size_t len = mScriptTableSize(table); if (!isList || !len) { @@ -652,9 +652,9 @@ struct mScriptValue* _luaCoerceTable(struct mScriptEngineContextLua* luaContext, return list; } -struct mScriptValue* _luaCoerce(struct mScriptEngineContextLua* luaContext, bool pop) { - if (lua_isnone(luaContext->lua, -1)) { - lua_pop(luaContext->lua, 1); +struct mScriptValue* _luaCoerce(struct mScriptEngineContextLua* luaContext, lua_State* lua, bool pop) { + if (lua_isnone(lua, -1)) { + lua_pop(lua, 1); return NULL; } @@ -662,27 +662,27 @@ struct mScriptValue* _luaCoerce(struct mScriptEngineContextLua* luaContext, bool const void* buffer; struct Table markedObjects; struct mScriptValue* value = NULL; - switch (lua_type(luaContext->lua, -1)) { + switch (lua_type(lua, -1)) { case LUA_TNIL: value = &mScriptValueNull; break; case LUA_TNUMBER: #if LUA_VERSION_NUM >= 503 - if (lua_isinteger(luaContext->lua, -1)) { + if (lua_isinteger(lua, -1)) { value = mScriptValueAlloc(mSCRIPT_TYPE_MS_S64); - value->value.s64 = lua_tointeger(luaContext->lua, -1); + value->value.s64 = lua_tointeger(lua, -1); break; } #endif value = mScriptValueAlloc(mSCRIPT_TYPE_MS_F64); - value->value.f64 = lua_tonumber(luaContext->lua, -1); + value->value.f64 = lua_tonumber(lua, -1); break; case LUA_TBOOLEAN: value = mScriptValueAlloc(mSCRIPT_TYPE_MS_BOOL); - value->value.u32 = lua_toboolean(luaContext->lua, -1); + value->value.u32 = lua_toboolean(lua, -1); break; case LUA_TSTRING: - buffer = lua_tolstring(luaContext->lua, -1, &size); + buffer = lua_tolstring(lua, -1, &size); value = mScriptStringCreateFromBytes(buffer, size); break; case LUA_TFUNCTION: @@ -690,35 +690,35 @@ struct mScriptValue* _luaCoerce(struct mScriptEngineContextLua* luaContext, bool if (!pop) { break; } - return _luaCoerceFunction(luaContext); + return _luaCoerceFunction(luaContext, lua); case LUA_TTABLE: // This function pops the value internally if (!pop) { break; } HashTableInit(&markedObjects, 0, NULL); - value = _luaCoerceTable(luaContext, &markedObjects); + value = _luaCoerceTable(luaContext, lua, &markedObjects); HashTableDeinit(&markedObjects); return value; case LUA_TUSERDATA: - if (!lua_getmetatable(luaContext->lua, -1)) { + if (!lua_getmetatable(lua, -1)) { break; } - luaL_getmetatable(luaContext->lua, "mSTStruct"); - if (!lua_rawequal(luaContext->lua, -1, -2)) { - lua_pop(luaContext->lua, 1); - luaL_getmetatable(luaContext->lua, "mSTList"); - if (!lua_rawequal(luaContext->lua, -1, -2)) { - lua_pop(luaContext->lua, 1); - luaL_getmetatable(luaContext->lua, "mSTTable"); - if (!lua_rawequal(luaContext->lua, -1, -2)) { - lua_pop(luaContext->lua, 2); + luaL_getmetatable(lua, "mSTStruct"); + if (!lua_rawequal(lua, -1, -2)) { + lua_pop(lua, 1); + luaL_getmetatable(lua, "mSTList"); + if (!lua_rawequal(lua, -1, -2)) { + lua_pop(lua, 1); + luaL_getmetatable(lua, "mSTTable"); + if (!lua_rawequal(lua, -1, -2)) { + lua_pop(lua, 2); break; } } } - lua_pop(luaContext->lua, 2); - value = lua_touserdata(luaContext->lua, -1); + lua_pop(lua, 2); + value = lua_touserdata(lua, -1); value = mScriptContextAccessWeakref(luaContext->d.context, value); if (value->type->base == mSCRIPT_TYPE_WRAPPER) { value = mScriptValueUnwrap(value); @@ -729,14 +729,14 @@ struct mScriptValue* _luaCoerce(struct mScriptEngineContextLua* luaContext, bool break; } if (pop) { - lua_pop(luaContext->lua, 1); + lua_pop(lua, 1); } return value; } -bool _luaWrap(struct mScriptEngineContextLua* luaContext, struct mScriptValue* value) { +bool _luaWrap(struct mScriptEngineContextLua* luaContext, lua_State* lua, struct mScriptValue* value) { if (!value) { - lua_pushnil(luaContext->lua); + lua_pushnil(lua); return true; } uint32_t weakref; @@ -744,7 +744,7 @@ bool _luaWrap(struct mScriptEngineContextLua* luaContext, struct mScriptValue* v if (value->type->base == mSCRIPT_TYPE_WRAPPER) { value = mScriptValueUnwrap(value); if (!value) { - lua_pushnil(luaContext->lua); + lua_pushnil(lua); return true; } mScriptContextFillPool(luaContext->d.context, value); @@ -778,7 +778,7 @@ bool _luaWrap(struct mScriptEngineContextLua* luaContext, struct mScriptValue* v weakref = value->value.u32; value = mScriptContextAccessWeakref(luaContext->d.context, value); if (!value) { - lua_pushnil(luaContext->lua); + lua_pushnil(lua); return true; } needsWeakref = true; @@ -787,95 +787,95 @@ bool _luaWrap(struct mScriptEngineContextLua* luaContext, struct mScriptValue* v struct mScriptValue* newValue; switch (value->type->base) { case mSCRIPT_TYPE_VOID: - lua_pushnil(luaContext->lua); + lua_pushnil(lua); break; case mSCRIPT_TYPE_SINT: if (value->type->size <= 4) { - lua_pushinteger(luaContext->lua, value->value.s32); + lua_pushinteger(lua, value->value.s32); } else if (value->type->size == 8) { - lua_pushinteger(luaContext->lua, value->value.s64); + lua_pushinteger(lua, value->value.s64); } else { ok = false; } break; case mSCRIPT_TYPE_UINT: if (value->type == mSCRIPT_TYPE_MS_BOOL) { - lua_pushboolean(luaContext->lua, !!value->value.u32); + lua_pushboolean(lua, !!value->value.u32); } else if (value->type->size <= 4) { - lua_pushinteger(luaContext->lua, value->value.u32); + lua_pushinteger(lua, value->value.u32); } else if (value->type->size == 8) { - lua_pushinteger(luaContext->lua, value->value.u64); + lua_pushinteger(lua, value->value.u64); } else { ok = false; } break; case mSCRIPT_TYPE_FLOAT: if (value->type->size == 4) { - lua_pushnumber(luaContext->lua, value->value.f32); + lua_pushnumber(lua, value->value.f32); } else if (value->type->size == 8) { - lua_pushnumber(luaContext->lua, value->value.f64); + lua_pushnumber(lua, value->value.f64); } else { ok = false; } break; case mSCRIPT_TYPE_STRING: if (!value->value.string) { - lua_pushnil(luaContext->lua); + lua_pushnil(lua); break; } if (value->type == mSCRIPT_TYPE_MS_STR) { - lua_pushlstring(luaContext->lua, value->value.string->buffer, value->value.string->size); + lua_pushlstring(lua, value->value.string->buffer, value->value.string->size); break; } if (value->type == mSCRIPT_TYPE_MS_CHARP) { - lua_pushstring(luaContext->lua, value->value.copaque); + lua_pushstring(lua, value->value.copaque); break; } ok = false; break; case mSCRIPT_TYPE_LIST: - newValue = lua_newuserdata(luaContext->lua, sizeof(*newValue)); + newValue = lua_newuserdata(lua, sizeof(*newValue)); if (needsWeakref) { *newValue = mSCRIPT_MAKE(WEAKREF, weakref); } else { mScriptValueRef(value); mScriptValueWrap(value, newValue); } - lua_getfield(luaContext->lua, LUA_REGISTRYINDEX, "mSTList"); - lua_setmetatable(luaContext->lua, -2); + lua_getfield(lua, LUA_REGISTRYINDEX, "mSTList"); + lua_setmetatable(lua, -2); break; case mSCRIPT_TYPE_TABLE: - newValue = lua_newuserdata(luaContext->lua, sizeof(*newValue)); + newValue = lua_newuserdata(lua, sizeof(*newValue)); if (needsWeakref) { *newValue = mSCRIPT_MAKE(WEAKREF, weakref); } else { mScriptValueRef(value); mScriptValueWrap(value, newValue); } - lua_getfield(luaContext->lua, LUA_REGISTRYINDEX, "mSTTable"); - lua_setmetatable(luaContext->lua, -2); + lua_getfield(lua, LUA_REGISTRYINDEX, "mSTTable"); + lua_setmetatable(lua, -2); break; case mSCRIPT_TYPE_FUNCTION: - newValue = lua_newuserdata(luaContext->lua, sizeof(*newValue)); + newValue = lua_newuserdata(lua, sizeof(*newValue)); newValue->type = value->type; newValue->refs = mSCRIPT_VALUE_UNREF; newValue->type->alloc(newValue); - lua_pushcclosure(luaContext->lua, _luaThunk, 1); + lua_pushcclosure(lua, _luaThunk, 1); break; case mSCRIPT_TYPE_OBJECT: if (!value->value.opaque) { - lua_pushnil(luaContext->lua); + lua_pushnil(lua); break; } - newValue = lua_newuserdata(luaContext->lua, sizeof(*newValue)); + newValue = lua_newuserdata(lua, sizeof(*newValue)); if (needsWeakref) { *newValue = mSCRIPT_MAKE(WEAKREF, weakref); } else { mScriptValueRef(value); mScriptValueWrap(value, newValue); } - lua_getfield(luaContext->lua, LUA_REGISTRYINDEX, "mSTStruct"); - lua_setmetatable(luaContext->lua, -2); + lua_getfield(lua, LUA_REGISTRYINDEX, "mSTStruct"); + lua_setmetatable(lua, -2); break; default: ok = false; @@ -1032,31 +1032,31 @@ const char* _luaGetError(struct mScriptEngineContext* context) { return luaContext->lastError; } -bool _luaPushFrame(struct mScriptEngineContextLua* luaContext, struct mScriptList* frame) { +bool _luaPushFrame(struct mScriptEngineContextLua* luaContext, lua_State* lua, struct mScriptList* frame) { bool ok = true; if (frame) { size_t i; for (i = 0; i < mScriptListSize(frame); ++i) { struct mScriptValue* value = mScriptListGetPointer(frame, i); - if (!_luaWrap(luaContext, value)) { + if (!_luaWrap(luaContext, lua, value)) { ok = false; break; } } } if (!ok) { - lua_pop(luaContext->lua, lua_gettop(luaContext->lua)); + lua_pop(lua, lua_gettop(lua)); } return ok; } -bool _luaPopFrame(struct mScriptEngineContextLua* luaContext, struct mScriptList* frame) { - int count = lua_gettop(luaContext->lua); +bool _luaPopFrame(struct mScriptEngineContextLua* luaContext, lua_State* lua, struct mScriptList* frame) { + int count = lua_gettop(lua); bool ok = true; if (frame) { int i; for (i = 0; i < count; ++i) { - struct mScriptValue* value = _luaCoerce(luaContext, true); + struct mScriptValue* value = _luaCoerce(luaContext, lua, true); if (!value) { ok = false; break; @@ -1068,7 +1068,7 @@ bool _luaPopFrame(struct mScriptEngineContextLua* luaContext, struct mScriptList } } if (count > i) { - lua_pop(luaContext->lua, count - i); + lua_pop(lua, count - i); } if (ok) { @@ -1127,7 +1127,7 @@ bool _luaInvoke(struct mScriptEngineContextLua* luaContext, struct mScriptFrame* return false; } - if (frame && !_luaPushFrame(luaContext, &frame->arguments)) { + if (frame && !_luaPushFrame(luaContext, luaContext->lua, &frame->arguments)) { mScriptContextDeactivate(luaContext->d.context); return false; } @@ -1151,7 +1151,7 @@ bool _luaInvoke(struct mScriptEngineContextLua* luaContext, struct mScriptFrame* return false; } - if (frame && !_luaPopFrame(luaContext, &frame->returnValues)) { + if (frame && !_luaPopFrame(luaContext, luaContext->lua, &frame->returnValues)) { mScriptContextDrainPool(luaContext->d.context); return false; } @@ -1184,10 +1184,6 @@ static struct mScriptEngineContextLua* _luaGetContext(lua_State* lua) { struct mScriptEngineContextLua* luaContext = lua_touserdata(lua, -1); lua_pop(lua, 1); - if (luaContext->lua != lua) { - lua_pushliteral(lua, "Function called from invalid context"); - lua_error(lua); - } return luaContext; } @@ -1195,7 +1191,7 @@ int _luaThunk(lua_State* lua) { struct mScriptEngineContextLua* luaContext = _luaGetContext(lua); struct mScriptFrame frame; mScriptFrameInit(&frame); - if (!_luaPopFrame(luaContext, &frame.arguments)) { + if (!_luaPopFrame(luaContext, lua, &frame.arguments)) { _freeFrame(&frame.arguments); mScriptContextDrainPool(luaContext->d.context); mScriptFrameDeinit(&frame); @@ -1212,7 +1208,7 @@ int _luaThunk(lua_State* lua) { return lua_error(lua); } - bool ok = _luaPushFrame(luaContext, &frame.returnValues); + bool ok = _luaPushFrame(luaContext, lua, &frame.returnValues); mScriptContextDrainPool(luaContext->d.context); mScriptFrameDeinit(&frame); if (!ok) { @@ -1220,7 +1216,7 @@ int _luaThunk(lua_State* lua) { return lua_error(lua); } - return lua_gettop(luaContext->lua); + return lua_gettop(lua); } int _luaGetObject(lua_State* lua) { @@ -1251,7 +1247,7 @@ int _luaGetObject(lua_State* lua) { return lua_error(lua); } - if (!_luaWrap(luaContext, &val)) { + if (!_luaWrap(luaContext, lua, &val)) { luaL_traceback(lua, lua, "Error translating value from runtime", 1); return lua_error(lua); } @@ -1263,7 +1259,7 @@ int _luaSetObject(lua_State* lua) { char key[MAX_KEY_SIZE]; const char* keyPtr = lua_tostring(lua, -2); struct mScriptValue* obj = lua_touserdata(lua, -3); - struct mScriptValue* val = _luaCoerce(luaContext, true); + struct mScriptValue* val = _luaCoerce(luaContext, lua, true); if (!keyPtr) { lua_pop(lua, 2); @@ -1312,12 +1308,12 @@ static int _luaGcObject(lua_State* lua) { int _luaGetTable(lua_State* lua) { struct mScriptEngineContextLua* luaContext = _luaGetContext(lua); char key[MAX_KEY_SIZE]; - int type = lua_type(luaContext->lua, -1); + int type = lua_type(lua, -1); const char* keyPtr = NULL; int64_t intKey; switch (type) { case LUA_TNUMBER: - intKey = lua_tointeger(luaContext->lua, -1); + intKey = lua_tointeger(lua, -1); break; case LUA_TSTRING: keyPtr = lua_tostring(lua, -1); @@ -1355,7 +1351,7 @@ int _luaGetTable(lua_State* lua) { return 0; } - if (!_luaWrap(luaContext, val)) { + if (!_luaWrap(luaContext, lua, val)) { luaL_traceback(lua, lua, "Error translating value from runtime", 1); return lua_error(lua); } @@ -1378,7 +1374,7 @@ int _luaLenTable(lua_State* lua) { struct mScriptValue val = mSCRIPT_MAKE_U64(mScriptTableSize(obj)); - if (!_luaWrap(luaContext, &val)) { + if (!_luaWrap(luaContext, lua, &val)) { luaL_traceback(lua, lua, "Error translating value from runtime", 1); return lua_error(lua); } @@ -1388,12 +1384,12 @@ int _luaLenTable(lua_State* lua) { static int _luaNextTable(lua_State* lua) { struct mScriptEngineContextLua* luaContext = _luaGetContext(lua); char key[MAX_KEY_SIZE]; - int type = lua_type(luaContext->lua, -1); + int type = lua_type(lua, -1); const char* keyPtr = NULL; struct mScriptValue keyVal = {0}; switch (type) { case LUA_TNUMBER: - keyVal = mSCRIPT_MAKE_S64(lua_tointeger(luaContext->lua, -1)); + keyVal = mSCRIPT_MAKE_S64(lua_tointeger(lua, -1)); break; case LUA_TSTRING: keyPtr = lua_tostring(lua, -1); @@ -1429,12 +1425,12 @@ static int _luaNextTable(lua_State* lua) { } } - if (!_luaWrap(luaContext, mScriptTableIteratorGetKey(table, &iter))) { + if (!_luaWrap(luaContext, lua, mScriptTableIteratorGetKey(table, &iter))) { luaL_traceback(lua, lua, "Iteration error", 1); return lua_error(lua); } - if (!_luaWrap(luaContext, mScriptTableIteratorGetValue(table, &iter))) { + if (!_luaWrap(luaContext, lua, mScriptTableIteratorGetValue(table, &iter))) { luaL_traceback(lua, lua, "Iteration error", 1); return lua_error(lua); } @@ -1453,9 +1449,9 @@ int _luaGetList(lua_State* lua) { struct mScriptEngineContextLua* luaContext = _luaGetContext(lua); ssize_t index; #if LUA_VERSION_NUM >= 503 - index = lua_tointeger(luaContext->lua, -1); + index = lua_tointeger(lua, -1); #else - index = lua_tonumber(luaContext->lua, -1); + index = lua_tonumber(lua, -1); #endif struct mScriptValue* obj = lua_touserdata(lua, -2); lua_pop(lua, 2); @@ -1481,7 +1477,7 @@ int _luaGetList(lua_State* lua) { --index; struct mScriptValue* val = mScriptListGetPointer(list, index); - if (!_luaWrap(luaContext, val)) { + if (!_luaWrap(luaContext, lua, val)) { luaL_traceback(lua, lua, "Error translating value from runtime", 1); return lua_error(lua); } @@ -1509,21 +1505,21 @@ static int _luaLenList(lua_State* lua) { static int _luaRequireShim(lua_State* lua) { struct mScriptEngineContextLua* luaContext = _luaGetContext(lua); - int oldtop = lua_gettop(luaContext->lua); + int oldtop = lua_gettop(lua); const char* path = lua_tostring(lua, lua_upvalueindex(1)); - lua_getglobal(luaContext->lua, "package"); + lua_getglobal(lua, "package"); - lua_pushliteral(luaContext->lua, "path"); - lua_pushstring(luaContext->lua, path); - lua_pushliteral(luaContext->lua, "/?.lua;"); - lua_pushstring(luaContext->lua, path); - lua_pushliteral(luaContext->lua, "/?/init.lua;"); - lua_pushliteral(luaContext->lua, "path"); - lua_gettable(luaContext->lua, -7); - char* oldpath = strdup(lua_tostring(luaContext->lua, -1)); - lua_concat(luaContext->lua, 5); - lua_settable(luaContext->lua, -3); + lua_pushliteral(lua, "path"); + lua_pushstring(lua, path); + lua_pushliteral(lua, "/?.lua;"); + lua_pushstring(lua, path); + lua_pushliteral(lua, "/?/init.lua;"); + lua_pushliteral(lua, "path"); + lua_gettable(lua, -7); + char* oldpath = strdup(lua_tostring(lua, -1)); + lua_concat(lua, 5); + lua_settable(lua, -3); #ifdef _WIN32 #define DLL "dll" @@ -1532,42 +1528,42 @@ static int _luaRequireShim(lua_State* lua) { #else #define DLL "so" #endif - lua_pushliteral(luaContext->lua, "cpath"); - lua_pushstring(luaContext->lua, path); - lua_pushliteral(luaContext->lua, "/?." DLL ";"); - lua_pushstring(luaContext->lua, path); - lua_pushliteral(luaContext->lua, "/?/init." DLL ";"); - lua_pushliteral(luaContext->lua, "cpath"); - lua_gettable(luaContext->lua, -7); - char* oldcpath = strdup(lua_tostring(luaContext->lua, -1)); - lua_concat(luaContext->lua, 5); - lua_settable(luaContext->lua, -3); + lua_pushliteral(lua, "cpath"); + lua_pushstring(lua, path); + lua_pushliteral(lua, "/?." DLL ";"); + lua_pushstring(lua, path); + lua_pushliteral(lua, "/?/init." DLL ";"); + lua_pushliteral(lua, "cpath"); + lua_gettable(lua, -7); + char* oldcpath = strdup(lua_tostring(lua, -1)); + lua_concat(lua, 5); + lua_settable(lua, -3); - lua_pop(luaContext->lua, 1); + lua_pop(lua, 1); - lua_rawgeti(luaContext->lua, LUA_REGISTRYINDEX, luaContext->require); - lua_insert(luaContext->lua, -2); - int ret = lua_pcall(luaContext->lua, 1, LUA_MULTRET, 0); + lua_rawgeti(lua, LUA_REGISTRYINDEX, luaContext->require); + lua_insert(lua, -2); + int ret = lua_pcall(lua, 1, LUA_MULTRET, 0); - lua_getglobal(luaContext->lua, "package"); + lua_getglobal(lua, "package"); - lua_pushliteral(luaContext->lua, "path"); - lua_pushstring(luaContext->lua, oldpath); - lua_settable(luaContext->lua, -3); + lua_pushliteral(lua, "path"); + lua_pushstring(lua, oldpath); + lua_settable(lua, -3); - lua_pushliteral(luaContext->lua, "cpath"); - lua_pushstring(luaContext->lua, oldcpath); - lua_settable(luaContext->lua, -3); + lua_pushliteral(lua, "cpath"); + lua_pushstring(lua, oldcpath); + lua_settable(lua, -3); - lua_pop(luaContext->lua, 1); + lua_pop(lua, 1); free(oldpath); free(oldcpath); if (ret) { - return lua_error(luaContext->lua); + return lua_error(lua); } - int newtop = lua_gettop(luaContext->lua); + int newtop = lua_gettop(lua); return newtop - oldtop + 1; } From 5ff777d301d0d674b124eac0cf56021997078c3a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 2 Apr 2024 22:53:02 -0700 Subject: [PATCH 032/338] Scripting: Add overloads, overload isKeyActive --- include/mgba/script/macros.h | 84 +++++++++++++++++++++++++++++++----- include/mgba/script/types.h | 10 ++++- src/script/context.c | 2 +- src/script/input.c | 45 ++++++++----------- src/script/test/classes.c | 67 +++++++++++++++++++++++++++- src/script/test/input.c | 38 ++++++++++++++++ src/script/test/types.c | 12 +++--- src/script/types.c | 46 +++++++++++++++----- src/tools/docgen.c | 8 ++++ 9 files changed, 256 insertions(+), 56 deletions(-) diff --git a/include/mgba/script/macros.h b/include/mgba/script/macros.h index 4acf7591ac6..7d2057d4e4f 100644 --- a/include/mgba/script/macros.h +++ b/include/mgba/script/macros.h @@ -254,7 +254,7 @@ CXX_GUARD_START return false; \ } -#define _mSCRIPT_DECLARE_STRUCT_METHOD(TYPE, NAME, S, NRET, RETURN, NPARAMS, DEFAULTS, ...) \ +#define _mSCRIPT_DECLARE_STRUCT_METHOD_HEAD(TYPE, NAME) \ static bool _mSTStructBinding_ ## TYPE ## _ ## NAME(struct mScriptFrame* frame, void* ctx); \ static const struct mScriptFunction _mSTStructBindingFunction_ ## TYPE ## _ ## NAME = { \ .call = &_mSTStructBinding_ ## TYPE ## _ ## NAME \ @@ -269,6 +269,9 @@ CXX_GUARD_START .alloc = _mSTStructBindingAlloc_ ## TYPE ## _ ## NAME, \ .details = { \ .function = { \ + +#define _mSCRIPT_DECLARE_STRUCT_METHOD(TYPE, NAME, S, NRET, RETURN, NPARAMS, DEFAULTS, ...) \ + _mSCRIPT_DECLARE_STRUCT_METHOD_HEAD(TYPE, NAME) \ .parameters = { \ .count = _mSUCC_ ## NPARAMS, \ .entries = { mSCRIPT_TYPE_MS_ ## S(TYPE), _mCALL(mSCRIPT_PREFIX_ ## NPARAMS, mSCRIPT_TYPE_MS_, _mEVEN_ ## NPARAMS(__VA_ARGS__)) }, \ @@ -283,6 +286,23 @@ CXX_GUARD_START } \ }; +#define _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD(TYPE, NAME, S, NRET, RETURN) \ + _mSCRIPT_DECLARE_STRUCT_METHOD_HEAD(TYPE, NAME) \ + .parameters = { \ + .count = 1, \ + .entries = { mSCRIPT_TYPE_MS_ ## S(TYPE) }, \ + .names = { "this" }, \ + .defaults = NULL, \ + .variable = true, \ + }, \ + .returnType = { \ + .count = NRET, \ + .entries = { RETURN } \ + }, \ + }, \ + } \ + }; + #define _mSCRIPT_DECLARE_STRUCT_METHOD_SIGNATURE(TYPE, RETURN, NAME, CONST, NPARAMS, ...) \ typedef RETURN (*_mSTStructFunctionType_ ## TYPE ## _ ## NAME)(_mCOMMA_ ## NPARAMS(CONST struct TYPE* , mSCRIPT_PREFIX_ ## NPARAMS(mSCRIPT_TYPE_C_, __VA_ARGS__))) @@ -302,6 +322,20 @@ CXX_GUARD_START return true; \ } \ +#define _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD_BINDING(TYPE, NAME, T) \ + static const struct mScriptFunctionOverload _mSTStructBindingOverloads_ ## TYPE ## _ ## NAME[]; \ + static bool _mSTStructBinding_ ## TYPE ## _ ## NAME(struct mScriptFrame* frame, void* ctx) { \ + UNUSED(ctx); \ + const struct mScriptFunctionOverload* overload = mScriptFunctionFindOverload(_mSTStructBindingOverloads_ ## TYPE ## _ ## NAME, &frame->arguments); \ + if (!overload) { \ + return false; \ + } \ + if (!mScriptCoerceFrame(&overload->type->details.function.parameters, &frame->arguments, &frame->arguments)) { \ + return false; \ + } \ + return overload->function->call(frame, overload->function->context); \ + } + #define mSCRIPT_DECLARE_STRUCT_METHOD(TYPE, RETURN, NAME, FUNCTION, NPARAMS, ...) \ _mSCRIPT_DECLARE_STRUCT_METHOD_SIGNATURE(TYPE, mSCRIPT_TYPE_C_ ## RETURN, NAME, , NPARAMS, _mEVEN_ ## NPARAMS(__VA_ARGS__)); \ _mSCRIPT_DECLARE_STRUCT_METHOD(TYPE, NAME, S, 1, mSCRIPT_TYPE_MS_ ## RETURN, NPARAMS, NULL, __VA_ARGS__) \ @@ -346,6 +380,22 @@ CXX_GUARD_START _mSCRIPT_DECLARE_STRUCT_METHOD(TYPE, NAME, CS, 0, 0, NPARAMS, _mIDENT(_mSTStructBindingDefaults_ ## TYPE ## _ ## NAME, __VA_ARGS__) \ _mSCRIPT_DECLARE_STRUCT_VOID_METHOD_BINDING(TYPE, NAME, FUNCTION, CS, NPARAMS, __VA_ARGS__) +#define mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD(TYPE, RETURN, NAME) \ + _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD(TYPE, NAME, S, 1, mSCRIPT_TYPE_MS_ ## RETURN) \ + _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD_BINDING(TYPE, NAME, S) + +#define mSCRIPT_DECLARE_STRUCT_OVERLOADED_VOID_METHOD(TYPE, NAME) \ + _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD(TYPE, NAME, S, 0, 0) \ + _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD_BINDING(TYPE, NAME, S) + +#define mSCRIPT_DECLARE_STRUCT_OVERLOADED_C_METHOD(TYPE, RETURN, NAME) \ + _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD(TYPE, NAME, CS, 1, mSCRIPT_TYPE_MS_ ## RETURN) \ + _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD_BINDING(TYPE, NAME, CS) + +#define mSCRIPT_DECLARE_STRUCT_OVERLOADED_VOID_C_METHOD(TYPE, NAME) \ + _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD(TYPE, NAME, CS, 0, 0) \ + _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD_BINDING(TYPE, NAME, CS) + #define mSCRIPT_DECLARE_STRUCT_D_METHOD(TYPE, RETURN, NAME, NPARAMS, ...) \ mSCRIPT_DECLARE_STRUCT_METHOD(TYPE, RETURN, NAME, p0->NAME, NPARAMS, __VA_ARGS__) @@ -417,27 +467,39 @@ CXX_GUARD_START #define mSCRIPT_DEFINE_DEFAULTS_END } -#define _mSCRIPT_DEFINE_STRUCT_BINDING(INIT_TYPE, TYPE, EXPORTED_NAME, NAME) { \ +#define mSCRIPT_DEFINE_STRUCT_METHOD_OVERLOADS(STRUCT, METHOD) \ + static const struct mScriptFunctionOverload _mSTStructBindingOverloads_ ## STRUCT ## _ ## METHOD[] = { \ + +#define mSCRIPT_DEFINE_STRUCT_METHOD_OVERLOAD(TYPE, FUNCTION) { \ + .type = &_mSTStructBindingType_ ## TYPE ## _ ## FUNCTION, \ + .function = &_mSTStructBindingFunction_ ## TYPE ## _ ## FUNCTION \ +}, + +#define mSCRIPT_DEFINE_OVERLOADS_END { NULL, NULL } } + +#define _mSCRIPT_DEFINE_STRUCT_BINDING(INIT_TYPE, TYPE, EXPORTED_NAME, NAME, OVERLOADS) { \ .type = mSCRIPT_CLASS_INIT_ ## INIT_TYPE, \ .info = { \ .member = { \ .name = #EXPORTED_NAME, \ - .type = &_mSTStructBindingType_ ## TYPE ## _ ## NAME \ + .type = &_mSTStructBindingType_ ## TYPE ## _ ## NAME, \ + .overloads = OVERLOADS, \ } \ }, \ }, #define mSCRIPT_DEFINE_STRUCT_METHOD_NAMED(TYPE, EXPORTED_NAME, NAME) \ - _mSCRIPT_DEFINE_STRUCT_BINDING(INSTANCE_MEMBER, TYPE, EXPORTED_NAME, NAME) + _mSCRIPT_DEFINE_STRUCT_BINDING(INSTANCE_MEMBER, TYPE, EXPORTED_NAME, NAME, NULL) #define mSCRIPT_DEFINE_STRUCT_METHOD(TYPE, NAME) mSCRIPT_DEFINE_STRUCT_METHOD_NAMED(TYPE, NAME, NAME) - -#define mSCRIPT_DEFINE_STRUCT_INIT(TYPE) _mSCRIPT_DEFINE_STRUCT_BINDING(INIT, TYPE, _init, _init) -#define mSCRIPT_DEFINE_STRUCT_INIT_NAMED(TYPE, NAME) _mSCRIPT_DEFINE_STRUCT_BINDING(INIT, TYPE, _init, NAME) -#define mSCRIPT_DEFINE_STRUCT_DEINIT(TYPE) _mSCRIPT_DEFINE_STRUCT_BINDING(DEINIT, TYPE, _deinit, _deinit) -#define mSCRIPT_DEFINE_STRUCT_DEINIT_NAMED(TYPE, NAME) _mSCRIPT_DEFINE_STRUCT_BINDING(DEINIT, TYPE, _deinit, NAME) -#define mSCRIPT_DEFINE_STRUCT_DEFAULT_GET(TYPE) _mSCRIPT_DEFINE_STRUCT_BINDING(GET, TYPE, _get, _get) -#define mSCRIPT_DEFINE_STRUCT_DEFAULT_SET(TYPE, SETTER) _mSCRIPT_DEFINE_STRUCT_BINDING(SET, TYPE, SETTER, SETTER) +#define mSCRIPT_DEFINE_STRUCT_OVERLOADED_METHOD(TYPE, NAME) _mSCRIPT_DEFINE_STRUCT_BINDING(INSTANCE_MEMBER, TYPE, NAME, NAME, _mSTStructBindingOverloads_ ## TYPE ## _ ## NAME) + +#define mSCRIPT_DEFINE_STRUCT_INIT(TYPE) _mSCRIPT_DEFINE_STRUCT_BINDING(INIT, TYPE, _init, _init, NULL) +#define mSCRIPT_DEFINE_STRUCT_INIT_NAMED(TYPE, NAME) _mSCRIPT_DEFINE_STRUCT_BINDING(INIT, TYPE, _init, NAME, NULL) +#define mSCRIPT_DEFINE_STRUCT_DEINIT(TYPE) _mSCRIPT_DEFINE_STRUCT_BINDING(DEINIT, TYPE, _deinit, _deinit, NULL) +#define mSCRIPT_DEFINE_STRUCT_DEINIT_NAMED(TYPE, NAME) _mSCRIPT_DEFINE_STRUCT_BINDING(DEINIT, TYPE, _deinit, NAME, NULL) +#define mSCRIPT_DEFINE_STRUCT_DEFAULT_GET(TYPE) _mSCRIPT_DEFINE_STRUCT_BINDING(GET, TYPE, _get, _get, NULL) +#define mSCRIPT_DEFINE_STRUCT_DEFAULT_SET(TYPE, SETTER) _mSCRIPT_DEFINE_STRUCT_BINDING(SET, TYPE, SETTER, SETTER, NULL) #define mSCRIPT_DEFINE_DOC_STRUCT_METHOD(SCOPE, TYPE, NAME) mSCRIPT_DEFINE_STRUCT_METHOD_NAMED(doc_ ## TYPE, NAME, NAME) diff --git a/include/mgba/script/types.h b/include/mgba/script/types.h index 1475f1a6ec6..5770456e6b5 100644 --- a/include/mgba/script/types.h +++ b/include/mgba/script/types.h @@ -259,6 +259,7 @@ struct mScriptClassMember { const char* name; const char* docstring; const struct mScriptType* type; + const struct mScriptFunctionOverload* overloads; size_t offset; bool readonly; }; @@ -275,6 +276,7 @@ struct mScriptClassInitDetails { const struct mScriptType* parent; struct mScriptClassMember member; struct mScriptClassCastMember castMember; + const struct mScriptFunctionOverload* overload; } info; }; @@ -332,6 +334,11 @@ struct mScriptFunction { void* context; }; +struct mScriptFunctionOverload { + const struct mScriptType* type; + const struct mScriptFunction* function; +}; + struct mScriptValue* mScriptValueAlloc(const struct mScriptType* type); void mScriptValueRef(struct mScriptValue* val); void mScriptValueDeref(struct mScriptValue* val); @@ -385,7 +392,8 @@ bool mScriptPopBool(struct mScriptList* list, bool* out); bool mScriptPopPointer(struct mScriptList* list, void** out); bool mScriptCast(const struct mScriptType* type, const struct mScriptValue* input, struct mScriptValue* output); -bool mScriptCoerceFrame(const struct mScriptTypeTuple* types, struct mScriptList* frame); +bool mScriptCoerceFrame(const struct mScriptTypeTuple* types, const struct mScriptList* input, struct mScriptList* output); +const struct mScriptFunctionOverload* mScriptFunctionFindOverload(const struct mScriptFunctionOverload* overloads, struct mScriptList* frame); CXX_GUARD_END diff --git a/src/script/context.c b/src/script/context.c index 090daf66d2a..47a4460f6e2 100644 --- a/src/script/context.c +++ b/src/script/context.c @@ -481,7 +481,7 @@ bool mScriptInvoke(const struct mScriptValue* val, struct mScriptFrame* frame) { return false; } const struct mScriptTypeFunction* signature = &val->type->details.function; - if (!mScriptCoerceFrame(&signature->parameters, &frame->arguments)) { + if (!mScriptCoerceFrame(&signature->parameters, &frame->arguments, &frame->arguments)) { return false; } const struct mScriptFunction* fn = val->value.opaque; diff --git a/src/script/input.c b/src/script/input.c index c103fa82cd8..1cb9f488b81 100644 --- a/src/script/input.c +++ b/src/script/input.c @@ -35,20 +35,28 @@ struct mScriptInputContext { }; static void _mScriptInputDeinit(struct mScriptInputContext*); -static bool _mScriptInputIsKeyActive(const struct mScriptInputContext*, struct mScriptValue*); +static bool _mScriptInputIsKeyActiveStr(const struct mScriptInputContext*, const char*); +static bool _mScriptInputIsKeyActiveNum(const struct mScriptInputContext*, uint32_t); static struct mScriptValue* _mScriptInputActiveKeys(const struct mScriptInputContext*); mSCRIPT_DECLARE_STRUCT(mScriptInputContext); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptInputContext, _deinit, _mScriptInputDeinit, 0); -mSCRIPT_DECLARE_STRUCT_C_METHOD(mScriptInputContext, BOOL, isKeyActive, _mScriptInputIsKeyActive, 1, WRAPPER, key); +mSCRIPT_DECLARE_STRUCT_C_METHOD(mScriptInputContext, BOOL, isKeyActiveStr, _mScriptInputIsKeyActiveStr, 1, CHARP, key); +mSCRIPT_DECLARE_STRUCT_C_METHOD(mScriptInputContext, BOOL, isKeyActiveNum, _mScriptInputIsKeyActiveNum, 1, U32, key); +mSCRIPT_DECLARE_STRUCT_OVERLOADED_C_METHOD(mScriptInputContext, BOOL, isKeyActive); mSCRIPT_DECLARE_STRUCT_C_METHOD(mScriptInputContext, WLIST, activeKeys, _mScriptInputActiveKeys, 0); +mSCRIPT_DEFINE_STRUCT_METHOD_OVERLOADS(mScriptInputContext, isKeyActive) + mSCRIPT_DEFINE_STRUCT_METHOD_OVERLOAD(mScriptInputContext, isKeyActiveStr) + mSCRIPT_DEFINE_STRUCT_METHOD_OVERLOAD(mScriptInputContext, isKeyActiveNum) +mSCRIPT_DEFINE_OVERLOADS_END; + mSCRIPT_DEFINE_STRUCT(mScriptInputContext) mSCRIPT_DEFINE_STRUCT_DEINIT(mScriptInputContext) mSCRIPT_DEFINE_DOCSTRING("Sequence number of the next event to be emitted") mSCRIPT_DEFINE_STRUCT_MEMBER(mScriptInputContext, U64, seq) mSCRIPT_DEFINE_DOCSTRING("Check if a given keyboard key is currently held. The input can be either the printable character for a key, the numerical Unicode codepoint, or a special value from C.KEY") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptInputContext, isKeyActive) + mSCRIPT_DEFINE_STRUCT_OVERLOADED_METHOD(mScriptInputContext, isKeyActive) mSCRIPT_DEFINE_DOCSTRING("Get a list of the currently active keys. The values are Unicode codepoints or special key values from C.KEY, not strings, so make sure to convert as needed") mSCRIPT_DEFINE_STRUCT_METHOD(mScriptInputContext, activeKeys) mSCRIPT_DEFINE_DOCSTRING("The currently active gamepad, if any") @@ -319,33 +327,18 @@ void _mScriptInputDeinit(struct mScriptInputContext* context) { TableDeinit(&context->activeKeys); } -bool _mScriptInputIsKeyActive(const struct mScriptInputContext* context, struct mScriptValue* value) { +bool _mScriptInputIsKeyActiveStr(const struct mScriptInputContext* context, const char* value) { uint32_t key; - struct mScriptValue intValue; - size_t length; - const char* strbuf; - - switch (value->type->base) { - case mSCRIPT_TYPE_SINT: - case mSCRIPT_TYPE_UINT: - case mSCRIPT_TYPE_FLOAT: - if (!mScriptCast(mSCRIPT_TYPE_MS_U32, value, &intValue)) { - return false; - } - key = intValue.value.u32; - break; - case mSCRIPT_TYPE_STRING: - if (value->value.string->length > 1) { - return false; - } - strbuf = value->value.string->buffer; - length = value->value.string->size; - key = utf8Char(&strbuf, &length); - break; - default: + size_t length = strlen(value); + key = utf8Char(&value, &length); + if (length > 0) { return false; } + void* down = TableLookup(&context->activeKeys, key); + return down != NULL; +} +bool _mScriptInputIsKeyActiveNum(const struct mScriptInputContext* context, uint32_t key) { void* down = TableLookup(&context->activeKeys, key); return down != NULL; } diff --git a/src/script/test/classes.c b/src/script/test/classes.c index f7c5eb12871..e0ce39d47a5 100644 --- a/src/script/test/classes.c +++ b/src/script/test/classes.c @@ -57,6 +57,11 @@ struct TestH { int32_t j; }; +struct TestI { + uint32_t num; + const char* str; +}; + static int32_t testAi0(struct TestA* a) { return a->i; } @@ -114,6 +119,14 @@ static void testSetC(struct TestG* g, const char* name, const char* val) { g->c = val; } +static void callNum(struct TestI* i, uint32_t num) { + i->num = num; +} + +static void callStr(struct TestI* i, const char* str) { + i->str = str; +} + #define MEMBER_A_DOCSTRING "Member a" mSCRIPT_DECLARE_STRUCT(TestA); @@ -201,12 +214,25 @@ mSCRIPT_DEFINE_STRUCT(TestG) mSCRIPT_DEFINE_STRUCT_DEFAULT_SET(TestG, setC) mSCRIPT_DEFINE_END; - mSCRIPT_DEFINE_STRUCT(TestH) mSCRIPT_DEFINE_STRUCT_MEMBER(TestH, S32, i) mSCRIPT_DEFINE_STRUCT_CONST_MEMBER(TestH, S32, j) mSCRIPT_DEFINE_END; +mSCRIPT_DECLARE_STRUCT(TestI); +mSCRIPT_DECLARE_STRUCT_VOID_METHOD(TestI, callStr, callStr, 1, CHARP, value); +mSCRIPT_DECLARE_STRUCT_VOID_METHOD(TestI, callNum, callNum, 1, U32, value); +mSCRIPT_DECLARE_STRUCT_OVERLOADED_VOID_METHOD(TestI, call); + +mSCRIPT_DEFINE_STRUCT_METHOD_OVERLOADS(TestI, call) + mSCRIPT_DEFINE_STRUCT_METHOD_OVERLOAD(TestI, callStr) + mSCRIPT_DEFINE_STRUCT_METHOD_OVERLOAD(TestI, callNum) +mSCRIPT_DEFINE_OVERLOADS_END; + +mSCRIPT_DEFINE_STRUCT(TestI) + mSCRIPT_DEFINE_STRUCT_OVERLOADED_METHOD(TestI, call) +mSCRIPT_DEFINE_END; + M_TEST_DEFINE(testALayout) { struct mScriptTypeClass* cls = mSCRIPT_TYPE_MS_S(TestA)->details.cls; assert_false(cls->init); @@ -1184,6 +1210,44 @@ M_TEST_DEFINE(testHSet) { assert_false(cls->init); } +M_TEST_DEFINE(testOverloadsBasic) { + struct mScriptTypeClass* cls = mSCRIPT_TYPE_MS_S(TestI)->details.cls; + assert_false(cls->init); + mScriptClassInit(cls); + assert_true(cls->init); + + struct TestI s = { + .num = 0, + .str = NULL, + }; + + struct mScriptValue sval = mSCRIPT_MAKE_S(TestI, &s); + struct mScriptValue fn; + struct mScriptFrame frame; + + assert_true(mScriptObjectGet(&sval, "call", &fn)); + + mScriptFrameInit(&frame); + mSCRIPT_PUSH(&frame.arguments, S(TestI), &s); + mSCRIPT_PUSH(&frame.arguments, U32, 1); + assert_true(mScriptInvoke(&fn, &frame)); + mScriptFrameDeinit(&frame); + assert_int_equal(s.num, 1); + assert_null(s.str); + + mScriptFrameInit(&frame); + mSCRIPT_PUSH(&frame.arguments, S(TestI), &s); + mSCRIPT_PUSH(&frame.arguments, CHARP, "called"); + assert_true(mScriptInvoke(&fn, &frame)); + mScriptFrameDeinit(&frame); + assert_int_equal(s.num, 1); + assert_string_equal(s.str, "called"); + + assert_true(cls->init); + mScriptClassDeinit(cls); + assert_false(cls->init); +} + M_TEST_SUITE_DEFINE(mScriptClasses, cmocka_unit_test(testALayout), cmocka_unit_test(testASignatures), @@ -1201,4 +1265,5 @@ M_TEST_SUITE_DEFINE(mScriptClasses, cmocka_unit_test(testFDeinit), cmocka_unit_test(testGSet), cmocka_unit_test(testHSet), + cmocka_unit_test(testOverloadsBasic), ) diff --git a/src/script/test/input.c b/src/script/test/input.c index 4c689a6efa5..641e1c6ab37 100644 --- a/src/script/test/input.c +++ b/src/script/test/input.c @@ -172,6 +172,43 @@ M_TEST_DEFINE(clearKeys) { mScriptContextDeinit(&context); } +M_TEST_DEFINE(numericKeys) { + SETUP_LUA; + + TEST_PROGRAM("assert(not input:isKeyActive(C.KEY.F1))"); + + TEST_PROGRAM( + "activeKey = false\n" + "state = nil\n" + "function cb(ev)\n" + " assert(ev.type == C.EV_TYPE.KEY)\n" + " activeKey = ev.key\n" + " state = ev.state\n" + "end\n" + "id = callbacks:add('key', cb)\n" + "assert(id)\n" + "assert(not activeKey)\n" + ); + + struct mScriptKeyEvent keyEvent = { + .d = { .type = mSCRIPT_EV_TYPE_KEY }, + .state = mSCRIPT_INPUT_STATE_DOWN, + .key = mSCRIPT_KEY_F1 + }; + mScriptContextFireEvent(&context, &keyEvent.d); + + TEST_PROGRAM("assert(input:isKeyActive(C.KEY.F1))"); + TEST_PROGRAM("assert(activeKey == C.KEY.F1)"); + TEST_PROGRAM("assert(state == C.INPUT_STATE.DOWN)"); + + keyEvent.state = mSCRIPT_INPUT_STATE_UP; + mScriptContextFireEvent(&context, &keyEvent.d); + + TEST_PROGRAM("assert(not input:isKeyActive(C.KEY.F1))"); + TEST_PROGRAM("assert(state == C.INPUT_STATE.UP)"); + + mScriptContextDeinit(&context); +} M_TEST_DEFINE(gamepadExport) { SETUP_LUA; @@ -219,5 +256,6 @@ M_TEST_SUITE_DEFINE_SETUP_TEARDOWN(mScriptInput, cmocka_unit_test(fireKey), cmocka_unit_test(activeKeys), cmocka_unit_test(clearKeys), + cmocka_unit_test(numericKeys), cmocka_unit_test(gamepadExport), ) diff --git a/src/script/test/types.c b/src/script/test/types.c index 5c66b3f7693..67b6fba9a54 100644 --- a/src/script/test/types.c +++ b/src/script/test/types.c @@ -372,25 +372,25 @@ M_TEST_DEFINE(wrongConst) { mScriptFrameInit(&frame); mSCRIPT_PUSH(&frame.arguments, S(Test), &a); signature.entries[0] = mSCRIPT_TYPE_MS_S(Test); - assert_true(mScriptCoerceFrame(&signature, &frame.arguments)); + assert_true(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); mSCRIPT_PUSH(&frame.arguments, CS(Test), &a); signature.entries[0] = mSCRIPT_TYPE_MS_CS(Test); - assert_true(mScriptCoerceFrame(&signature, &frame.arguments)); + assert_true(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); mSCRIPT_PUSH(&frame.arguments, S(Test), &a); signature.entries[0] = mSCRIPT_TYPE_MS_CS(Test); - assert_true(mScriptCoerceFrame(&signature, &frame.arguments)); + assert_true(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); mSCRIPT_PUSH(&frame.arguments, CS(Test), &a); signature.entries[0] = mSCRIPT_TYPE_MS_S(Test); - assert_false(mScriptCoerceFrame(&signature, &frame.arguments)); + assert_false(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); @@ -402,7 +402,7 @@ M_TEST_DEFINE(wrongConst) { mSCRIPT_PUSH(&frame.arguments, S(Test), &a); assert_false(mScriptPopCSTest(&frame.arguments, &cb)); signature.entries[0] = mSCRIPT_TYPE_MS_CS(Test); - assert_true(mScriptCoerceFrame(&signature, &frame.arguments)); + assert_true(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); assert_true(mScriptPopCSTest(&frame.arguments, &cb)); mScriptFrameDeinit(&frame); @@ -410,7 +410,7 @@ M_TEST_DEFINE(wrongConst) { mSCRIPT_PUSH(&frame.arguments, CS(Test), &a); assert_false(mScriptPopSTest(&frame.arguments, &b)); signature.entries[0] = mSCRIPT_TYPE_MS_S(Test); - assert_false(mScriptCoerceFrame(&signature, &frame.arguments)); + assert_false(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); assert_false(mScriptPopSTest(&frame.arguments, &b)); mScriptFrameDeinit(&frame); diff --git a/src/script/types.c b/src/script/types.c index 20f9458397c..d860d40c0c3 100644 --- a/src/script/types.c +++ b/src/script/types.c @@ -1238,6 +1238,9 @@ static void _mScriptClassInit(struct mScriptTypeClass* cls, const struct mScript member->docstring = docstring; docstring = NULL; } + if (detail->info.member.type->base != mSCRIPT_TYPE_FUNCTION) { + abort(); + } if (detail->info.member.type->details.function.parameters.count != 3) { abort(); } @@ -1773,21 +1776,24 @@ bool mScriptCast(const struct mScriptType* type, const struct mScriptValue* inpu return false; } -bool mScriptCoerceFrame(const struct mScriptTypeTuple* types, struct mScriptList* frame) { - if (types->count < mScriptListSize(frame) && !types->variable) { +bool mScriptCoerceFrame(const struct mScriptTypeTuple* types, const struct mScriptList* input, struct mScriptList* output) { + if (types->count < mScriptListSize(input) && !types->variable) { return false; } - if (types->count > mScriptListSize(frame) && !types->variable && !types->defaults) { + if (types->count > mScriptListSize(input) && !types->variable && !types->defaults) { return false; } + if (output) { + mScriptListResize(output, mScriptListSize(input) - mScriptListSize(output)); + } size_t i; - for (i = 0; i < mScriptListSize(frame) && i < types->count; ++i) { - if (types->entries[i] == mScriptListGetPointer(frame, i)->type) { + for (i = 0; i < mScriptListSize(input) && i < types->count; ++i) { + if (types->entries[i] == mScriptListGetConstPointer(input, i)->type) { continue; } - struct mScriptValue* unwrapped = NULL; - if (mScriptListGetPointer(frame, i)->type->base == mSCRIPT_TYPE_WRAPPER) { - unwrapped = mScriptValueUnwrap(mScriptListGetPointer(frame, i)); + const struct mScriptValue* unwrapped = NULL; + if (mScriptListGetConstPointer(input, i)->type->base == mSCRIPT_TYPE_WRAPPER) { + unwrapped = mScriptValueUnwrapConst(mScriptListGetConstPointer(input, i)); if (types->entries[i]->base == mSCRIPT_TYPE_WRAPPER) { if (types->entries[i]->details.type == unwrapped->type) { continue; @@ -1796,7 +1802,12 @@ bool mScriptCoerceFrame(const struct mScriptTypeTuple* types, struct mScriptList continue; } } - if (!mScriptCast(types->entries[i], mScriptListGetPointer(frame, i), mScriptListGetPointer(frame, i))) { + struct mScriptValue fakeVal; + struct mScriptValue* castTo = &fakeVal; + if (output) { + castTo = mScriptListGetPointer(output, i); + } + if (!mScriptCast(types->entries[i], mScriptListGetConstPointer(input, i), castTo)) { return false; } } @@ -1808,11 +1819,26 @@ bool mScriptCoerceFrame(const struct mScriptTypeTuple* types, struct mScriptList if (!types->defaults[i].type) { return false; } - memcpy(mScriptListAppend(frame), &types->defaults[i], sizeof(struct mScriptValue)); + if (output) { + memcpy(mScriptListAppend(output), &types->defaults[i], sizeof(struct mScriptValue)); + } } return true; } +const struct mScriptFunctionOverload* mScriptFunctionFindOverload(const struct mScriptFunctionOverload* overloads, struct mScriptList* frame) { + size_t i; + for (i = 0; overloads[i].type; ++i) { + if (overloads[i].type->base != mSCRIPT_TYPE_FUNCTION) { + continue; + } + if (mScriptCoerceFrame(&overloads[i].type->details.function.parameters, frame, NULL)) { + return &overloads[i]; + } + } + return NULL; +} + static void addTypesFromTuple(struct Table* types, const struct mScriptTypeTuple* tuple) { size_t i; for (i = 0; i < tuple->count; ++i) { diff --git a/src/tools/docgen.c b/src/tools/docgen.c index f57fb8d4428..cdabb472c77 100644 --- a/src/tools/docgen.c +++ b/src/tools/docgen.c @@ -190,6 +190,14 @@ void explainClass(struct mScriptTypeClass* cls, int level) { fprintf(out, "%s readonly: true\n", indent); } fprintf(out, "%s type: %s\n", indent, details->info.member.type->name); + if (details->info.member.overloads) { + fprintf(out, "%s overloads:\n", indent); + size_t i; + for (i = 0; details->info.member.overloads[i].type; ++i) { + mScriptTypeAdd(&types, details->info.member.overloads[i].type); + fprintf(out, "%s - %s\n", indent, details->info.member.overloads[i].type->name); + } + } break; case mSCRIPT_CLASS_INIT_END: break; From fb7ad7dbfb281478e362e944bb07f453740b7eb2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 3 Apr 2024 02:55:59 -0700 Subject: [PATCH 033/338] Qt: Actually load defaults again --- src/platform/qt/InputController.cpp | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/platform/qt/InputController.cpp b/src/platform/qt/InputController.cpp index d5e799b5a90..3deca07f392 100644 --- a/src/platform/qt/InputController.cpp +++ b/src/platform/qt/InputController.cpp @@ -172,15 +172,16 @@ void InputController::setConfiguration(ConfigController* config) { } bool InputController::loadConfiguration(uint32_t type) { - if (!mInputMapLoad(&m_inputMap, type, m_config->input())) { - return false; - } + bool loaded = mInputMapLoad(&m_inputMap, type, m_config->input()); auto driver = m_inputDrivers.value(type); if (!driver) { return false; } + if (!loaded) { + driver->bindDefaults(this); + } driver->loadConfiguration(m_config); - return true; + return loaded; } bool InputController::loadProfile(uint32_t type, const QString& profile) { From 68d120ec5571fedfe43f0150b13221d6c87ce81a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 3 Apr 2024 02:56:29 -0700 Subject: [PATCH 034/338] SDL: Start actually using SDL_GameController for its intended purpose --- src/platform/qt/GBAKeyEditor.cpp | 6 +- src/platform/qt/SettingsView.cpp | 5 ++ src/platform/qt/Window.cpp | 5 ++ src/platform/qt/input/SDLInputDriver.h | 4 ++ src/platform/sdl/sdl-events.c | 94 ++++++++++++++++++++------ src/platform/sdl/sdl-events.h | 1 + 6 files changed, 93 insertions(+), 22 deletions(-) diff --git a/src/platform/qt/GBAKeyEditor.cpp b/src/platform/qt/GBAKeyEditor.cpp index 4536bda2ad2..2afb546ad24 100644 --- a/src/platform/qt/GBAKeyEditor.cpp +++ b/src/platform/qt/GBAKeyEditor.cpp @@ -54,7 +54,7 @@ GBAKeyEditor::GBAKeyEditor(InputController* controller, int type, const QString& refresh(); #ifdef BUILD_SDL - if (type == SDL_BINDING_BUTTON) { + if (type == SDL_BINDING_BUTTON || type == SDL_BINDING_CONTROLLER) { m_profileSelect = new QComboBox(this); connect(m_profileSelect, static_cast(&QComboBox::currentIndexChanged), this, &GBAKeyEditor::selectGamepad); @@ -265,7 +265,7 @@ void GBAKeyEditor::refresh() { void GBAKeyEditor::lookupBinding(const mInputMap* map, KeyEditor* keyEditor, int key) { #ifdef BUILD_SDL - if (m_type == SDL_BINDING_BUTTON) { + if (m_type == SDL_BINDING_BUTTON || m_type == SDL_BINDING_CONTROLLER) { int value = mInputQueryBinding(map, m_type, key); keyEditor->setValueButton(value); return; @@ -329,7 +329,7 @@ void GBAKeyEditor::lookupHats(const mInputMap* map) { void GBAKeyEditor::bindKey(const KeyEditor* keyEditor, int key) { InputMapper mapper = m_controller->mapper(m_type); #ifdef BUILD_SDL - if (m_type == SDL_BINDING_BUTTON && keyEditor->axis() >= 0) { + if ((m_type == SDL_BINDING_BUTTON || m_type == SDL_BINDING_CONTROLLER) && keyEditor->axis() >= 0) { mapper.bindAxis(keyEditor->axis(), keyEditor->direction(), key); } if (m_type == SDL_BINDING_BUTTON && keyEditor->hat() >= 0) { diff --git a/src/platform/qt/SettingsView.cpp b/src/platform/qt/SettingsView.cpp index 7c41cb4a4e9..e95da696c2a 100644 --- a/src/platform/qt/SettingsView.cpp +++ b/src/platform/qt/SettingsView.cpp @@ -334,8 +334,13 @@ SettingsView::SettingsView(ConfigController* controller, InputController* inputC GBAKeyEditor* buttonEditor = nullptr; #ifdef BUILD_SDL +#if SDL_VERSION_ATLEAST(2, 0, 0) + QString profile = inputController->profileForType(SDL_BINDING_CONTROLLER); + buttonEditor = new GBAKeyEditor(inputController, SDL_BINDING_CONTROLLER, profile); +#else QString profile = inputController->profileForType(SDL_BINDING_BUTTON); buttonEditor = new GBAKeyEditor(inputController, SDL_BINDING_BUTTON, profile); +#endif addPage(tr("Controllers"), buttonEditor, Page::CONTROLLERS); connect(m_ui.buttonBox, &QDialogButtonBox::accepted, buttonEditor, &GBAKeyEditor::save); #endif diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index cc439f60f07..6216e2247d2 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -177,8 +177,13 @@ Window::Window(CoreManager* manager, ConfigController* config, int playerId, QWi #ifdef BUILD_SDL m_inputController.addInputDriver(std::make_shared(&m_inputController)); +#if SDL_VERSION_ATLEAST(2, 0, 0) + m_inputController.setGamepadDriver(SDL_BINDING_CONTROLLER); + m_inputController.setSensorDriver(SDL_BINDING_CONTROLLER); +#else m_inputController.setGamepadDriver(SDL_BINDING_BUTTON); m_inputController.setSensorDriver(SDL_BINDING_BUTTON); +#endif #endif m_shortcutController->setConfigController(m_config); diff --git a/src/platform/qt/input/SDLInputDriver.h b/src/platform/qt/input/SDLInputDriver.h index 4a4916ad39d..d10661ed759 100644 --- a/src/platform/qt/input/SDLInputDriver.h +++ b/src/platform/qt/input/SDLInputDriver.h @@ -31,7 +31,11 @@ Q_OBJECT SDLInputDriver(InputController*, QObject* parent = nullptr); ~SDLInputDriver(); +#if SDL_VERSION_ATLEAST(2, 0, 0) + uint32_t type() const override { return SDL_BINDING_CONTROLLER; } +#else uint32_t type() const override { return SDL_BINDING_BUTTON; } +#endif QString visibleName() const override { return QLatin1String("SDL"); } QString currentProfile() const override; diff --git a/src/platform/sdl/sdl-events.c b/src/platform/sdl/sdl-events.c index 41783b3c3c0..e146bfd90b2 100644 --- a/src/platform/sdl/sdl-events.c +++ b/src/platform/sdl/sdl-events.c @@ -167,12 +167,30 @@ void mSDLInitBindingsGBA(struct mInputMap* inputMap) { mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_RIGHT, GBA_KEY_RIGHT); #endif +#if SDL_VERSION_ATLEAST(2, 0, 0) + mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_A, GBA_KEY_A); + mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_B, GBA_KEY_B); + mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_LEFTSHOULDER, GBA_KEY_L); + mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_RIGHTSHOULDER, GBA_KEY_R); + mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_START, GBA_KEY_START); + mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_BACK, GBA_KEY_SELECT); + mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_DPAD_UP, GBA_KEY_UP); + mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_DPAD_DOWN, GBA_KEY_DOWN); + mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_DPAD_LEFT, GBA_KEY_LEFT); + mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_DPAD_RIGHT, GBA_KEY_RIGHT); + + struct mInputAxis description = (struct mInputAxis) { GBA_KEY_RIGHT, GBA_KEY_LEFT, 0x4000, -0x4000 }; + mInputBindAxis(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_AXIS_LEFTX, &description); + description = (struct mInputAxis) { GBA_KEY_DOWN, GBA_KEY_UP, 0x4000, -0x4000 }; + mInputBindAxis(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_AXIS_LEFTY, &description); +#else struct mInputAxis description = { GBA_KEY_RIGHT, GBA_KEY_LEFT, 0x4000, -0x4000 }; mInputBindAxis(inputMap, SDL_BINDING_BUTTON, 0, &description); description = (struct mInputAxis) { GBA_KEY_DOWN, GBA_KEY_UP, 0x4000, -0x4000 }; mInputBindAxis(inputMap, SDL_BINDING_BUTTON, 1, &description); mInputBindHat(inputMap, SDL_BINDING_BUTTON, 0, &GBAInputInfo.hat); +#endif } bool mSDLAttachPlayer(struct mSDLEvents* events, struct mSDLPlayer* player) { @@ -284,17 +302,19 @@ void mSDLDetachPlayer(struct mSDLEvents* events, struct mSDLPlayer* player) { void mSDLPlayerLoadConfig(struct mSDLPlayer* context, const struct Configuration* config) { mInputMapLoad(context->bindings, SDL_BINDING_KEY, config); if (context->joystick) { - mInputMapLoad(context->bindings, SDL_BINDING_BUTTON, config); #if SDL_VERSION_ATLEAST(2, 0, 0) + mInputMapLoad(context->bindings, SDL_BINDING_CONTROLLER, config); char name[34] = {0}; SDL_JoystickGetGUIDString(SDL_JoystickGetGUID(context->joystick->joystick), name, sizeof(name)); + mInputProfileLoad(context->bindings, SDL_BINDING_CONTROLLER, config, name); #else + mInputMapLoad(context->bindings, SDL_BINDING_BUTTON, config); const char* name = SDL_JoystickName(SDL_JoystickIndex(context->joystick->joystick)); if (!name) { return; } -#endif mInputProfileLoad(context->bindings, SDL_BINDING_BUTTON, config, name); +#endif const char* value; char* end; @@ -410,7 +430,7 @@ void mSDLUpdateJoysticks(struct mSDLEvents* events, const struct Configuration* if (events->preferredJoysticks[i] && strcmp(events->preferredJoysticks[i], joystickName) == 0) { events->players[i]->joystick = joystick; if (config) { - mInputProfileLoad(events->players[i]->bindings, SDL_BINDING_BUTTON, config, joystickName); + mInputProfileLoad(events->players[i]->bindings, SDL_BINDING_CONTROLLER, config, joystickName); } return; } @@ -421,7 +441,7 @@ void mSDLUpdateJoysticks(struct mSDLEvents* events, const struct Configuration* } events->players[i]->joystick = joystick; if (config && joystickName[0]) { - mInputProfileLoad(events->players[i]->bindings, SDL_BINDING_BUTTON, config, joystickName); + mInputProfileLoad(events->players[i]->bindings, SDL_BINDING_CONTROLLER, config, joystickName); } break; } @@ -574,6 +594,45 @@ static void _mSDLHandleKeypress(struct mCoreThread* context, struct mSDLPlayer* } } +#if SDL_VERSION_ATLEAST(2, 0, 0) +static void _mSDLHandleControllerButton(struct mCoreThread* context, struct mSDLPlayer* sdlContext, const struct SDL_ControllerButtonEvent* event) { + int key = 0; + key = mInputMapKey(sdlContext->bindings, SDL_BINDING_CONTROLLER, event->button); + if (key == -1) { + return; + } + + mCoreThreadInterrupt(context); + if (event->type == SDL_CONTROLLERBUTTONDOWN) { + context->core->addKeys(context->core, 1 << key); + } else { + context->core->clearKeys(context->core, 1 << key); + } + mCoreThreadContinue(context); +} + +static void _mSDLHandleControllerAxis(struct mCoreThread* context, struct mSDLPlayer* sdlContext, const struct SDL_ControllerAxisEvent* event) { + int clearKeys = ~mInputClearAxis(sdlContext->bindings, SDL_BINDING_CONTROLLER, event->axis, -1); + int newKeys = 0; + int key = mInputMapAxis(sdlContext->bindings, SDL_BINDING_CONTROLLER, event->axis, event->value); + if (key != -1) { + newKeys |= 1 << key; + } + clearKeys &= ~newKeys; + mCoreThreadInterrupt(context); + context->core->clearKeys(context->core, clearKeys); + context->core->addKeys(context->core, newKeys); + mCoreThreadContinue(context); +} + +static void _mSDLHandleWindowEvent(struct mSDLPlayer* sdlContext, const struct SDL_WindowEvent* event) { + switch (event->event) { + case SDL_WINDOWEVENT_SIZE_CHANGED: + sdlContext->windowUpdated = 1; + break; + } +} +#else static void _mSDLHandleJoyButton(struct mCoreThread* context, struct mSDLPlayer* sdlContext, const struct SDL_JoyButtonEvent* event) { int key = 0; key = mInputMapKey(sdlContext->bindings, SDL_BINDING_BUTTON, event->button); @@ -616,16 +675,6 @@ static void _mSDLHandleJoyAxis(struct mCoreThread* context, struct mSDLPlayer* s context->core->clearKeys(context->core, clearKeys); context->core->addKeys(context->core, newKeys); mCoreThreadContinue(context); - -} - -#if SDL_VERSION_ATLEAST(2, 0, 0) -static void _mSDLHandleWindowEvent(struct mSDLPlayer* sdlContext, const struct SDL_WindowEvent* event) { - switch (event->event) { - case SDL_WINDOWEVENT_SIZE_CHANGED: - sdlContext->windowUpdated = 1; - break; - } } #endif @@ -638,17 +687,19 @@ void mSDLHandleEvent(struct mCoreThread* context, struct mSDLPlayer* sdlContext, case SDL_WINDOWEVENT: _mSDLHandleWindowEvent(sdlContext, &event->window); break; + case SDL_CONTROLLERBUTTONDOWN: + case SDL_CONTROLLERBUTTONUP: + _mSDLHandleControllerButton(context, sdlContext, &event->cbutton); + break; + case SDL_CONTROLLERAXISMOTION: + _mSDLHandleControllerAxis(context, sdlContext, &event->caxis); + break; #else case SDL_VIDEORESIZE: sdlContext->newWidth = event->resize.w; sdlContext->newHeight = event->resize.h; sdlContext->windowUpdated = 1; break; -#endif - case SDL_KEYDOWN: - case SDL_KEYUP: - _mSDLHandleKeypress(context, sdlContext, &event->key); - break; case SDL_JOYBUTTONDOWN: case SDL_JOYBUTTONUP: _mSDLHandleJoyButton(context, sdlContext, &event->jbutton); @@ -659,6 +710,11 @@ void mSDLHandleEvent(struct mCoreThread* context, struct mSDLPlayer* sdlContext, case SDL_JOYAXISMOTION: _mSDLHandleJoyAxis(context, sdlContext, &event->jaxis); break; +#endif + case SDL_KEYDOWN: + case SDL_KEYUP: + _mSDLHandleKeypress(context, sdlContext, &event->key); + break; } } diff --git a/src/platform/sdl/sdl-events.h b/src/platform/sdl/sdl-events.h index 8bdbd7c0b04..e49613932ec 100644 --- a/src/platform/sdl/sdl-events.h +++ b/src/platform/sdl/sdl-events.h @@ -29,6 +29,7 @@ mLOG_DECLARE_CATEGORY(SDL_EVENTS); #define SDL_BINDING_KEY 0x53444C4BU #define SDL_BINDING_BUTTON 0x53444C42U +#define SDL_BINDING_CONTROLLER 0x53444C43U #define MAX_PLAYERS 4 From 9320588e45ab0c71f27dc7f6d570bda27082a8b9 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 3 Apr 2024 04:41:54 -0700 Subject: [PATCH 035/338] Qt: Switch SDL controller usage from Joystick to GameController --- CMakeLists.txt | 2 +- src/platform/qt/GBAKeyEditor.cpp | 1 + src/platform/qt/KeyEditor.cpp | 32 +++- src/platform/qt/KeyEditor.h | 5 + src/platform/qt/ShortcutView.cpp | 1 + src/platform/qt/input/Gamepad.h | 3 + src/platform/qt/input/SDLInputDriver.cpp | 56 +++++- src/platform/qt/input/SDLInputDriver.h | 3 + src/platform/sdl/sdl-events.c | 207 +++++++++++++++++++++++ src/platform/sdl/sdl-events.h | 3 + 10 files changed, 307 insertions(+), 6 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 4bf16066526..3f2ff468615 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -39,7 +39,7 @@ if(NOT MSVC) # TODO: Remove this once mScript KV pairs support const correctness set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Werror=incompatible-pointer-types") endif() - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${WARNING_FLAGS} -Woverloaded-virtual") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${WARNING_FLAGS} -Woverloaded-virtual -Werror=reorder") else() set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -D_CRT_SECURE_NO_WARNINGS /wd4003 /wd4244 /wd4146 /wd4267 /Zc:preprocessor-") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -D_CRT_SECURE_NO_WARNINGS /wd4003 /wd4244 /wd4146 /wd4267 /Zc:preprocessor-") diff --git a/src/platform/qt/GBAKeyEditor.cpp b/src/platform/qt/GBAKeyEditor.cpp index 2afb546ad24..8a8427973b1 100644 --- a/src/platform/qt/GBAKeyEditor.cpp +++ b/src/platform/qt/GBAKeyEditor.cpp @@ -122,6 +122,7 @@ GBAKeyEditor::GBAKeyEditor(InputController* controller, int type, const QString& connect(key, &KeyEditor::valueChanged, this, &GBAKeyEditor::setNext); connect(key, &KeyEditor::axisChanged, this, &GBAKeyEditor::setNext); connect(key, &KeyEditor::hatChanged, this, &GBAKeyEditor::setNext); + key->setInputController(m_controller); key->installEventFilter(this); } diff --git a/src/platform/qt/KeyEditor.cpp b/src/platform/qt/KeyEditor.cpp index 7d3ba1990db..50702da731c 100644 --- a/src/platform/qt/KeyEditor.cpp +++ b/src/platform/qt/KeyEditor.cpp @@ -5,6 +5,8 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include "KeyEditor.h" +#include "InputController.h" +#include "input/Gamepad.h" #include "input/GamepadAxisEvent.h" #include "input/GamepadButtonEvent.h" #include "ShortcutController.h" @@ -18,6 +20,7 @@ using namespace QGBA; KeyEditor::KeyEditor(QWidget* parent) : QLineEdit(parent) + , m_controller(nullptr) , m_direction(GamepadAxisEvent::NEUTRAL) , m_hatDirection(GamepadHatEvent::CENTER) { @@ -26,6 +29,13 @@ KeyEditor::KeyEditor(QWidget* parent) m_lastKey.setSingleShot(true); } +void KeyEditor::setInputController(InputController* controller) { + m_controller = controller; + if (m_button) { + updateButtonText(); + } +} + void KeyEditor::setValue(int key) { m_key = key; if (m_button) { @@ -204,10 +214,28 @@ void KeyEditor::updateButtonText() { } } if (m_key >= 0) { - text.append(QString::number(m_key)); + std::shared_ptr gamepad; + if (m_controller && m_controller->gamepadDriver()) { + gamepad = m_controller->gamepadDriver()->activeGamepad(); + } + if (!gamepad) { + text.append(QString::number(m_key)); + } else { + text.append(gamepad->buttonHumanName(m_key)); + } } if (m_direction != GamepadAxisEvent::NEUTRAL) { - text.append((m_direction == GamepadAxisEvent::NEGATIVE ? "-" : "+") + QString::number(m_axis)); + QString name; + std::shared_ptr gamepad; + if (m_controller && m_controller->gamepadDriver()) { + gamepad = m_controller->gamepadDriver()->activeGamepad(); + } + if (!gamepad) { + name = QString::number(m_axis); + } else { + name = gamepad->axisHumanName(m_axis); + } + text.append((m_direction == GamepadAxisEvent::NEGATIVE ? "-" : "+") + name); } if (text.isEmpty()) { setText(tr("---")); diff --git a/src/platform/qt/KeyEditor.h b/src/platform/qt/KeyEditor.h index c1bb56fae3b..93af927ac98 100644 --- a/src/platform/qt/KeyEditor.h +++ b/src/platform/qt/KeyEditor.h @@ -13,12 +13,16 @@ namespace QGBA { +class InputController; + class KeyEditor : public QLineEdit { Q_OBJECT public: KeyEditor(QWidget* parent = nullptr); + void setInputController(InputController* controller); + int value() const { return m_key; } GamepadAxisEvent::Direction direction() const { return m_direction; } @@ -57,6 +61,7 @@ public slots: int m_axis = -1; int m_hat = -1; bool m_button = false; + InputController* m_controller; GamepadAxisEvent::Direction m_direction; GamepadHatEvent::Direction m_hatDirection; QTimer m_lastKey; diff --git a/src/platform/qt/ShortcutView.cpp b/src/platform/qt/ShortcutView.cpp index 5efbc4d6295..f457263c578 100644 --- a/src/platform/qt/ShortcutView.cpp +++ b/src/platform/qt/ShortcutView.cpp @@ -54,6 +54,7 @@ void ShortcutView::setInputController(InputController* controller) { } m_input = controller; m_input->stealFocus(this); + m_ui.keyEdit->setInputController(controller); } void ShortcutView::load(const QModelIndex& index) { diff --git a/src/platform/qt/input/Gamepad.h b/src/platform/qt/input/Gamepad.h index 1781885cd8d..9a1cf19ec7d 100644 --- a/src/platform/qt/input/Gamepad.h +++ b/src/platform/qt/input/Gamepad.h @@ -22,6 +22,9 @@ Q_OBJECT virtual QList currentAxes() = 0; virtual QList currentHats() = 0; + virtual QString buttonHumanName(int) const = 0; + virtual QString axisHumanName(int) const = 0; + virtual int buttonCount() const = 0; virtual int axisCount() const = 0; virtual int hatCount() const = 0; diff --git a/src/platform/qt/input/SDLInputDriver.cpp b/src/platform/qt/input/SDLInputDriver.cpp index e3a77094fc8..72d148057a1 100644 --- a/src/platform/qt/input/SDLInputDriver.cpp +++ b/src/platform/qt/input/SDLInputDriver.cpp @@ -257,13 +257,20 @@ QList SDLGamepad::currentButtons() { return {}; } - SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->joystick; QList buttons; +#if SDL_VERSION_ATLEAST(2, 0, 0) + SDL_GameController* controller = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->controller; + for (int i = 0; i < SDL_CONTROLLER_BUTTON_MAX; ++i) { + buttons.append(SDL_GameControllerGetButton(controller, static_cast(i))); + } +#else + SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->joystick; int numButtons = SDL_JoystickNumButtons(joystick); for (int i = 0; i < numButtons; ++i) { buttons.append(SDL_JoystickGetButton(joystick, i)); } +#endif return buttons; } @@ -273,13 +280,20 @@ QList SDLGamepad::currentAxes() { return {}; } - SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->joystick; QList axes; +#if SDL_VERSION_ATLEAST(2, 0, 0) + SDL_GameController* controller = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->controller; + for (int i = 0; i < SDL_CONTROLLER_AXIS_MAX; ++i) { + axes.append(SDL_GameControllerGetAxis(controller, static_cast(i))); + } +#else + SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->joystick; int numAxes = SDL_JoystickNumAxes(joystick); for (int i = 0; i < numAxes; ++i) { axes.append(SDL_JoystickGetAxis(joystick, i)); } +#endif return axes; } @@ -289,24 +303,52 @@ QList SDLGamepad::currentHats() { return {}; } - SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->joystick; QList hats; +#if !SDL_VERSION_ATLEAST(2, 0, 0) + SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->joystick; int numHats = SDL_JoystickNumHats(joystick); for (int i = 0; i < numHats; ++i) { hats.append(static_cast(SDL_JoystickGetHat(joystick, i))); } +#endif return hats; } +QString SDLGamepad::buttonHumanName(int button) const { +#if SDL_VERSION_ATLEAST(2, 0, 0) + SDL_GameController* controller = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->controller; + const char* name = mSDLButtonName(controller, static_cast(button)); + if (name) { + return QString::fromUtf8(name); + } +#endif + return QString::number(button); +} + +QString SDLGamepad::axisHumanName(int axis) const { +#if SDL_VERSION_ATLEAST(2, 0, 0) + SDL_GameController* controller = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->controller; + const char* name = mSDLAxisName(controller, static_cast(axis)); + if (name) { + return QString::fromUtf8(name); + } +#endif + return QString::number(axis); +} + int SDLGamepad::buttonCount() const { if (!verify()) { return -1; } +#if SDL_VERSION_ATLEAST(2, 0, 0) + return SDL_CONTROLLER_BUTTON_MAX; +#else SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->joystick; return SDL_JoystickNumButtons(joystick); +#endif } int SDLGamepad::axisCount() const { @@ -314,8 +356,12 @@ int SDLGamepad::axisCount() const { return -1; } +#if SDL_VERSION_ATLEAST(2, 0, 0) + return SDL_CONTROLLER_AXIS_MAX; +#else SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->joystick; return SDL_JoystickNumAxes(joystick); +#endif } int SDLGamepad::hatCount() const { @@ -323,8 +369,12 @@ int SDLGamepad::hatCount() const { return -1; } +#if SDL_VERSION_ATLEAST(2, 0, 0) + return 0; +#else SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->joystick; return SDL_JoystickNumHats(joystick); +#endif } QString SDLGamepad::name() const { diff --git a/src/platform/qt/input/SDLInputDriver.h b/src/platform/qt/input/SDLInputDriver.h index d10661ed759..217dc40a7e5 100644 --- a/src/platform/qt/input/SDLInputDriver.h +++ b/src/platform/qt/input/SDLInputDriver.h @@ -93,6 +93,9 @@ Q_OBJECT int axisCount() const override; int hatCount() const override; + QString buttonHumanName(int) const override; + QString axisHumanName(int) const override; + QString name() const override; QString visibleName() const override; diff --git a/src/platform/sdl/sdl-events.c b/src/platform/sdl/sdl-events.c index e146bfd90b2..38377563649 100644 --- a/src/platform/sdl/sdl-events.c +++ b/src/platform/sdl/sdl-events.c @@ -886,4 +886,211 @@ void mSDLSetScreensaverSuspendable(struct mSDLEvents* events, bool suspendable) SDL_EnableScreenSaver(); } } + +static const char* const buttonNamesXbox360[SDL_CONTROLLER_BUTTON_MAX] = { + [SDL_CONTROLLER_BUTTON_A] = "A", + [SDL_CONTROLLER_BUTTON_B] = "B", + [SDL_CONTROLLER_BUTTON_X] = "X", + [SDL_CONTROLLER_BUTTON_Y] = "Y", + [SDL_CONTROLLER_BUTTON_BACK] = "Back", + [SDL_CONTROLLER_BUTTON_GUIDE] = "Xbox", + [SDL_CONTROLLER_BUTTON_START] = "Start", + [SDL_CONTROLLER_BUTTON_LEFTSTICK] = "LS", + [SDL_CONTROLLER_BUTTON_RIGHTSTICK] = "RS", + [SDL_CONTROLLER_BUTTON_LEFTSHOULDER] = "LB", + [SDL_CONTROLLER_BUTTON_RIGHTSHOULDER] = "RB", + [SDL_CONTROLLER_BUTTON_MISC1] = "Misc", + [SDL_CONTROLLER_BUTTON_PADDLE1] = "P1", + [SDL_CONTROLLER_BUTTON_PADDLE2] = "P2", + [SDL_CONTROLLER_BUTTON_PADDLE3] = "P3", + [SDL_CONTROLLER_BUTTON_PADDLE4] = "P4", + [SDL_CONTROLLER_BUTTON_TOUCHPAD] = "Touch", +}; + +#if SDL_VERSION_ATLEAST(2, 0, 12) +static const char* const buttonNamesXboxOne[SDL_CONTROLLER_BUTTON_MAX] = { + [SDL_CONTROLLER_BUTTON_A] = "A", + [SDL_CONTROLLER_BUTTON_B] = "B", + [SDL_CONTROLLER_BUTTON_X] = "X", + [SDL_CONTROLLER_BUTTON_Y] = "Y", + [SDL_CONTROLLER_BUTTON_BACK] = "View", + [SDL_CONTROLLER_BUTTON_GUIDE] = "Xbox", + [SDL_CONTROLLER_BUTTON_START] = "Menu", + [SDL_CONTROLLER_BUTTON_LEFTSTICK] = "LS", + [SDL_CONTROLLER_BUTTON_RIGHTSTICK] = "RS", + [SDL_CONTROLLER_BUTTON_LEFTSHOULDER] = "LB", + [SDL_CONTROLLER_BUTTON_RIGHTSHOULDER] = "RB", + [SDL_CONTROLLER_BUTTON_MISC1] = "Share", + [SDL_CONTROLLER_BUTTON_PADDLE1] = "P1", + [SDL_CONTROLLER_BUTTON_PADDLE2] = "P2", + [SDL_CONTROLLER_BUTTON_PADDLE3] = "P3", + [SDL_CONTROLLER_BUTTON_PADDLE4] = "P4", + [SDL_CONTROLLER_BUTTON_TOUCHPAD] = "Touch", +}; + +static const char* const buttonNamesPlayStation[SDL_CONTROLLER_BUTTON_MAX] = { + [SDL_CONTROLLER_BUTTON_A] = "×", + [SDL_CONTROLLER_BUTTON_B] = "â—‹", + [SDL_CONTROLLER_BUTTON_X] = "â–¡", + [SDL_CONTROLLER_BUTTON_Y] = "â–³", + [SDL_CONTROLLER_BUTTON_BACK] = "Share", + [SDL_CONTROLLER_BUTTON_GUIDE] = "PS", + [SDL_CONTROLLER_BUTTON_START] = "Options", + [SDL_CONTROLLER_BUTTON_LEFTSTICK] = "L3", + [SDL_CONTROLLER_BUTTON_RIGHTSTICK] = "R3", + [SDL_CONTROLLER_BUTTON_LEFTSHOULDER] = "L1", + [SDL_CONTROLLER_BUTTON_RIGHTSHOULDER] = "R1", + [SDL_CONTROLLER_BUTTON_MISC1] = "Misc", + [SDL_CONTROLLER_BUTTON_PADDLE1] = "P1", + [SDL_CONTROLLER_BUTTON_PADDLE2] = "P2", + [SDL_CONTROLLER_BUTTON_PADDLE3] = "P3", + [SDL_CONTROLLER_BUTTON_PADDLE4] = "P4", + [SDL_CONTROLLER_BUTTON_TOUCHPAD] = "Touch", +}; + +static const char* const buttonNamesNintedo[SDL_CONTROLLER_BUTTON_MAX] = { + [SDL_CONTROLLER_BUTTON_A] = "A", + [SDL_CONTROLLER_BUTTON_B] = "B", + [SDL_CONTROLLER_BUTTON_X] = "X", + [SDL_CONTROLLER_BUTTON_Y] = "Y", + [SDL_CONTROLLER_BUTTON_BACK] = "-", + [SDL_CONTROLLER_BUTTON_GUIDE] = "Home", + [SDL_CONTROLLER_BUTTON_START] = "+", + [SDL_CONTROLLER_BUTTON_LEFTSTICK] = "LS", + [SDL_CONTROLLER_BUTTON_RIGHTSTICK] = "RS", + [SDL_CONTROLLER_BUTTON_LEFTSHOULDER] = "L", + [SDL_CONTROLLER_BUTTON_RIGHTSHOULDER] = "R", + [SDL_CONTROLLER_BUTTON_MISC1] = "Share", + [SDL_CONTROLLER_BUTTON_PADDLE1] = "P1", + [SDL_CONTROLLER_BUTTON_PADDLE2] = "P2", + [SDL_CONTROLLER_BUTTON_PADDLE3] = "P3", + [SDL_CONTROLLER_BUTTON_PADDLE4] = "P4", + [SDL_CONTROLLER_BUTTON_TOUCHPAD] = "Touch", +}; + +static const char* const buttonNamesGeneric[SDL_CONTROLLER_BUTTON_MAX] = { + [SDL_CONTROLLER_BUTTON_A] = "A", + [SDL_CONTROLLER_BUTTON_B] = "B", + [SDL_CONTROLLER_BUTTON_X] = "X", + [SDL_CONTROLLER_BUTTON_Y] = "Y", + [SDL_CONTROLLER_BUTTON_BACK] = "Select", + [SDL_CONTROLLER_BUTTON_GUIDE] = "Guide", + [SDL_CONTROLLER_BUTTON_START] = "Start", + [SDL_CONTROLLER_BUTTON_LEFTSTICK] = "LS", + [SDL_CONTROLLER_BUTTON_RIGHTSTICK] = "RS", + [SDL_CONTROLLER_BUTTON_LEFTSHOULDER] = "LB", + [SDL_CONTROLLER_BUTTON_RIGHTSHOULDER] = "RB", + [SDL_CONTROLLER_BUTTON_MISC1] = "Misc", + [SDL_CONTROLLER_BUTTON_PADDLE1] = "P1", + [SDL_CONTROLLER_BUTTON_PADDLE2] = "P2", + [SDL_CONTROLLER_BUTTON_PADDLE3] = "P3", + [SDL_CONTROLLER_BUTTON_PADDLE4] = "P4", + [SDL_CONTROLLER_BUTTON_TOUCHPAD] = "Touch", +}; +#endif + +const char* mSDLButtonName(SDL_GameController* controller, SDL_GameControllerButton button) { + const char* const* buttonNames = buttonNamesXbox360; + +#if SDL_VERSION_ATLEAST(2, 0, 12) + switch (SDL_GameControllerGetType(controller)) { + case SDL_CONTROLLER_TYPE_XBOX360: + buttonNames = buttonNamesXbox360; + break; + case SDL_CONTROLLER_TYPE_XBOXONE: + buttonNames = buttonNamesXboxOne; + break; + case SDL_CONTROLLER_TYPE_PS3: + case SDL_CONTROLLER_TYPE_PS4: +#if SDL_VERSION_ATLEAST(2, 0, 14) + case SDL_CONTROLLER_TYPE_PS5: +#endif + buttonNames = buttonNamesPlayStation; + break; + case SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_PRO: + buttonNames = buttonNamesNintedo; + break; + default: + buttonNames = buttonNamesGeneric; + break; + } +#endif + + switch (button) { + case SDL_CONTROLLER_BUTTON_DPAD_UP: + return "D↑"; + case SDL_CONTROLLER_BUTTON_DPAD_DOWN: + return "D↓"; + case SDL_CONTROLLER_BUTTON_DPAD_LEFT: + return "Dâ†"; + case SDL_CONTROLLER_BUTTON_DPAD_RIGHT: + return "D→"; + default: + return buttonNames[button]; + case SDL_CONTROLLER_BUTTON_INVALID: + case SDL_CONTROLLER_BUTTON_MAX: + break; + } + return NULL; +} + +static const char* const axisNamesXbox[SDL_CONTROLLER_AXIS_MAX] = { + [SDL_CONTROLLER_AXIS_TRIGGERLEFT] = "LT", + [SDL_CONTROLLER_AXIS_TRIGGERRIGHT] = "RT", +}; + +#if SDL_VERSION_ATLEAST(2, 0, 12) +static const char* const axisNamesPlayStation[SDL_CONTROLLER_AXIS_MAX] = { + [SDL_CONTROLLER_AXIS_TRIGGERLEFT] = "L3", + [SDL_CONTROLLER_AXIS_TRIGGERRIGHT] = "R3", +}; + +static const char* const axisNamesNintendo[SDL_CONTROLLER_AXIS_MAX] = { + [SDL_CONTROLLER_AXIS_TRIGGERLEFT] = "ZL", + [SDL_CONTROLLER_AXIS_TRIGGERRIGHT] = "ZR", +}; +#endif + +const char* mSDLAxisName(SDL_GameController* controller, SDL_GameControllerAxis axis) { + const char* const* axisNames = axisNamesXbox; + +#if SDL_VERSION_ATLEAST(2, 0, 12) + switch (SDL_GameControllerGetType(controller)) { + case SDL_CONTROLLER_TYPE_XBOX360: + case SDL_CONTROLLER_TYPE_XBOXONE: + default: + axisNames = axisNamesXbox; + break; + case SDL_CONTROLLER_TYPE_PS3: + case SDL_CONTROLLER_TYPE_PS4: +#if SDL_VERSION_ATLEAST(2, 0, 14) + case SDL_CONTROLLER_TYPE_PS5: +#endif + axisNames = axisNamesPlayStation; + break; + case SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_PRO: + axisNames = axisNamesNintendo; + break; + } +#endif + + switch (axis) { + case SDL_CONTROLLER_AXIS_LEFTX: + return "X"; + case SDL_CONTROLLER_AXIS_LEFTY: + return "Y"; + case SDL_CONTROLLER_AXIS_RIGHTX: + return "RX"; + case SDL_CONTROLLER_AXIS_RIGHTY: + return "RY"; + case SDL_CONTROLLER_AXIS_TRIGGERLEFT: + case SDL_CONTROLLER_AXIS_TRIGGERRIGHT: + return axisNames[axis]; + case SDL_CONTROLLER_AXIS_INVALID: + case SDL_CONTROLLER_AXIS_MAX: + break; + } + return NULL; +} + #endif diff --git a/src/platform/sdl/sdl-events.h b/src/platform/sdl/sdl-events.h index e49613932ec..741503be429 100644 --- a/src/platform/sdl/sdl-events.h +++ b/src/platform/sdl/sdl-events.h @@ -126,6 +126,9 @@ void mSDLHandleEvent(struct mCoreThread* context, struct mSDLPlayer* sdlContext, void mSDLSuspendScreensaver(struct mSDLEvents*); void mSDLResumeScreensaver(struct mSDLEvents*); void mSDLSetScreensaverSuspendable(struct mSDLEvents*, bool suspendable); + +const char* mSDLButtonName(SDL_GameController*, SDL_GameControllerButton); +const char* mSDLAxisName(SDL_GameController*, SDL_GameControllerAxis); #endif CXX_GUARD_END From 6e39eb37f6db51f893410117f45dcdd3a6128eb6 Mon Sep 17 00:00:00 2001 From: gallegonovato Date: Sat, 29 Jul 2023 11:45:37 +0000 Subject: [PATCH 036/338] Qt: Update translation (Spanish) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/es/ --- src/platform/qt/ts/mgba-es.ts | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/src/platform/qt/ts/mgba-es.ts b/src/platform/qt/ts/mgba-es.ts index 83c4d5d989d..16238357bb3 100644 --- a/src/platform/qt/ts/mgba-es.ts +++ b/src/platform/qt/ts/mgba-es.ts @@ -716,7 +716,7 @@ Tamaño de descarga: %3 Image files (*.png *.jpg *.bmp) - + Archivos de imagen (*.png *.jpg *.bmp) @@ -3752,17 +3752,17 @@ Tamaño de descarga: %3 Trying to detach a multiplayer player that's not attached - + Intentando desvincular a un multijugador que no está conectado Trying to get player ID for a multiplayer player that's not attached - + Intentando obtener el ID de un multijugador que no está conectado Trying to get save ID for a multiplayer player that's not attached - + Intentando obtener el ID de guardado de un multijugador que no está conectado @@ -4310,7 +4310,7 @@ Tamaño de descarga: %3 Save file: - + Guarda el archivo: @@ -4477,7 +4477,7 @@ Tamaño de descarga: %3 + RTC - + + RTC @@ -4759,12 +4759,12 @@ Tamaño de descarga: %3 Select image - Seleccionar imagen + Seleccionar una imagen Image file (*.png *.jpg *.jpeg) - Archivo de imagen (*.png *.jpg *.jpeg) + Archivo de imagen (*.png *.jpg *.jpeg) @@ -5089,7 +5089,7 @@ Tamaño de descarga: %3 Custom border: - + Borde personalizado: @@ -5134,7 +5134,7 @@ Tamaño de descarga: %3 Rewind speed: - + Velocidad del rebobinado: @@ -6388,12 +6388,12 @@ Tamaño de descarga: %3 Increase fast forward speed - + Aumentar la velocidad del avance rápido Decrease fast forward speed - + Reducir la velocidad del avance rápido @@ -6771,17 +6771,17 @@ Tamaño de descarga: %3 Super (L) - Super (L) + Súper (L) Super (R) - Super (R) + Súper (R) Menu - Menú + Menú From 5acef1c454dac84d54458896547cc937b20e0589 Mon Sep 17 00:00:00 2001 From: Momo cao Date: Fri, 22 Sep 2023 00:52:19 +0000 Subject: [PATCH 037/338] Qt: Update translation (Spanish) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/es/ --- src/platform/qt/ts/mgba-es.ts | 34 ++++++++++++++++++---------------- 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/src/platform/qt/ts/mgba-es.ts b/src/platform/qt/ts/mgba-es.ts index 16238357bb3..7dfe054c7e1 100644 --- a/src/platform/qt/ts/mgba-es.ts +++ b/src/platform/qt/ts/mgba-es.ts @@ -656,7 +656,7 @@ Tamaño de descarga: %3 Use default image - Utilizar la imagen por defecto + Utilizar imagen por defecto @@ -686,17 +686,17 @@ Tamaño de descarga: %3 Build finished - Construcción finalizada + Compilación finalizada Forwarder finished building - Transmisor terminado de construir + Transmisor terminado de compilar Build failed - Falló la construcción + Falló la compilación @@ -3762,7 +3762,7 @@ Tamaño de descarga: %3 Trying to get save ID for a multiplayer player that's not attached - Intentando obtener el ID de guardado de un multijugador que no está conectado + Intentando obtener ID de guardado para un jugador multijugador que no está conectado @@ -3780,7 +3780,7 @@ Tamaño de descarga: %3 Export - Esportar + Exportar @@ -4228,7 +4228,7 @@ Tamaño de descarga: %3 Hurry up! - ¡Apúrate! + ¡Apresúrate! @@ -4310,7 +4310,7 @@ Tamaño de descarga: %3 Save file: - Guarda el archivo: + Guardar: @@ -4759,7 +4759,7 @@ Tamaño de descarga: %3 Select image - Seleccionar una imagen + Seleccionar imagen @@ -4792,14 +4792,16 @@ Tamaño de descarga: %3 Hace %n hora Hace %n horas + Hace %n horas %n day(s) ago - Hace %n dia - Hace %n dias + Hace %n día + Hace %n días + Hace %n días @@ -5134,7 +5136,7 @@ Tamaño de descarga: %3 Rewind speed: - Velocidad del rebobinado: + Velocidad de rebobinado: @@ -6106,7 +6108,7 @@ Tamaño de descarga: %3 Load ROM in archive... - Cargar ROM desde contenedor... + Cargar ROM desde archivo comprimido... @@ -6151,7 +6153,7 @@ Tamaño de descarga: %3 Recent - Cargar reciente + Reciente @@ -6388,12 +6390,12 @@ Tamaño de descarga: %3 Increase fast forward speed - Aumentar la velocidad del avance rápido + Aumentar la velocidad de avance rápido Decrease fast forward speed - Reducir la velocidad del avance rápido + Disminuir velocidad de avance rápido From dcb07f6e3363151f8267f9279071c03a7f4e81b4 Mon Sep 17 00:00:00 2001 From: Hoseok Seo Date: Fri, 4 Aug 2023 02:23:05 +0000 Subject: [PATCH 038/338] Qt: Update translation (Korean) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/ko/ --- src/platform/qt/ts/mgba-ko.ts | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/src/platform/qt/ts/mgba-ko.ts b/src/platform/qt/ts/mgba-ko.ts index a0955e5005a..05a8dc60410 100644 --- a/src/platform/qt/ts/mgba-ko.ts +++ b/src/platform/qt/ts/mgba-ko.ts @@ -716,7 +716,7 @@ Download size: %3 Image files (*.png *.jpg *.bmp) - + ì´ë¯¸ì§€ íŒŒì¼ (*.png *.jpg *.bmp) @@ -3752,17 +3752,17 @@ Download size: %3 Trying to detach a multiplayer player that's not attached - + ì—°ê²°ë˜ì§€ ì•Šì€ ë©€í‹°í”Œë ˆì´ì–´ 플레ì´ì–´ë¥¼ 분리하려고 함 Trying to get player ID for a multiplayer player that's not attached - + ì—°ê²°ë˜ì§€ ì•Šì€ ë©€í‹°í”Œë ˆì´ì–´ 플레ì´ì–´ì˜ 플레ì´ì–´ ID를 가져오려고 함 Trying to get save ID for a multiplayer player that's not attached - + ì—°ê²°ë˜ì§€ ì•Šì€ ë©€í‹°í”Œë ˆì´ì–´ 플레ì´ì–´ì˜ 저장 ID를 얻으려고 함 @@ -4310,7 +4310,7 @@ Download size: %3 Save file: - + 저장 파ì¼: @@ -4477,7 +4477,7 @@ Download size: %3 + RTC - + + RTC @@ -4759,12 +4759,12 @@ Download size: %3 Select image - ì´ë¯¸ì§€ ì„ íƒ + ì´ë¯¸ì§€ ì„ íƒ Image file (*.png *.jpg *.jpeg) - ì´ë¯¸ì§€ íŒŒì¼ (*.png *.jpg *.jpeg) + ì´ë¯¸ì§€ íŒŒì¼ (*.png *.jpg *.jpeg) @@ -5067,7 +5067,7 @@ Download size: %3 Custom border: - + 커스텀 í…Œë‘리: @@ -5112,7 +5112,7 @@ Download size: %3 Rewind speed: - + ë˜ê°ê¸° ì†ë„: @@ -6325,12 +6325,12 @@ Download size: %3 Increase fast forward speed - + 빨리 ê°ê¸° ì†ë„ í–¥ìƒ Decrease fast forward speed - + 빨리 ê°ê¸° ì†ë„ 줄ì´ê¸° @@ -6769,17 +6769,17 @@ Download size: %3 Super (L) - ìŠˆí¼ (L) + ìŠˆí¼ (L) Super (R) - ìŠˆí¼ (R) + ìŠˆí¼ (R) Menu - 메뉴 + 메뉴 From 424ef6ff745a5fea974705d74d4a79315ae9afe6 Mon Sep 17 00:00:00 2001 From: Felipe Date: Tue, 1 Aug 2023 13:33:20 +0000 Subject: [PATCH 039/338] Qt: Update translation (Portuguese (Brazil)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/pt_BR/ --- src/platform/qt/ts/mgba-pt_BR.ts | 32 +++++++++++++++++--------------- 1 file changed, 17 insertions(+), 15 deletions(-) diff --git a/src/platform/qt/ts/mgba-pt_BR.ts b/src/platform/qt/ts/mgba-pt_BR.ts index 2cbfde5287f..77573eb1ba2 100644 --- a/src/platform/qt/ts/mgba-pt_BR.ts +++ b/src/platform/qt/ts/mgba-pt_BR.ts @@ -716,7 +716,7 @@ Tamanho do download: %3 Image files (*.png *.jpg *.bmp) - + Arquivo da imagem (*.png *.jpg *.bmp) @@ -3752,17 +3752,17 @@ Tamanho do download: %3 Trying to detach a multiplayer player that's not attached - + Tentando desconectar um jogador multiplayer que não está conectado Trying to get player ID for a multiplayer player that's not attached - + Tentando obter a ID do jogador pra um jogador multiplayer que não está conectado Trying to get save ID for a multiplayer player that's not attached - + Tentando obter a ID salva pra um jogador multiplayer que não está conectado @@ -4310,7 +4310,7 @@ Tamanho do download: %3 Save file: - + Arquivo do save: @@ -4477,7 +4477,7 @@ Tamanho do download: %3 + RTC - + + RTC @@ -4759,12 +4759,12 @@ Tamanho do download: %3 Select image - Selecionar imagem + Selecionar imagem Image file (*.png *.jpg *.jpeg) - Arquivo da imagem (*.png *.jpg *.jpeg) + Arquivo da imagem (*.png *.jpg *.jpeg) @@ -4792,6 +4792,7 @@ Tamanho do download: %3 %n hora atrás %n horas atrás + @@ -4800,6 +4801,7 @@ Tamanho do download: %3 %n dia atrás %n dias atrás + @@ -5089,7 +5091,7 @@ Tamanho do download: %3 Custom border: - + Borda personalizada: @@ -5134,7 +5136,7 @@ Tamanho do download: %3 Rewind speed: - + Velocidade do retrocesso: @@ -6388,12 +6390,12 @@ Tamanho do download: %3 Increase fast forward speed - + Aumentar a velocidade do avanço rápido Decrease fast forward speed - + Diminuir a velocidade do avanço rápido @@ -6771,17 +6773,17 @@ Tamanho do download: %3 Super (L) - Super (E) + Super (E) Super (R) - Super (D) + Super (D) Menu - Menu + Menu From 7af70a69bb4b8f74257bacbc7310769788b1f8f4 Mon Sep 17 00:00:00 2001 From: Eryk Michalak Date: Sat, 30 Sep 2023 10:54:29 +0000 Subject: [PATCH 040/338] Qt: Update translation (Polish) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/pl/ --- src/platform/qt/ts/mgba-pl.ts | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/src/platform/qt/ts/mgba-pl.ts b/src/platform/qt/ts/mgba-pl.ts index 180b32630a7..650563e2e03 100644 --- a/src/platform/qt/ts/mgba-pl.ts +++ b/src/platform/qt/ts/mgba-pl.ts @@ -716,7 +716,7 @@ Rozmiar pobierania: %3 Image files (*.png *.jpg *.bmp) - + Obrazy (*.png *.jpg *.bmp) @@ -3752,17 +3752,17 @@ Rozmiar pobierania: %3 Trying to detach a multiplayer player that's not attached - + Próba odÅ‚Ä…czenia gracza multiplayer, który nie jest doÅ‚Ä…czony Trying to get player ID for a multiplayer player that's not attached - + Próba uzyskania ID gracza w trybie wieloosobowym, który nie jest poÅ‚Ä…czony Trying to get save ID for a multiplayer player that's not attached - + Próba uzyskania identyfikatora zapisu dla gracza multiplayer, który nie jest poÅ‚Ä…czony @@ -4310,7 +4310,7 @@ Rozmiar pobierania: %3 Save file: - + Zapisz plik: @@ -4477,7 +4477,7 @@ Rozmiar pobierania: %3 + RTC - + + RTC @@ -4759,12 +4759,12 @@ Rozmiar pobierania: %3 Select image - Wybierz obraz + Wybierz obraz Image file (*.png *.jpg *.jpeg) - Plik graficzny (*.png *.jpg *.jpeg) + Plik graficzny (*.png *.jpg *.jpeg) @@ -5251,7 +5251,7 @@ Rozmiar pobierania: %3 Custom border: - + Niestandardowa ramka: @@ -5287,7 +5287,7 @@ Rozmiar pobierania: %3 Rewind speed: - + PrÄ™dkość przewijania: @@ -6405,12 +6405,12 @@ Rozmiar pobierania: %3 Increase fast forward speed - + ZwiÄ™kszenie prÄ™dkoÅ›ci przewijania do przodu Decrease fast forward speed - + Zmiejszenie prÄ™dkoÅ›ci przewijania do przodu @@ -6773,17 +6773,17 @@ Rozmiar pobierania: %3 Super (L) - Super (L) + Super (L) Super (R) - Super (R) + Super (R) Menu - Menu + Menu From 3a37c1d3ff1c2725af7c96bfbd6e90ce2ff8e578 Mon Sep 17 00:00:00 2001 From: Ensar Melih Bulut Date: Tue, 17 Oct 2023 20:39:46 +0000 Subject: [PATCH 041/338] Qt: Update translation (Turkish) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/tr/ --- src/platform/qt/ts/mgba-tr.ts | 47 +++++++++++++++++++---------------- 1 file changed, 26 insertions(+), 21 deletions(-) diff --git a/src/platform/qt/ts/mgba-tr.ts b/src/platform/qt/ts/mgba-tr.ts index d239b59c2d8..73ab0b7caa7 100644 --- a/src/platform/qt/ts/mgba-tr.ts +++ b/src/platform/qt/ts/mgba-tr.ts @@ -6,22 +6,22 @@ Game Boy Advance ROMs (%1) - Game Boy Advance ROMları (%1) + Game Boy Advance ROM'ları (%1) Game Boy ROMs (%1) - Game Boy ROMları (%1) + Game Boy ROM'ları (%1) All ROMs (%1) - Bütün ROMlar (%1) + Bütün ROM'lar (%1) %1 Video Logs (*.mvl) - + %1 Video Günlükleri (*.mvl) @@ -64,47 +64,52 @@ Game Boy Advance, Nintendo Co., Ltd.'nin tescilli ticari markasıdır. An update is available - + Bir güncelleme mevcut An update to %1 is available. - + %1 için bir güncelleme mevcut. + Do you want to download and install it now? You will need to restart the emulator when the download is complete. - + +Åžimdi indirip yüklemek istiyor musunuz? Ä°ndirme iÅŸlemi tamamlandığında öykünücüyü yeniden baÅŸlatmanız gerekecektir. Auto-update is not available on this platform. If you wish to update you will need to do it manually. - + +Otomatik güncelleme bu platformda mevcut deÄŸildir. Güncellemek istiyorsanız bunu manuel olarak yapmanız gerekecektir. Current version: %1 New version: %2 Download size: %3 - + Güncel sürüm: %1 +Yeni sürüm: %2 +Ä°ndirme boyutu: %3 Downloading update... - + Güncelleme indiriliyor... Downloading failed. Please update manually. - + Ä°ndirme baÅŸarısız oldu. Lütfen manuel olarak güncelleyin. Downloading done. Press OK to restart %1 and install the update. - + Ä°ndirme tamamlandı. %1 yeniden baÅŸlatmak ve güncellemeyi yüklemek için Tamam'a basın. @@ -112,22 +117,22 @@ Download size: %3 Stable - + Kararlı Development - + GeliÅŸtirme Unknown - Bilinmeyen + Bilinmeyen (None) - + (Yok) @@ -188,17 +193,17 @@ Download size: %3 Can't set format of context-less audio device - + BaÄŸlamdan bağımsız ses cihazının formatı ayarlanamıyor Audio device is missing its core - + Ses cihazının çekirdeÄŸi eksik Writing data to read-only audio device - + Salt okunur ses cihazına veri yazma @@ -6074,7 +6079,7 @@ Download size: %3 This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - Emülatörün yapılandırmasını yürütülebilir dosya ile aynı dizinden yüklemesini saÄŸlar. Devam etmek istiyor musun? + Öyküncünün yapılandırmasını yürütülebilir dosya ile aynı dizinden yüklemesini saÄŸlar. Devam etmek istiyor musunuz? @@ -6084,7 +6089,7 @@ Download size: %3 Some changes will not take effect until the emulator is restarted. - Bazı deÄŸiÅŸiklikler emülatör yeniden baÅŸlatılıncaya kadar etkili olmaz. + Bazı deÄŸiÅŸiklikler öyküncü yeniden baÅŸlatılıncaya kadar etkili olmaz. From 0a8470a6d0f6491ee6dab2b14e752738baf98f8f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Enes=20=C3=87etinkal?= Date: Sat, 27 Jan 2024 19:42:44 +0000 Subject: [PATCH 042/338] Qt: Update translation (Turkish) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/tr/ --- src/platform/qt/ts/mgba-tr.ts | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/src/platform/qt/ts/mgba-tr.ts b/src/platform/qt/ts/mgba-tr.ts index 73ab0b7caa7..a98e0639b0c 100644 --- a/src/platform/qt/ts/mgba-tr.ts +++ b/src/platform/qt/ts/mgba-tr.ts @@ -211,7 +211,7 @@ Yeni sürüm: %2 Can't start an audio processor without input - + GiriÅŸsiz ses iÅŸlemcisi baÅŸlatılamaz @@ -219,7 +219,7 @@ Yeni sürüm: %2 Can't start an audio processor without input - + GiriÅŸsiz ses iÅŸlemcisi baÅŸlatılamaz @@ -287,28 +287,28 @@ Yeni sürüm: %2 BattleChip data missing - + BattleChip verisi yok BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? - + BattleChip verisi yok. Bazı grafikler olmadan BattleChip Gates hala çalışır. Verileri ÅŸimdi indirmek istermisin? Select deck file - + Deste dosyası seç Incompatible deck - + Uyumsuz deste The selected deck is not compatible with this Chip Gate - + Seçilen deste bu Chip Gate ile uyumlu deÄŸildir @@ -334,7 +334,7 @@ Yeni sürüm: %2 Add New Code - + Yeni Kod Ekle @@ -344,12 +344,12 @@ Yeni sürüm: %2 Add Lines - + Satır ekle Code type - + Kod tipi @@ -370,7 +370,7 @@ Yeni sürüm: %2 Autodetect (recommended) - + Otoseç (tavsiye edilir) @@ -381,7 +381,7 @@ Yeni sürüm: %2 Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. - + Bazı hileler eklenemedi. Lütfen onların doÄŸru formatlandığından emin ol ve/yada baÅŸa hile tiplerini dene. @@ -400,7 +400,7 @@ Yeni sürüm: %2 Reset the game? - + Oyun sıfırlansım mı? From b78d230ba984c514babc33877acdf5e06a0647e0 Mon Sep 17 00:00:00 2001 From: Guih48 Date: Fri, 20 Oct 2023 16:42:39 +0000 Subject: [PATCH 043/338] Qt: Update translation (Hungarian) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/hu/ --- src/platform/qt/ts/mgba-hu.ts | 72 +++++++++++++++++++---------------- 1 file changed, 39 insertions(+), 33 deletions(-) diff --git a/src/platform/qt/ts/mgba-hu.ts b/src/platform/qt/ts/mgba-hu.ts index 4e5f7e1f08f..6db9b2da969 100644 --- a/src/platform/qt/ts/mgba-hu.ts +++ b/src/platform/qt/ts/mgba-hu.ts @@ -21,7 +21,7 @@ %1 Video Logs (*.mvl) - + %1 Videonaplók (*.mvl) @@ -50,8 +50,9 @@ © 2013 – {year} Jeffrey Pfau, licensed under the Mozilla Public License, version 2.0 Game Boy Advance is a registered trademark of Nintendo Co., Ltd. - © 2013 – {year} Jeffrey Pfau, a Mozilla Public License 2.0 alatt licencelve -A Game Boy Advance a Nintendo Co., Ltd. bejegyzett védjegye + © 2013 – {year} Jeffrey Pfau, a Mozilla Public License 2.0 alatt licencelve. + +A Game Boy Advance a Nintendo Co., Ltd. bejegyzett védjegye. @@ -64,47 +65,52 @@ A Game Boy Advance a Nintendo Co., Ltd. bejegyzett védjegye An update is available - + Egy frissítés érhetÅ‘ el An update to %1 is available. - + Egy frissítés elérhetÅ‘ %1 verzióra. + Do you want to download and install it now? You will need to restart the emulator when the download is complete. - + +Szeretné most letöleni és telepíteni? Az emulátor újraindítására lesz szükség a letöltés befejezésekor. Auto-update is not available on this platform. If you wish to update you will need to do it manually. - + +Az automatikus frisítés ezen platformon nem elérhetÅ‘, a frissítéseket manuálisan telepíthetÅ‘k. Current version: %1 New version: %2 Download size: %3 - + Jelenlegi verzió: %1 +Új verzió: %2 +LetöltendÅ‘ adat: %3 Downloading update... - + Frissítés letöltése... Downloading failed. Please update manually. - + A letöltés meghiúsult. Próbálja meg manuálisan frissíteni aprogramot. Downloading done. Press OK to restart %1 and install the update. - + A letöltés kész. Nyomja meg az OK gombot %1 újraindításához és a frissítés telepítéséhez. @@ -112,22 +118,22 @@ Download size: %3 Stable - + Stabil Development - + Fejlesztési Unknown - + Nem ismert (None) - + (nincs) @@ -148,7 +154,7 @@ Download size: %3 Tile # - + Cím # @@ -232,7 +238,7 @@ Download size: %3 Insert - + Beszúrás @@ -329,7 +335,7 @@ Download size: %3 Add New Code - + Új kód hozzáadása @@ -339,12 +345,12 @@ Download size: %3 Add Lines - + Sorok hozzáadása Code type - + Kód típusa @@ -365,7 +371,7 @@ Download size: %3 Autodetect (recommended) - + Automatikus felisnerés (javasolt) @@ -376,7 +382,7 @@ Download size: %3 Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. - + Néhány csalást nem sikerült betölteni. EllenÅ‘rizze, hogy helyesen formázottak-e és/vagy próbáljon ki más csalástípust! @@ -390,7 +396,7 @@ Download size: %3 Rewinding not currently enabled - + Visszatekerés jelenleg nem engedélyezett @@ -451,7 +457,7 @@ Download size: %3 Debugger - HibakeresÅ‘ + HibakeresÅ‘ @@ -477,7 +483,7 @@ Download size: %3 Connect to Dolphin - Csatlakozás Dolphin emulátorhoz + Csatlakozás Dolphin emulátorhoz @@ -512,12 +518,12 @@ Download size: %3 Couldn't Connect - + Nem sikerült csatlakozni Could not connect to Dolphin. - + Nem sikerült csatlakozni Dolphin emulátorhoz. @@ -719,7 +725,7 @@ Download size: %3 Inspect frame - Képkocka vizsgáló + Képkocka vizsgálata @@ -965,22 +971,22 @@ Download size: %3 Autodetect - Automatikus észlelés + Automatikus észlelés Game Boy (DMG) - + Game Boy (DMG) Game Boy Pocket (MGB) - + Game Boy Pocket (MGB) Super Game Boy (SGB) - + Super Game Boy (SGB) @@ -1138,7 +1144,7 @@ Download size: %3 0x0000 - + 0x0000 From af2e2fd517c712a08a5a501dc710580f06e3b3b6 Mon Sep 17 00:00:00 2001 From: Anatolij Vasilev Date: Fri, 3 Nov 2023 10:39:49 +0000 Subject: [PATCH 044/338] Qt: Update translation (German) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/de/ --- src/platform/qt/ts/mgba-de.ts | 48 +++++++++++++++++------------------ 1 file changed, 24 insertions(+), 24 deletions(-) diff --git a/src/platform/qt/ts/mgba-de.ts b/src/platform/qt/ts/mgba-de.ts index a1d1b2e1588..ce7f38c30a4 100644 --- a/src/platform/qt/ts/mgba-de.ts +++ b/src/platform/qt/ts/mgba-de.ts @@ -70,7 +70,7 @@ Game Boy Advance ist eine eingetragene Marke von Nintendo Co., Ltd. An update to %1 is available. - Ein Update für %1 ist verfügbar. + Ein Update auf %1 ist verfügbar. @@ -132,7 +132,7 @@ Download-Größe: %3 (None) - (keiner) + (Nichts) @@ -145,7 +145,7 @@ Download-Größe: %3 Loading... - Laden â€¦ + Lädt â€¦ @@ -198,7 +198,7 @@ Download-Größe: %3 Audio device is missing its core - Dem Audio-Gerät fehlt ein Core + Dem Audio-Gerät fehlt sein Core @@ -395,7 +395,7 @@ Download-Größe: %3 Rewinding not currently enabled - Rücklauf ist derzeit nicht aktiviert + Zurückspulen ist derzeit nicht aktiviert @@ -716,7 +716,7 @@ Download-Größe: %3 Image files (*.png *.jpg *.bmp) - + Bilddateien (*.png *.jpg *.bmp) @@ -724,7 +724,7 @@ Download-Größe: %3 Inspect frame - Bild beobachten + Frame untersuchen @@ -734,7 +734,7 @@ Download-Größe: %3 Freeze frame - Bild einfrieren + Frame einfrieren @@ -3752,17 +3752,17 @@ Download-Größe: %3 Trying to detach a multiplayer player that's not attached - + Versuch Multiplayer-Spieler zu trennen der nicht verbunden ist Trying to get player ID for a multiplayer player that's not attached - + Versuch Spieler-ID festzustellen von einem Multiplayer-Spieler der nicht verbunden ist Trying to get save ID for a multiplayer player that's not attached - + Versuch Speicherstand-ID festzustellen von einem Multiplayer-Spieler der nicht verbunden ist @@ -4310,7 +4310,7 @@ Download-Größe: %3 Save file: - + Speicherstand: @@ -4477,7 +4477,7 @@ Download-Größe: %3 + RTC - + + RTC @@ -4759,12 +4759,12 @@ Download-Größe: %3 Select image - Bild auswählen + Bild auswählen Image file (*.png *.jpg *.jpeg) - Bilddatei (*.png *.jpg *.jpeg) + Bilddatei (*.png *.jpg *.jpeg) @@ -5074,7 +5074,7 @@ Download-Größe: %3 Custom border: - + Benutzerdefinierter Rand: @@ -5119,7 +5119,7 @@ Download-Größe: %3 Rewind speed: - + Zurückspulgeschwindigkeit: @@ -5457,7 +5457,7 @@ Download-Größe: %3 Enable rewind - Rücklauf aktivieren + Zurückspulen aktivieren @@ -5467,7 +5467,7 @@ Download-Größe: %3 Rewind history: - Rücklauf-Verlauf: + Zurückspulverlauf: @@ -6317,12 +6317,12 @@ Download-Größe: %3 Increase fast forward speed - + Vorspulgeschwindigkeit erhöhen Decrease fast forward speed - + Vorspulgeschwindigkeit senken @@ -6771,17 +6771,17 @@ Download-Größe: %3 Super (L) - Super (L) + Super (L) Super (R) - Super (R) + Super (R) Menu - Menü + Menü From 33bfd7f752e0c035a811b4c2487397bb268e6871 Mon Sep 17 00:00:00 2001 From: ssantos Date: Mon, 18 Dec 2023 15:26:35 +0000 Subject: [PATCH 045/338] Qt: Update translation (Portuguese) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/pt/ --- src/platform/qt/ts/mgba-pt.ts | 32 +++++++++++++++++--------------- 1 file changed, 17 insertions(+), 15 deletions(-) diff --git a/src/platform/qt/ts/mgba-pt.ts b/src/platform/qt/ts/mgba-pt.ts index 72af03abedf..cddb1dd8cf0 100644 --- a/src/platform/qt/ts/mgba-pt.ts +++ b/src/platform/qt/ts/mgba-pt.ts @@ -716,7 +716,7 @@ Tamanho da descarga: %3 Image files (*.png *.jpg *.bmp) - + Ficheiro da imagem (*.png *.jpg *.bmp) @@ -3752,17 +3752,17 @@ Tamanho da descarga: %3 Trying to detach a multiplayer player that's not attached - + A tentar desconectar um jogador multiplayer que não está conectado Trying to get player ID for a multiplayer player that's not attached - + A tentar obter a ID do jogador para um jogador multiplayer que não está conectado Trying to get save ID for a multiplayer player that's not attached - + A tentar obter a ID gravada para um jogador multiplayer que não está conectado @@ -4310,7 +4310,7 @@ Tamanho da descarga: %3 Save file: - + Ficheiro do save: @@ -4477,7 +4477,7 @@ Tamanho da descarga: %3 + RTC - + + RTC @@ -4759,12 +4759,12 @@ Tamanho da descarga: %3 Select image - Selecionar imagem + Selecionar imagem Image file (*.png *.jpg *.jpeg) - Ficheiro da imagem (*.png *.jpg *.jpeg) + Ficheiro da imagem (*.png *.jpg *.jpeg) @@ -4792,6 +4792,7 @@ Tamanho da descarga: %3 %n hora atrás %n horas atrás + %n horas atrás @@ -4800,6 +4801,7 @@ Tamanho da descarga: %3 %n dia atrás %n dias atrás + %n dias atrás @@ -5249,7 +5251,7 @@ Tamanho da descarga: %3 Custom border: - + Borda personalizada: @@ -5285,7 +5287,7 @@ Tamanho da descarga: %3 Rewind speed: - + Velocidade do retrocesso: @@ -6403,12 +6405,12 @@ Tamanho da descarga: %3 Increase fast forward speed - + Aumentar a velocidade do avanço rápido Decrease fast forward speed - + Diminuir a velocidade do avanço rápido @@ -6771,17 +6773,17 @@ Tamanho da descarga: %3 Super (L) - Super (E) + Super (E) Super (R) - Super (D) + Super (D) Menu - Menu + Menu From 910326f29d3d29b941f61d659f812bc35ade1b51 Mon Sep 17 00:00:00 2001 From: Imre Kristoffer Eilertsen Date: Thu, 22 Feb 2024 01:36:33 +0000 Subject: [PATCH 046/338] =?UTF-8?q?Qt:=20Update=20translation=20(Norwegian?= =?UTF-8?q?=20Bokm=C3=A5l)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/nb_NO/ --- src/platform/qt/ts/mgba-nb_NO.ts | 764 +++++++++++++++---------------- 1 file changed, 382 insertions(+), 382 deletions(-) diff --git a/src/platform/qt/ts/mgba-nb_NO.ts b/src/platform/qt/ts/mgba-nb_NO.ts index 128bee3ac7f..4a97f0c6073 100644 --- a/src/platform/qt/ts/mgba-nb_NO.ts +++ b/src/platform/qt/ts/mgba-nb_NO.ts @@ -16,7 +16,7 @@ All ROMs (%1) - + Alle ROM-filer (%1) @@ -64,7 +64,7 @@ Game Boy Advance er et registrert varemerke tilhørende Nintendo Co., Ltd. An update is available - + En oppdatering er tilgjengelig @@ -96,7 +96,7 @@ Nedlastningsstørrelse: %3 Downloading update... - Laster ned ny versjon … + Laster ned oppdatering … @@ -114,22 +114,22 @@ Nedlastningsstørrelse: %3 Stable - + Stabil Development - + Utvikling Unknown - Ukjent + Ukjent (None) - + (Ingen) @@ -142,7 +142,7 @@ Nedlastningsstørrelse: %3 Loading... - Laster inn … + Laster inn ... @@ -264,7 +264,7 @@ Nedlastningsstørrelse: %3 Inserted - + Satt inn @@ -331,7 +331,7 @@ Nedlastningsstørrelse: %3 Add New Code - + Legg til ny kode @@ -341,7 +341,7 @@ Nedlastningsstørrelse: %3 Add Lines - + Legg til linjer @@ -367,7 +367,7 @@ Nedlastningsstørrelse: %3 Autodetect (recommended) - + Auto-oppdag (anbefales) @@ -463,7 +463,7 @@ Nedlastningsstørrelse: %3 Break - + Stopp @@ -514,12 +514,12 @@ Nedlastningsstørrelse: %3 Couldn't Connect - + Kunne ikke koble til Could not connect to Dolphin. - + Klarte ikke Ã¥ koble til Dolphin. @@ -527,7 +527,7 @@ Nedlastningsstørrelse: %3 3DS - + 3DS @@ -540,7 +540,7 @@ Nedlastningsstørrelse: %3 Icon - + Ikon @@ -553,17 +553,17 @@ Nedlastningsstørrelse: %3 Bubble - + Boble Background - Bakgrunn + Bakgrunn Startup - + Oppstart @@ -576,12 +576,12 @@ Nedlastningsstørrelse: %3 Files - + Filer ROM file: - + ROM-fil: @@ -593,7 +593,7 @@ Nedlastningsstørrelse: %3 Output filename: - + Utdata-filnavn: @@ -603,7 +603,7 @@ Nedlastningsstørrelse: %3 Latest stable version - + Nyeste stabile versjon @@ -613,42 +613,42 @@ Nedlastningsstørrelse: %3 Specific file - + Spesifikk fil Base file: - + Grunnfil: System - + System 3DS - + 3DS Vita - + Vita Presentation - + Presentasjon Title: - + Tittel: Images: - + Bilder: @@ -658,17 +658,17 @@ Nedlastningsstørrelse: %3 Preferred size: - + Ønsket størrelse: Select image file - + Velg bildefil Select ROM file - + Velg ROM-fil @@ -678,7 +678,7 @@ Nedlastningsstørrelse: %3 Select base file - + Velg grunnfil @@ -708,12 +708,12 @@ Nedlastningsstørrelse: %3 Select an image - + Velg et bilde Image files (*.png *.jpg *.bmp) - + Bildefiler (*.png *.jpg *.bmp) @@ -736,7 +736,7 @@ Nedlastningsstørrelse: %3 Backdrop color - + Bakgrunnsfarge @@ -791,12 +791,12 @@ Nedlastningsstørrelse: %3 Backdrop - + Bakgrunn Frame - + Ramme @@ -850,7 +850,7 @@ Nedlastningsstørrelse: %3 Bind address - + Bindingsadresse @@ -875,7 +875,7 @@ Nedlastningsstørrelse: %3 Break - + Stopp @@ -967,7 +967,7 @@ Nedlastningsstørrelse: %3 Autodetect - + Auto-oppdag @@ -1037,7 +1037,7 @@ Nedlastningsstørrelse: %3 MBC5 + Rumble - + MBC5 + risting @@ -1047,7 +1047,7 @@ Nedlastningsstørrelse: %3 MBC7 (Tilt) - + MBC7 (Tilt) @@ -1112,12 +1112,12 @@ Nedlastningsstørrelse: %3 GGB-81 - + GGB-81 Li Cheng - + Li Cheng @@ -1135,12 +1135,12 @@ Nedlastningsstørrelse: %3 I/O Viewer - + I/O-visning 0x0000 - + 0x0000 @@ -1232,7 +1232,7 @@ Nedlastningsstørrelse: %3 Enable OBJ - + Skru pÃ¥ OBJ @@ -1252,17 +1252,17 @@ Nedlastningsstørrelse: %3 Currently in VBlank - + For øyeblikket i VBlank Currently in HBlank - + For øyeblikket i HBlank Currently in VCounter - + For øyeblikket i VCounter @@ -1319,7 +1319,7 @@ Nedlastningsstørrelse: %3 Enable 256-color - + Skru pÃ¥ 256-fargemodus @@ -1742,7 +1742,7 @@ Nedlastningsstørrelse: %3 Initial volume - + Volum ved begynnelse @@ -1801,28 +1801,28 @@ Nedlastningsstørrelse: %3 0% - 0% + 0 % 100% - 100% + 100% 50% - 50% + 50% 25% - 25% + 25% @@ -1830,7 +1830,7 @@ Nedlastningsstørrelse: %3 75% - 75% + 75% @@ -1848,13 +1848,13 @@ Nedlastningsstørrelse: %3 15 - 15 + 15 7 - 7 + 7 @@ -1954,7 +1954,7 @@ Nedlastningsstørrelse: %3 0 - 0 + 0 @@ -1967,7 +1967,7 @@ Nedlastningsstørrelse: %3 1 - 1 + 1 @@ -2137,22 +2137,22 @@ Nedlastningsstørrelse: %3 Right/A - + Høyre/A Left/B - + Venstre/B Up/Select - + Opp/Select Down/Start - + Ned/Start @@ -2162,7 +2162,7 @@ Nedlastningsstørrelse: %3 Active face buttons - + Skru pÃ¥ hovedknappene @@ -2182,12 +2182,12 @@ Nedlastningsstørrelse: %3 Divider - + Skillelinje 1/16 - 1/16 + 1/16 @@ -2479,7 +2479,7 @@ Nedlastningsstørrelse: %3 Red - Rød + Rød @@ -2618,7 +2618,7 @@ Nedlastningsstørrelse: %3 Immediate - + Umiddelbart @@ -2681,7 +2681,7 @@ Nedlastningsstørrelse: %3 Video Capture - + Videoopptak @@ -2715,7 +2715,7 @@ Nedlastningsstørrelse: %3 1/64 - 1/64 + 1/64 @@ -2724,7 +2724,7 @@ Nedlastningsstørrelse: %3 1/256 - 1/256 + 1/256 @@ -2733,14 +2733,14 @@ Nedlastningsstørrelse: %3 1/1024 - 1/1024 + 1/1024 Cascade - + Cascade @@ -2891,7 +2891,7 @@ Nedlastningsstørrelse: %3 Gamepak - + Spillkassett @@ -2905,7 +2905,7 @@ Nedlastningsstørrelse: %3 4 - 4 + 4 @@ -2913,7 +2913,7 @@ Nedlastningsstørrelse: %3 3 - 3 + 3 @@ -2922,7 +2922,7 @@ Nedlastningsstørrelse: %3 2 - 2 + 2 @@ -2931,7 +2931,7 @@ Nedlastningsstørrelse: %3 8 - 8 + 8 @@ -2966,7 +2966,7 @@ Nedlastningsstørrelse: %3 PHI terminal - + PHI-terminal @@ -2977,17 +2977,17 @@ Nedlastningsstørrelse: %3 4.19MHz - + 4,19MHz 8.38MHz - + 8,38MHz 16.78MHz - + 16,78MHz @@ -3006,7 +3006,7 @@ Nedlastningsstørrelse: %3 --- - + --- @@ -3019,7 +3019,7 @@ Nedlastningsstørrelse: %3 Location - + Sted @@ -3034,7 +3034,7 @@ Nedlastningsstørrelse: %3 CRC32 - + CRC32 @@ -3111,12 +3111,12 @@ Nedlastningsstørrelse: %3 Load State - + Last inn tilstand Save State - + Lagre tilstand @@ -3170,12 +3170,12 @@ Nedlastningsstørrelse: %3 Stub - + Stump Game Error - Spillfeil + Spillfeil @@ -3183,7 +3183,7 @@ Nedlastningsstørrelse: %3 [%1] %2: %3 - + [%1] %2: %3 @@ -3208,7 +3208,7 @@ Nedlastningsstørrelse: %3 WARN - + ADVARSEL @@ -3246,7 +3246,7 @@ Nedlastningsstørrelse: %3 Stub - + Stump @@ -3304,7 +3304,7 @@ Nedlastningsstørrelse: %3 Export - Eksporter + Eksporter @@ -3352,12 +3352,12 @@ Nedlastningsstørrelse: %3 Mirror - + Speilvend None - Ingen + Ingen @@ -3367,12 +3367,12 @@ Nedlastningsstørrelse: %3 Horizontal - + Horisontal Vertical - + Vertikal @@ -3389,7 +3389,7 @@ Nedlastningsstørrelse: %3 Portable Network Graphics (*.png) - + Portable Network Graphics (*.png) @@ -3440,7 +3440,7 @@ Nedlastningsstørrelse: %3 Paste - Lim inn + Lim inn @@ -3450,7 +3450,7 @@ Nedlastningsstørrelse: %3 All - + Alle @@ -3480,12 +3480,12 @@ Nedlastningsstørrelse: %3 TBL - + TBL ISO-8859-1 - + ISO-8859-1 @@ -3519,7 +3519,7 @@ Nedlastningsstørrelse: %3 Numeric - + Numerisk @@ -3535,7 +3535,7 @@ Nedlastningsstørrelse: %3 Guess - + Gjett @@ -3555,17 +3555,17 @@ Nedlastningsstørrelse: %3 Number type - + Nummertype Decimal - + Desimal Hexadecimal - + Heksadesimal @@ -3640,17 +3640,17 @@ Nedlastningsstørrelse: %3 (%0/%1×) - + (%0/%1×) (â…Ÿ%0×) - + (â…Ÿ%0×) (%0×) - + (%0×) @@ -3741,7 +3741,7 @@ Nedlastningsstørrelse: %3 Frame %1 - + Bilde %1 @@ -3807,17 +3807,17 @@ Nedlastningsstørrelse: %3 Export - Eksporter + Eksporter Attributes - + Attributter Transform - + Transformer @@ -3851,13 +3851,13 @@ Nedlastningsstørrelse: %3 H Short for horizontal - + H V Short for vertical - + V @@ -3878,7 +3878,7 @@ Nedlastningsstørrelse: %3 Enabled - + Skrudd pÃ¥ @@ -3894,7 +3894,7 @@ Nedlastningsstørrelse: %3 0x%0 - + 0x%0 @@ -3906,7 +3906,7 @@ Nedlastningsstørrelse: %3 --- - + --- @@ -3916,12 +3916,12 @@ Nedlastningsstørrelse: %3 OBJWIN - + OBJWIN Invalid - + Ugyldig @@ -3945,7 +3945,7 @@ Nedlastningsstørrelse: %3 Game Overrides - + Overstyringer for spill @@ -3958,7 +3958,7 @@ Nedlastningsstørrelse: %3 Autodetect - + Auto-oppdag @@ -3973,7 +3973,7 @@ Nedlastningsstørrelse: %3 Tilt - + Tilt @@ -4013,7 +4013,7 @@ Nedlastningsstørrelse: %3 EEPROM 8kB - + EEPROM 8kB @@ -4033,7 +4033,7 @@ Nedlastningsstørrelse: %3 Game Boy Player features - + Game Boy Player-funksjoner @@ -4043,12 +4043,12 @@ Nedlastningsstørrelse: %3 Game Boy - + Game Boy Game Boy model - + Game Boy-modell @@ -4073,7 +4073,7 @@ Nedlastningsstørrelse: %3 Palette preset - + ForhÃ¥ndsvalgt fargepalett @@ -4096,7 +4096,7 @@ Nedlastningsstørrelse: %3 Palette - Palett + Palett @@ -4151,17 +4151,17 @@ Nedlastningsstørrelse: %3 Export OBJ - + Eksporter OBJ #%0 - + #%0 0x%0 - + 0x%0 @@ -4169,7 +4169,7 @@ Nedlastningsstørrelse: %3 0x%0 (%1) - 0x%0 (%1) + 0x%0 (%1) @@ -4197,7 +4197,7 @@ Nedlastningsstørrelse: %3 All - + Alle @@ -4207,12 +4207,12 @@ Nedlastningsstørrelse: %3 X - + X Y - + Y @@ -4277,32 +4277,32 @@ Nedlastningsstørrelse: %3 ROM Info - + ROM-info Game name: - + Spillets navn: Internal name: - + Internt navn: Game ID: - + Spill-ID: File size: - + Filstørrelse: CRC32: - + CRC32: @@ -4340,7 +4340,7 @@ Nedlastningsstørrelse: %3 Save - Lagre + Lagre @@ -4350,7 +4350,7 @@ Nedlastningsstørrelse: %3 Include save file - + Inkluder lagrefilen @@ -4378,7 +4378,7 @@ Nedlastningsstørrelse: %3 Select save game - + Velg lagrefil @@ -4439,7 +4439,7 @@ Nedlastningsstørrelse: %3 Output file - + Utdatafil @@ -4459,7 +4459,7 @@ Nedlastningsstørrelse: %3 SRAM - SRAM + SRAM @@ -4469,7 +4469,7 @@ Nedlastningsstørrelse: %3 %1 EEPROM - + %1 EEPROM @@ -4509,17 +4509,17 @@ Nedlastningsstørrelse: %3 MBC6 SRAM - + MBC6-SRAM TAMA5 - TAMA5 + TAMA5 %1 (%2) - + %1 (%2) @@ -4555,12 +4555,12 @@ Nedlastningsstørrelse: %3 Run - + Kjør File - + Fil @@ -4570,17 +4570,17 @@ Nedlastningsstørrelse: %3 Load script... - + Last inn skript... &Reset - + &Omstart 0 - 0 + 0 @@ -4595,7 +4595,7 @@ Nedlastningsstørrelse: %3 All files (*.*) - + Alle filer (*.*) @@ -4603,12 +4603,12 @@ Nedlastningsstørrelse: %3 Sensors - + Sensorer Realtime clock - Sanntidsklokke + Sanntidsklokke @@ -4618,7 +4618,7 @@ Nedlastningsstørrelse: %3 System time - + Systemtid @@ -4628,7 +4628,7 @@ Nedlastningsstørrelse: %3 Now - + NÃ¥ @@ -4638,27 +4638,27 @@ Nedlastningsstørrelse: %3 sec - + sek MM/dd/yy hh:mm:ss AP - + dd/mm/YYYY hh:mm:ss AP Light sensor - Lyssensor + Lyssensor Brightness - + Lysstyrke Tilt sensor - + Tiltsensor @@ -4675,12 +4675,12 @@ Nedlastningsstørrelse: %3 Gyroscope - Gyroskop + Gyroskop Sensitivity - + Følsomhet @@ -4715,12 +4715,12 @@ Nedlastningsstørrelse: %3 None - Ingen + Ingen None (Still Image) - + Ingen (stillbilde) @@ -4756,32 +4756,32 @@ Nedlastningsstørrelse: %3 Select image - Velg bilde + Velg bilde Image file (*.png *.jpg *.jpeg) - + Bildefil (*.png *.jpg *.jpeg) (%1×%2) - + (%1×%2) Never - + Aldri Just now - + Akkurat nÃ¥ Less than an hour ago - + Mindre enn én time siden @@ -4802,12 +4802,12 @@ Nedlastningsstørrelse: %3 Settings - + Innstillinger Audio/Video - + Lyd/Video @@ -4817,93 +4817,93 @@ Nedlastningsstørrelse: %3 Interface - + Grensesnitt Update - + Oppdater Emulation - + Emulering Enhancements - + Forbedringer BIOS - + BIOS Paths - + Filbaner Logging - + Loggføring Game Boy - + Game Boy Audio driver: - + Lyddriver: Audio buffer: - + Lydbuffer: 1536 - 1536 + 1536 512 - 512 + 512 768 - 768 + 768 1024 - 1024 + 1024 2048 - 2048 + 2048 3072 - 3072 + 3072 4096 - 4096 + 4096 samples - + datapunkter @@ -4914,32 +4914,32 @@ Nedlastningsstørrelse: %3 44100 - 44100 + 44100 22050 - 22050 + 22050 32000 - 32000 + 32000 48000 - 48000 + 48000 Hz - + Hz Volume: - + Volum: @@ -4947,7 +4947,7 @@ Nedlastningsstørrelse: %3 Mute - + Demp lyd @@ -4962,7 +4962,7 @@ Nedlastningsstørrelse: %3 All windows - + Alle vinduer @@ -4977,7 +4977,7 @@ Nedlastningsstørrelse: %3 Display driver: - + Skjermdriver: @@ -4987,45 +4987,45 @@ Nedlastningsstørrelse: %3 Skip every - + Hopp over hver frames - + bilder FPS target: - + SiktemÃ¥l for bildefrekvens: frames per second - + bilder per sekund Sync: - + Synkroniser: Video - + Video Audio - + Lyd Lock aspect ratio - + LÃ¥s visningsforhold @@ -5035,7 +5035,7 @@ Nedlastningsstørrelse: %3 Bilinear filtering - + Bilineær filtrering @@ -5046,7 +5046,7 @@ Nedlastningsstørrelse: %3 Pause - + Pause @@ -5056,7 +5056,7 @@ Nedlastningsstørrelse: %3 On loading a game: - + NÃ¥r det lastes inn et spill: @@ -5081,32 +5081,32 @@ Nedlastningsstørrelse: %3 Current channel: - + NÃ¥værende kanal: Current version: - + NÃ¥værende versjon: Update channel: - + Oppdateringskanal: Available version: - + Tilgjengelig versjon: (Unknown) - + (Ukjent) Last checked: - + Sist sjekket: @@ -5116,7 +5116,7 @@ Nedlastningsstørrelse: %3 Check now - + Sjekk nÃ¥ @@ -5126,37 +5126,37 @@ Nedlastningsstørrelse: %3 SGB color palette if available - + SGB-fargepalett hvis tilgjengelig GBC color palette if available - + GBC-fargepalett hvis tilgjengelig SGB (preferred) or GBC color palette if available - + SGB (foretrukket) eller GBC-fargepalett hvis tilgjengelig Game Boy Camera - + Game Boy Camera Driver: - + Driver: Source: - + Kilde: Native (59.7275) - + Systemstandard (59.7275) @@ -5166,32 +5166,32 @@ Nedlastningsstørrelse: %3 Language - + SprÃ¥k Library: - + Bibliotek: List view - + Listevisning Tree view - + Tre-visning Show when no game open - + Vis nÃ¥r ingen spill er Ã¥pne Clear cache - + Tøm mellomlageret @@ -5231,7 +5231,7 @@ Nedlastningsstørrelse: %3 Show FPS in title bar - + Vis bildefrekvensen i tittellinjen @@ -5272,7 +5272,7 @@ Nedlastningsstørrelse: %3 Enable rewind - + Skru pÃ¥ tilbakespoling @@ -5292,12 +5292,12 @@ Nedlastningsstørrelse: %3 Run all - + Kjør alle Remove known - + Fjern kjente @@ -5328,54 +5328,54 @@ Nedlastningsstørrelse: %3 Models - + Modeller GB only: - + Kun GB: SGB compatible: - + SGB-kompatibel: GBC only: - + Kun GBC: GBC compatible: - + GBC-kompatibel: SGB and GBC compatible: - + SGB- og GBC-kompatible: Game Boy palette - + Game Boy-fargepalett Preset: - + ForhÃ¥ndsinnstilling: Screenshot - + Skjermbilde Cheat codes - + Juksekoder @@ -5395,7 +5395,7 @@ Nedlastningsstørrelse: %3 Software - + Programvare @@ -5410,7 +5410,7 @@ Nedlastningsstørrelse: %3 (240×160) - + (240×160) @@ -5444,22 +5444,22 @@ Nedlastningsstørrelse: %3 Skip BIOS intro - + Hopp over BIOS-introen GBA BIOS file: - + GBA-BIOS-fil: GBC BIOS file: - + GBC-BIOS-fil: SGB BIOS file: - + SGB-BIOS-fil: @@ -5488,7 +5488,7 @@ Nedlastningsstørrelse: %3 Patches - + Patcher @@ -5498,7 +5498,7 @@ Nedlastningsstørrelse: %3 Log to file - + Loggfør til en fil @@ -5528,7 +5528,7 @@ Nedlastningsstørrelse: %3 Super Game Boy borders - + Super Game Boy-kanter @@ -5567,7 +5567,7 @@ Nedlastningsstørrelse: %3 Shaders - Skyggeleggere + Skygger @@ -5577,17 +5577,17 @@ Nedlastningsstørrelse: %3 Name - Navn + Navn Author - + Skaper Description - + Beskrivelse @@ -5615,7 +5615,7 @@ Nedlastningsstørrelse: %3 Gamepad - + Kontroller @@ -5628,17 +5628,17 @@ Nedlastningsstørrelse: %3 Keyboard - Tastatur + Tastatur Gamepad - + Kontroller Clear - Tøm + Tøm @@ -5672,17 +5672,17 @@ Nedlastningsstørrelse: %3 Export All - + Eksporter alle 256 colors - + 256 farger Palette - Palett + Palett @@ -5697,7 +5697,7 @@ Nedlastningsstørrelse: %3 Fit to window - + Tilpass til vinduet @@ -5717,7 +5717,7 @@ Nedlastningsstørrelse: %3 Both - Begge + Begge @@ -5727,7 +5727,7 @@ Nedlastningsstørrelse: %3 Copy All - + Kopier alle @@ -5755,44 +5755,44 @@ Nedlastningsstørrelse: %3 Start - Start + Begynn Stop - Stopp + Stopp Select File - Velg fil + Velg fil Presets - + ForhÃ¥ndsinnstillinger High &Quality - + Høy &kvalitet &YouTube - + &YouTube WebM - + WebM MP4 - + MP4 @@ -5802,22 +5802,22 @@ Nedlastningsstørrelse: %3 4K - 4K + 4K &1080p - + &1080p &720p - + &720p &480p - + &480p @@ -5827,47 +5827,47 @@ Nedlastningsstørrelse: %3 Format - + Format MKV - + MKV AVI - + AVI H.264 - + H.264 H.264 (NVENC) - + H.264 (NVENC) HEVC - + HEVC HEVC (NVENC) - + HEVC (NVENC) VP8 - + VP8 VP9 - + VP9 @@ -5878,12 +5878,12 @@ Nedlastningsstørrelse: %3 None - Ingen + Ingen FLAC - + FLAC @@ -5893,27 +5893,27 @@ Nedlastningsstørrelse: %3 Opus - + Opus Vorbis - + Vorbis MP3 - + MP3 AAC - + AAC Uncompressed - + Ukomprimert @@ -5923,32 +5923,32 @@ Nedlastningsstørrelse: %3 ABR - + ABR VBR - + VBR CRF - + CRF Dimensions - Dimensjoner + Dimensjoner Lock aspect ratio - + LÃ¥s visningsforhold Show advanced - Vis avanserte innstillinger + Vis avansert @@ -5974,7 +5974,7 @@ Nedlastningsstørrelse: %3 Select save - + Velg lagrefil @@ -5989,12 +5989,12 @@ Nedlastningsstørrelse: %3 Select e-Reader dotcode - + Velg e-Reader-punktkode e-Reader card (*.raw *.bin *.bmp) - + e-Reader-kort (*.raw *.bin *.bmp) @@ -6019,7 +6019,7 @@ Nedlastningsstørrelse: %3 Video logs (*.mvl) - + Videologgføringer (*.mvl) @@ -6036,12 +6036,12 @@ Nedlastningsstørrelse: %3 Couldn't Start - + Klarte ikke Ã¥ starte opp Could not start game. - + Klarte ikke Ã¥ starte opp spillet. @@ -6071,7 +6071,7 @@ Nedlastningsstørrelse: %3 Restart needed - + Gjennomfør omstart @@ -6086,12 +6086,12 @@ Nedlastningsstørrelse: %3 %1 - %2 - + %1 - %2 %1 - %2 - %3 - + %1 - %2 - %3 @@ -6101,12 +6101,12 @@ Nedlastningsstørrelse: %3 &File - + &Fil Load &ROM... - + Last inn &ROM... @@ -6126,7 +6126,7 @@ Nedlastningsstørrelse: %3 Select save game - + Velg lagrefil @@ -6142,12 +6142,12 @@ Nedlastningsstørrelse: %3 Select e-Reader card images - + Velg e-Reader-kortavbildninger Image file (*.png *.jpg *.jpeg) - + Bildefil (*.png *.jpg *.jpeg) @@ -6177,17 +6177,17 @@ Nedlastningsstørrelse: %3 Boot BIOS - + Oppstarts-BIOS Replace ROM... - + Bytt ROM.... Scan e-Reader dotcodes... - + Skann e-Reader-punktkoder... @@ -6202,7 +6202,7 @@ Nedlastningsstørrelse: %3 Recent - + Nylig @@ -6212,7 +6212,7 @@ Nedlastningsstørrelse: %3 &Load state - + &Last inn tilstand @@ -6222,7 +6222,7 @@ Nedlastningsstørrelse: %3 &Save state - + &Lagre en tilstand @@ -6323,47 +6323,47 @@ Nedlastningsstørrelse: %3 Connect to Dolphin... - + Koble til Dolphin... Report bug... - + Rapporter inn feil... About... - + Om … E&xit - + A&vslutt &Emulation - + &Emulering &Reset - + &Omstart Sh&utdown - + Skr&u av Yank game pak - + Dra ut spillkassetten &Pause - + &Pause @@ -6393,7 +6393,7 @@ Nedlastningsstørrelse: %3 %0x - %0x + %0x @@ -6408,7 +6408,7 @@ Nedlastningsstørrelse: %3 Rewind (held) - + Spol tilbake (holdt) @@ -6423,37 +6423,37 @@ Nedlastningsstørrelse: %3 Solar sensor - + Solsensor Increase solar level - + Øke solnivÃ¥et Decrease solar level - + Reduser solnivÃ¥et Brightest solar level - + Lyseste solnivÃ¥ Darkest solar level - + Mørkeste solnivÃ¥ Brightness %1 - + Lysstyrke %1 Game Boy Printer... - + Game Boy Printer... @@ -6468,22 +6468,22 @@ Nedlastningsstørrelse: %3 Frame size - + Rammestørrelse %1× - %1× + %1× Toggle fullscreen - + Skru pÃ¥/av fullskjerm Lock aspect ratio - + LÃ¥s visningsforhold @@ -6498,7 +6498,7 @@ Nedlastningsstørrelse: %3 Bilinear filtering - + Bilineær filtrering @@ -6508,7 +6508,7 @@ Nedlastningsstørrelse: %3 Mute - + Demp lyd @@ -6518,17 +6518,17 @@ Nedlastningsstørrelse: %3 Native (59.7275) - + Systemstandard (59.7275) Take &screenshot - + Ta &skjermbilde F12 - + F12 @@ -6548,7 +6548,7 @@ Nedlastningsstørrelse: %3 Audio channels - + Lydkanaler @@ -6558,7 +6558,7 @@ Nedlastningsstørrelse: %3 &Tools - + Verk&tøy @@ -6573,7 +6573,7 @@ Nedlastningsstørrelse: %3 Game Pak sensors... - + Game Pak-sensorer ... @@ -6588,7 +6588,7 @@ Nedlastningsstørrelse: %3 Settings... - + Innstillinger… @@ -6613,7 +6613,7 @@ Nedlastningsstørrelse: %3 View &palette... - + Vis &palett ... @@ -6628,7 +6628,7 @@ Nedlastningsstørrelse: %3 View &map... - + Vis &kart … @@ -6663,7 +6663,7 @@ Nedlastningsstørrelse: %3 Exit fullscreen - + GÃ¥ ut av fullskjerm @@ -6728,7 +6728,7 @@ Nedlastningsstørrelse: %3 Clear - Tøm + Tøm @@ -6736,47 +6736,47 @@ Nedlastningsstørrelse: %3 %1 byte - + %1 byte %1 kiB - + %1 kiB %1 MiB - + %1 MiB GBA - + GBA GB - + GB ? - + ? Super (L) - + Super (L) Super (R) - + Super (R) Menu - Meny + Meny @@ -6784,22 +6784,22 @@ Nedlastningsstørrelse: %3 Shift - + Shift Control - + Kontroll Alt - + Alt Meta - + Meta From 890713124414cc03fca28bb3e6b87e2183db2732 Mon Sep 17 00:00:00 2001 From: Hexaae Date: Sun, 25 Feb 2024 22:41:33 +0000 Subject: [PATCH 047/338] Qt: Update translation (Italian) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/it/ --- src/platform/qt/ts/mgba-it.ts | 102 +++++++++++++++++----------------- 1 file changed, 51 insertions(+), 51 deletions(-) diff --git a/src/platform/qt/ts/mgba-it.ts b/src/platform/qt/ts/mgba-it.ts index a0a0deb5edd..12a018db737 100644 --- a/src/platform/qt/ts/mgba-it.ts +++ b/src/platform/qt/ts/mgba-it.ts @@ -530,12 +530,12 @@ Dimensione del download: %3 3DS - + 3DS Vita - + Vita @@ -543,12 +543,12 @@ Dimensione del download: %3 Icon - + Icona Banner - + Striscia @@ -556,7 +556,7 @@ Dimensione del download: %3 Bubble - + Bolla @@ -566,7 +566,7 @@ Dimensione del download: %3 Startup - + Avvio @@ -574,17 +574,17 @@ Dimensione del download: %3 Create forwarder - + Crea Icona di avvio Files - + File ROM file: - + File ROM: @@ -596,127 +596,127 @@ Dimensione del download: %3 Output filename: - + Nome file in uscita: Forwarder base: - + Base dell'Icona di avvio: Latest stable version - + Ultima versione stabile Latest development build - + Ultima development build Specific file - + File specifico Base file: - + File base: System - + Sistema 3DS - + 3DS Vita - + Vita Presentation - + Presentazione Title: - + Titolo: Images: - + Immagini: Use default image - + Usa immagine predefinita Preferred size: - + Dimensione preferita: Select image file - + Seleziona file immagine Select ROM file - + Seleziona file ROM Select output filename - + Selezione nome file in uscita Select base file - + Selezione file base Build finished - + Build completata Forwarder finished building - + Icona di avvio compilazione completata Build failed - + Build fallita Failed to build forwarder - + Impossibile compilare Icona di avvio %1 installable package (*.%2) - + %1 pacchetto installabile (*.%2) Select an image - + Seleziona una immagine Image files (*.png *.jpg *.bmp) - + File immagine (*.png *.jpg *.bmp) @@ -1085,12 +1085,12 @@ Dimensione del download: %3 NT (old 1) - + NT (vec. 1) NT (old 2) - + NT (vec. 2) @@ -1115,12 +1115,12 @@ Dimensione del download: %3 GGB-81 - + GGB-81 Li Cheng - + Li Cheng @@ -3752,17 +3752,17 @@ Dimensione del download: %3 Trying to detach a multiplayer player that's not attached - + Tentativo di scollegare un giocatore in multi che non è collegato Trying to get player ID for a multiplayer player that's not attached - + Cerco di ottenere l'ID giocatore per un giocatore in multi non collegato Trying to get save ID for a multiplayer player that's not attached - + Cerco di ottenere l'ID di salvataggio per un giocatore in multi non collegato @@ -4310,7 +4310,7 @@ Dimensione del download: %3 Save file: - + Salva file: @@ -4477,7 +4477,7 @@ Dimensione del download: %3 + RTC - + + RTC @@ -4779,7 +4779,7 @@ Dimensione del download: %3 Just now - Solo adesso + Proprio adesso @@ -5079,7 +5079,7 @@ Dimensione del download: %3 Custom border: - + Bordo personalizzato: @@ -5109,7 +5109,7 @@ Dimensione del download: %3 Last checked: - Vista l'ultima volta: + Ultimo controllo: @@ -5124,7 +5124,7 @@ Dimensione del download: %3 Rewind speed: - + Velocità riavvolgimento: @@ -5891,7 +5891,7 @@ Dimensione del download: %3 WavPack - + WavPack @@ -6312,12 +6312,12 @@ Dimensione del download: %3 Increase fast forward speed - + Aumenta la velocità di avvolgimento veloce Decrease fast forward speed - + Diminuisci la velocità di avvolgimento veloce @@ -6447,7 +6447,7 @@ Dimensione del download: %3 Create forwarder... - + Crea Icona di avvio... From ee1a860ac4e944e8c450bf182baa5587621d926a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 3 Apr 2024 04:57:19 -0700 Subject: [PATCH 048/338] SDL: Fix build on SDL 2.0.12 --- src/platform/sdl/sdl-events.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/platform/sdl/sdl-events.c b/src/platform/sdl/sdl-events.c index 38377563649..cd34a778173 100644 --- a/src/platform/sdl/sdl-events.c +++ b/src/platform/sdl/sdl-events.c @@ -920,12 +920,14 @@ static const char* const buttonNamesXboxOne[SDL_CONTROLLER_BUTTON_MAX] = { [SDL_CONTROLLER_BUTTON_RIGHTSTICK] = "RS", [SDL_CONTROLLER_BUTTON_LEFTSHOULDER] = "LB", [SDL_CONTROLLER_BUTTON_RIGHTSHOULDER] = "RB", +#if SDL_VERSION_ATLEAST(2, 0, 14) [SDL_CONTROLLER_BUTTON_MISC1] = "Share", [SDL_CONTROLLER_BUTTON_PADDLE1] = "P1", [SDL_CONTROLLER_BUTTON_PADDLE2] = "P2", [SDL_CONTROLLER_BUTTON_PADDLE3] = "P3", [SDL_CONTROLLER_BUTTON_PADDLE4] = "P4", [SDL_CONTROLLER_BUTTON_TOUCHPAD] = "Touch", +#endif }; static const char* const buttonNamesPlayStation[SDL_CONTROLLER_BUTTON_MAX] = { @@ -940,12 +942,14 @@ static const char* const buttonNamesPlayStation[SDL_CONTROLLER_BUTTON_MAX] = { [SDL_CONTROLLER_BUTTON_RIGHTSTICK] = "R3", [SDL_CONTROLLER_BUTTON_LEFTSHOULDER] = "L1", [SDL_CONTROLLER_BUTTON_RIGHTSHOULDER] = "R1", +#if SDL_VERSION_ATLEAST(2, 0, 14) [SDL_CONTROLLER_BUTTON_MISC1] = "Misc", [SDL_CONTROLLER_BUTTON_PADDLE1] = "P1", [SDL_CONTROLLER_BUTTON_PADDLE2] = "P2", [SDL_CONTROLLER_BUTTON_PADDLE3] = "P3", [SDL_CONTROLLER_BUTTON_PADDLE4] = "P4", [SDL_CONTROLLER_BUTTON_TOUCHPAD] = "Touch", +#endif }; static const char* const buttonNamesNintedo[SDL_CONTROLLER_BUTTON_MAX] = { @@ -960,12 +964,14 @@ static const char* const buttonNamesNintedo[SDL_CONTROLLER_BUTTON_MAX] = { [SDL_CONTROLLER_BUTTON_RIGHTSTICK] = "RS", [SDL_CONTROLLER_BUTTON_LEFTSHOULDER] = "L", [SDL_CONTROLLER_BUTTON_RIGHTSHOULDER] = "R", +#if SDL_VERSION_ATLEAST(2, 0, 14) [SDL_CONTROLLER_BUTTON_MISC1] = "Share", [SDL_CONTROLLER_BUTTON_PADDLE1] = "P1", [SDL_CONTROLLER_BUTTON_PADDLE2] = "P2", [SDL_CONTROLLER_BUTTON_PADDLE3] = "P3", [SDL_CONTROLLER_BUTTON_PADDLE4] = "P4", [SDL_CONTROLLER_BUTTON_TOUCHPAD] = "Touch", +#endif }; static const char* const buttonNamesGeneric[SDL_CONTROLLER_BUTTON_MAX] = { From b5a2f62c88957217d4b0b1a18806b3f602947684 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 3 Apr 2024 04:59:04 -0700 Subject: [PATCH 049/338] SDL: Really fix the build this time --- src/platform/sdl/sdl-events.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/platform/sdl/sdl-events.c b/src/platform/sdl/sdl-events.c index cd34a778173..08a369c7352 100644 --- a/src/platform/sdl/sdl-events.c +++ b/src/platform/sdl/sdl-events.c @@ -899,12 +899,14 @@ static const char* const buttonNamesXbox360[SDL_CONTROLLER_BUTTON_MAX] = { [SDL_CONTROLLER_BUTTON_RIGHTSTICK] = "RS", [SDL_CONTROLLER_BUTTON_LEFTSHOULDER] = "LB", [SDL_CONTROLLER_BUTTON_RIGHTSHOULDER] = "RB", +#if SDL_VERSION_ATLEAST(2, 0, 14) [SDL_CONTROLLER_BUTTON_MISC1] = "Misc", [SDL_CONTROLLER_BUTTON_PADDLE1] = "P1", [SDL_CONTROLLER_BUTTON_PADDLE2] = "P2", [SDL_CONTROLLER_BUTTON_PADDLE3] = "P3", [SDL_CONTROLLER_BUTTON_PADDLE4] = "P4", [SDL_CONTROLLER_BUTTON_TOUCHPAD] = "Touch", +#endif }; #if SDL_VERSION_ATLEAST(2, 0, 12) @@ -986,12 +988,14 @@ static const char* const buttonNamesGeneric[SDL_CONTROLLER_BUTTON_MAX] = { [SDL_CONTROLLER_BUTTON_RIGHTSTICK] = "RS", [SDL_CONTROLLER_BUTTON_LEFTSHOULDER] = "LB", [SDL_CONTROLLER_BUTTON_RIGHTSHOULDER] = "RB", +#if SDL_VERSION_ATLEAST(2, 0, 14) [SDL_CONTROLLER_BUTTON_MISC1] = "Misc", [SDL_CONTROLLER_BUTTON_PADDLE1] = "P1", [SDL_CONTROLLER_BUTTON_PADDLE2] = "P2", [SDL_CONTROLLER_BUTTON_PADDLE3] = "P3", [SDL_CONTROLLER_BUTTON_PADDLE4] = "P4", [SDL_CONTROLLER_BUTTON_TOUCHPAD] = "Touch", +#endif }; #endif From 104d746c1ead326f9499abe443c131f9bf701a98 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 4 Apr 2024 00:28:58 -0700 Subject: [PATCH 050/338] Core: Fix some mutex ordering --- src/core/thread.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/core/thread.c b/src/core/thread.c index 4b470777d57..11465e23213 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -433,13 +433,13 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { threadContext->run(threadContext); } } + MutexLock(&impl->stateMutex); } - while (impl->state < mTHREAD_SHUTDOWN) { - MutexLock(&impl->stateMutex); + if (impl->state < mTHREAD_SHUTDOWN) { impl->state = mTHREAD_SHUTDOWN; - MutexUnlock(&impl->stateMutex); } + MutexUnlock(&impl->stateMutex); if (core->opts.rewindEnable) { mCoreRewindContextDeinit(&impl->rewind); From 008a6f3f237bb7cb86b43386cc5c160e97053704 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 4 Apr 2024 00:31:47 -0700 Subject: [PATCH 051/338] Scripting: Attempt to fix MSVC build --- include/mgba/script/macros.h | 4 ++-- include/mgba/script/types.h | 1 + 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/include/mgba/script/macros.h b/include/mgba/script/macros.h index 7d2057d4e4f..70eed0af58b 100644 --- a/include/mgba/script/macros.h +++ b/include/mgba/script/macros.h @@ -323,7 +323,7 @@ CXX_GUARD_START } \ #define _mSCRIPT_DECLARE_STRUCT_OVERLOADED_METHOD_BINDING(TYPE, NAME, T) \ - static const struct mScriptFunctionOverload _mSTStructBindingOverloads_ ## TYPE ## _ ## NAME[]; \ + static const struct mScriptFunctionOverload _mSTStructBindingOverloads_ ## TYPE ## _ ## NAME[mSCRIPT_OVERLOADS_MAX]; \ static bool _mSTStructBinding_ ## TYPE ## _ ## NAME(struct mScriptFrame* frame, void* ctx) { \ UNUSED(ctx); \ const struct mScriptFunctionOverload* overload = mScriptFunctionFindOverload(_mSTStructBindingOverloads_ ## TYPE ## _ ## NAME, &frame->arguments); \ @@ -468,7 +468,7 @@ CXX_GUARD_START #define mSCRIPT_DEFINE_DEFAULTS_END } #define mSCRIPT_DEFINE_STRUCT_METHOD_OVERLOADS(STRUCT, METHOD) \ - static const struct mScriptFunctionOverload _mSTStructBindingOverloads_ ## STRUCT ## _ ## METHOD[] = { \ + static const struct mScriptFunctionOverload _mSTStructBindingOverloads_ ## STRUCT ## _ ## METHOD[mSCRIPT_OVERLOADS_MAX] = { \ #define mSCRIPT_DEFINE_STRUCT_METHOD_OVERLOAD(TYPE, FUNCTION) { \ .type = &_mSTStructBindingType_ ## TYPE ## _ ## FUNCTION, \ diff --git a/include/mgba/script/types.h b/include/mgba/script/types.h index 5770456e6b5..5b07abe3bc2 100644 --- a/include/mgba/script/types.h +++ b/include/mgba/script/types.h @@ -16,6 +16,7 @@ CXX_GUARD_START #define mSCRIPT_VALUE_UNREF -1 #define mSCRIPT_PARAMS_MAX 8 +#define mSCRIPT_OVERLOADS_MAX 8 #define mSCRIPT_VALUE_DOC_FUNCTION(NAME) (&_mScriptDoc_ ## NAME) From e61a324df28d250c67e6bec3f37ca6de1b9b119d Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 4 Apr 2024 22:49:48 -0700 Subject: [PATCH 052/338] Core: More threading cleanup --- include/mgba/core/thread.h | 3 ++- src/core/thread.c | 42 +++++++++++++++++++------------------- 2 files changed, 23 insertions(+), 22 deletions(-) diff --git a/include/mgba/core/thread.h b/include/mgba/core/thread.h index d3d8a9e9277..9f2c229bec2 100644 --- a/include/mgba/core/thread.h +++ b/include/mgba/core/thread.h @@ -87,7 +87,8 @@ struct mCoreThreadInternal { int requested; Mutex stateMutex; - Condition stateCond; + Condition stateOnThreadCond; + Condition stateOffThreadCond; int interruptDepth; bool frameWasOn; diff --git a/src/core/thread.c b/src/core/thread.c index 11465e23213..e0ace624027 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -44,12 +44,12 @@ static void _mCoreLog(struct mLogger* logger, int category, enum mLogLevel level static void _changeState(struct mCoreThreadInternal* threadContext, enum mCoreThreadState newState) { threadContext->state = newState; - ConditionWake(&threadContext->stateCond); + ConditionWake(&threadContext->stateOffThreadCond); } static void _waitOnInterrupt(struct mCoreThreadInternal* threadContext) { while (threadContext->state == mTHREAD_INTERRUPTED || threadContext->state == mTHREAD_INTERRUPTING) { - ConditionWait(&threadContext->stateCond, &threadContext->stateMutex); + ConditionWait(&threadContext->stateOnThreadCond, &threadContext->stateMutex); } } @@ -110,7 +110,7 @@ static void _wait(struct mCoreThreadInternal* threadContext) { #endif MutexLock(&threadContext->stateMutex); - ConditionWake(&threadContext->stateCond); + ConditionWake(&threadContext->stateOnThreadCond); } static void _waitOnRequest(struct mCoreThreadInternal* threadContext, enum mCoreThreadRequest request) { @@ -140,7 +140,7 @@ static void _sendRequest(struct mCoreThreadInternal* threadContext, enum mCoreTh static void _cancelRequest(struct mCoreThreadInternal* threadContext, enum mCoreThreadRequest request) { threadContext->requested &= ~request; _pokeRequest(threadContext); - ConditionWake(&threadContext->stateCond); + ConditionWake(&threadContext->stateOffThreadCond); } void _frameStarted(void* context) { @@ -351,19 +351,18 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { while (impl->state >= mTHREAD_MIN_WAITING && impl->state < mTHREAD_EXITING) { if (impl->state == mTHREAD_INTERRUPTING) { - impl->state = mTHREAD_INTERRUPTED; - ConditionWake(&impl->stateCond); + _changeState(impl, mTHREAD_INTERRUPTED); } while (impl->state >= mTHREAD_MIN_WAITING && impl->state <= mTHREAD_MAX_WAITING) { #ifdef USE_DEBUGGERS if (debugger && debugger->state != DEBUGGER_SHUTDOWN) { mDebuggerUpdate(debugger); - ConditionWaitTimed(&impl->stateCond, &impl->stateMutex, 10); + ConditionWaitTimed(&impl->stateOnThreadCond, &impl->stateMutex, 10); } else #endif { - ConditionWait(&impl->stateCond, &impl->stateMutex); + ConditionWait(&impl->stateOnThreadCond, &impl->stateMutex); } if (impl->sync.audioWait) { @@ -392,14 +391,13 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { if (impl->state == mTHREAD_REQUEST) { if (pendingRequests) { if (pendingRequests & mTHREAD_REQ_PAUSE) { - impl->state = mTHREAD_PAUSED; + _changeState(impl, mTHREAD_PAUSED); } if (pendingRequests & mTHREAD_REQ_WAIT) { - impl->state = mTHREAD_PAUSED; + _changeState(impl, mTHREAD_PAUSED); } } else { - impl->state = mTHREAD_RUNNING; - ConditionWake(&threadContext->impl->stateCond); + _changeState(impl, mTHREAD_RUNNING); } } MutexUnlock(&impl->stateMutex); @@ -439,6 +437,7 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { if (impl->state < mTHREAD_SHUTDOWN) { impl->state = mTHREAD_SHUTDOWN; } + ConditionWake(&threadContext->impl->stateOffThreadCond); MutexUnlock(&impl->stateMutex); if (core->opts.rewindEnable) { @@ -477,7 +476,8 @@ bool mCoreThreadStart(struct mCoreThread* threadContext) { } MutexInit(&threadContext->impl->stateMutex); - ConditionInit(&threadContext->impl->stateCond); + ConditionInit(&threadContext->impl->stateOnThreadCond); + ConditionInit(&threadContext->impl->stateOffThreadCond); MutexInit(&threadContext->impl->sync.videoFrameMutex); ConditionInit(&threadContext->impl->sync.videoFrameAvailableCond); @@ -502,7 +502,7 @@ bool mCoreThreadStart(struct mCoreThread* threadContext) { MutexLock(&threadContext->impl->stateMutex); ThreadCreate(&threadContext->impl->thread, _mCoreThreadRun, threadContext); while (threadContext->impl->state < mTHREAD_RUNNING) { - ConditionWait(&threadContext->impl->stateCond, &threadContext->impl->stateMutex); + ConditionWait(&threadContext->impl->stateOffThreadCond, &threadContext->impl->stateMutex); } MutexUnlock(&threadContext->impl->stateMutex); @@ -544,7 +544,7 @@ bool mCoreThreadHasCrashed(struct mCoreThread* threadContext) { void mCoreThreadMarkCrashed(struct mCoreThread* threadContext) { MutexLock(&threadContext->impl->stateMutex); - threadContext->impl->state = mTHREAD_CRASHED; + _changeState(threadContext->impl, mTHREAD_CRASHED); MutexUnlock(&threadContext->impl->stateMutex); } @@ -552,7 +552,7 @@ void mCoreThreadClearCrashed(struct mCoreThread* threadContext) { MutexLock(&threadContext->impl->stateMutex); if (threadContext->impl->state == mTHREAD_CRASHED) { threadContext->impl->state = mTHREAD_REQUEST; - ConditionWake(&threadContext->impl->stateCond); + ConditionWake(&threadContext->impl->stateOnThreadCond); } MutexUnlock(&threadContext->impl->stateMutex); } @@ -561,7 +561,7 @@ void mCoreThreadEnd(struct mCoreThread* threadContext) { MutexLock(&threadContext->impl->stateMutex); _waitOnInterrupt(threadContext->impl); threadContext->impl->state = mTHREAD_EXITING; - ConditionWake(&threadContext->impl->stateCond); + ConditionWake(&threadContext->impl->stateOnThreadCond); MutexUnlock(&threadContext->impl->stateMutex); MutexLock(&threadContext->impl->sync.audioBufferMutex); threadContext->impl->sync.audioWait = 0; @@ -590,7 +590,8 @@ void mCoreThreadJoin(struct mCoreThread* threadContext) { ThreadJoin(&threadContext->impl->thread); MutexDeinit(&threadContext->impl->stateMutex); - ConditionDeinit(&threadContext->impl->stateCond); + ConditionDeinit(&threadContext->impl->stateOnThreadCond); + ConditionDeinit(&threadContext->impl->stateOffThreadCond); MutexDeinit(&threadContext->impl->sync.videoFrameMutex); ConditionWake(&threadContext->impl->sync.videoFrameAvailableCond); @@ -642,7 +643,6 @@ void mCoreThreadInterruptFromThread(struct mCoreThread* threadContext) { return; } threadContext->impl->state = mTHREAD_INTERRUPTING; - ConditionWake(&threadContext->impl->stateCond); MutexUnlock(&threadContext->impl->stateMutex); } @@ -658,7 +658,7 @@ void mCoreThreadContinue(struct mCoreThread* threadContext) { } else { threadContext->impl->state = mTHREAD_RUNNING; } - ConditionWake(&threadContext->impl->stateCond); + ConditionWake(&threadContext->impl->stateOnThreadCond); } MutexUnlock(&threadContext->impl->stateMutex); } @@ -718,7 +718,7 @@ void mCoreThreadSetRewinding(struct mCoreThread* threadContext, bool rewinding) threadContext->impl->rewinding = rewinding; if (rewinding && threadContext->impl->state == mTHREAD_CRASHED) { threadContext->impl->state = mTHREAD_REQUEST; - ConditionWake(&threadContext->impl->stateCond); + ConditionWake(&threadContext->impl->stateOnThreadCond); } MutexUnlock(&threadContext->impl->stateMutex); } From 1f2d0d505625414eacbd38f426b94e274ea18aa6 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 5 Apr 2024 00:10:09 -0700 Subject: [PATCH 053/338] GBA GPIO: Fix gyro read-out start (fixes #3141) --- CHANGES | 1 + src/gba/cart/gpio.c | 10 ++++++---- src/platform/3ds/main.c | 2 +- src/platform/libretro/libretro.c | 2 +- src/platform/psp2/psp2-context.c | 2 +- src/platform/sdl/sdl-events.c | 4 ++-- src/platform/switch/main.c | 2 +- src/platform/wii/main.c | 2 +- 8 files changed, 14 insertions(+), 11 deletions(-) diff --git a/CHANGES b/CHANGES index efb7d494e1c..5abed6a7eab 100644 --- a/CHANGES +++ b/CHANGES @@ -12,6 +12,7 @@ Emulation fixes: - GB Video: Implement DMG-style sprite ordering - GBA: Unhandled bkpt should be treated as an undefined exception - GBA GPIO: Fix tilt scale and orientation (fixes mgba.io/i/2703) + - GBA GPIO: Fix gyro read-out start (fixes mgba.io/i/3141) - GBA I/O: Fix HALTCNT access behavior (fixes mgba.io/i/2309) - GBA SIO: Fix MULTI mode SIOCNT bit 7 writes on secondary GBAs (fixes mgba.io/i/3110) - GBA Video: Disable BG target 1 blending when OBJ blending (fixes mgba.io/i/2722) diff --git a/src/gba/cart/gpio.c b/src/gba/cart/gpio.c index 53c14dafda5..811dc1e8a1c 100644 --- a/src/gba/cart/gpio.c +++ b/src/gba/cart/gpio.c @@ -320,18 +320,20 @@ void _gyroReadPins(struct GBACartridgeHardware* hw) { return; } + // Write bit on falling edge + bool doOutput = hw->gyroEdge && !(hw->pinState & 2); if (hw->pinState & 1) { if (gyro->sample) { gyro->sample(gyro); } int32_t sample = gyro->readGyroZ(gyro); - // Normalize to ~12 bits, focused on 0x6C0 - hw->gyroSample = (sample >> 21) + 0x6C0; // Crop off an extra bit so that we can't go negative + // Normalize to ~12 bits, focused on 0x700 + hw->gyroSample = (sample >> 21) + 0x700; // Crop off an extra bit so that we can't go negative + doOutput = true; } - if (hw->gyroEdge && !(hw->pinState & 2)) { - // Write bit on falling edge + if (doOutput) { unsigned bit = hw->gyroSample >> 15; hw->gyroSample <<= 1; _outputPins(hw, bit << 2); diff --git a/src/platform/3ds/main.c b/src/platform/3ds/main.c index 0f7bb27b93d..36df49a9c0b 100644 --- a/src/platform/3ds/main.c +++ b/src/platform/3ds/main.c @@ -704,7 +704,7 @@ static int32_t _readTiltY(struct mRotationSource* source) { static int32_t _readGyroZ(struct mRotationSource* source) { struct m3DSRotationSource* rotation = (struct m3DSRotationSource*) source; - return rotation->gyro.y << 18L; // Yes, y + return rotation->gyro.y << 17L; // Yes, y } static void _startRequestImage(struct mImageSource* source, unsigned w, unsigned h, int colorFormats) { diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index bea9f62731f..69c547b5734 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -1390,7 +1390,7 @@ static void _updateRotation(struct mRotationSource* source) { tiltY = sensorGetCallback(0, RETRO_SENSOR_ACCELEROMETER_Y) * 2e8f; } if (gyroEnabled) { - gyroZ = sensorGetCallback(0, RETRO_SENSOR_GYROSCOPE_Z) * -1.1e9f; + gyroZ = sensorGetCallback(0, RETRO_SENSOR_GYROSCOPE_Z) * -5.5e8f; } } diff --git a/src/platform/psp2/psp2-context.c b/src/platform/psp2/psp2-context.c index a7504f7cca9..1e48c2f24f5 100644 --- a/src/platform/psp2/psp2-context.c +++ b/src/platform/psp2/psp2-context.c @@ -149,7 +149,7 @@ static int32_t _readTiltY(struct mRotationSource* source) { static int32_t _readGyroZ(struct mRotationSource* source) { struct mSceRotationSource* rotation = (struct mSceRotationSource*) source; - return rotation->state.gyro.z * -0x10000000; + return rotation->state.gyro.z * -0x8000000; } static void _setRumble(struct mRumble* source, int enable) { diff --git a/src/platform/sdl/sdl-events.c b/src/platform/sdl/sdl-events.c index 08a369c7352..46807cae1e6 100644 --- a/src/platform/sdl/sdl-events.c +++ b/src/platform/sdl/sdl-events.c @@ -823,14 +823,14 @@ static void _mSDLRotationSample(struct mRotationSource* source) { float theta[3]; int count = SDL_GameControllerGetSensorData(controller, SDL_SENSOR_GYRO, theta, 3); if (count >= 0) { - rotation->zDelta = theta[1] / -10.f; + rotation->zDelta = theta[1] / -20.f; } return; } } #endif if (rotation->gyroZ >= 0) { - rotation->zDelta = SDL_JoystickGetAxis(rotation->p->joystick->joystick, rotation->gyroZ) / 1.e5f; + rotation->zDelta = SDL_JoystickGetAxis(rotation->p->joystick->joystick, rotation->gyroZ) / 2.e5f; return; } diff --git a/src/platform/switch/main.c b/src/platform/switch/main.c index ef3e12164b2..15196aaeca5 100644 --- a/src/platform/switch/main.c +++ b/src/platform/switch/main.c @@ -644,7 +644,7 @@ void _sampleRotation(struct mRotationSource* source) { } tiltX = sixaxis.acceleration.x * 3e8f; tiltY = sixaxis.acceleration.y * -3e8f; - gyroZ = sixaxis.angular_velocity.z * -1.1e9f; + gyroZ = sixaxis.angular_velocity.z * -5.5e8f; } int32_t _readTiltX(struct mRotationSource* source) { diff --git a/src/platform/wii/main.c b/src/platform/wii/main.c index db3ed724296..60d4e95ae8a 100644 --- a/src/platform/wii/main.c +++ b/src/platform/wii/main.c @@ -1731,7 +1731,7 @@ void _sampleRotation(struct mRotationSource* source) { return; } gyroZ = exp.mp.rz - 0x1FA0; - gyroZ <<= 18; + gyroZ <<= 17; } int32_t _readTiltX(struct mRotationSource* source) { From 04a95a5445b2617a0015a268bd3e36577c521214 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 8 Apr 2024 02:10:58 -0700 Subject: [PATCH 054/338] CHANGES: Remove duplicate entry --- CHANGES | 1 - 1 file changed, 1 deletion(-) diff --git a/CHANGES b/CHANGES index 5abed6a7eab..e08179d7246 100644 --- a/CHANGES +++ b/CHANGES @@ -11,7 +11,6 @@ Emulation fixes: - GB Serialize: Add missing Pocket Cam state to savestates - GB Video: Implement DMG-style sprite ordering - GBA: Unhandled bkpt should be treated as an undefined exception - - GBA GPIO: Fix tilt scale and orientation (fixes mgba.io/i/2703) - GBA GPIO: Fix gyro read-out start (fixes mgba.io/i/3141) - GBA I/O: Fix HALTCNT access behavior (fixes mgba.io/i/2309) - GBA SIO: Fix MULTI mode SIOCNT bit 7 writes on secondary GBAs (fixes mgba.io/i/3110) From 47ec447dd0902661c3e21766b60788a43778d401 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 8 Apr 2024 02:11:14 -0700 Subject: [PATCH 055/338] CMakeLists: Fix strtof_l detection logic --- CMakeLists.txt | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 3f2ff468615..aee8ac51247 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -345,18 +345,14 @@ find_function(popcount32) find_function(futimens) find_function(futimes) +find_function(localtime_r) find_function(realpath) if(ANDROID AND ANDROID_NDK_MAJOR GREATER 13) - find_function(localtime_r) - set(HAVE_STRTOF_L ON) -elseif(CMAKE_SYSTEM_NAME STREQUAL "Linux") - find_function(localtime_r) + list(APPEND FUNCTION_DEFINES HAVE_STRTOF_L) +elseif(NOT CMAKE_SYSTEM_NAME STREQUAL "Linux") # The strtof_l on Linux not actually exposed nor actually strtof_l - set(HAVE_STRTOF_L OFF) -else() - find_function(localtime_r) find_function(strtof_l) endif() From 02b2f5a98a7f430c60d66948d8ab57102261c302 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 8 Apr 2024 02:52:47 -0700 Subject: [PATCH 056/338] flags.h: Add missing flags --- src/core/flags.h.in | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/core/flags.h.in b/src/core/flags.h.in index 3bd142a44ac..5a9e4e6ef5e 100644 --- a/src/core/flags.h.in +++ b/src/core/flags.h.in @@ -59,6 +59,10 @@ #cmakedefine USE_DEBUGGERS #endif +#ifndef USE_DISCORD_RPC +#cmakedefine USE_DISCORD_RPC +#endif + #ifndef USE_EDITLINE #cmakedefine USE_EDITLINE #endif @@ -133,6 +137,10 @@ #cmakedefine HAVE_CRC32 #endif +#ifndef HAVE_LOCALE +#cmakedefine HAVE_LOCALE +#endif + #ifndef HAVE_LOCALTIME_R #cmakedefine HAVE_LOCALTIME_R #endif @@ -149,6 +157,10 @@ #cmakedefine HAVE_PTHREAD_SETNAME_NP #endif +#ifndef HAVE_SNPRINTF_L +#cmakedefine HAVE_SNPRINTF_L +#endif + #ifndef HAVE_STRDUP #cmakedefine HAVE_STRDUP #endif From 4652bbb4271af4054acfbf779df8720e424ad80b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 8 Apr 2024 02:53:00 -0700 Subject: [PATCH 057/338] Util: Fix #if into #ifdef --- src/util/formatting.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/util/formatting.c b/src/util/formatting.c index e1e1c0bf001..2506ddc9c66 100644 --- a/src/util/formatting.c +++ b/src/util/formatting.c @@ -46,26 +46,26 @@ float strtof_l(const char* restrict str, char** restrict end, locale_t locale) { #endif int ftostr_u(char* restrict str, size_t size, float f) { -#if HAVE_LOCALE +#ifdef HAVE_LOCALE locale_t l = newlocale(LC_NUMERIC_MASK, "C", 0); #else locale_t l = "C"; #endif int res = ftostr_l(str, size, f, l); -#if HAVE_LOCALE +#ifdef HAVE_LOCALE freelocale(l); #endif return res; } float strtof_u(const char* restrict str, char** restrict end) { -#if HAVE_LOCALE +#ifdef HAVE_LOCALE locale_t l = newlocale(LC_NUMERIC_MASK, "C", 0); #else locale_t l = "C"; #endif float res = strtof_l(str, end, l); -#if HAVE_LOCALE +#ifdef HAVE_LOCALE freelocale(l); #endif return res; From 0e441527c896022ff7a558529618f2a28036f6b2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 8 Apr 2024 03:08:10 -0700 Subject: [PATCH 058/338] CMake: Rename USE_DEBUGGERS and USE_GDB_STUB to ENABLE_DEBUGGERS and ENABLE_GDB_STUB ENABLE flags are for optional features, USE flags are for optional dependencies --- CMakeLists.txt | 26 +++++++++---------- include/mgba/core/core.h | 6 ++--- include/mgba/core/scripting.h | 6 ++--- include/mgba/internal/arm/decoder.h | 2 +- include/mgba/internal/gba/gba.h | 2 +- src/arm/decoder.c | 2 +- src/core/core.c | 2 +- src/core/flags.h.in | 16 ++++++------ src/core/scripting.c | 16 ++++++------ src/core/test/scripting.c | 4 +-- src/core/thread.c | 6 ++--- src/debugger/CMakeLists.txt | 2 +- src/debugger/cli-debugger.c | 2 +- src/debugger/debugger.c | 6 ++--- src/feature/commandline.c | 12 ++++----- src/gb/core.c | 6 ++--- src/gb/gb.c | 4 +-- src/gba/core.c | 8 +++--- src/gba/gba.c | 14 +++++----- src/platform/python/_builder.h | 2 +- src/platform/python/engine.c | 10 +++---- src/platform/python/lib.h | 2 +- src/platform/qt/CMakeLists.txt | 4 +-- src/platform/qt/CoreController.cpp | 8 +++--- src/platform/qt/CoreController.h | 4 +-- src/platform/qt/GDBController.h | 2 +- src/platform/qt/Window.cpp | 20 +++++++------- src/platform/qt/Window.h | 8 +++--- .../qt/scripting/ScriptingController.cpp | 2 +- src/platform/sdl/main.c | 6 ++--- src/platform/sdl/sdl-events.c | 2 +- src/platform/test/rom-test-main.c | 6 ++--- src/script/stdlib.c | 2 +- 33 files changed, 110 insertions(+), 110 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index aee8ac51247..24caaaf9f32 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -46,11 +46,11 @@ else() endif() if(NOT LIBMGBA_ONLY) - set(USE_DEBUGGERS ON CACHE BOOL "Whether or not to enable the debugging infrastructure") + set(ENABLE_DEBUGGERS ON CACHE BOOL "Whether or not to enable the debugging infrastructure") if (NOT WIN32) set(USE_EDITLINE ON CACHE BOOL "Whether or not to enable the CLI-mode debugger") endif() - set(USE_GDB_STUB ON CACHE BOOL "Whether or not to enable the GDB stub ARM debugger") + set(ENABLE_GDB_STUB ON CACHE BOOL "Whether or not to enable the GDB stub ARM debugger") set(USE_FFMPEG ON CACHE BOOL "Whether or not to enable FFmpeg support") set(USE_ZLIB ON CACHE BOOL "Whether or not to enable zlib support") set(USE_MINIZIP ON CACHE BOOL "Whether or not to enable external minizip support") @@ -301,7 +301,7 @@ endif() if(DEFINED 3DS OR DEFINED PSP2 OR DEFINED WII OR DEFINED SWITCH) set(IS_EMBEDDED ON) - set(USE_DEBUGGERS OFF) + set(ENABLE_DEBUGGERS OFF) set(USE_SQLITE3 OFF) set(USE_DISCORD_RPC OFF) set(USE_LIBZIP OFF CACHE BOOL "") @@ -313,12 +313,12 @@ if(DEFINED SWITCH) endif() if(NOT M_CORE_GBA) - set(USE_GDB_STUB OFF) + set(ENABLE_GDB_STUB OFF) endif() -if(NOT USE_DEBUGGERS) +if(NOT ENABLE_DEBUGGERS) set(USE_EDITLINE OFF) - set(USE_GDB_STUB OFF) + set(ENABLE_GDB_STUB OFF) endif() if(WII) @@ -489,7 +489,7 @@ if(NOT BUILD_GLES2 AND NOT BUILD_GLES3 AND NOT LIBMGBA_ONLY) endif() if(DISABLE_DEPS) - set(USE_GDB_STUB OFF) + set(ENABLE_GDB_STUB OFF) set(USE_DISCORD_RPC OFF) set(USE_JSON_C OFF) set(USE_SQLITE3 OFF) @@ -541,8 +541,8 @@ else() set(DEBUGGER_LIB "") endif() -if(USE_GDB_STUB) - list(APPEND FEATURES GDB_STUB) +if(ENABLE_GDB_STUB) + list(APPEND ENABLES GDB_STUB) endif() source_group("Debugger" FILES ${DEBUGGER_SRC}) @@ -851,10 +851,10 @@ if(M_CORE_GBA) list(APPEND TEST_SRC ${ARM_TEST_SRC} ${GBA_TEST_SRC}) endif() -if(USE_DEBUGGERS) +if(ENABLE_DEBUGGERS) list(APPEND FEATURE_SRC ${DEBUGGER_SRC}) list(APPEND TEST_SRC ${DEBUGGER_TEST_SRC}) - list(APPEND FEATURES DEBUGGERS) + list(APPEND ENABLES DEBUGGERS) endif() if(ENABLE_SCRIPTING) @@ -1312,11 +1312,11 @@ if(NOT QUIET AND NOT LIBMGBA_ONLY) message(STATUS " Game Boy Advance: ${M_CORE_GBA}") message(STATUS " Game Boy: ${M_CORE_GB}") message(STATUS "Features:") - message(STATUS " Debuggers: ${USE_DEBUGGERS}") + message(STATUS " Debuggers: ${ENABLE_DEBUGGERS}") if(NOT WIN32) message(STATUS " CLI debugger: ${USE_EDITLINE}") endif() - message(STATUS " GDB stub: ${USE_GDB_STUB}") + message(STATUS " GDB stub: ${ENABLE_GDB_STUB}") message(STATUS " GIF/Video recording: ${USE_FFMPEG}") message(STATUS " Screenshot/advanced savestate support: ${USE_PNG}") message(STATUS " ZIP support: ${SUMMARY_ZIP}") diff --git a/include/mgba/core/core.h b/include/mgba/core/core.h index 052e367957f..99bfd0e8375 100644 --- a/include/mgba/core/core.h +++ b/include/mgba/core/core.h @@ -18,7 +18,7 @@ CXX_GUARD_START #include #endif #include -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS #include #endif @@ -146,7 +146,7 @@ struct mCore { bool (*readRegister)(const struct mCore*, const char* name, void* out); bool (*writeRegister)(struct mCore*, const char* name, const void* in); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS bool (*supportsDebuggerType)(struct mCore*, enum mDebuggerType); struct mDebuggerPlatform* (*debuggerPlatform)(struct mCore*); struct CLIDebuggerSystem* (*cliDebuggerSystem)(struct mCore*); @@ -219,7 +219,7 @@ const struct mCoreMemoryBlock* mCoreGetMemoryBlockInfo(struct mCore* core, uint3 #ifdef USE_ELF struct ELF; bool mCoreLoadELF(struct mCore* core, struct ELF* elf); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void mCoreLoadELFSymbols(struct mDebuggerSymbols* symbols, struct ELF*); #endif #endif diff --git a/include/mgba/core/scripting.h b/include/mgba/core/scripting.h index 64587488302..a8fdbc425e1 100644 --- a/include/mgba/core/scripting.h +++ b/include/mgba/core/scripting.h @@ -10,7 +10,7 @@ CXX_GUARD_START -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS #include #endif #include @@ -35,7 +35,7 @@ struct mScriptEngine { void (*run)(struct mScriptEngine*); bool (*lookupSymbol)(struct mScriptEngine*, const char* name, int32_t* out); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void (*debuggerEntered)(struct mScriptEngine*, enum mDebuggerEntryReason, struct mDebuggerEntryInfo*); #endif }; @@ -63,7 +63,7 @@ void mScriptBridgeDestroy(struct mScriptBridge*); void mScriptBridgeInstallEngine(struct mScriptBridge*, struct mScriptEngine*); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void mScriptBridgeSetDebugger(struct mScriptBridge*, struct mDebugger*); struct mDebugger* mScriptBridgeGetDebugger(struct mScriptBridge*); void mScriptBridgeDebuggerEntered(struct mScriptBridge*, enum mDebuggerEntryReason, struct mDebuggerEntryInfo*); diff --git a/include/mgba/internal/arm/decoder.h b/include/mgba/internal/arm/decoder.h index c0efb22e86c..f6e19769884 100644 --- a/include/mgba/internal/arm/decoder.h +++ b/include/mgba/internal/arm/decoder.h @@ -221,7 +221,7 @@ bool ARMDecodeThumbCombine(struct ARMInstructionInfo* info1, struct ARMInstructi struct ARMInstructionInfo* out); uint32_t ARMResolveMemoryAccess(struct ARMInstructionInfo* info, struct ARMRegisterFile* regs, uint32_t pc); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS struct mDebuggerSymbols; int ARMDisassemble(const struct ARMInstructionInfo* info, struct ARMCore* core, const struct mDebuggerSymbols* symbols, uint32_t pc, char* buffer, int blen); #endif diff --git a/include/mgba/internal/gba/gba.h b/include/mgba/internal/gba/gba.h index 020dd2ab5db..e66ac47f337 100644 --- a/include/mgba/internal/gba/gba.h +++ b/include/mgba/internal/gba/gba.h @@ -160,7 +160,7 @@ struct ELF; bool GBAVerifyELFEntry(struct ELF* elf, uint32_t target); #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS struct mDebugger; void GBAAttachDebugger(struct GBA* gba, struct mDebugger* debugger); void GBADetachDebugger(struct GBA* gba); diff --git a/src/arm/decoder.c b/src/arm/decoder.c index 01622cc9df1..21ea0e872c3 100644 --- a/src/arm/decoder.c +++ b/src/arm/decoder.c @@ -9,7 +9,7 @@ #include #include -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS #define ADVANCE(AMOUNT) \ if (AMOUNT >= blen) { \ buffer[blen - 1] = '\0'; \ diff --git a/src/core/core.c b/src/core/core.c index a7de239430f..bc68fd5d2bc 100644 --- a/src/core/core.c +++ b/src/core/core.c @@ -467,7 +467,7 @@ bool mCoreLoadELF(struct mCore* core, struct ELF* elf) { return true; } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void mCoreLoadELFSymbols(struct mDebuggerSymbols* symbols, struct ELF* elf) { size_t symIndex = ELFFindSection(elf, ".symtab"); size_t names = ELFFindSection(elf, ".strtab"); diff --git a/src/core/flags.h.in b/src/core/flags.h.in index 5a9e4e6ef5e..ebfd67ed93a 100644 --- a/src/core/flags.h.in +++ b/src/core/flags.h.in @@ -49,16 +49,20 @@ // ENABLE flags +#ifndef ENABLE_DEBUGGERS +#cmakedefine ENABLE_DEBUGGERS +#endif + +#ifndef ENABLE_GDB_STUB +#cmakedefine ENABLE_GDB_STUB +#endif + #ifndef ENABLE_SCRIPTING #cmakedefine ENABLE_SCRIPTING #endif // USE flags -#ifndef USE_DEBUGGERS -#cmakedefine USE_DEBUGGERS -#endif - #ifndef USE_DISCORD_RPC #cmakedefine USE_DISCORD_RPC #endif @@ -79,10 +83,6 @@ #cmakedefine USE_FFMPEG #endif -#ifndef USE_GDB_STUB -#cmakedefine USE_GDB_STUB -#endif - #ifndef USE_JSON_C #cmakedefine USE_JSON_C #endif diff --git a/src/core/scripting.c b/src/core/scripting.c index 5b1f39a63f7..1fd37aeb900 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -64,7 +64,7 @@ static void _seRun(const char* key, void* value, void* user) { se->run(se); } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS struct mScriptDebuggerEntry { enum mDebuggerEntryReason reason; struct mDebuggerEntryInfo* info; @@ -98,7 +98,7 @@ void mScriptBridgeInstallEngine(struct mScriptBridge* sb, struct mScriptEngine* HashTableInsert(&sb->engines, name, se); } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void mScriptBridgeSetDebugger(struct mScriptBridge* sb, struct mDebugger* debugger) { if (sb->debugger == debugger) { return; @@ -159,7 +159,7 @@ struct mScriptMemoryDomain { struct mCoreMemoryBlock block; }; -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS struct mScriptBreakpointName { uint32_t address; uint32_t maxAddress; @@ -189,7 +189,7 @@ struct mScriptCoreAdapter { struct mCore* core; struct mScriptContext* context; struct mScriptValue memory; -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS struct mScriptDebugger debugger; #endif struct mRumble rumble; @@ -701,7 +701,7 @@ static void _rebuildMemoryMap(struct mScriptContext* context, struct mScriptCore } } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS static void _freeBreakpoint(void* bp) { struct mScriptBreakpoint* point = bp; HashTableDeinit(&point->callbacks); @@ -929,7 +929,7 @@ static bool _mScriptCoreAdapterClearBreakpoint(struct mScriptCoreAdapter* adapte static void _mScriptCoreAdapterDeinit(struct mScriptCoreAdapter* adapter) { _clearMemoryMap(adapter->context, adapter, false); adapter->memory.type->free(&adapter->memory); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (adapter->core->debugger) { mDebuggerDetachModule(adapter->core->debugger, &adapter->debugger.d); } @@ -982,7 +982,7 @@ mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, _deinit, _mScriptCoreAdap mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, reset, _mScriptCoreAdapterReset, 0); mSCRIPT_DECLARE_STRUCT_METHOD(mScriptCoreAdapter, WTABLE, setRotationCallbacks, _mScriptCoreAdapterSetRotationCbTable, 1, WTABLE, cbTable); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, setSolarSensorCallback, _mScriptCoreAdapterSetLuminanceCb, 1, WRAPPER, callback); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptCoreAdapter, S64, setBreakpoint, _mScriptCoreAdapterSetBreakpoint, 3, WRAPPER, callback, U32, address, S32, segment); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptCoreAdapter, S64, setWatchpoint, _mScriptCoreAdapterSetWatchpoint, 4, WRAPPER, callback, U32, address, S32, type, S32, segment); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptCoreAdapter, S64, setRangeWatchpoint, _mScriptCoreAdapterSetRangeWatchpoint, 5, WRAPPER, callback, U32, minAddress, U32, maxAddress, S32, type, S32, segment); @@ -1040,7 +1040,7 @@ mSCRIPT_DEFINE_STRUCT(mScriptCoreAdapter) "Note that the full range of values is not used by games, and the exact range depends on the calibration done by the game itself." ) mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, setSolarSensorCallback) -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS mSCRIPT_DEFINE_DOCSTRING("Set a breakpoint at a given address") mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, setBreakpoint) mSCRIPT_DEFINE_DOCSTRING("Clear a breakpoint or watchpoint for a given id returned by a previous call") diff --git a/src/core/test/scripting.c b/src/core/test/scripting.c index c2593bf14a1..d2f0f0a0004 100644 --- a/src/core/test/scripting.c +++ b/src/core/test/scripting.c @@ -327,7 +327,7 @@ M_TEST_DEFINE(screenshot) { TEARDOWN_CORE; } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void _setupBp(struct mCore* core) { switch (core->platform(core)) { #ifdef M_CORE_GBA @@ -727,7 +727,7 @@ M_TEST_SUITE_DEFINE_SETUP_TEARDOWN(mScriptCore, cmocka_unit_test(memoryWrite), cmocka_unit_test(logging), cmocka_unit_test(screenshot), -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS #ifdef M_CORE_GBA cmocka_unit_test(basicBreakpointGBA), #endif diff --git a/src/core/thread.c b/src/core/thread.c index e0ace624027..43a569d4f9b 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -103,7 +103,7 @@ static void _wait(struct mCoreThreadInternal* threadContext) { MutexUnlock(&threadContext->sync.audioBufferMutex); } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (threadContext->core && threadContext->core->debugger) { mDebuggerInterrupt(threadContext->core->debugger); } @@ -330,7 +330,7 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { MutexLock(&impl->stateMutex); while (impl->state < mTHREAD_EXITING) { -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS struct mDebugger* debugger = core->debugger; if (debugger) { MutexUnlock(&impl->stateMutex); @@ -355,7 +355,7 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { } while (impl->state >= mTHREAD_MIN_WAITING && impl->state <= mTHREAD_MAX_WAITING) { -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (debugger && debugger->state != DEBUGGER_SHUTDOWN) { mDebuggerUpdate(debugger); ConditionWaitTimed(&impl->stateOnThreadCond, &impl->stateMutex, 10); diff --git a/src/debugger/CMakeLists.txt b/src/debugger/CMakeLists.txt index ce2ade635e8..976f88c931d 100644 --- a/src/debugger/CMakeLists.txt +++ b/src/debugger/CMakeLists.txt @@ -15,7 +15,7 @@ if(USE_EDITLINE) list(APPEND SOURCE_FILES cli-el-backend.c) endif() -if(USE_GDB_STUB) +if(ENABLE_GDB_STUB) list(APPEND SOURCE_FILES gdb-stub.c) endif() diff --git a/src/debugger/cli-debugger.c b/src/debugger/cli-debugger.c index 9c9696f9f65..6d5b70e9768 100644 --- a/src/debugger/cli-debugger.c +++ b/src/debugger/cli-debugger.c @@ -1420,7 +1420,7 @@ static void _loadSymbols(struct CLIDebugger* debugger, struct CLIDebugVector* dv #ifdef USE_ELF struct ELF* elf = ELFOpen(vf); if (elf) { -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS mCoreLoadELFSymbols(symbolTable, elf); #endif ELFClose(elf); diff --git a/src/debugger/debugger.c b/src/debugger/debugger.c index 7de4772d721..a03f106d928 100644 --- a/src/debugger/debugger.c +++ b/src/debugger/debugger.c @@ -10,7 +10,7 @@ #include #include -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB #include #endif @@ -37,7 +37,7 @@ struct mDebuggerModule* mDebuggerCreateModule(enum mDebuggerType type, struct mC union DebugUnion { struct mDebuggerModule d; struct CLIDebugger cli; -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB struct GDBStub gdb; #endif }; @@ -52,7 +52,7 @@ struct mDebuggerModule* mDebuggerCreateModule(enum mDebuggerType type, struct mC CLIDebuggerAttachSystem(&debugger->cli, sys); break; case DEBUGGER_GDB: -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB GDBStubCreate(&debugger->gdb); struct Address localHost = { .version = IPV4, diff --git a/src/feature/commandline.c b/src/feature/commandline.c index 7e720886d3a..cdf788b1990 100644 --- a/src/feature/commandline.c +++ b/src/feature/commandline.c @@ -12,7 +12,7 @@ #include #include -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB #include #endif #ifdef USE_EDITLINE @@ -40,7 +40,7 @@ static const struct option _options[] = { #ifdef USE_EDITLINE { "debug", no_argument, 0, 'd' }, #endif -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB { "gdb", no_argument, 0, 'g' }, #endif { "help", no_argument, 0, 'h' }, @@ -85,7 +85,7 @@ bool mArgumentsParse(struct mArguments* args, int argc, char* const* argv, struc #ifdef USE_EDITLINE "d" #endif -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB "g" #endif ; @@ -151,7 +151,7 @@ bool mArgumentsParse(struct mArguments* args, int argc, char* const* argv, struc args->debugCli = true; break; #endif -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB case 'g': args->debugAtStart = true; args->debugGdb = true; @@ -231,7 +231,7 @@ bool mArgumentsApplyDebugger(const struct mArguments* args, struct mCore* core, } #endif -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB if (args->debugGdb) { struct mDebuggerModule* module = mDebuggerCreateModule(DEBUGGER_GDB, core); if (module) { @@ -355,7 +355,7 @@ void usage(const char* arg0, const char* prologue, const char* epilogue, const s #ifdef USE_EDITLINE " -d, --debug Use command-line debugger\n" #endif -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB " -g, --gdb Start GDB session (default port 2345)\n" #endif " -l, --log-level N Log level mask\n" diff --git a/src/gb/core.c b/src/gb/core.c index 9154221d6d2..1018b9f8249 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -164,7 +164,7 @@ static void _GBCoreDeinit(struct mCore* core) { #if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 mDirectorySetDeinit(&core->dirs); #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (core->symbolTable) { mDebuggerSymbolTableDestroy(core->symbolTable); } @@ -1060,7 +1060,7 @@ static bool _GBCoreWriteRegister(struct mCore* core, const char* name, const voi return false; } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS static bool _GBCoreSupportsDebuggerType(struct mCore* core, enum mDebuggerType type) { UNUSED(core); switch (type) { @@ -1352,7 +1352,7 @@ struct mCore* GBCoreCreate(void) { core->listRegisters = _GBCoreListRegisters; core->readRegister = _GBCoreReadRegister; core->writeRegister = _GBCoreWriteRegister; -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS core->supportsDebuggerType = _GBCoreSupportsDebuggerType; core->debuggerPlatform = _GBCoreDebuggerPlatform; core->cliDebuggerSystem = _GBCoreCliDebuggerSystem; diff --git a/src/gb/gb.c b/src/gb/gb.c index b3bb62a8021..c0e966c27ca 100644 --- a/src/gb/gb.c +++ b/src/gb/gb.c @@ -940,7 +940,7 @@ void GBProcessEvents(struct SM83Core* cpu) { nextEvent = cycles; do { -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS gb->timing.globalCycles += nextEvent; #endif nextEvent = mTimingTick(&gb->timing, nextEvent); @@ -1057,7 +1057,7 @@ void GBStop(struct SM83Core* cpu) { void GBIllegal(struct SM83Core* cpu) { struct GB* gb = (struct GB*) cpu->master; mLOG(GB, GAME_ERROR, "Hit illegal opcode at address %04X:%02X", cpu->pc, cpu->bus); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (cpu->components && cpu->components[CPU_COMPONENT_DEBUGGER]) { struct mDebuggerEntryInfo info = { .address = cpu->pc, diff --git a/src/gba/core.c b/src/gba/core.c index 54c436b3a89..dd5df523baf 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -313,7 +313,7 @@ static void _GBACoreDeinit(struct mCore* core) { #if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 mDirectorySetDeinit(&core->dirs); #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (core->symbolTable) { mDebuggerSymbolTableDestroy(core->symbolTable); } @@ -1218,7 +1218,7 @@ static bool _GBACoreWriteRegister(struct mCore* core, const char* name, const vo return true; } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS static bool _GBACoreSupportsDebuggerType(struct mCore* core, enum mDebuggerType type) { UNUSED(core); switch (type) { @@ -1280,7 +1280,7 @@ static void _GBACoreLoadSymbols(struct mCore* core, struct VFile* vf) { #ifdef USE_ELF struct ELF* elf = ELFOpen(vf); if (elf) { -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS mCoreLoadELFSymbols(core->symbolTable, elf); #endif ELFClose(elf); @@ -1565,7 +1565,7 @@ struct mCore* GBACoreCreate(void) { core->listRegisters = _GBACoreListRegisters; core->readRegister = _GBACoreReadRegister; core->writeRegister = _GBACoreWriteRegister; -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS core->supportsDebuggerType = _GBACoreSupportsDebuggerType; core->debuggerPlatform = _GBACoreDebuggerPlatform; core->cliDebuggerSystem = _GBACoreCliDebuggerSystem; diff --git a/src/gba/gba.c b/src/gba/gba.c index 31008507c37..41eee7435f0 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -49,7 +49,7 @@ static void GBATestIRQNoDelay(struct ARMCore* cpu); static void _triggerIRQ(struct mTiming*, void* user, uint32_t cyclesLate); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS static bool _setSoftwareBreakpoint(struct ARMDebugger*, uint32_t address, enum ExecutionMode mode, uint32_t* opcode); static void _clearSoftwareBreakpoint(struct ARMDebugger*, const struct ARMDebugBreakpoint*); #endif @@ -305,7 +305,7 @@ static void GBAProcessEvents(struct ARMCore* cpu) { do { int32_t cycles = cpu->cycles; cpu->cycles = 0; -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS gba->timing.globalCycles += cycles < nextEvent ? nextEvent : cycles; #endif #ifndef NDEBUG @@ -338,7 +338,7 @@ static void GBAProcessEvents(struct ARMCore* cpu) { } } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void GBAAttachDebugger(struct GBA* gba, struct mDebugger* debugger) { gba->debugger = (struct ARMDebugger*) debugger->platform; gba->debugger->setSoftwareBreakpoint = _setSoftwareBreakpoint; @@ -850,7 +850,7 @@ void GBAGetGameTitle(const struct GBA* gba, char* out) { void GBAHitStub(struct ARMCore* cpu, uint32_t opcode) { struct GBA* gba = (struct GBA*) cpu->master; UNUSED(gba); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (gba->debugger) { struct mDebuggerEntryInfo info = { .address = _ARMPCAddress(cpu), @@ -873,7 +873,7 @@ void GBAIllegal(struct ARMCore* cpu, uint32_t opcode) { // TODO: More sensible category? mLOG(GBA, WARN, "Illegal opcode: %08x", opcode); } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (gba->debugger) { struct mDebuggerEntryInfo info = { .address = _ARMPCAddress(cpu), @@ -888,7 +888,7 @@ void GBAIllegal(struct ARMCore* cpu, uint32_t opcode) { void GBABreakpoint(struct ARMCore* cpu, int immediate) { struct GBA* gba = (struct GBA*) cpu->master; switch (immediate) { -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS case CPU_COMPONENT_DEBUGGER: if (gba->debugger) { struct mDebuggerEntryInfo info = { @@ -1053,7 +1053,7 @@ void GBAClearBreakpoint(struct GBA* gba, uint32_t address, enum ExecutionMode mo } } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS static bool _setSoftwareBreakpoint(struct ARMDebugger* debugger, uint32_t address, enum ExecutionMode mode, uint32_t* opcode) { GBASetBreakpoint((struct GBA*) debugger->cpu->master, &debugger->d.p->d, address, mode, opcode); return true; diff --git a/src/platform/python/_builder.h b/src/platform/python/_builder.h index eef4cf0461b..e06e4f5ccdc 100644 --- a/src/platform/python/_builder.h +++ b/src/platform/python/_builder.h @@ -67,7 +67,7 @@ void free(void*); #include #include #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS #include #include #endif diff --git a/src/platform/python/engine.c b/src/platform/python/engine.c index 67d1d7b49cb..86ec2cf5c84 100644 --- a/src/platform/python/engine.c +++ b/src/platform/python/engine.c @@ -9,7 +9,7 @@ #include #include -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS #include #endif @@ -23,7 +23,7 @@ static bool mPythonScriptEngineLoadScript(struct mScriptEngine*, const char* nam static void mPythonScriptEngineRun(struct mScriptEngine*); static bool mPythonScriptEngineLookupSymbol(struct mScriptEngine*, const char* name, int32_t* out); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS static void mPythonScriptDebuggerEntered(struct mScriptEngine*, enum mDebuggerEntryReason, struct mDebuggerEntryInfo*); #endif @@ -41,7 +41,7 @@ struct mPythonScriptEngine* mPythonCreateScriptEngine(void) { engine->d.loadScript = mPythonScriptEngineLoadScript; engine->d.run = mPythonScriptEngineRun; engine->d.lookupSymbol = mPythonScriptEngineLookupSymbol; -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS engine->d.debuggerEntered = mPythonScriptDebuggerEntered; #endif engine->sb = NULL; @@ -82,7 +82,7 @@ bool mPythonScriptEngineLoadScript(struct mScriptEngine* se, const char* name, s void mPythonScriptEngineRun(struct mScriptEngine* se) { struct mPythonScriptEngine* engine = (struct mPythonScriptEngine*) se; -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS struct mDebugger* debugger = mScriptBridgeGetDebugger(engine->sb); if (debugger) { mPythonSetDebugger(debugger); @@ -97,7 +97,7 @@ bool mPythonScriptEngineLookupSymbol(struct mScriptEngine* se, const char* name, return mPythonLookupSymbol(name, out); } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void mPythonScriptDebuggerEntered(struct mScriptEngine* se, enum mDebuggerEntryReason reason, struct mDebuggerEntryInfo* info) { struct mPythonScriptEngine* engine = (struct mPythonScriptEngine*) se; diff --git a/src/platform/python/lib.h b/src/platform/python/lib.h index 0dd8754ed76..d0893101f5b 100644 --- a/src/platform/python/lib.h +++ b/src/platform/python/lib.h @@ -6,7 +6,7 @@ extern bool mPythonLoadScript(const char*, struct VFile*); extern void mPythonRunPending(); extern bool mPythonLookupSymbol(const char* name, int32_t* out); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS extern void mPythonSetDebugger(struct mDebugger*); extern void mPythonDebuggerEntered(enum mDebuggerEntryReason, struct mDebuggerEntryInfo*); #endif diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index fe898be1e8b..05f5add0adf 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -249,7 +249,7 @@ if(NOT AUDIO_SRC) return() endif() -if(USE_DEBUGGERS) +if(ENABLE_DEBUGGERS) list(APPEND SOURCE_FILES DebuggerController.cpp DebuggerConsole.cpp @@ -257,7 +257,7 @@ if(USE_DEBUGGERS) MemoryAccessLogView.cpp) endif() -if(USE_GDB_STUB) +if(ENABLE_GDB_STUB) list(APPEND SOURCE_FILES GDBController.cpp GDBWindow.cpp) endif() diff --git a/src/platform/qt/CoreController.cpp b/src/platform/qt/CoreController.cpp index dd74cce7882..660de1f574f 100644 --- a/src/platform/qt/CoreController.cpp +++ b/src/platform/qt/CoreController.cpp @@ -49,7 +49,7 @@ CoreController::CoreController(mCore* core, QObject* parent) GBASIODolphinCreate(&m_dolphin); #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS mDebuggerInit(&m_debugger); #endif @@ -218,7 +218,7 @@ CoreController::~CoreController() { mCoreThreadJoin(&m_threadContext); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS mDebuggerDeinit(&m_debugger); #endif @@ -331,7 +331,7 @@ void CoreController::loadConfig(ConfigController* config) { #endif } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void CoreController::attachDebugger(bool interrupt) { Interrupter interrupter(this); if (!m_threadContext.core->debugger) { @@ -478,7 +478,7 @@ void CoreController::start() { void CoreController::stop() { setSync(false); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS detachDebugger(); #endif setPaused(false); diff --git a/src/platform/qt/CoreController.h b/src/platform/qt/CoreController.h index c46b4d6e953..684d864d051 100644 --- a/src/platform/qt/CoreController.h +++ b/src/platform/qt/CoreController.h @@ -107,7 +107,7 @@ Q_OBJECT mCheatDevice* cheatDevice() { return m_threadContext.core->cheatDevice(m_threadContext.core); } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS mDebugger* debugger() { return &m_debugger; } void attachDebugger(bool interrupt = true); void detachDebugger(); @@ -305,7 +305,7 @@ public slots: bool m_autoload; int m_autosaveCounter = 0; -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS struct mDebugger m_debugger; #endif diff --git a/src/platform/qt/GDBController.h b/src/platform/qt/GDBController.h index 6bf0a713277..50c0fb927de 100644 --- a/src/platform/qt/GDBController.h +++ b/src/platform/qt/GDBController.h @@ -7,7 +7,7 @@ #include "DebuggerController.h" -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB #include diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index 6216e2247d2..117da820d56 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -211,7 +211,7 @@ void Window::argumentsPassed() { m_pendingState = args->savestate; } -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB if (args->debugGdb) { if (!m_gdbController) { m_gdbController = new GDBController(this); @@ -224,7 +224,7 @@ void Window::argumentsPassed() { } #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (args->debugCli) { consoleOpen(); } @@ -607,7 +607,7 @@ std::function Window::openNamedControllerTView(std::unique_ptr* name, }; } -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB void Window::gdbOpen() { if (!m_gdbController) { m_gdbController = new GDBController(this); @@ -619,7 +619,7 @@ void Window::gdbOpen() { } #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void Window::consoleOpen() { if (!m_console) { m_console = new DebuggerConsoleController(this); @@ -1677,14 +1677,14 @@ void Window::setupMenu(QMenuBar* menubar) { m_actions.addAction(tr("Make portable"), "makePortable", this, &Window::tryMakePortable, "tools"); m_actions.addSeparator("tools"); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS m_actions.addAction(tr("Open debugger console..."), "debuggerWindow", this, &Window::consoleOpen, "tools"); -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB auto gdbWindow = addGameAction(tr("Start &GDB server..."), "gdbWindow", this, &Window::gdbOpen, "tools"); m_platformActions.insert(mPLATFORM_GBA, gdbWindow); #endif #endif -#if defined(USE_DEBUGGERS) || defined(ENABLE_SCRIPTING) +#if defined(ENABLE_DEBUGGERS) || defined(ENABLE_SCRIPTING) m_actions.addSeparator("tools"); #endif @@ -1714,7 +1714,7 @@ void Window::setupMenu(QMenuBar* menubar) { addGameAction(tr("Search memory..."), "memorySearch", openControllerTView(), "stateViews"); addGameAction(tr("View &I/O registers..."), "ioViewer", openControllerTView(), "stateViews"); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS addGameAction(tr("Log memory &accesses..."), "memoryAccessView", openControllerTView(), "tools"); #endif @@ -2132,13 +2132,13 @@ void Window::setController(CoreController* controller, const QString& fname) { } #endif -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB if (m_gdbController) { m_gdbController->setController(m_controller); } #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (m_console) { m_console->setController(m_controller); } diff --git a/src/platform/qt/Window.h b/src/platform/qt/Window.h index b2e8de82b75..4bcb6b7f9e0 100644 --- a/src/platform/qt/Window.h +++ b/src/platform/qt/Window.h @@ -108,11 +108,11 @@ public slots: void startVideoLog(); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS void consoleOpen(); #endif -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB void gdbOpen(); #endif @@ -206,7 +206,7 @@ private slots: LogController m_log{0}; LogView* m_logView; -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS DebuggerConsoleController* m_console = nullptr; #endif LoadSaveState* m_stateWindow = nullptr; @@ -249,7 +249,7 @@ private slots: std::unique_ptr m_gifView; #endif -#ifdef USE_GDB_STUB +#ifdef ENABLE_GDB_STUB GDBController* m_gdbController = nullptr; #endif diff --git a/src/platform/qt/scripting/ScriptingController.cpp b/src/platform/qt/scripting/ScriptingController.cpp index 79b46e9d09f..b1d68e22ab9 100644 --- a/src/platform/qt/scripting/ScriptingController.cpp +++ b/src/platform/qt/scripting/ScriptingController.cpp @@ -302,7 +302,7 @@ void ScriptingController::updateGamepad() { void ScriptingController::attach() { CoreController::Interrupter interrupter(m_controller); mScriptContextAttachCore(&m_scriptContext, m_controller->thread()->core); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS m_controller->attachDebugger(false); #endif } diff --git a/src/platform/sdl/main.c b/src/platform/sdl/main.c index d6a41f6117a..1a1d3f6fc76 100644 --- a/src/platform/sdl/main.c +++ b/src/platform/sdl/main.c @@ -217,12 +217,12 @@ int mSDLRun(struct mSDLRenderer* renderer, struct mArguments* args) { #ifdef ENABLE_PYTHON mPythonSetup(bridge); #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS CLIDebuggerScriptEngineInstall(bridge); #endif #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS struct mDebugger debugger; mDebuggerInit(&debugger); bool hasDebugger = mArgumentsApplyDebugger(args, renderer->core, &debugger); @@ -292,7 +292,7 @@ int mSDLRun(struct mSDLRenderer* renderer, struct mArguments* args) { mScriptBridgeDestroy(bridge); #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (hasDebugger) { renderer->core->detachDebugger(renderer->core); mDebuggerDeinit(&debugger); diff --git a/src/platform/sdl/sdl-events.c b/src/platform/sdl/sdl-events.c index 46807cae1e6..eceaf18081a 100644 --- a/src/platform/sdl/sdl-events.c +++ b/src/platform/sdl/sdl-events.c @@ -505,7 +505,7 @@ static void _mSDLHandleKeypress(struct mCoreThread* context, struct mSDLPlayer* } if (event->type == SDL_KEYDOWN) { switch (event->keysym.sym) { -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS case SDLK_F11: if (context->core->debugger) { mDebuggerEnter(context->core->debugger, DEBUGGER_ENTER_MANUAL, NULL); diff --git a/src/platform/test/rom-test-main.c b/src/platform/test/rom-test-main.c index 8c0d4fd3d02..8524a852f4b 100644 --- a/src/platform/test/rom-test-main.c +++ b/src/platform/test/rom-test-main.c @@ -139,7 +139,7 @@ int main(int argc, char * argv[]) { goto loadError; } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS struct mDebugger debugger; mDebuggerInit(&debugger); bool hasDebugger = mArgumentsApplyDebugger(&args, core, &debugger); @@ -165,7 +165,7 @@ int main(int argc, char * argv[]) { savestate->close(savestate); } -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (hasDebugger) { do { mDebuggerRun(&debugger); @@ -178,7 +178,7 @@ int main(int argc, char * argv[]) { core->unloadROM(core); -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS if (hasDebugger) { core->detachDebugger(core); mDebuggerDeinit(&debugger); diff --git a/src/script/stdlib.c b/src/script/stdlib.c index 33ec0b751e8..6e81cfd8634 100644 --- a/src/script/stdlib.c +++ b/src/script/stdlib.c @@ -160,7 +160,7 @@ void mScriptContextAttachStdlib(struct mScriptContext* context) { mSCRIPT_KV_SENTINEL }); #endif -#ifdef USE_DEBUGGERS +#ifdef ENABLE_DEBUGGERS mScriptContextExportConstants(context, "WATCHPOINT_TYPE", (struct mScriptKVPair[]) { mSCRIPT_CONSTANT_PAIR(WATCHPOINT, WRITE), mSCRIPT_CONSTANT_PAIR(WATCHPOINT, READ), From 2037e97fc9e4d58ed9565dd4f6b0b25f813841ef Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 8 Apr 2024 22:42:18 +0000 Subject: [PATCH 059/338] Qt: Update translation (Chinese (Simplified)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/zh_Hans/ --- src/platform/qt/ts/mgba-zh_CN.ts | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/platform/qt/ts/mgba-zh_CN.ts b/src/platform/qt/ts/mgba-zh_CN.ts index 150ad5404fd..6992a62809e 100644 --- a/src/platform/qt/ts/mgba-zh_CN.ts +++ b/src/platform/qt/ts/mgba-zh_CN.ts @@ -4366,7 +4366,7 @@ Download size: %3 Save games and save states (%1) - ä¿å­˜æ¸¸æˆå’Œå³æ—¶å­˜æ¡£ï¼ˆ%1) + ä¿å­˜æ¸¸æˆå’Œå³æ—¶å­˜æ¡£ (%1) @@ -4376,7 +4376,7 @@ Download size: %3 Save games (%1) - ä¿å­˜æ¸¸æˆï¼ˆ%1) + ä¿å­˜æ¸¸æˆ (%1) @@ -6124,7 +6124,7 @@ Download size: %3 Save games (%1) - ä¿å­˜æ¸¸æˆï¼ˆ%1) + ä¿å­˜æ¸¸æˆ (%1) @@ -6134,7 +6134,7 @@ Download size: %3 mGBA save state files (%1) - mGBA å³æ—¶å­˜æ¡£æ–‡ä»¶ï¼ˆ%1) + mGBA å³æ—¶å­˜æ¡£æ–‡ä»¶ (%1) From 61172d837fc22dfb715f0bb1aec2e41cadb8fd76 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 8 Apr 2024 19:59:11 -0700 Subject: [PATCH 060/338] Core: Fix thread not waking up properly on canceling request --- src/core/thread.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/core/thread.c b/src/core/thread.c index 43a569d4f9b..18c1c20e16b 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -140,7 +140,7 @@ static void _sendRequest(struct mCoreThreadInternal* threadContext, enum mCoreTh static void _cancelRequest(struct mCoreThreadInternal* threadContext, enum mCoreThreadRequest request) { threadContext->requested &= ~request; _pokeRequest(threadContext); - ConditionWake(&threadContext->stateOffThreadCond); + ConditionWake(&threadContext->stateOnThreadCond); } void _frameStarted(void* context) { From 72202544bb0dcc444a4ef6ff5f52cf22c34f1da4 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 9 Apr 2024 00:50:23 -0700 Subject: [PATCH 061/338] Core: Don't trigger watchpoints with access inside of a script (fixes #3050) --- src/core/scripting.c | 104 +++++++++++++++++++++++++++++++++++++- src/core/test/scripting.c | 35 +++++++++++++ 2 files changed, 138 insertions(+), 1 deletion(-) diff --git a/src/core/scripting.c b/src/core/scripting.c index 1fd37aeb900..acf324e1ff4 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -182,6 +182,7 @@ struct mScriptDebugger { struct Table cbidMap; struct Table bpidMap; int64_t nextBreakpoint; + bool reentered; }; #endif @@ -779,6 +780,7 @@ static void _scriptDebuggerInit(struct mDebuggerModule* debugger) { struct mScriptDebugger* scriptDebugger = (struct mScriptDebugger*) debugger; debugger->isPaused = false; debugger->needsCallback = false; + scriptDebugger->reentered = false; HashTableInit(&scriptDebugger->breakpoints, 0, _freeBreakpoint); HashTableInit(&scriptDebugger->cbidMap, 0, NULL); @@ -812,6 +814,11 @@ static void _scriptDebuggerEntered(struct mDebuggerModule* debugger, enum mDebug default: return; } + + if (scriptDebugger->reentered) { + return; + } + _runCallbacks(scriptDebugger, point); debugger->isPaused = false; } @@ -976,18 +983,105 @@ static void _mScriptCoreAdapterSetLuminanceCb(struct mScriptCoreAdapter* adapter adapter->luminanceCb = callback; } +static uint32_t _mScriptCoreAdapterRead8(struct mScriptCoreAdapter* adapter, uint32_t address) { +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = true; +#endif + uint32_t value = adapter->core->busRead8(adapter->core, address); +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = false; +#endif + return value; +} + +static uint32_t _mScriptCoreAdapterRead16(struct mScriptCoreAdapter* adapter, uint32_t address) { +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = true; +#endif + uint32_t value = adapter->core->busRead16(adapter->core, address); +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = false; +#endif + return value; +} + +static uint32_t _mScriptCoreAdapterRead32(struct mScriptCoreAdapter* adapter, uint32_t address) { +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = true; +#endif + uint32_t value = adapter->core->busRead32(adapter->core, address); +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = false; +#endif + return value; +} + +static struct mScriptValue* _mScriptCoreAdapterReadRange(struct mScriptCoreAdapter* adapter, uint32_t address, uint32_t length) { +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = true; +#endif + struct mScriptValue* value = mScriptStringCreateEmpty(length); + char* buffer = value->value.string->buffer; + uint32_t i; + for (i = 0; i < length; ++i, ++address) { + buffer[i] = adapter->core->busRead8(adapter->core, address); + } +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = false; +#endif + return value; +} + +static void _mScriptCoreAdapterWrite8(struct mScriptCoreAdapter* adapter, uint32_t address, uint8_t value) { +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = true; +#endif + adapter->core->busWrite8(adapter->core, address, value); +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = false; +#endif +} + +static void _mScriptCoreAdapterWrite16(struct mScriptCoreAdapter* adapter, uint32_t address, uint16_t value) { +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = true; +#endif + adapter->core->busWrite16(adapter->core, address, value); +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = false; +#endif +} + +static void _mScriptCoreAdapterWrite32(struct mScriptCoreAdapter* adapter, uint32_t address, uint32_t value) { +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = true; +#endif + adapter->core->busWrite32(adapter->core, address, value); +#ifdef ENABLE_DEBUGGERS + adapter->debugger.reentered = false; +#endif +} + mSCRIPT_DECLARE_STRUCT(mScriptCoreAdapter); mSCRIPT_DECLARE_STRUCT_METHOD(mScriptCoreAdapter, W(mCore), _get, _mScriptCoreAdapterGet, 1, CHARP, name); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, _deinit, _mScriptCoreAdapterDeinit, 0); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, reset, _mScriptCoreAdapterReset, 0); mSCRIPT_DECLARE_STRUCT_METHOD(mScriptCoreAdapter, WTABLE, setRotationCallbacks, _mScriptCoreAdapterSetRotationCbTable, 1, WTABLE, cbTable); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, setSolarSensorCallback, _mScriptCoreAdapterSetLuminanceCb, 1, WRAPPER, callback); + +mSCRIPT_DECLARE_STRUCT_METHOD(mScriptCoreAdapter, U32, read8, _mScriptCoreAdapterRead8, 1, U32, address); +mSCRIPT_DECLARE_STRUCT_METHOD(mScriptCoreAdapter, U32, read16, _mScriptCoreAdapterRead16, 1, U32, address); +mSCRIPT_DECLARE_STRUCT_METHOD(mScriptCoreAdapter, U32, read32, _mScriptCoreAdapterRead32, 1, U32, address); +mSCRIPT_DECLARE_STRUCT_METHOD(mScriptCoreAdapter, WSTR, readRange, _mScriptCoreAdapterReadRange, 2, U32, address, U32, length); +mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, write8, _mScriptCoreAdapterWrite8, 2, U32, address, U8, value); +mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, write16, _mScriptCoreAdapterWrite16, 2, U32, address, U16, value); +mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, write32, _mScriptCoreAdapterWrite32, 2, U32, address, U32, value); + #ifdef ENABLE_DEBUGGERS mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptCoreAdapter, S64, setBreakpoint, _mScriptCoreAdapterSetBreakpoint, 3, WRAPPER, callback, U32, address, S32, segment); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptCoreAdapter, S64, setWatchpoint, _mScriptCoreAdapterSetWatchpoint, 4, WRAPPER, callback, U32, address, S32, type, S32, segment); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptCoreAdapter, S64, setRangeWatchpoint, _mScriptCoreAdapterSetRangeWatchpoint, 5, WRAPPER, callback, U32, minAddress, U32, maxAddress, S32, type, S32, segment); mSCRIPT_DECLARE_STRUCT_METHOD(mScriptCoreAdapter, BOOL, clearBreakpoint, _mScriptCoreAdapterClearBreakpoint, 1, S64, cbid); -#endif mSCRIPT_DEFINE_STRUCT_BINDING_DEFAULTS(mScriptCoreAdapter, setBreakpoint) mSCRIPT_NO_DEFAULT, @@ -1009,6 +1103,7 @@ mSCRIPT_DEFINE_STRUCT_BINDING_DEFAULTS(mScriptCoreAdapter, setRangeWatchpoint) mSCRIPT_NO_DEFAULT, mSCRIPT_S32(-1) mSCRIPT_DEFINE_DEFAULTS_END; +#endif mSCRIPT_DEFINE_STRUCT(mScriptCoreAdapter) mSCRIPT_DEFINE_CLASS_DOCSTRING( @@ -1040,6 +1135,13 @@ mSCRIPT_DEFINE_STRUCT(mScriptCoreAdapter) "Note that the full range of values is not used by games, and the exact range depends on the calibration done by the game itself." ) mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, setSolarSensorCallback) + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, read8) + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, read16) + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, read32) + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, readRange) + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, write8) + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, write16) + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, write32) #ifdef ENABLE_DEBUGGERS mSCRIPT_DEFINE_DOCSTRING("Set a breakpoint at a given address") mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, setBreakpoint) diff --git a/src/core/test/scripting.c b/src/core/test/scripting.c index d2f0f0a0004..e66f2a722fd 100644 --- a/src/core/test/scripting.c +++ b/src/core/test/scripting.c @@ -547,6 +547,40 @@ M_TEST_DEFINE(basicWatchpoint) { mDebuggerDeinit(&debugger); } +M_TEST_DEFINE(watchpointReentrant) { + SETUP_LUA; + mScriptContextAttachStdlib(&context); + CREATE_CORE; + struct mDebugger debugger; + core->reset(core); + mScriptContextAttachCore(&context, core); + + mDebuggerInit(&debugger); + mDebuggerAttach(&debugger, core); + + TEST_PROGRAM( + "hit = 0\n" + "function bkpt()\n" + " hit = hit + 1\n" + "end" + ); + struct mScriptValue base = mSCRIPT_MAKE_S32(RAM_BASE); + lua->setGlobal(lua, "base", &base); + TEST_PROGRAM("assert(0 < emu:setWatchpoint(bkpt, base, C.WATCHPOINT_TYPE.READ))"); + + TEST_PROGRAM("hit = 0"); + core->busRead8(core, RAM_BASE); + TEST_PROGRAM("assert(hit == 1)"); + TEST_PROGRAM("emu:read8(base)"); + TEST_PROGRAM("assert(hit == 1)"); + core->busRead8(core, RAM_BASE); + TEST_PROGRAM("assert(hit == 2)"); + + mScriptContextDeinit(&context); + TEARDOWN_CORE; + mDebuggerDeinit(&debugger); +} + M_TEST_DEFINE(removeBreakpoint) { SETUP_LUA; mScriptContextAttachStdlib(&context); @@ -736,6 +770,7 @@ M_TEST_SUITE_DEFINE_SETUP_TEARDOWN(mScriptCore, #endif cmocka_unit_test(multipleBreakpoint), cmocka_unit_test(basicWatchpoint), + cmocka_unit_test(watchpointReentrant), cmocka_unit_test(removeBreakpoint), cmocka_unit_test(overlappingBreakpoint), cmocka_unit_test(overlappingWatchpoint), From cbd117eb3a9eba367e58b9139f46f29294fe7ebe Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 10 Apr 2024 23:54:40 -0700 Subject: [PATCH 062/338] Util: Start bringing up better audio resampling --- include/mgba-util/interpolator.h | 33 +++++++++++++ src/util/CMakeLists.txt | 1 + src/util/interpolator.c | 83 ++++++++++++++++++++++++++++++++ 3 files changed, 117 insertions(+) create mode 100644 include/mgba-util/interpolator.h create mode 100644 src/util/interpolator.c diff --git a/include/mgba-util/interpolator.h b/include/mgba-util/interpolator.h new file mode 100644 index 00000000000..4cb7231fdc7 --- /dev/null +++ b/include/mgba-util/interpolator.h @@ -0,0 +1,33 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#ifndef M_INTERPOLATOR_H +#define M_INTERPOLATOR_H + +#include + +struct mSampleBuffer { + int16_t* data; + size_t samples; + int channels; +}; + +struct mInterpolator { + int16_t (*interpolate)(const struct mInterpolator* interp, const struct mSampleBuffer* data, double time, double sampleStep); +}; + +struct mInterpolatorSinc { + struct mInterpolator d; + + unsigned resolution; + unsigned width; + double* sincLut; + double* windowLut; +}; + +void mInterpolatorSincInit(struct mInterpolatorSinc* interp, unsigned resolution, unsigned width); +void mInterpolatorSincDeinit(struct mInterpolatorSinc* interp); + +#endif diff --git a/src/util/CMakeLists.txt b/src/util/CMakeLists.txt index eb82215d703..820a178d5c1 100644 --- a/src/util/CMakeLists.txt +++ b/src/util/CMakeLists.txt @@ -19,6 +19,7 @@ set(SOURCE_FILES image.c image/export.c image/png-io.c + interpolator.c patch.c patch-fast.c patch-ips.c diff --git a/src/util/interpolator.c b/src/util/interpolator.c new file mode 100644 index 00000000000..2fceee898ab --- /dev/null +++ b/src/util/interpolator.c @@ -0,0 +1,83 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#include + +enum { + mSINC_RESOLUTION = 8192, + mSINC_WIDTH = 8, +}; + +static int16_t mInterpolatorSincInterpolate(const struct mInterpolator*, const struct mSampleBuffer* data, double time, double sampleStep); + +void mInterpolatorSincInit(struct mInterpolatorSinc* interp, unsigned resolution, unsigned width) { + interp->d.interpolate = mInterpolatorSincInterpolate; + + if (!resolution) { + resolution = mSINC_RESOLUTION; + } + if (!width) { + width = mSINC_WIDTH; + } + unsigned samples = resolution * width; + double dy = M_PI / samples; + double y = dy; + double dx = dy * width; + double x = dx; + + interp->sincLut = calloc(samples + 1, sizeof(double)); + interp->windowLut = calloc(samples + 1, sizeof(double)); + + interp->sincLut[0] = 0; + interp->windowLut[0] = 1; + + unsigned i; + for (i = 1; i <= samples; ++i, x += dx, y += dy) { + interp->sincLut[i] = x < width ? sin(x) / x : 0.0; + // Three term Nuttall window with continuous first derivative + interp->windowLut[i] = 0.40897 + 0.5 * cos(y) + 0.09103 * cos(2 * y); + } +} + +void mInterpolatorSincDeinit(struct mInterpolatorSinc* interp) { + free(interp->sincLut); + free(interp->windowLut); +} + +int16_t mInterpolatorSincInterpolate(const struct mInterpolator* interpolator, const struct mSampleBuffer* data, double time, double sampleStep) { + struct mInterpolatorSinc* interp = (struct mInterpolatorSinc*) interpolator; + ssize_t index = (ssize_t) time; + double subsample = time - floor(time); + unsigned step = sampleStep > 1 ? interp->resolution * sampleStep : interp->resolution; + unsigned yShift = subsample * step; + unsigned xShift = subsample * interp->resolution; + double sum = 0.0; + double kernelSum = 0.0; + double kernel; + + ssize_t i; + for (i = 1 - (ssize_t) interp->width; i <= (ssize_t) interp->width; ++i) { + unsigned window = i * interp->resolution; + if (yShift > window) { + window = yShift - window; + } else { + window -= yShift; + } + + unsigned sinc = i * step; + if (xShift > sinc) { + sinc = xShift - sinc; + } else { + sinc -= xShift; + } + + kernel = interp->sincLut[sinc] * interp->windowLut[window]; + kernelSum += kernel; + if (index + i >= 0 && index + i < (ssize_t) data->samples) { + sum += data->data[(index + i) * data->channels] * kernel; + } + } + return sum / kernelSum; +} From 2d03ae64ba7b72a2d722cbc90b26b024d7006d02 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 11 Apr 2024 00:47:45 -0700 Subject: [PATCH 063/338] 3DS: Handle audio resampling in DSP --- src/platform/3ds/main.c | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/src/platform/3ds/main.c b/src/platform/3ds/main.c index 36df49a9c0b..fb4f63a56ba 100644 --- a/src/platform/3ds/main.c +++ b/src/platform/3ds/main.c @@ -343,9 +343,8 @@ static void _gameLoaded(struct mGUIRunner* runner) { } osSetSpeedupEnable(true); - double ratio = GBAAudioCalculateRatio(1, 268111856.f / 4481136.f, 1); - blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), 32768 * ratio); - blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), 32768 * ratio); + blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), 32768); + blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), 32768); if (hasSound != NO_SOUND) { audioPos = 0; } @@ -858,7 +857,7 @@ int main(int argc, char* argv[]) { ndspChnReset(0); ndspChnSetFormat(0, NDSP_FORMAT_STEREO_PCM16); ndspChnSetInterp(0, NDSP_INTERP_NONE); - ndspChnSetRate(0, 0x8000); + ndspChnSetRate(0, 32822); ndspChnWaveBufClear(0); audioLeft = linearMemAlign(AUDIO_SAMPLES * DSP_BUFFERS * 2 * sizeof(int16_t), 0x80); memset(dspBuffer, 0, sizeof(dspBuffer)); From a8023e4f6a2614a77d445f03082825346789880e Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 11 Apr 2024 20:33:51 -0700 Subject: [PATCH 064/338] Qt: Remove debug message from CMakeLists --- src/platform/qt/CMakeLists.txt | 1 - 1 file changed, 1 deletion(-) diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index 05f5add0adf..673170f0f68 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -29,7 +29,6 @@ set(QT_VERSIONS 6 5) foreach(V ${QT_VERSIONS}) set(QT Qt${V}) set(QT_V ${V}) - message("${V} ${QT} ${QT_V}") find_package(${QT} COMPONENTS Core Widgets Network OPTIONAL_COMPONENTS Multimedia) if(QT_V GREATER_EQUAL 6) find_package(${QT} COMPONENTS OpenGL OpenGLWidgets) From bc6a80137fcd96c8f3dcf33284906acf0ae64a2b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 12 Apr 2024 00:46:12 -0700 Subject: [PATCH 065/338] Util: Start adding CircleBuffer tests --- src/util/CMakeLists.txt | 1 + src/util/test/circle-buffer.c | 163 ++++++++++++++++++++++++++++++++++ 2 files changed, 164 insertions(+) create mode 100644 src/util/test/circle-buffer.c diff --git a/src/util/CMakeLists.txt b/src/util/CMakeLists.txt index 820a178d5c1..f0bc85a3d6e 100644 --- a/src/util/CMakeLists.txt +++ b/src/util/CMakeLists.txt @@ -36,6 +36,7 @@ set(GUI_FILES gui/menu.c) set(TEST_FILES + test/circle-buffer.c test/color.c test/geometry.c test/image.c diff --git a/src/util/test/circle-buffer.c b/src/util/test/circle-buffer.c new file mode 100644 index 00000000000..ff580e23e77 --- /dev/null +++ b/src/util/test/circle-buffer.c @@ -0,0 +1,163 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#include "util/test/suite.h" + +#include + +M_TEST_DEFINE(basicCircle) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int8_t i; + for (i = 0; i < 63; ++i) { + assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + } + for (i = 0; i < 63; ++i) { + int8_t value; + assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(value, i); + } + + for (i = 0; i < 63; ++i) { + assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + } + for (i = 0; i < 63; ++i) { + int8_t value; + assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(value, i); + } +} + +M_TEST_DEFINE(basicAlignment16) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int16_t i; + for (i = 0; i < 29; ++i) { + assert_int_equal(CircleBufferWrite16(&buffer, i), 2); + } + for (i = 0; i < 29; ++i) { + int16_t value; + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(value, i); + } + + int8_t i8; + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + + for (i = 0; i < 29; ++i) { + assert_int_equal(CircleBufferWrite16(&buffer, i), 2); + } + for (i = 0; i < 29; ++i) { + int16_t value; + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(value, i); + } +} + + +M_TEST_DEFINE(basicAlignment32) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int32_t i; + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + } + for (i = 0; i < 15; ++i) { + int32_t value; + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i); + } + + int8_t i8; + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + } + for (i = 0; i < 15; ++i) { + int32_t value; + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i); + } + + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + } + for (i = 0; i < 15; ++i) { + int32_t value; + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i); + } + + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + } + for (i = 0; i < 15; ++i) { + int32_t value; + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i); + } +} + +M_TEST_DEFINE(capacity) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int8_t i; + for (i = 0; i < 64; ++i) { + assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + } + for (i = 0; i < 64; ++i) { + int8_t value; + assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(value, i); + } + + for (i = 0; i < 64; ++i) { + assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + } + assert_int_equal(CircleBufferWrite8(&buffer, 64), 0); + + for (i = 0; i < 64; ++i) { + int8_t value; + assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(value, i); + } +} + +M_TEST_DEFINE(overCapacity16) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int8_t i; + for (i = 0; i < 63; ++i) { + assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + } + assert_int_equal(CircleBufferWrite16(&buffer, 0xFFFF), 0); +} + +M_TEST_SUITE_DEFINE(CircleBuffer, + cmocka_unit_test(basicCircle), + cmocka_unit_test(basicAlignment16), + cmocka_unit_test(basicAlignment32), + cmocka_unit_test(capacity), + cmocka_unit_test(overCapacity16), +) From cecb4543c328b5a8216d9665508946717d48d0f3 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 12 Apr 2024 00:54:54 -0700 Subject: [PATCH 066/338] Util: Remember to free memory in tests --- src/util/test/circle-buffer.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/util/test/circle-buffer.c b/src/util/test/circle-buffer.c index ff580e23e77..0415f83a17a 100644 --- a/src/util/test/circle-buffer.c +++ b/src/util/test/circle-buffer.c @@ -30,6 +30,8 @@ M_TEST_DEFINE(basicCircle) { assert_int_equal(CircleBufferRead8(&buffer, &value), 1); assert_int_equal(value, i); } + + CircleBufferDeinit(&buffer); } M_TEST_DEFINE(basicAlignment16) { @@ -59,6 +61,8 @@ M_TEST_DEFINE(basicAlignment16) { assert_int_equal(CircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i); } + + CircleBufferDeinit(&buffer); } @@ -113,6 +117,8 @@ M_TEST_DEFINE(basicAlignment32) { assert_int_equal(CircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } + + CircleBufferDeinit(&buffer); } M_TEST_DEFINE(capacity) { @@ -140,6 +146,8 @@ M_TEST_DEFINE(capacity) { assert_int_equal(CircleBufferRead8(&buffer, &value), 1); assert_int_equal(value, i); } + + CircleBufferDeinit(&buffer); } M_TEST_DEFINE(overCapacity16) { @@ -152,6 +160,8 @@ M_TEST_DEFINE(overCapacity16) { assert_int_equal(CircleBufferWrite8(&buffer, i), 1); } assert_int_equal(CircleBufferWrite16(&buffer, 0xFFFF), 0); + + CircleBufferDeinit(&buffer); } M_TEST_SUITE_DEFINE(CircleBuffer, From 042a66bb8040a1bb0c15d119130866cb86a1a764 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 12 Apr 2024 20:52:16 -0700 Subject: [PATCH 067/338] Scripting: Fix leak when freeing painters --- src/script/image.c | 1 + 1 file changed, 1 insertion(+) diff --git a/src/script/image.c b/src/script/image.c index 7705ebd9a8c..2bd5a8736e8 100644 --- a/src/script/image.c +++ b/src/script/image.c @@ -131,6 +131,7 @@ static struct mScriptValue* _mScriptPainterGet(struct mScriptPainter* painter, c void _mScriptPainterDeinit(struct mScriptPainter* painter) { mScriptValueDeref(painter->image); + free(painter); } mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mPainter, setBlend, _mPainterSetBlend, 1, BOOL, enable); From 6d2109dd48b784e44e173f84f41cc2cbfe0da045 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 12 Apr 2024 21:27:35 -0700 Subject: [PATCH 068/338] Util: Add offset parameter to CircleBufferDump, more tests --- include/mgba-util/circle-buffer.h | 2 +- src/util/circle-buffer.c | 11 +-- src/util/test/circle-buffer.c | 116 ++++++++++++++++++++++++++++++ 3 files changed, 123 insertions(+), 6 deletions(-) diff --git a/include/mgba-util/circle-buffer.h b/include/mgba-util/circle-buffer.h index dee1f1f2adb..995f2f32b2e 100644 --- a/include/mgba-util/circle-buffer.h +++ b/include/mgba-util/circle-buffer.h @@ -31,7 +31,7 @@ int CircleBufferRead8(struct CircleBuffer* buffer, int8_t* value); int CircleBufferRead16(struct CircleBuffer* buffer, int16_t* value); int CircleBufferRead32(struct CircleBuffer* buffer, int32_t* value); size_t CircleBufferRead(struct CircleBuffer* buffer, void* output, size_t length); -size_t CircleBufferDump(const struct CircleBuffer* buffer, void* output, size_t length); +size_t CircleBufferDump(const struct CircleBuffer* buffer, void* output, size_t length, size_t offset); CXX_GUARD_END diff --git a/src/util/circle-buffer.c b/src/util/circle-buffer.c index c77a71ebadf..d58ea0c44e4 100644 --- a/src/util/circle-buffer.c +++ b/src/util/circle-buffer.c @@ -264,15 +264,16 @@ size_t CircleBufferRead(struct CircleBuffer* buffer, void* output, size_t length return length; } -size_t CircleBufferDump(const struct CircleBuffer* buffer, void* output, size_t length) { +size_t CircleBufferDump(const struct CircleBuffer* buffer, void* output, size_t length, size_t offset) { int8_t* data = buffer->readPtr; - if (buffer->size == 0) { + if (buffer->size <= offset) { return 0; } - if (length > buffer->size) { - length = buffer->size; + if (length > buffer->size - offset) { + length = buffer->size - offset; } - size_t remaining = buffer->capacity - ((int8_t*) data - (int8_t*) buffer->data); + data += offset; + size_t remaining = buffer->capacity - ((uintptr_t) data - (uintptr_t) buffer->data); if (length <= remaining) { memcpy(output, data, length); } else { diff --git a/src/util/test/circle-buffer.c b/src/util/test/circle-buffer.c index 0415f83a17a..1bfb0c11161 100644 --- a/src/util/test/circle-buffer.c +++ b/src/util/test/circle-buffer.c @@ -164,10 +164,126 @@ M_TEST_DEFINE(overCapacity16) { CircleBufferDeinit(&buffer); } +M_TEST_DEFINE(writeLenCapacity) { + struct CircleBuffer buffer; + const char* data = " Lorem ipsum dolor sit amet, consectetur adipiscing elit placerat."; + char databuf[64]; + + CircleBufferInit(&buffer, 64); + + assert_int_equal(CircleBufferWrite(&buffer, data, 64), 64); + assert_int_equal(CircleBufferSize(&buffer), 64); + assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); + assert_int_equal(CircleBufferSize(&buffer), 0); + assert_memory_equal(data, databuf, 64); + + assert_int_equal(CircleBufferWrite(&buffer, data, 48), 48); + assert_int_equal(CircleBufferSize(&buffer), 48); + assert_int_equal(CircleBufferWrite(&buffer, data, 48), 0); + assert_int_equal(CircleBufferSize(&buffer), 48); + assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 48); + assert_memory_equal(data, databuf, 48); + + assert_int_equal(CircleBufferWrite(&buffer, data, 48), 48); + assert_int_equal(CircleBufferSize(&buffer), 48); + assert_int_equal(CircleBufferWrite(&buffer, data, 16), 16); + assert_int_equal(CircleBufferSize(&buffer), 64); + assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); + assert_int_equal(CircleBufferSize(&buffer), 0); + assert_memory_equal(data, databuf, 48); + assert_memory_equal(data, &databuf[48], 16); + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(dumpBasic) { + struct CircleBuffer buffer; + const char* data = " Lorem ipsum dolor sit amet, consectetur adipiscing elit placerat."; + char databuf[64]; + + CircleBufferInit(&buffer, 64); + + assert_int_equal(CircleBufferWrite(&buffer, data, 64), 64); + assert_int_equal(CircleBufferSize(&buffer), 64); + assert_int_equal(CircleBufferDump(&buffer, databuf, 64, 0), 64); + assert_int_equal(CircleBufferSize(&buffer), 64); + assert_memory_equal(data, databuf, 64); + assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); + assert_int_equal(CircleBufferSize(&buffer), 0); + assert_memory_equal(data, databuf, 64); + + assert_int_equal(CircleBufferWrite(&buffer, data, 48), 48); + assert_int_equal(CircleBufferSize(&buffer), 48); + assert_int_equal(CircleBufferDump(&buffer, databuf, 48, 0), 48); + assert_int_equal(CircleBufferSize(&buffer), 48); + assert_memory_equal(data, databuf, 48); + assert_int_equal(CircleBufferRead(&buffer, databuf, 16), 16); + assert_int_equal(CircleBufferSize(&buffer), 32); + assert_memory_equal(data, databuf, 16); + assert_int_equal(CircleBufferDump(&buffer, databuf, 48, 0), 32); + assert_int_equal(CircleBufferSize(&buffer), 32); + assert_memory_equal(&data[16], databuf, 32); + + assert_int_equal(CircleBufferWrite(&buffer, data, 32), 32); + assert_int_equal(CircleBufferSize(&buffer), 64); + assert_int_equal(CircleBufferDump(&buffer, databuf, 64, 0), 64); + assert_int_equal(CircleBufferSize(&buffer), 64); + assert_memory_equal(&data[16], databuf, 32); + assert_memory_equal(data, &databuf[32], 32); + assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); + assert_memory_equal(&data[16], databuf, 32); + assert_memory_equal(data, &databuf[32], 32); + assert_int_equal(CircleBufferSize(&buffer), 0); + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(dumpOffset) { + struct CircleBuffer buffer; + const char* data = " Lorem ipsum dolor sit amet, consectetur adipiscing elit placerat."; + char databuf[64]; + + CircleBufferInit(&buffer, 64); + + assert_int_equal(CircleBufferWrite(&buffer, data, 48), 48); + assert_int_equal(CircleBufferSize(&buffer), 48); + assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 0), 32); + assert_memory_equal(data, databuf, 32); + assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 16), 32); + assert_memory_equal(&data[16], databuf, 32); + assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 32), 16); + assert_memory_equal(&data[32], databuf, 16); + + assert_int_equal(CircleBufferRead(&buffer, databuf, 16), 16); + assert_int_equal(CircleBufferSize(&buffer), 32); + assert_memory_equal(data, databuf, 16); + assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 0), 32); + assert_memory_equal(&data[16], databuf, 32); + assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 16), 16); + assert_memory_equal(&data[32], databuf, 16); + + assert_int_equal(CircleBufferWrite(&buffer, data, 32), 32); + assert_int_equal(CircleBufferSize(&buffer), 64); + assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 0), 32); + assert_memory_equal(&data[16], databuf, 32); + assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 16), 32); + assert_memory_equal(&data[32], databuf, 16); + assert_memory_equal(data, &databuf[16], 16); + assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 32), 32); + assert_memory_equal(data, databuf, 32); + assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 48), 16); + assert_memory_equal(&data[16], databuf, 16); + + CircleBufferDeinit(&buffer); +} + M_TEST_SUITE_DEFINE(CircleBuffer, cmocka_unit_test(basicCircle), cmocka_unit_test(basicAlignment16), cmocka_unit_test(basicAlignment32), cmocka_unit_test(capacity), cmocka_unit_test(overCapacity16), + cmocka_unit_test(writeLenCapacity), + cmocka_unit_test(dumpBasic), + cmocka_unit_test(dumpOffset), ) From c689a7fd48a5f66cc30898d487eafecab9bfc6da Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 12 Apr 2024 21:31:06 -0700 Subject: [PATCH 069/338] Util: Add CircleBufferWriteTruncate --- include/mgba-util/circle-buffer.h | 1 + src/util/circle-buffer.c | 7 +++++++ src/util/test/circle-buffer.c | 27 +++++++++++++++++++++++++++ 3 files changed, 35 insertions(+) diff --git a/include/mgba-util/circle-buffer.h b/include/mgba-util/circle-buffer.h index 995f2f32b2e..137b6a7f900 100644 --- a/include/mgba-util/circle-buffer.h +++ b/include/mgba-util/circle-buffer.h @@ -27,6 +27,7 @@ int CircleBufferWrite8(struct CircleBuffer* buffer, int8_t value); int CircleBufferWrite16(struct CircleBuffer* buffer, int16_t value); int CircleBufferWrite32(struct CircleBuffer* buffer, int32_t value); size_t CircleBufferWrite(struct CircleBuffer* buffer, const void* input, size_t length); +size_t CircleBufferWriteTruncate(struct CircleBuffer* buffer, const void* input, size_t length); int CircleBufferRead8(struct CircleBuffer* buffer, int8_t* value); int CircleBufferRead16(struct CircleBuffer* buffer, int16_t* value); int CircleBufferRead32(struct CircleBuffer* buffer, int32_t* value); diff --git a/src/util/circle-buffer.c b/src/util/circle-buffer.c index d58ea0c44e4..12ead5033ef 100644 --- a/src/util/circle-buffer.c +++ b/src/util/circle-buffer.c @@ -153,6 +153,13 @@ size_t CircleBufferWrite(struct CircleBuffer* buffer, const void* input, size_t return length; } +size_t CircleBufferWriteTruncate(struct CircleBuffer* buffer, const void* input, size_t length) { + if (buffer->size + length > buffer->capacity) { + length = buffer->capacity - buffer->size; + } + return CircleBufferWrite(buffer, input, length); +} + int CircleBufferRead8(struct CircleBuffer* buffer, int8_t* value) { int8_t* data = buffer->readPtr; if (buffer->size < sizeof(int8_t)) { diff --git a/src/util/test/circle-buffer.c b/src/util/test/circle-buffer.c index 1bfb0c11161..b60f73a56a5 100644 --- a/src/util/test/circle-buffer.c +++ b/src/util/test/circle-buffer.c @@ -196,6 +196,32 @@ M_TEST_DEFINE(writeLenCapacity) { CircleBufferDeinit(&buffer); } +M_TEST_DEFINE(writeTruncate) { + struct CircleBuffer buffer; + const char* data = " Lorem ipsum dolor sit amet, consectetur adipiscing elit placerat."; + char databuf[64]; + + CircleBufferInit(&buffer, 64); + + assert_int_equal(CircleBufferWriteTruncate(&buffer, data, 64), 64); + assert_int_equal(CircleBufferSize(&buffer), 64); + assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); + assert_int_equal(CircleBufferSize(&buffer), 0); + assert_memory_equal(data, databuf, 64); + + assert_int_equal(CircleBufferWriteTruncate(&buffer, data, 48), 48); + assert_int_equal(CircleBufferSize(&buffer), 48); + assert_int_equal(CircleBufferWrite(&buffer, data, 48), 0); + assert_int_equal(CircleBufferSize(&buffer), 48); + assert_int_equal(CircleBufferWriteTruncate(&buffer, data, 48), 16); + assert_int_equal(CircleBufferSize(&buffer), 64); + assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); + assert_memory_equal(data, databuf, 48); + assert_memory_equal(data, &databuf[48], 16); + + CircleBufferDeinit(&buffer); +} + M_TEST_DEFINE(dumpBasic) { struct CircleBuffer buffer; const char* data = " Lorem ipsum dolor sit amet, consectetur adipiscing elit placerat."; @@ -284,6 +310,7 @@ M_TEST_SUITE_DEFINE(CircleBuffer, cmocka_unit_test(capacity), cmocka_unit_test(overCapacity16), cmocka_unit_test(writeLenCapacity), + cmocka_unit_test(writeTruncate), cmocka_unit_test(dumpBasic), cmocka_unit_test(dumpOffset), ) From ce46b6fe786a3dd31eeae05333b856ba45bebdbd Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 12 Apr 2024 22:20:12 -0700 Subject: [PATCH 070/338] Util: Fix overzealous CircleBufferRead/Write16, lots more tests --- src/util/circle-buffer.c | 4 +- src/util/test/circle-buffer.c | 216 +++++++++++++++++++++++++++++++--- 2 files changed, 199 insertions(+), 21 deletions(-) diff --git a/src/util/circle-buffer.c b/src/util/circle-buffer.c index 12ead5033ef..2747206616c 100644 --- a/src/util/circle-buffer.c +++ b/src/util/circle-buffer.c @@ -102,7 +102,7 @@ int CircleBufferWrite16(struct CircleBuffer* buffer, int16_t value) { if (buffer->size + sizeof(int16_t) > buffer->capacity) { return 0; } - if ((intptr_t) data & 0x3) { + if ((intptr_t) data & 0x1) { int written = 0; written += CircleBufferWrite8(buffer, ((int8_t*) &value)[0]); written += CircleBufferWrite8(buffer, ((int8_t*) &value)[1]); @@ -187,7 +187,7 @@ int CircleBufferRead16(struct CircleBuffer* buffer, int16_t* value) { if (buffer->size < sizeof(int16_t)) { return 0; } - if ((intptr_t) data & 0x3) { + if ((intptr_t) data & 0x1) { int read = 0; read += CircleBufferRead8(buffer, &((int8_t*) value)[0]); read += CircleBufferRead8(buffer, &((int8_t*) value)[1]); diff --git a/src/util/test/circle-buffer.c b/src/util/test/circle-buffer.c index b60f73a56a5..0d8234d0c6f 100644 --- a/src/util/test/circle-buffer.c +++ b/src/util/test/circle-buffer.c @@ -22,41 +22,36 @@ M_TEST_DEFINE(basicCircle) { assert_int_equal(value, i); } - for (i = 0; i < 63; ++i) { - assert_int_equal(CircleBufferWrite8(&buffer, i), 1); - } - for (i = 0; i < 63; ++i) { - int8_t value; - assert_int_equal(CircleBufferRead8(&buffer, &value), 1); - assert_int_equal(value, i); - } - CircleBufferDeinit(&buffer); } M_TEST_DEFINE(basicAlignment16) { struct CircleBuffer buffer; + int8_t i8; CircleBufferInit(&buffer, 64); + // Aligned buffer int16_t i; - for (i = 0; i < 29; ++i) { + for (i = 0; i < 31; ++i) { assert_int_equal(CircleBufferWrite16(&buffer, i), 2); } - for (i = 0; i < 29; ++i) { + for (i = 0; i < 31; ++i) { int16_t value; assert_int_equal(CircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i); } - int8_t i8; + // Misaligned buffer + CircleBufferClear(&buffer); assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - for (i = 0; i < 29; ++i) { + for (i = 0; i < 31; ++i) { assert_int_equal(CircleBufferWrite16(&buffer, i), 2); } - for (i = 0; i < 29; ++i) { + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 31; ++i) { int16_t value; assert_int_equal(CircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i); @@ -65,12 +60,12 @@ M_TEST_DEFINE(basicAlignment16) { CircleBufferDeinit(&buffer); } - M_TEST_DEFINE(basicAlignment32) { struct CircleBuffer buffer; CircleBufferInit(&buffer, 64); + // Aligned buffer int32_t i; for (i = 0; i < 15; ++i) { assert_int_equal(CircleBufferWrite32(&buffer, i), 4); @@ -81,37 +76,51 @@ M_TEST_DEFINE(basicAlignment32) { assert_int_equal(value, i); } + // Singly misaligned buffer int8_t i8; assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 15; ++i) { assert_int_equal(CircleBufferWrite32(&buffer, i), 4); } + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 15; ++i) { int32_t value; assert_int_equal(CircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } + // Doubly misaligned buffer assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 1), 1); for (i = 0; i < 15; ++i) { assert_int_equal(CircleBufferWrite32(&buffer, i), 4); } + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 15; ++i) { int32_t value; assert_int_equal(CircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } + // Triply misaligned buffer assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 1), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 2), 1); for (i = 0; i < 15; ++i) { assert_int_equal(CircleBufferWrite32(&buffer, i), 4); } + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 15; ++i) { int32_t value; assert_int_equal(CircleBufferRead32(&buffer, &value), 4); @@ -150,6 +159,168 @@ M_TEST_DEFINE(capacity) { CircleBufferDeinit(&buffer); } +M_TEST_DEFINE(overflowWrap8) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int8_t value; + int8_t i; + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + for (i = 0; i < 63; ++i) { + assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + } + assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + for (i = 0; i < 63; ++i) { + assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(value, i); + } + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(overflowWrap16) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int16_t value; + int16_t i; + assert_int_equal(CircleBufferWrite16(&buffer, 0), 2); + assert_int_equal(CircleBufferWrite16(&buffer, 0), 2); + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + for (i = 0; i < 31; ++i) { + assert_int_equal(CircleBufferWrite16(&buffer, i), 2); + } + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + for (i = 0; i < 31; ++i) { + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(value, i); + } + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(overflowWrap16_1) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int8_t i8; + int16_t value; + int16_t i; + assert_int_equal(CircleBufferWrite16(&buffer, 0), 2); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + for (i = 0; i < 31; ++i) { + assert_int_equal(CircleBufferWrite16(&buffer, i), 2); + } + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 31; ++i) { + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(value, i); + } + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(overflowWrap32) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int32_t value; + int32_t i; + assert_int_equal(CircleBufferWrite32(&buffer, 0), 4); + assert_int_equal(CircleBufferWrite32(&buffer, 0), 4); + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + } + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i); + } + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(overflowWrap32_1) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int8_t i8; + int32_t value; + int32_t i; + assert_int_equal(CircleBufferWrite32(&buffer, 0), 4); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + } + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i); + } + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(overflowWrap32_2) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int16_t i16; + int32_t value; + int32_t i; + assert_int_equal(CircleBufferWrite32(&buffer, 0), 4); + assert_int_equal(CircleBufferWrite16(&buffer, 0), 2); + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + } + assert_int_equal(CircleBufferRead16(&buffer, &i16), 2); + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i); + } + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(overflowWrap32_3) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 64); + + int8_t i8; + int32_t value; + int32_t i; + assert_int_equal(CircleBufferWrite32(&buffer, 0), 4); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + } + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 15; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i); + } + + CircleBufferDeinit(&buffer); +} + M_TEST_DEFINE(overCapacity16) { struct CircleBuffer buffer; @@ -308,6 +479,13 @@ M_TEST_SUITE_DEFINE(CircleBuffer, cmocka_unit_test(basicAlignment16), cmocka_unit_test(basicAlignment32), cmocka_unit_test(capacity), + cmocka_unit_test(overflowWrap8), + cmocka_unit_test(overflowWrap16), + cmocka_unit_test(overflowWrap16_1), + cmocka_unit_test(overflowWrap32), + cmocka_unit_test(overflowWrap32_1), + cmocka_unit_test(overflowWrap32_2), + cmocka_unit_test(overflowWrap32_3), cmocka_unit_test(overCapacity16), cmocka_unit_test(writeLenCapacity), cmocka_unit_test(writeTruncate), From e8c6613b12276ca439c5a3881f3ae93ab7efd861 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 12 Apr 2024 22:59:08 -0700 Subject: [PATCH 071/338] Util: Fix misaligned end pointer case --- src/util/circle-buffer.c | 8 +- src/util/test/circle-buffer.c | 468 ++++++++++++++++++++++++++++++++++ 2 files changed, 472 insertions(+), 4 deletions(-) diff --git a/src/util/circle-buffer.c b/src/util/circle-buffer.c index 2747206616c..032418e1615 100644 --- a/src/util/circle-buffer.c +++ b/src/util/circle-buffer.c @@ -72,7 +72,7 @@ int CircleBufferWrite32(struct CircleBuffer* buffer, int32_t value) { if (buffer->size + sizeof(int32_t) > buffer->capacity) { return 0; } - if ((intptr_t) data & 0x3) { + if (((intptr_t) data & 0x3) || (uintptr_t) data - (uintptr_t) buffer->data > buffer->capacity - sizeof(int32_t)) { int written = 0; written += CircleBufferWrite8(buffer, ((int8_t*) &value)[0]); written += CircleBufferWrite8(buffer, ((int8_t*) &value)[1]); @@ -102,7 +102,7 @@ int CircleBufferWrite16(struct CircleBuffer* buffer, int16_t value) { if (buffer->size + sizeof(int16_t) > buffer->capacity) { return 0; } - if ((intptr_t) data & 0x1) { + if (((intptr_t) data & 0x1) || (uintptr_t) data - (uintptr_t) buffer->data > buffer->capacity - sizeof(int16_t)) { int written = 0; written += CircleBufferWrite8(buffer, ((int8_t*) &value)[0]); written += CircleBufferWrite8(buffer, ((int8_t*) &value)[1]); @@ -187,7 +187,7 @@ int CircleBufferRead16(struct CircleBuffer* buffer, int16_t* value) { if (buffer->size < sizeof(int16_t)) { return 0; } - if ((intptr_t) data & 0x1) { + if (((intptr_t) data & 0x1) || (uintptr_t) data - (uintptr_t) buffer->data > buffer->capacity - sizeof(int16_t)) { int read = 0; read += CircleBufferRead8(buffer, &((int8_t*) value)[0]); read += CircleBufferRead8(buffer, &((int8_t*) value)[1]); @@ -215,7 +215,7 @@ int CircleBufferRead32(struct CircleBuffer* buffer, int32_t* value) { if (buffer->size < sizeof(int32_t)) { return 0; } - if ((intptr_t) data & 0x3) { + if (((intptr_t) data & 0x3) || (uintptr_t) data - (uintptr_t) buffer->data > buffer->capacity - sizeof(int32_t)) { int read = 0; read += CircleBufferRead8(buffer, &((int8_t*) value)[0]); read += CircleBufferRead8(buffer, &((int8_t*) value)[1]); diff --git a/src/util/test/circle-buffer.c b/src/util/test/circle-buffer.c index 0d8234d0c6f..545b7cffb3f 100644 --- a/src/util/test/circle-buffer.c +++ b/src/util/test/circle-buffer.c @@ -321,6 +321,470 @@ M_TEST_DEFINE(overflowWrap32_3) { CircleBufferDeinit(&buffer); } +M_TEST_DEFINE(weirdSize16) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 15); + + // Aligned, no overflow wrap + int16_t value; + int16_t i; + for (i = 0; i < 7; ++i) { + assert_int_equal(CircleBufferWrite16(&buffer, i * 0x102), 2); + } + assert_int_equal(CircleBufferWrite16(&buffer, 7), 0); + for (i = 0; i < 7; ++i) { + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(value, i * 0x102); + } + + // Misaligned, no overflow wrap + CircleBufferClear(&buffer); + int8_t i8; + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 7; ++i) { + assert_int_equal(CircleBufferWrite16(&buffer, i * 0x102), 2); + } + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 7; ++i) { + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(value, i * 0x102); + } + + // Aligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 6; ++i) { + assert_int_equal(CircleBufferWrite16(&buffer, i * 0x102), 2); + } + assert_int_equal(CircleBufferWrite16(&buffer, 6 * 0x102), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite16(&buffer, 6 * 0x102), 2); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 7; ++i) { + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(value, i * 0x102); + } + + // Misaligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 6; ++i) { + assert_int_equal(CircleBufferWrite16(&buffer, i * 0x102), 2); + } + assert_int_equal(CircleBufferWrite16(&buffer, 6 * 0x102), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite16(&buffer, 6 * 0x102), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite16(&buffer, 6 * 0x102), 2); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 7; ++i) { + assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(value, i * 0x102); + } + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(weirdSize32_1) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 13); + + // Aligned, no overflow wrap + int32_t value; + int32_t i; + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 3), 0); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Misaligned, no overflow wrap + CircleBufferClear(&buffer); + int8_t i8; + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Aligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 2; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Misaligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 2; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(weirdSize32_2) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 14); + + // Aligned, no overflow wrap + int32_t value; + int8_t i8; + int32_t i; + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 3), 0); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Singly misaligned, no overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Doubly misaligned, no overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Aligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 2; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Singly misaligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 2; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Doubly misaligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 2; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + CircleBufferDeinit(&buffer); +} + +M_TEST_DEFINE(weirdSize32_3) { + struct CircleBuffer buffer; + + CircleBufferInit(&buffer, 15); + + // Aligned, no overflow wrap + int32_t value; + int8_t i8; + int32_t i; + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 3), 0); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Singly misaligned, no overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Doubly misaligned, no overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Triply misaligned, no overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Aligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 2; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Singly misaligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 2; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Doubly misaligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 2; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + // Triply misaligned, overflow wrap + CircleBufferClear(&buffer); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + + for (i = 0; i < 2; ++i) { + assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + for (i = 0; i < 3; ++i) { + assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(value, i * 0x1020304); + } + + CircleBufferDeinit(&buffer); +} + M_TEST_DEFINE(overCapacity16) { struct CircleBuffer buffer; @@ -486,6 +950,10 @@ M_TEST_SUITE_DEFINE(CircleBuffer, cmocka_unit_test(overflowWrap32_1), cmocka_unit_test(overflowWrap32_2), cmocka_unit_test(overflowWrap32_3), + cmocka_unit_test(weirdSize16), + cmocka_unit_test(weirdSize32_1), + cmocka_unit_test(weirdSize32_2), + cmocka_unit_test(weirdSize32_3), cmocka_unit_test(overCapacity16), cmocka_unit_test(writeLenCapacity), cmocka_unit_test(writeTruncate), From b62ae33f38954df4acfc966117eb6cbc83f5ceb4 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 12 Apr 2024 23:17:07 -0700 Subject: [PATCH 072/338] Util: Change mInterpolator data API --- include/mgba-util/interpolator.h | 8 +++----- src/util/interpolator.c | 8 +++----- 2 files changed, 6 insertions(+), 10 deletions(-) diff --git a/include/mgba-util/interpolator.h b/include/mgba-util/interpolator.h index 4cb7231fdc7..43b75da2702 100644 --- a/include/mgba-util/interpolator.h +++ b/include/mgba-util/interpolator.h @@ -8,14 +8,12 @@ #include -struct mSampleBuffer { - int16_t* data; - size_t samples; - int channels; +struct mInterpData { + int16_t (*at)(const void* mInterpData, size_t index); }; struct mInterpolator { - int16_t (*interpolate)(const struct mInterpolator* interp, const struct mSampleBuffer* data, double time, double sampleStep); + int16_t (*interpolate)(const struct mInterpolator* interp, const struct mInterpData* data, double time, double sampleStep); }; struct mInterpolatorSinc { diff --git a/src/util/interpolator.c b/src/util/interpolator.c index 2fceee898ab..a9daaa539b9 100644 --- a/src/util/interpolator.c +++ b/src/util/interpolator.c @@ -10,7 +10,7 @@ enum { mSINC_WIDTH = 8, }; -static int16_t mInterpolatorSincInterpolate(const struct mInterpolator*, const struct mSampleBuffer* data, double time, double sampleStep); +static int16_t mInterpolatorSincInterpolate(const struct mInterpolator*, const struct mInterpData*, double time, double sampleStep); void mInterpolatorSincInit(struct mInterpolatorSinc* interp, unsigned resolution, unsigned width) { interp->d.interpolate = mInterpolatorSincInterpolate; @@ -46,7 +46,7 @@ void mInterpolatorSincDeinit(struct mInterpolatorSinc* interp) { free(interp->windowLut); } -int16_t mInterpolatorSincInterpolate(const struct mInterpolator* interpolator, const struct mSampleBuffer* data, double time, double sampleStep) { +int16_t mInterpolatorSincInterpolate(const struct mInterpolator* interpolator, const struct mInterpData* data, double time, double sampleStep) { struct mInterpolatorSinc* interp = (struct mInterpolatorSinc*) interpolator; ssize_t index = (ssize_t) time; double subsample = time - floor(time); @@ -75,9 +75,7 @@ int16_t mInterpolatorSincInterpolate(const struct mInterpolator* interpolator, c kernel = interp->sincLut[sinc] * interp->windowLut[window]; kernelSum += kernel; - if (index + i >= 0 && index + i < (ssize_t) data->samples) { - sum += data->data[(index + i) * data->channels] * kernel; - } + sum += data->at(data, index + i) * kernel; } return sum / kernelSum; } From fd4175ebf85ce589ddd0c6da95b41f8f8cdb7bf2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 12 Apr 2024 23:27:37 -0700 Subject: [PATCH 073/338] Util: Rename CircleBuffer to mCircleBuffer --- include/mgba-util/circle-buffer.h | 32 +- include/mgba-util/vfs.h | 4 +- include/mgba/internal/gba/audio.h | 2 +- src/feature/gui/gui-runner.c | 16 +- src/feature/gui/gui-runner.h | 2 +- src/feature/video-logger.c | 64 +-- src/gba/extra/audio-mixer.c | 14 +- src/platform/psp2/psp2-context.c | 12 +- src/platform/sdl/sdl-events.c | 20 +- src/platform/sdl/sdl-events.h | 4 +- src/util/circle-buffer.c | 60 +- src/util/patch-ups.c | 28 +- src/util/test/circle-buffer.c | 888 +++++++++++++++--------------- src/util/vfs/vfs-fifo.c | 12 +- 14 files changed, 579 insertions(+), 579 deletions(-) diff --git a/include/mgba-util/circle-buffer.h b/include/mgba-util/circle-buffer.h index 137b6a7f900..c93040c6a41 100644 --- a/include/mgba-util/circle-buffer.h +++ b/include/mgba-util/circle-buffer.h @@ -10,7 +10,7 @@ CXX_GUARD_START -struct CircleBuffer { +struct mCircleBuffer { void* data; size_t capacity; size_t size; @@ -18,21 +18,21 @@ struct CircleBuffer { void* writePtr; }; -void CircleBufferInit(struct CircleBuffer* buffer, unsigned capacity); -void CircleBufferDeinit(struct CircleBuffer* buffer); -size_t CircleBufferSize(const struct CircleBuffer* buffer); -size_t CircleBufferCapacity(const struct CircleBuffer* buffer); -void CircleBufferClear(struct CircleBuffer* buffer); -int CircleBufferWrite8(struct CircleBuffer* buffer, int8_t value); -int CircleBufferWrite16(struct CircleBuffer* buffer, int16_t value); -int CircleBufferWrite32(struct CircleBuffer* buffer, int32_t value); -size_t CircleBufferWrite(struct CircleBuffer* buffer, const void* input, size_t length); -size_t CircleBufferWriteTruncate(struct CircleBuffer* buffer, const void* input, size_t length); -int CircleBufferRead8(struct CircleBuffer* buffer, int8_t* value); -int CircleBufferRead16(struct CircleBuffer* buffer, int16_t* value); -int CircleBufferRead32(struct CircleBuffer* buffer, int32_t* value); -size_t CircleBufferRead(struct CircleBuffer* buffer, void* output, size_t length); -size_t CircleBufferDump(const struct CircleBuffer* buffer, void* output, size_t length, size_t offset); +void mCircleBufferInit(struct mCircleBuffer* buffer, unsigned capacity); +void mCircleBufferDeinit(struct mCircleBuffer* buffer); +size_t mCircleBufferSize(const struct mCircleBuffer* buffer); +size_t mCircleBufferCapacity(const struct mCircleBuffer* buffer); +void mCircleBufferClear(struct mCircleBuffer* buffer); +int mCircleBufferWrite8(struct mCircleBuffer* buffer, int8_t value); +int mCircleBufferWrite16(struct mCircleBuffer* buffer, int16_t value); +int mCircleBufferWrite32(struct mCircleBuffer* buffer, int32_t value); +size_t mCircleBufferWrite(struct mCircleBuffer* buffer, const void* input, size_t length); +size_t mCircleBufferWriteTruncate(struct mCircleBuffer* buffer, const void* input, size_t length); +int mCircleBufferRead8(struct mCircleBuffer* buffer, int8_t* value); +int mCircleBufferRead16(struct mCircleBuffer* buffer, int16_t* value); +int mCircleBufferRead32(struct mCircleBuffer* buffer, int32_t* value); +size_t mCircleBufferRead(struct mCircleBuffer* buffer, void* output, size_t length); +size_t mCircleBufferDump(const struct mCircleBuffer* buffer, void* output, size_t length, size_t offset); CXX_GUARD_END diff --git a/include/mgba-util/vfs.h b/include/mgba-util/vfs.h index eee68b99e31..b9c4ca6b238 100644 --- a/include/mgba-util/vfs.h +++ b/include/mgba-util/vfs.h @@ -73,8 +73,8 @@ struct VFile* VFileFromMemory(void* mem, size_t size); struct VFile* VFileFromConstMemory(const void* mem, size_t size); struct VFile* VFileMemChunk(const void* mem, size_t size); -struct CircleBuffer; -struct VFile* VFileFIFO(struct CircleBuffer* backing); +struct mCircleBuffer; +struct VFile* VFileFIFO(struct mCircleBuffer* backing); struct VDir* VDirOpen(const char* path); struct VDir* VDirOpenArchive(const char* path); diff --git a/include/mgba/internal/gba/audio.h b/include/mgba/internal/gba/audio.h index 8b212dd6a23..f2d878e4e1c 100644 --- a/include/mgba/internal/gba/audio.h +++ b/include/mgba/internal/gba/audio.h @@ -253,7 +253,7 @@ struct GBAMP2kTrack { struct GBAMP2kMusicPlayerTrack track; struct GBAMP2kSoundChannel* channel; uint8_t lastCommand; - struct CircleBuffer buffer; + struct mCircleBuffer buffer; uint32_t samplePlaying; float currentOffset; bool waiting; diff --git a/src/feature/gui/gui-runner.c b/src/feature/gui/gui-runner.c index 8c25a79fbd7..b3ce21ad970 100644 --- a/src/feature/gui/gui-runner.c +++ b/src/feature/gui/gui-runner.c @@ -220,7 +220,7 @@ void mGUIInit(struct mGUIRunner* runner, const char* port) { runner->fps = 0; runner->lastFpsCheck = 0; runner->totalDelta = 0; - CircleBufferInit(&runner->fpsBuffer, FPS_BUFFER_SIZE * sizeof(uint32_t)); + mCircleBufferInit(&runner->fpsBuffer, FPS_BUFFER_SIZE * sizeof(uint32_t)); mInputMapInit(&runner->params.keyMap, &_mGUIKeyInfo); mCoreConfigInit(&runner->config, runner->port); @@ -284,7 +284,7 @@ void mGUIDeinit(struct mGUIRunner* runner) { if (runner->teardown) { runner->teardown(runner); } - CircleBufferDeinit(&runner->fpsBuffer); + mCircleBufferDeinit(&runner->fpsBuffer); mInputMapDeinit(&runner->params.keyMap); mCoreConfigDeinit(&runner->config); if (logger.vf) { @@ -502,7 +502,7 @@ void mGUIRun(struct mGUIRunner* runner, const char* path) { runner->fps = 0; bool fastForward = false; while (running) { - CircleBufferClear(&runner->fpsBuffer); + mCircleBufferClear(&runner->fpsBuffer); runner->totalDelta = 0; struct timeval tv; gettimeofday(&tv, 0); @@ -610,17 +610,17 @@ void mGUIRun(struct mGUIRunner* runner, const char* path) { uint64_t delta = t - runner->lastFpsCheck; runner->lastFpsCheck = t; if (delta > 0x7FFFFFFFLL) { - CircleBufferClear(&runner->fpsBuffer); + mCircleBufferClear(&runner->fpsBuffer); runner->fps = 0; } - if (CircleBufferSize(&runner->fpsBuffer) == CircleBufferCapacity(&runner->fpsBuffer)) { + if (mCircleBufferSize(&runner->fpsBuffer) == mCircleBufferCapacity(&runner->fpsBuffer)) { int32_t last; - CircleBufferRead32(&runner->fpsBuffer, &last); + mCircleBufferRead32(&runner->fpsBuffer, &last); runner->totalDelta -= last; } - CircleBufferWrite32(&runner->fpsBuffer, delta); + mCircleBufferWrite32(&runner->fpsBuffer, delta); runner->totalDelta += delta; - runner->fps = (CircleBufferSize(&runner->fpsBuffer) * FPS_GRANULARITY * 1000000.0f) / (runner->totalDelta * sizeof(uint32_t)); + runner->fps = (mCircleBufferSize(&runner->fpsBuffer) * FPS_GRANULARITY * 1000000.0f) / (runner->totalDelta * sizeof(uint32_t)); } } if (frame % (AUTOSAVE_GRANULARITY * (fastForwarding ? 2 : 1)) == 0) { diff --git a/src/feature/gui/gui-runner.h b/src/feature/gui/gui-runner.h index 0dc412838bd..334ef57d966 100644 --- a/src/feature/gui/gui-runner.h +++ b/src/feature/gui/gui-runner.h @@ -78,7 +78,7 @@ struct mGUIRunner { float fps; int64_t lastFpsCheck; int32_t totalDelta; - struct CircleBuffer fpsBuffer; + struct mCircleBuffer fpsBuffer; void (*setup)(struct mGUIRunner*); void (*teardown)(struct mGUIRunner*); diff --git a/src/feature/video-logger.c b/src/feature/video-logger.c index fb2065b425b..978700864c5 100644 --- a/src/feature/video-logger.c +++ b/src/feature/video-logger.c @@ -87,8 +87,8 @@ struct mVideoLogChannel { enum mVideoLoggerInjectionPoint injectionPoint; uint32_t ignorePackets; - struct CircleBuffer injectedBuffer; - struct CircleBuffer buffer; + struct mCircleBuffer injectedBuffer; + struct mCircleBuffer buffer; }; struct mVideoLogContext { @@ -662,8 +662,8 @@ bool mVideoLogContextLoad(struct mVideoLogContext* context, struct VFile* vf) { size_t i; for (i = 0; i < context->nChannels; ++i) { - CircleBufferInit(&context->channels[i].injectedBuffer, BUFFER_BASE_SIZE); - CircleBufferInit(&context->channels[i].buffer, BUFFER_BASE_SIZE); + mCircleBufferInit(&context->channels[i].injectedBuffer, BUFFER_BASE_SIZE); + mCircleBufferInit(&context->channels[i].buffer, BUFFER_BASE_SIZE); context->channels[i].bufferRemaining = 0; context->channels[i].currentPointer = pointer; context->channels[i].p = context; @@ -676,8 +676,8 @@ bool mVideoLogContextLoad(struct mVideoLogContext* context, struct VFile* vf) { #ifdef USE_ZLIB static void _flushBufferCompressed(struct mVideoLogContext* context) { - struct CircleBuffer* buffer = &context->channels[context->activeChannel].buffer; - if (!CircleBufferSize(buffer)) { + struct mCircleBuffer* buffer = &context->channels[context->activeChannel].buffer; + if (!mCircleBufferSize(buffer)) { return; } struct VFile* vfm = VFileMemChunk(NULL, 0); @@ -707,20 +707,20 @@ static void _flushBuffer(struct mVideoLogContext* context) { } #endif - struct CircleBuffer* buffer = &context->channels[context->activeChannel].buffer; - if (!CircleBufferSize(buffer)) { + struct mCircleBuffer* buffer = &context->channels[context->activeChannel].buffer; + if (!mCircleBufferSize(buffer)) { return; } struct mVLBlockHeader header = { 0 }; STORE_32LE(mVL_BLOCK_DATA, 0, &header.blockType); - STORE_32LE(CircleBufferSize(buffer), 0, &header.length); + STORE_32LE(mCircleBufferSize(buffer), 0, &header.length); STORE_32LE(context->activeChannel, 0, &header.channelId); context->backing->write(context->backing, &header, sizeof(header)); uint8_t writeBuffer[0x800]; - while (CircleBufferSize(buffer)) { - size_t read = CircleBufferRead(buffer, writeBuffer, sizeof(writeBuffer)); + while (mCircleBufferSize(buffer)) { + size_t read = mCircleBufferRead(buffer, writeBuffer, sizeof(writeBuffer)); context->backing->write(context->backing, writeBuffer, read); } } @@ -743,8 +743,8 @@ void mVideoLogContextDestroy(struct mCore* core, struct mVideoLogContext* contex size_t i; for (i = 0; i < context->nChannels; ++i) { - CircleBufferDeinit(&context->channels[i].injectedBuffer); - CircleBufferDeinit(&context->channels[i].buffer); + mCircleBufferDeinit(&context->channels[i].injectedBuffer); + mCircleBufferDeinit(&context->channels[i].buffer); #ifdef USE_ZLIB if (context->channels[i].inflating) { inflateEnd(&context->channels[i].inflateStream); @@ -778,8 +778,8 @@ void mVideoLogContextRewind(struct mVideoLogContext* context, struct mCore* core size_t i; for (i = 0; i < context->nChannels; ++i) { - CircleBufferClear(&context->channels[i].injectedBuffer); - CircleBufferClear(&context->channels[i].buffer); + mCircleBufferClear(&context->channels[i].injectedBuffer); + mCircleBufferClear(&context->channels[i].buffer); context->channels[i].bufferRemaining = 0; context->channels[i].currentPointer = pointer; #ifdef USE_ZLIB @@ -805,8 +805,8 @@ int mVideoLoggerAddChannel(struct mVideoLogContext* context) { int chid = context->nChannels; ++context->nChannels; context->channels[chid].p = context; - CircleBufferInit(&context->channels[chid].injectedBuffer, BUFFER_BASE_SIZE); - CircleBufferInit(&context->channels[chid].buffer, BUFFER_BASE_SIZE); + mCircleBufferInit(&context->channels[chid].injectedBuffer, BUFFER_BASE_SIZE); + mCircleBufferInit(&context->channels[chid].buffer, BUFFER_BASE_SIZE); context->channels[chid].injecting = false; context->channels[chid].injectionPoint = LOGGER_INJECTION_IMMEDIATE; context->channels[chid].ignorePackets = 0; @@ -898,7 +898,7 @@ static size_t _readBufferCompressed(struct VFile* vf, struct mVideoLogChannel* c } } - thisWrite = CircleBufferWrite(&channel->buffer, zbuffer, thisWrite - channel->inflateStream.avail_out); + thisWrite = mCircleBufferWrite(&channel->buffer, zbuffer, thisWrite - channel->inflateStream.avail_out); length -= thisWrite; read += thisWrite; @@ -921,7 +921,7 @@ static void _readBuffer(struct VFile* vf, struct mVideoLogChannel* channel, size if (thisRead <= 0) { return; } - size_t thisWrite = CircleBufferWrite(&channel->buffer, buffer, thisRead); + size_t thisWrite = mCircleBufferWrite(&channel->buffer, buffer, thisRead); length -= thisWrite; channel->bufferRemaining -= thisWrite; channel->currentPointer += thisWrite; @@ -986,16 +986,16 @@ static ssize_t mVideoLoggerReadChannel(struct mVideoLogChannel* channel, void* d if (channelId >= mVL_MAX_CHANNELS) { return 0; } - struct CircleBuffer* buffer = &channel->buffer; + struct mCircleBuffer* buffer = &channel->buffer; if (channel->injecting) { buffer = &channel->injectedBuffer; } - if (CircleBufferSize(buffer) >= length) { - return CircleBufferRead(buffer, data, length); + if (mCircleBufferSize(buffer) >= length) { + return mCircleBufferRead(buffer, data, length); } ssize_t size = 0; - if (CircleBufferSize(buffer)) { - size = CircleBufferRead(buffer, data, CircleBufferSize(buffer)); + if (mCircleBufferSize(buffer)) { + size = mCircleBufferRead(buffer, data, mCircleBufferSize(buffer)); if (size <= 0) { return size; } @@ -1005,7 +1005,7 @@ static ssize_t mVideoLoggerReadChannel(struct mVideoLogChannel* channel, void* d if (channel->injecting || !_fillBuffer(context, channelId, BUFFER_BASE_SIZE)) { return size; } - size += CircleBufferRead(buffer, data, length); + size += mCircleBufferRead(buffer, data, length); return size; } @@ -1019,20 +1019,20 @@ static ssize_t mVideoLoggerWriteChannel(struct mVideoLogChannel* channel, const _flushBuffer(context); context->activeChannel = channelId; } - struct CircleBuffer* buffer = &channel->buffer; + struct mCircleBuffer* buffer = &channel->buffer; if (channel->injecting) { buffer = &channel->injectedBuffer; } - if (CircleBufferCapacity(buffer) - CircleBufferSize(buffer) < length) { + if (mCircleBufferCapacity(buffer) - mCircleBufferSize(buffer) < length) { _flushBuffer(context); - if (CircleBufferCapacity(buffer) < length) { - CircleBufferDeinit(buffer); - CircleBufferInit(buffer, toPow2(length << 1)); + if (mCircleBufferCapacity(buffer) < length) { + mCircleBufferDeinit(buffer); + mCircleBufferInit(buffer, toPow2(length << 1)); } } - ssize_t read = CircleBufferWrite(buffer, data, length); - if (CircleBufferCapacity(buffer) == CircleBufferSize(buffer)) { + ssize_t read = mCircleBufferWrite(buffer, data, length); + if (mCircleBufferCapacity(buffer) == mCircleBufferSize(buffer)) { _flushBuffer(context); } return read; diff --git a/src/gba/extra/audio-mixer.c b/src/gba/extra/audio-mixer.c index 2a14f1ce661..e01b609b407 100644 --- a/src/gba/extra/audio-mixer.c +++ b/src/gba/extra/audio-mixer.c @@ -43,7 +43,7 @@ void _mp2kInit(void* cpu, struct mCPUComponent* component) { size_t i; for (i = 0; i < MP2K_MAX_SOUND_CHANNELS; ++i) { mixer->activeTracks[i].channel = &mixer->context.chans[i]; - CircleBufferInit(&mixer->activeTracks[i].buffer, 0x10000); + mCircleBufferInit(&mixer->activeTracks[i].buffer, 0x10000); } } @@ -51,7 +51,7 @@ void _mp2kDeinit(struct mCPUComponent* component) { struct GBAAudioMixer* mixer = (struct GBAAudioMixer*) component; size_t i; for (i = 0; i < MP2K_MAX_SOUND_CHANNELS; ++i) { - CircleBufferDeinit(&mixer->activeTracks[i].buffer); + mCircleBufferDeinit(&mixer->activeTracks[i].buffer); } } @@ -130,8 +130,8 @@ static void _stepSample(struct GBAAudioMixer* mixer, struct GBAMP2kTrack* track) (sample * track->channel->rightVolume * track->channel->envelopeV) >> 9 }; - CircleBufferWrite16(&track->buffer, stereo.left); - CircleBufferWrite16(&track->buffer, stereo.right); + mCircleBufferWrite16(&track->buffer, stereo.left); + mCircleBufferWrite16(&track->buffer, stereo.right); sampleOffset += mixer->p->sampleInterval / OVERSAMPLE; while (sampleOffset > freq) { @@ -265,7 +265,7 @@ void _mp2kStep(struct GBAAudioMixer* mixer) { } else { track->currentOffset = 0; track->samplePlaying = 0; - CircleBufferClear(&track->buffer); + mCircleBufferClear(&track->buffer); } } mixer->frame -= VIDEO_TOTAL_LENGTH / mixer->tempo; @@ -281,9 +281,9 @@ void _mp2kStep(struct GBAAudioMixer* mixer) { continue; } int16_t value; - CircleBufferRead16(&mixer->activeTracks[track].buffer, &value); + mCircleBufferRead16(&mixer->activeTracks[track].buffer, &value); sample.left += value; - CircleBufferRead16(&mixer->activeTracks[track].buffer, &value); + mCircleBufferRead16(&mixer->activeTracks[track].buffer, &value); sample.right += value; } sample.left = (sample.left * mixer->p->masterVolume) >> 8; diff --git a/src/platform/psp2/psp2-context.c b/src/platform/psp2/psp2-context.c index 1e48c2f24f5..34623a87654 100644 --- a/src/platform/psp2/psp2-context.c +++ b/src/platform/psp2/psp2-context.c @@ -65,7 +65,7 @@ static struct mSceRotationSource { static struct mSceRumble { struct mRumble d; - struct CircleBuffer history; + struct mCircleBuffer history; int current; } rumble; @@ -155,12 +155,12 @@ static int32_t _readGyroZ(struct mRotationSource* source) { static void _setRumble(struct mRumble* source, int enable) { struct mSceRumble* rumble = (struct mSceRumble*) source; rumble->current += enable; - if (CircleBufferSize(&rumble->history) == RUMBLE_PWM) { + if (mCircleBufferSize(&rumble->history) == RUMBLE_PWM) { int8_t oldLevel; - CircleBufferRead8(&rumble->history, &oldLevel); + mCircleBufferRead8(&rumble->history, &oldLevel); rumble->current -= oldLevel; } - CircleBufferWrite8(&rumble->history, enable); + mCircleBufferWrite8(&rumble->history, enable); int small = (rumble->current << 21) / 65793; int big = ((rumble->current * rumble->current) << 18) / 65793; struct SceCtrlActuator state = { @@ -342,7 +342,7 @@ void mPSP2Setup(struct mGUIRunner* runner) { runner->core->setPeripheral(runner->core, mPERIPH_ROTATION, &rotation.d); rumble.d.setRumble = _setRumble; - CircleBufferInit(&rumble.history, RUMBLE_PWM); + mCircleBufferInit(&rumble.history, RUMBLE_PWM); runner->core->setPeripheral(runner->core, mPERIPH_RUMBLE, &rumble.d); camera.d.startRequestImage = _startRequestImage; @@ -482,7 +482,7 @@ void mPSP2Unpaused(struct mGUIRunner* runner) { void mPSP2Teardown(struct mGUIRunner* runner) { UNUSED(runner); - CircleBufferDeinit(&rumble.history); + mCircleBufferDeinit(&rumble.history); vita2d_free_texture(tex[0]); vita2d_free_texture(tex[1]); vita2d_free_texture(screenshot); diff --git a/src/platform/sdl/sdl-events.c b/src/platform/sdl/sdl-events.c index eceaf18081a..950bb94f3c4 100644 --- a/src/platform/sdl/sdl-events.c +++ b/src/platform/sdl/sdl-events.c @@ -202,7 +202,7 @@ bool mSDLAttachPlayer(struct mSDLEvents* events, struct mSDLPlayer* player) { #if SDL_VERSION_ATLEAST(2, 0, 0) player->rumble.d.setRumble = _mSDLSetRumble; - CircleBufferInit(&player->rumble.history, RUMBLE_PWM); + mCircleBufferInit(&player->rumble.history, RUMBLE_PWM); player->rumble.level = 0; player->rumble.activeLevel = 0; player->rumble.p = player; @@ -219,7 +219,7 @@ bool mSDLAttachPlayer(struct mSDLEvents* events, struct mSDLPlayer* player) { player->rotation.gyroY = 1; player->rotation.gyroZ = -1; player->rotation.zDelta = 0; - CircleBufferInit(&player->rotation.zHistory, sizeof(float) * GYRO_STEPS); + mCircleBufferInit(&player->rotation.zHistory, sizeof(float) * GYRO_STEPS); player->rotation.p = player; player->playerId = events->playersAttached; @@ -293,9 +293,9 @@ void mSDLDetachPlayer(struct mSDLEvents* events, struct mSDLPlayer* player) { } } --events->playersAttached; - CircleBufferDeinit(&player->rotation.zHistory); + mCircleBufferDeinit(&player->rotation.zHistory); #if SDL_VERSION_ATLEAST(2, 0, 0) - CircleBufferDeinit(&player->rumble.history); + mCircleBufferDeinit(&player->rumble.history); #endif } @@ -739,12 +739,12 @@ static void _mSDLSetRumble(struct mRumble* rumble, int enable) { int8_t originalLevel = sdlRumble->level; sdlRumble->level += enable; - if (CircleBufferSize(&sdlRumble->history) == RUMBLE_PWM) { + if (mCircleBufferSize(&sdlRumble->history) == RUMBLE_PWM) { int8_t oldLevel; - CircleBufferRead8(&sdlRumble->history, &oldLevel); + mCircleBufferRead8(&sdlRumble->history, &oldLevel); sdlRumble->level -= oldLevel; } - CircleBufferWrite8(&sdlRumble->history, enable); + mCircleBufferWrite8(&sdlRumble->history, enable); if (sdlRumble->level == originalLevel) { return; } @@ -851,10 +851,10 @@ static void _mSDLRotationSample(struct mRotationSource* source) { rotation->oldY = y; float oldZ = 0; - if (CircleBufferSize(&rotation->zHistory) == GYRO_STEPS * sizeof(float)) { - CircleBufferRead32(&rotation->zHistory, (int32_t*) &oldZ); + if (mCircleBufferSize(&rotation->zHistory) == GYRO_STEPS * sizeof(float)) { + mCircleBufferRead32(&rotation->zHistory, (int32_t*) &oldZ); } - CircleBufferWrite32(&rotation->zHistory, theta.i); + mCircleBufferWrite32(&rotation->zHistory, theta.i); rotation->zDelta += theta.f - oldZ; } diff --git a/src/platform/sdl/sdl-events.h b/src/platform/sdl/sdl-events.h index 741503be429..877818a01a4 100644 --- a/src/platform/sdl/sdl-events.h +++ b/src/platform/sdl/sdl-events.h @@ -76,7 +76,7 @@ struct mSDLPlayer { int level; float activeLevel; - struct CircleBuffer history; + struct mCircleBuffer history; } rumble; #else int newWidth; @@ -98,7 +98,7 @@ struct mSDLPlayer { int gyroY; int gyroZ; float gyroSensitivity; - struct CircleBuffer zHistory; + struct mCircleBuffer zHistory; int oldX; int oldY; float zDelta; diff --git a/src/util/circle-buffer.c b/src/util/circle-buffer.c index 032418e1615..f0d074d36f9 100644 --- a/src/util/circle-buffer.c +++ b/src/util/circle-buffer.c @@ -6,7 +6,7 @@ #include #ifndef NDEBUG -static int _checkIntegrity(struct CircleBuffer* buffer) { +static int _checkIntegrity(struct mCircleBuffer* buffer) { if ((int8_t*) buffer->writePtr - (int8_t*) buffer->readPtr == (ssize_t) buffer->size) { return 1; } @@ -20,32 +20,32 @@ static int _checkIntegrity(struct CircleBuffer* buffer) { } #endif -void CircleBufferInit(struct CircleBuffer* buffer, unsigned capacity) { +void mCircleBufferInit(struct mCircleBuffer* buffer, unsigned capacity) { buffer->data = malloc(capacity); buffer->capacity = capacity; - CircleBufferClear(buffer); + mCircleBufferClear(buffer); } -void CircleBufferDeinit(struct CircleBuffer* buffer) { +void mCircleBufferDeinit(struct mCircleBuffer* buffer) { free(buffer->data); buffer->data = 0; } -size_t CircleBufferSize(const struct CircleBuffer* buffer) { +size_t mCircleBufferSize(const struct mCircleBuffer* buffer) { return buffer->size; } -size_t CircleBufferCapacity(const struct CircleBuffer* buffer) { +size_t mCircleBufferCapacity(const struct mCircleBuffer* buffer) { return buffer->capacity; } -void CircleBufferClear(struct CircleBuffer* buffer) { +void mCircleBufferClear(struct mCircleBuffer* buffer) { buffer->size = 0; buffer->readPtr = buffer->data; buffer->writePtr = buffer->data; } -int CircleBufferWrite8(struct CircleBuffer* buffer, int8_t value) { +int mCircleBufferWrite8(struct mCircleBuffer* buffer, int8_t value) { int8_t* data = buffer->writePtr; if (buffer->size + sizeof(int8_t) > buffer->capacity) { return 0; @@ -67,17 +67,17 @@ int CircleBufferWrite8(struct CircleBuffer* buffer, int8_t value) { return 1; } -int CircleBufferWrite32(struct CircleBuffer* buffer, int32_t value) { +int mCircleBufferWrite32(struct mCircleBuffer* buffer, int32_t value) { int32_t* data = buffer->writePtr; if (buffer->size + sizeof(int32_t) > buffer->capacity) { return 0; } if (((intptr_t) data & 0x3) || (uintptr_t) data - (uintptr_t) buffer->data > buffer->capacity - sizeof(int32_t)) { int written = 0; - written += CircleBufferWrite8(buffer, ((int8_t*) &value)[0]); - written += CircleBufferWrite8(buffer, ((int8_t*) &value)[1]); - written += CircleBufferWrite8(buffer, ((int8_t*) &value)[2]); - written += CircleBufferWrite8(buffer, ((int8_t*) &value)[3]); + written += mCircleBufferWrite8(buffer, ((int8_t*) &value)[0]); + written += mCircleBufferWrite8(buffer, ((int8_t*) &value)[1]); + written += mCircleBufferWrite8(buffer, ((int8_t*) &value)[2]); + written += mCircleBufferWrite8(buffer, ((int8_t*) &value)[3]); return written; } *data = value; @@ -97,15 +97,15 @@ int CircleBufferWrite32(struct CircleBuffer* buffer, int32_t value) { return 4; } -int CircleBufferWrite16(struct CircleBuffer* buffer, int16_t value) { +int mCircleBufferWrite16(struct mCircleBuffer* buffer, int16_t value) { int16_t* data = buffer->writePtr; if (buffer->size + sizeof(int16_t) > buffer->capacity) { return 0; } if (((intptr_t) data & 0x1) || (uintptr_t) data - (uintptr_t) buffer->data > buffer->capacity - sizeof(int16_t)) { int written = 0; - written += CircleBufferWrite8(buffer, ((int8_t*) &value)[0]); - written += CircleBufferWrite8(buffer, ((int8_t*) &value)[1]); + written += mCircleBufferWrite8(buffer, ((int8_t*) &value)[0]); + written += mCircleBufferWrite8(buffer, ((int8_t*) &value)[1]); return written; } *data = value; @@ -125,7 +125,7 @@ int CircleBufferWrite16(struct CircleBuffer* buffer, int16_t value) { return 2; } -size_t CircleBufferWrite(struct CircleBuffer* buffer, const void* input, size_t length) { +size_t mCircleBufferWrite(struct mCircleBuffer* buffer, const void* input, size_t length) { int8_t* data = buffer->writePtr; if (buffer->size + length > buffer->capacity) { return 0; @@ -153,14 +153,14 @@ size_t CircleBufferWrite(struct CircleBuffer* buffer, const void* input, size_t return length; } -size_t CircleBufferWriteTruncate(struct CircleBuffer* buffer, const void* input, size_t length) { +size_t mCircleBufferWriteTruncate(struct mCircleBuffer* buffer, const void* input, size_t length) { if (buffer->size + length > buffer->capacity) { length = buffer->capacity - buffer->size; } - return CircleBufferWrite(buffer, input, length); + return mCircleBufferWrite(buffer, input, length); } -int CircleBufferRead8(struct CircleBuffer* buffer, int8_t* value) { +int mCircleBufferRead8(struct mCircleBuffer* buffer, int8_t* value) { int8_t* data = buffer->readPtr; if (buffer->size < sizeof(int8_t)) { return 0; @@ -182,15 +182,15 @@ int CircleBufferRead8(struct CircleBuffer* buffer, int8_t* value) { return 1; } -int CircleBufferRead16(struct CircleBuffer* buffer, int16_t* value) { +int mCircleBufferRead16(struct mCircleBuffer* buffer, int16_t* value) { int16_t* data = buffer->readPtr; if (buffer->size < sizeof(int16_t)) { return 0; } if (((intptr_t) data & 0x1) || (uintptr_t) data - (uintptr_t) buffer->data > buffer->capacity - sizeof(int16_t)) { int read = 0; - read += CircleBufferRead8(buffer, &((int8_t*) value)[0]); - read += CircleBufferRead8(buffer, &((int8_t*) value)[1]); + read += mCircleBufferRead8(buffer, &((int8_t*) value)[0]); + read += mCircleBufferRead8(buffer, &((int8_t*) value)[1]); return read; } *value = *data; @@ -210,17 +210,17 @@ int CircleBufferRead16(struct CircleBuffer* buffer, int16_t* value) { return 2; } -int CircleBufferRead32(struct CircleBuffer* buffer, int32_t* value) { +int mCircleBufferRead32(struct mCircleBuffer* buffer, int32_t* value) { int32_t* data = buffer->readPtr; if (buffer->size < sizeof(int32_t)) { return 0; } if (((intptr_t) data & 0x3) || (uintptr_t) data - (uintptr_t) buffer->data > buffer->capacity - sizeof(int32_t)) { int read = 0; - read += CircleBufferRead8(buffer, &((int8_t*) value)[0]); - read += CircleBufferRead8(buffer, &((int8_t*) value)[1]); - read += CircleBufferRead8(buffer, &((int8_t*) value)[2]); - read += CircleBufferRead8(buffer, &((int8_t*) value)[3]); + read += mCircleBufferRead8(buffer, &((int8_t*) value)[0]); + read += mCircleBufferRead8(buffer, &((int8_t*) value)[1]); + read += mCircleBufferRead8(buffer, &((int8_t*) value)[2]); + read += mCircleBufferRead8(buffer, &((int8_t*) value)[3]); return read; } *value = *data; @@ -240,7 +240,7 @@ int CircleBufferRead32(struct CircleBuffer* buffer, int32_t* value) { return 4; } -size_t CircleBufferRead(struct CircleBuffer* buffer, void* output, size_t length) { +size_t mCircleBufferRead(struct mCircleBuffer* buffer, void* output, size_t length) { int8_t* data = buffer->readPtr; if (buffer->size == 0) { return 0; @@ -271,7 +271,7 @@ size_t CircleBufferRead(struct CircleBuffer* buffer, void* output, size_t length return length; } -size_t CircleBufferDump(const struct CircleBuffer* buffer, void* output, size_t length, size_t offset) { +size_t mCircleBufferDump(const struct mCircleBuffer* buffer, void* output, size_t length, size_t offset) { int8_t* data = buffer->readPtr; if (buffer->size <= offset) { return 0; diff --git a/src/util/patch-ups.c b/src/util/patch-ups.c index bce88e74d8a..72d0e14a833 100644 --- a/src/util/patch-ups.c +++ b/src/util/patch-ups.c @@ -23,7 +23,7 @@ static size_t _UPSOutputSize(struct Patch* patch, size_t inSize); static bool _UPSApplyPatch(struct Patch* patch, const void* in, size_t inSize, void* out, size_t outSize); static bool _BPSApplyPatch(struct Patch* patch, const void* in, size_t inSize, void* out, size_t outSize); -static size_t _decodeLength(struct VFile* vf, struct CircleBuffer* buffer); +static size_t _decodeLength(struct VFile* vf, struct mCircleBuffer* buffer); bool loadPatchUPS(struct Patch* patch) { patch->vf->seek(patch->vf, 0, SEEK_SET); @@ -77,42 +77,42 @@ bool _UPSApplyPatch(struct Patch* patch, const void* in, size_t inSize, void* ou return false; } - struct CircleBuffer buffer; + struct mCircleBuffer buffer; memcpy(out, in, inSize > outSize ? outSize : inSize); size_t offset = 0; size_t alreadyRead = 0; uint8_t* buf = out; - CircleBufferInit(&buffer, BUFFER_SIZE); + mCircleBufferInit(&buffer, BUFFER_SIZE); while (alreadyRead < filesize + IN_CHECKSUM) { offset += _decodeLength(patch->vf, &buffer); int8_t byte; while (true) { - if (!CircleBufferSize(&buffer)) { + if (!mCircleBufferSize(&buffer)) { uint8_t block[BUFFER_SIZE]; ssize_t read = patch->vf->read(patch->vf, block, sizeof(block)); if (read < 1) { - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); return false; } - CircleBufferWrite(&buffer, block, read); + mCircleBufferWrite(&buffer, block, read); } - CircleBufferRead8(&buffer, &byte); + mCircleBufferRead8(&buffer, &byte); if (!byte) { break; } if (offset >= outSize) { - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); return false; } buf[offset] ^= byte; ++offset; } ++offset; - alreadyRead = patch->vf->seek(patch->vf, 0, SEEK_CUR) - CircleBufferSize(&buffer); + alreadyRead = patch->vf->seek(patch->vf, 0, SEEK_CUR) - mCircleBufferSize(&buffer); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); uint32_t goodCrc32; patch->vf->seek(patch->vf, OUT_CHECKSUM, SEEK_END); @@ -223,21 +223,21 @@ bool _BPSApplyPatch(struct Patch* patch, const void* in, size_t inSize, void* ou return true; } -size_t _decodeLength(struct VFile* vf, struct CircleBuffer* buffer) { +size_t _decodeLength(struct VFile* vf, struct mCircleBuffer* buffer) { size_t shift = 1; size_t value = 0; uint8_t byte; while (true) { if (buffer) { - if (!CircleBufferSize(buffer)) { + if (!mCircleBufferSize(buffer)) { uint8_t block[BUFFER_SIZE]; ssize_t read = vf->read(vf, block, sizeof(block)); if (read < 1) { return false; } - CircleBufferWrite(buffer, block, read); + mCircleBufferWrite(buffer, block, read); } - CircleBufferRead8(buffer, (int8_t*) &byte); + mCircleBufferRead8(buffer, (int8_t*) &byte); } else { if (vf->read(vf, &byte, 1) != 1) { break; diff --git a/src/util/test/circle-buffer.c b/src/util/test/circle-buffer.c index 545b7cffb3f..9ba3839714d 100644 --- a/src/util/test/circle-buffer.c +++ b/src/util/test/circle-buffer.c @@ -8,937 +8,937 @@ #include M_TEST_DEFINE(basicCircle) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); int8_t i; for (i = 0; i < 63; ++i) { - assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, i), 1); } for (i = 0; i < 63; ++i) { int8_t value; - assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &value), 1); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(basicAlignment16) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; int8_t i8; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); // Aligned buffer int16_t i; for (i = 0; i < 31; ++i) { - assert_int_equal(CircleBufferWrite16(&buffer, i), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, i), 2); } for (i = 0; i < 31; ++i) { int16_t value; - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i); } // Misaligned buffer - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 31; ++i) { - assert_int_equal(CircleBufferWrite16(&buffer, i), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, i), 2); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 31; ++i) { int16_t value; - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(basicAlignment32) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); // Aligned buffer int32_t i; for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i), 4); } for (i = 0; i < 15; ++i) { int32_t value; - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } // Singly misaligned buffer int8_t i8; - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 15; ++i) { int32_t value; - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } // Doubly misaligned buffer - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 1), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 1), 1); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 15; ++i) { int32_t value; - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } // Triply misaligned buffer - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 1), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 2), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 1), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 2), 1); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 15; ++i) { int32_t value; - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(capacity) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); int8_t i; for (i = 0; i < 64; ++i) { - assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, i), 1); } for (i = 0; i < 64; ++i) { int8_t value; - assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &value), 1); assert_int_equal(value, i); } for (i = 0; i < 64; ++i) { - assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, i), 1); } - assert_int_equal(CircleBufferWrite8(&buffer, 64), 0); + assert_int_equal(mCircleBufferWrite8(&buffer, 64), 0); for (i = 0; i < 64; ++i) { int8_t value; - assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &value), 1); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(overflowWrap8) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); int8_t value; int8_t i; - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &value), 1); for (i = 0; i < 63; ++i) { - assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, i), 1); } - assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &value), 1); for (i = 0; i < 63; ++i) { - assert_int_equal(CircleBufferRead8(&buffer, &value), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &value), 1); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(overflowWrap16) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); int16_t value; int16_t i; - assert_int_equal(CircleBufferWrite16(&buffer, 0), 2); - assert_int_equal(CircleBufferWrite16(&buffer, 0), 2); - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, 0), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, 0), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); for (i = 0; i < 31; ++i) { - assert_int_equal(CircleBufferWrite16(&buffer, i), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, i), 2); } - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); for (i = 0; i < 31; ++i) { - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(overflowWrap16_1) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); int8_t i8; int16_t value; int16_t i; - assert_int_equal(CircleBufferWrite16(&buffer, 0), 2); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, 0), 2); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); for (i = 0; i < 31; ++i) { - assert_int_equal(CircleBufferWrite16(&buffer, i), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, i), 2); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 31; ++i) { - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(overflowWrap32) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); int32_t value; int32_t i; - assert_int_equal(CircleBufferWrite32(&buffer, 0), 4); - assert_int_equal(CircleBufferWrite32(&buffer, 0), 4); - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, 0), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, 0), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i), 4); } - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(overflowWrap32_1) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); int8_t i8; int32_t value; int32_t i; - assert_int_equal(CircleBufferWrite32(&buffer, 0), 4); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, 0), 4); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(overflowWrap32_2) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); int16_t i16; int32_t value; int32_t i; - assert_int_equal(CircleBufferWrite32(&buffer, 0), 4); - assert_int_equal(CircleBufferWrite16(&buffer, 0), 2); - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, 0), 4); + assert_int_equal(mCircleBufferWrite16(&buffer, 0), 2); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i), 4); } - assert_int_equal(CircleBufferRead16(&buffer, &i16), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &i16), 2); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(overflowWrap32_3) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); int8_t i8; int32_t value; int32_t i; - assert_int_equal(CircleBufferWrite32(&buffer, 0), 4); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, 0), 4); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 15; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(weirdSize16) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 15); + mCircleBufferInit(&buffer, 15); // Aligned, no overflow wrap int16_t value; int16_t i; for (i = 0; i < 7; ++i) { - assert_int_equal(CircleBufferWrite16(&buffer, i * 0x102), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, i * 0x102), 2); } - assert_int_equal(CircleBufferWrite16(&buffer, 7), 0); + assert_int_equal(mCircleBufferWrite16(&buffer, 7), 0); for (i = 0; i < 7; ++i) { - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i * 0x102); } // Misaligned, no overflow wrap - CircleBufferClear(&buffer); + mCircleBufferClear(&buffer); int8_t i8; - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 7; ++i) { - assert_int_equal(CircleBufferWrite16(&buffer, i * 0x102), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, i * 0x102), 2); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 7; ++i) { - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i * 0x102); } // Aligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 6; ++i) { - assert_int_equal(CircleBufferWrite16(&buffer, i * 0x102), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, i * 0x102), 2); } - assert_int_equal(CircleBufferWrite16(&buffer, 6 * 0x102), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite16(&buffer, 6 * 0x102), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, 6 * 0x102), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite16(&buffer, 6 * 0x102), 2); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 7; ++i) { - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i * 0x102); } // Misaligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 6; ++i) { - assert_int_equal(CircleBufferWrite16(&buffer, i * 0x102), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, i * 0x102), 2); } - assert_int_equal(CircleBufferWrite16(&buffer, 6 * 0x102), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite16(&buffer, 6 * 0x102), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite16(&buffer, 6 * 0x102), 2); + assert_int_equal(mCircleBufferWrite16(&buffer, 6 * 0x102), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite16(&buffer, 6 * 0x102), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite16(&buffer, 6 * 0x102), 2); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 7; ++i) { - assert_int_equal(CircleBufferRead16(&buffer, &value), 2); + assert_int_equal(mCircleBufferRead16(&buffer, &value), 2); assert_int_equal(value, i * 0x102); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(weirdSize32_1) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 13); + mCircleBufferInit(&buffer, 13); // Aligned, no overflow wrap int32_t value; int32_t i; for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferWrite32(&buffer, 3), 0); + assert_int_equal(mCircleBufferWrite32(&buffer, 3), 0); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Misaligned, no overflow wrap - CircleBufferClear(&buffer); + mCircleBufferClear(&buffer); int8_t i8; - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Aligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 2; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 4); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Misaligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 2; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); - } - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); - - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(weirdSize32_2) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 14); + mCircleBufferInit(&buffer, 14); // Aligned, no overflow wrap int32_t value; int8_t i8; int32_t i; for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferWrite32(&buffer, 3), 0); + assert_int_equal(mCircleBufferWrite32(&buffer, 3), 0); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Singly misaligned, no overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Doubly misaligned, no overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Aligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 2; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 4); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Singly misaligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 2; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); - } - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); - - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Doubly misaligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 2; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); - } - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); - - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(weirdSize32_3) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 15); + mCircleBufferInit(&buffer, 15); // Aligned, no overflow wrap int32_t value; int8_t i8; int32_t i; for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferWrite32(&buffer, 3), 0); + assert_int_equal(mCircleBufferWrite32(&buffer, 3), 0); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Singly misaligned, no overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Doubly misaligned, no overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Triply misaligned, no overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Aligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 2; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 4); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Singly misaligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 2; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); } - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 4); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Doubly misaligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 2; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); - } - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); - - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } // Triply misaligned, overflow wrap - CircleBufferClear(&buffer); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); - assert_int_equal(CircleBufferWrite8(&buffer, 0), 1); + mCircleBufferClear(&buffer); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, 0), 1); for (i = 0; i < 2; ++i) { - assert_int_equal(CircleBufferWrite32(&buffer, i * 0x1020304), 4); - } - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 0); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferWrite32(&buffer, 2 * 0x1020304), 4); - - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); - assert_int_equal(CircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, i * 0x1020304), 4); + } + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 0); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferWrite32(&buffer, 2 * 0x1020304), 4); + + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); + assert_int_equal(mCircleBufferRead8(&buffer, &i8), 1); for (i = 0; i < 3; ++i) { - assert_int_equal(CircleBufferRead32(&buffer, &value), 4); + assert_int_equal(mCircleBufferRead32(&buffer, &value), 4); assert_int_equal(value, i * 0x1020304); } - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(overCapacity16) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); int8_t i; for (i = 0; i < 63; ++i) { - assert_int_equal(CircleBufferWrite8(&buffer, i), 1); + assert_int_equal(mCircleBufferWrite8(&buffer, i), 1); } - assert_int_equal(CircleBufferWrite16(&buffer, 0xFFFF), 0); + assert_int_equal(mCircleBufferWrite16(&buffer, 0xFFFF), 0); - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(writeLenCapacity) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; const char* data = " Lorem ipsum dolor sit amet, consectetur adipiscing elit placerat."; char databuf[64]; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); - assert_int_equal(CircleBufferWrite(&buffer, data, 64), 64); - assert_int_equal(CircleBufferSize(&buffer), 64); - assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); - assert_int_equal(CircleBufferSize(&buffer), 0); + assert_int_equal(mCircleBufferWrite(&buffer, data, 64), 64); + assert_int_equal(mCircleBufferSize(&buffer), 64); + assert_int_equal(mCircleBufferRead(&buffer, databuf, 64), 64); + assert_int_equal(mCircleBufferSize(&buffer), 0); assert_memory_equal(data, databuf, 64); - assert_int_equal(CircleBufferWrite(&buffer, data, 48), 48); - assert_int_equal(CircleBufferSize(&buffer), 48); - assert_int_equal(CircleBufferWrite(&buffer, data, 48), 0); - assert_int_equal(CircleBufferSize(&buffer), 48); - assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 48); + assert_int_equal(mCircleBufferWrite(&buffer, data, 48), 48); + assert_int_equal(mCircleBufferSize(&buffer), 48); + assert_int_equal(mCircleBufferWrite(&buffer, data, 48), 0); + assert_int_equal(mCircleBufferSize(&buffer), 48); + assert_int_equal(mCircleBufferRead(&buffer, databuf, 64), 48); assert_memory_equal(data, databuf, 48); - assert_int_equal(CircleBufferWrite(&buffer, data, 48), 48); - assert_int_equal(CircleBufferSize(&buffer), 48); - assert_int_equal(CircleBufferWrite(&buffer, data, 16), 16); - assert_int_equal(CircleBufferSize(&buffer), 64); - assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); - assert_int_equal(CircleBufferSize(&buffer), 0); + assert_int_equal(mCircleBufferWrite(&buffer, data, 48), 48); + assert_int_equal(mCircleBufferSize(&buffer), 48); + assert_int_equal(mCircleBufferWrite(&buffer, data, 16), 16); + assert_int_equal(mCircleBufferSize(&buffer), 64); + assert_int_equal(mCircleBufferRead(&buffer, databuf, 64), 64); + assert_int_equal(mCircleBufferSize(&buffer), 0); assert_memory_equal(data, databuf, 48); assert_memory_equal(data, &databuf[48], 16); - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(writeTruncate) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; const char* data = " Lorem ipsum dolor sit amet, consectetur adipiscing elit placerat."; char databuf[64]; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); - assert_int_equal(CircleBufferWriteTruncate(&buffer, data, 64), 64); - assert_int_equal(CircleBufferSize(&buffer), 64); - assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); - assert_int_equal(CircleBufferSize(&buffer), 0); + assert_int_equal(mCircleBufferWriteTruncate(&buffer, data, 64), 64); + assert_int_equal(mCircleBufferSize(&buffer), 64); + assert_int_equal(mCircleBufferRead(&buffer, databuf, 64), 64); + assert_int_equal(mCircleBufferSize(&buffer), 0); assert_memory_equal(data, databuf, 64); - assert_int_equal(CircleBufferWriteTruncate(&buffer, data, 48), 48); - assert_int_equal(CircleBufferSize(&buffer), 48); - assert_int_equal(CircleBufferWrite(&buffer, data, 48), 0); - assert_int_equal(CircleBufferSize(&buffer), 48); - assert_int_equal(CircleBufferWriteTruncate(&buffer, data, 48), 16); - assert_int_equal(CircleBufferSize(&buffer), 64); - assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); + assert_int_equal(mCircleBufferWriteTruncate(&buffer, data, 48), 48); + assert_int_equal(mCircleBufferSize(&buffer), 48); + assert_int_equal(mCircleBufferWrite(&buffer, data, 48), 0); + assert_int_equal(mCircleBufferSize(&buffer), 48); + assert_int_equal(mCircleBufferWriteTruncate(&buffer, data, 48), 16); + assert_int_equal(mCircleBufferSize(&buffer), 64); + assert_int_equal(mCircleBufferRead(&buffer, databuf, 64), 64); assert_memory_equal(data, databuf, 48); assert_memory_equal(data, &databuf[48], 16); - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(dumpBasic) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; const char* data = " Lorem ipsum dolor sit amet, consectetur adipiscing elit placerat."; char databuf[64]; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); - assert_int_equal(CircleBufferWrite(&buffer, data, 64), 64); - assert_int_equal(CircleBufferSize(&buffer), 64); - assert_int_equal(CircleBufferDump(&buffer, databuf, 64, 0), 64); - assert_int_equal(CircleBufferSize(&buffer), 64); + assert_int_equal(mCircleBufferWrite(&buffer, data, 64), 64); + assert_int_equal(mCircleBufferSize(&buffer), 64); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 64, 0), 64); + assert_int_equal(mCircleBufferSize(&buffer), 64); assert_memory_equal(data, databuf, 64); - assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); - assert_int_equal(CircleBufferSize(&buffer), 0); + assert_int_equal(mCircleBufferRead(&buffer, databuf, 64), 64); + assert_int_equal(mCircleBufferSize(&buffer), 0); assert_memory_equal(data, databuf, 64); - assert_int_equal(CircleBufferWrite(&buffer, data, 48), 48); - assert_int_equal(CircleBufferSize(&buffer), 48); - assert_int_equal(CircleBufferDump(&buffer, databuf, 48, 0), 48); - assert_int_equal(CircleBufferSize(&buffer), 48); + assert_int_equal(mCircleBufferWrite(&buffer, data, 48), 48); + assert_int_equal(mCircleBufferSize(&buffer), 48); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 48, 0), 48); + assert_int_equal(mCircleBufferSize(&buffer), 48); assert_memory_equal(data, databuf, 48); - assert_int_equal(CircleBufferRead(&buffer, databuf, 16), 16); - assert_int_equal(CircleBufferSize(&buffer), 32); + assert_int_equal(mCircleBufferRead(&buffer, databuf, 16), 16); + assert_int_equal(mCircleBufferSize(&buffer), 32); assert_memory_equal(data, databuf, 16); - assert_int_equal(CircleBufferDump(&buffer, databuf, 48, 0), 32); - assert_int_equal(CircleBufferSize(&buffer), 32); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 48, 0), 32); + assert_int_equal(mCircleBufferSize(&buffer), 32); assert_memory_equal(&data[16], databuf, 32); - assert_int_equal(CircleBufferWrite(&buffer, data, 32), 32); - assert_int_equal(CircleBufferSize(&buffer), 64); - assert_int_equal(CircleBufferDump(&buffer, databuf, 64, 0), 64); - assert_int_equal(CircleBufferSize(&buffer), 64); + assert_int_equal(mCircleBufferWrite(&buffer, data, 32), 32); + assert_int_equal(mCircleBufferSize(&buffer), 64); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 64, 0), 64); + assert_int_equal(mCircleBufferSize(&buffer), 64); assert_memory_equal(&data[16], databuf, 32); assert_memory_equal(data, &databuf[32], 32); - assert_int_equal(CircleBufferRead(&buffer, databuf, 64), 64); + assert_int_equal(mCircleBufferRead(&buffer, databuf, 64), 64); assert_memory_equal(&data[16], databuf, 32); assert_memory_equal(data, &databuf[32], 32); - assert_int_equal(CircleBufferSize(&buffer), 0); + assert_int_equal(mCircleBufferSize(&buffer), 0); - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } M_TEST_DEFINE(dumpOffset) { - struct CircleBuffer buffer; + struct mCircleBuffer buffer; const char* data = " Lorem ipsum dolor sit amet, consectetur adipiscing elit placerat."; char databuf[64]; - CircleBufferInit(&buffer, 64); + mCircleBufferInit(&buffer, 64); - assert_int_equal(CircleBufferWrite(&buffer, data, 48), 48); - assert_int_equal(CircleBufferSize(&buffer), 48); - assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 0), 32); + assert_int_equal(mCircleBufferWrite(&buffer, data, 48), 48); + assert_int_equal(mCircleBufferSize(&buffer), 48); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 32, 0), 32); assert_memory_equal(data, databuf, 32); - assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 16), 32); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 32, 16), 32); assert_memory_equal(&data[16], databuf, 32); - assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 32), 16); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 32, 32), 16); assert_memory_equal(&data[32], databuf, 16); - assert_int_equal(CircleBufferRead(&buffer, databuf, 16), 16); - assert_int_equal(CircleBufferSize(&buffer), 32); + assert_int_equal(mCircleBufferRead(&buffer, databuf, 16), 16); + assert_int_equal(mCircleBufferSize(&buffer), 32); assert_memory_equal(data, databuf, 16); - assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 0), 32); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 32, 0), 32); assert_memory_equal(&data[16], databuf, 32); - assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 16), 16); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 32, 16), 16); assert_memory_equal(&data[32], databuf, 16); - assert_int_equal(CircleBufferWrite(&buffer, data, 32), 32); - assert_int_equal(CircleBufferSize(&buffer), 64); - assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 0), 32); + assert_int_equal(mCircleBufferWrite(&buffer, data, 32), 32); + assert_int_equal(mCircleBufferSize(&buffer), 64); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 32, 0), 32); assert_memory_equal(&data[16], databuf, 32); - assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 16), 32); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 32, 16), 32); assert_memory_equal(&data[32], databuf, 16); assert_memory_equal(data, &databuf[16], 16); - assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 32), 32); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 32, 32), 32); assert_memory_equal(data, databuf, 32); - assert_int_equal(CircleBufferDump(&buffer, databuf, 32, 48), 16); + assert_int_equal(mCircleBufferDump(&buffer, databuf, 32, 48), 16); assert_memory_equal(&data[16], databuf, 16); - CircleBufferDeinit(&buffer); + mCircleBufferDeinit(&buffer); } -M_TEST_SUITE_DEFINE(CircleBuffer, +M_TEST_SUITE_DEFINE(mCircleBuffer, cmocka_unit_test(basicCircle), cmocka_unit_test(basicAlignment16), cmocka_unit_test(basicAlignment32), diff --git a/src/util/vfs/vfs-fifo.c b/src/util/vfs/vfs-fifo.c index 5b6af576042..c7bb5be0403 100644 --- a/src/util/vfs/vfs-fifo.c +++ b/src/util/vfs/vfs-fifo.c @@ -8,7 +8,7 @@ struct VFileFIFO { struct VFile d; - struct CircleBuffer* backing; + struct mCircleBuffer* backing; }; static bool _vffClose(struct VFile* vf); @@ -21,7 +21,7 @@ static void _vffTruncate(struct VFile* vf, size_t size); static ssize_t _vffSize(struct VFile* vf); static bool _vffSync(struct VFile* vf, void* buffer, size_t size); -struct VFile* VFileFIFO(struct CircleBuffer* backing) { +struct VFile* VFileFIFO(struct mCircleBuffer* backing) { if (!backing) { return NULL; } @@ -61,12 +61,12 @@ static off_t _vffSeek(struct VFile* vf, off_t offset, int whence) { static ssize_t _vffRead(struct VFile* vf, void* buffer, size_t size) { struct VFileFIFO* vff = (struct VFileFIFO*) vf; - return CircleBufferRead(vff->backing, buffer, size); + return mCircleBufferRead(vff->backing, buffer, size); } static ssize_t _vffWrite(struct VFile* vf, const void* buffer, size_t size) { struct VFileFIFO* vff = (struct VFileFIFO*) vf; - return CircleBufferWrite(vff->backing, buffer, size); + return mCircleBufferWrite(vff->backing, buffer, size); } static void* _vffMap(struct VFile* vf, size_t size, int flags) { @@ -85,13 +85,13 @@ static void _vffUnmap(struct VFile* vf, void* memory, size_t size) { static void _vffTruncate(struct VFile* vf, size_t size) { struct VFileFIFO* vff = (struct VFileFIFO*) vf; if (!size) { - CircleBufferClear(vff->backing); + mCircleBufferClear(vff->backing); } } static ssize_t _vffSize(struct VFile* vf) { struct VFileFIFO* vff = (struct VFileFIFO*) vf; - return CircleBufferSize(vff->backing); + return mCircleBufferSize(vff->backing); } static bool _vffSync(struct VFile* vf, void* buffer, size_t size) { From 237d502404632de326c9c467f8a2c691f89f25c2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 13 Apr 2024 00:48:37 -0700 Subject: [PATCH 074/338] Util: Add prototype mAudioBuffer wrapper --- include/mgba-util/audio-buffer.h | 34 ++++++++++++++++++ src/util/audio-buffer.c | 59 ++++++++++++++++++++++++++++++++ 2 files changed, 93 insertions(+) create mode 100644 include/mgba-util/audio-buffer.h create mode 100644 src/util/audio-buffer.c diff --git a/include/mgba-util/audio-buffer.h b/include/mgba-util/audio-buffer.h new file mode 100644 index 00000000000..b6d7608223a --- /dev/null +++ b/include/mgba-util/audio-buffer.h @@ -0,0 +1,34 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#ifndef M_AUDIO_BUFFER_H +#define M_AUDIO_BUFFER_H + +#include + +CXX_GUARD_START + +#include + +struct mAudioBuffer { + struct mCircleBuffer data; + unsigned channels; +}; + +void mAudioBufferInit(struct mAudioBuffer* buffer, size_t capacity, unsigned channels); +void mAudioBufferDeinit(struct mAudioBuffer* buffer); + +size_t mAudioBufferAvailable(const struct mAudioBuffer* buffer); +size_t mAudioBufferCapacity(const struct mAudioBuffer* buffer); + +void mAudioBufferClear(struct mAudioBuffer* buffer); +int16_t mAudioBufferPeek(const struct mAudioBuffer* buffer, unsigned channel, size_t offset); +size_t mAudioBufferDump(const struct mAudioBuffer* buffer, int16_t* samples, size_t count, size_t offset); +size_t mAudioBufferRead(struct mAudioBuffer* buffer, int16_t* samples, size_t count); +size_t mAudioBufferWrite(struct mAudioBuffer* buffer, const int16_t* samples, size_t count); + +CXX_GUARD_END + +#endif diff --git a/src/util/audio-buffer.c b/src/util/audio-buffer.c new file mode 100644 index 00000000000..bb705b38c00 --- /dev/null +++ b/src/util/audio-buffer.c @@ -0,0 +1,59 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#include + +#include + +void mAudioBufferInit(struct mAudioBuffer* buffer, size_t capacity, unsigned channels) { + mCircleBufferInit(&buffer->data, capacity * channels * sizeof(int16_t)); + buffer->channels = capacity; +} + +void mAudioBufferDeinit(struct mAudioBuffer* buffer) { + mCircleBufferDeinit(&buffer->data); +} + +size_t mAudioBufferAvailable(const struct mAudioBuffer* buffer) { + return mCircleBufferSize(&buffer->data) / (buffer->channels * sizeof(int16_t)); +} + +size_t mAudioBufferCapacity(const struct mAudioBuffer* buffer) { + return mCircleBufferCapacity(&buffer->data) / (buffer->channels * sizeof(int16_t)); +} + +void mAudioBufferClear(struct mAudioBuffer* buffer) { + mCircleBufferClear(&buffer->data); +} + +int16_t mAudioBufferPeek(const struct mAudioBuffer* buffer, unsigned channel, size_t offset) { + int16_t sample; + if (!mCircleBufferDump(&buffer->data, &sample, sizeof(int16_t), (offset * buffer->channels + channel) * sizeof(int16_t))) { + return 0; + } + return sample; +} + +size_t mAudioBufferDump(const struct mAudioBuffer* buffer, int16_t* samples, size_t count, size_t offset) { + return mCircleBufferDump(&buffer->data, + samples, + count * buffer->channels * sizeof(int16_t), + offset * buffer->channels * sizeof(int16_t)) / + (buffer->channels * sizeof(int16_t)); +} + +size_t mAudioBufferRead(struct mAudioBuffer* buffer, int16_t* samples, size_t count) { + return mCircleBufferRead(&buffer->data, samples, count * buffer->channels * sizeof(int16_t)) / + (buffer->channels * sizeof(int16_t)); +} + +size_t mAudioBufferWrite(struct mAudioBuffer* buffer, const int16_t* samples, size_t count) { + size_t free = mCircleBufferCapacity(&buffer->data) - mCircleBufferSize(&buffer->data); + if (count * buffer->channels * sizeof(int16_t) > free) { + count = free / (buffer->channels * sizeof(int16_t)); + } + return mCircleBufferWrite(&buffer->data, samples, count * buffer->channels * sizeof(int16_t)) / + (buffer->channels * sizeof(int16_t)); +} From f13a087b040e07a41f0ce61d5b5b0b1ab581e67b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 14 Apr 2024 04:17:15 -0700 Subject: [PATCH 075/338] Feature: Fix (unused) mVideoProxyBackendRun with block=true --- src/feature/proxy-backend.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/feature/proxy-backend.c b/src/feature/proxy-backend.c index fb6e555edbf..3cfe7c39d0a 100644 --- a/src/feature/proxy-backend.c +++ b/src/feature/proxy-backend.c @@ -229,7 +229,7 @@ bool mVideoProxyBackendRun(struct mVideoProxyBackend* proxy, bool block) { } ok = true; } - } while (block); + } while (block && !ok); return ok; } From 2d7000c8ae4cf0c7da4d283fe1f711290f2847ab Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 14 Apr 2024 04:18:43 -0700 Subject: [PATCH 076/338] Util: Remove unreachable code --- src/util/string.c | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/util/string.c b/src/util/string.c index b2bf376c6e5..4a9e35de53a 100644 --- a/src/util/string.c +++ b/src/util/string.c @@ -285,9 +285,6 @@ char* latin1ToUtf8(const char* latin1, size_t length) { size_t utf8TotalBytes = 0; size_t utf8Length = 0; for (offset = 0; offset < length; ++offset) { - if (length == 0) { - break; - } uint8_t unichar = latin1[offset]; size_t bytes = toUtf8(unichar, buffer); utf8Length += bytes; From a999a8760733cd226741d5e9cc05557aeda3eee3 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 14 Apr 2024 04:22:40 -0700 Subject: [PATCH 077/338] Debugger: Actually handle parseLexedExpression returning false --- src/debugger/cli-debugger.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/debugger/cli-debugger.c b/src/debugger/cli-debugger.c index 6d5b70e9768..95b2037dcd4 100644 --- a/src/debugger/cli-debugger.c +++ b/src/debugger/cli-debugger.c @@ -615,7 +615,7 @@ static struct ParseTree* _parseTree(const char** string) { struct ParseTree* tree = NULL; if (!error) { tree = parseTreeCreate(); - parseLexedExpression(tree, &lv); + error = !parseLexedExpression(tree, &lv); } lexFree(&lv); LexVectorClear(&lv); From e8e6b803f25d0a873bcce75d71c4ff40ef4371ae Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 14 Apr 2024 16:54:02 -0700 Subject: [PATCH 078/338] Qt: Fix window resizing when no game is loaded --- src/platform/qt/Window.cpp | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index 117da820d56..fe2253367e1 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -1523,10 +1523,18 @@ void Window::setupMenu(QMenuBar* menubar) { auto setSize = m_actions.addAction(tr("%1×").arg(QString::number(i)), QString("frame.%1x").arg(QString::number(i)), [this, i]() { auto setSize = m_frameSizes[i]; showNormal(); - QSize size(GBA_VIDEO_HORIZONTAL_PIXELS, GBA_VIDEO_VERTICAL_PIXELS); +#if defined(M_CORE_GBA) + QSize minimumSize = QSize(GBA_VIDEO_HORIZONTAL_PIXELS, GBA_VIDEO_VERTICAL_PIXELS); +#elif defined(M_CORE_GB) + QSize minimumSize = QSize(GB_VIDEO_HORIZONTAL_PIXELS, GB_VIDEO_VERTICAL_PIXELS); +#endif + QSize size; if (m_display) { size = m_display->contentSize(); } + if (size.isNull()) { + size = minimumSize; + } size *= i; m_savedScale = i; m_config->setOption("scaleMultiplier", i); // TODO: Port to other From be85200b3e1eecd291dc93193a5594b104438653 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 14 Apr 2024 20:22:11 -0700 Subject: [PATCH 079/338] Qt: Fix race condition in Qt display driver that could cause division by zero --- src/platform/qt/DisplayQt.cpp | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/platform/qt/DisplayQt.cpp b/src/platform/qt/DisplayQt.cpp index 1d9efebecde..db84c268976 100644 --- a/src/platform/qt/DisplayQt.cpp +++ b/src/platform/qt/DisplayQt.cpp @@ -130,6 +130,10 @@ void DisplayQt::paintEvent(QPaintEvent*) { struct mRectangle frame; VideoBackendGetFrame(&m_backend, &frame); QPoint origin(-frame.x, -frame.y); + QSize drawSize(contentSize()); + if (!drawSize.isValid() || drawSize.width() < 1 || drawSize.height() < 1) { + return; + } QRect full(clampSize(contentSize(), size(), isAspectRatioLocked(), isIntegerScalingLocked())); painter.save(); painter.translate(full.topLeft()); From d1a6e6b747990356754d988e65842eaa02ab9e0c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 14 Apr 2024 20:39:58 -0700 Subject: [PATCH 080/338] Qt: Add option to lock the maximum frame size (closes #1493) --- CHANGES | 1 + include/mgba/feature/proxy-backend.h | 2 ++ include/mgba/feature/video-backend.h | 2 +- src/feature/proxy-backend.c | 10 +++++---- src/platform/opengl/gl.c | 23 ++++++++++++++------- src/platform/opengl/gles2.c | 20 ++++++++++++------ src/platform/qt/Display.h | 2 ++ src/platform/qt/DisplayGL.cpp | 15 +++++++++++++- src/platform/qt/DisplayGL.h | 3 +++ src/platform/qt/DisplayQt.cpp | 17 +++++++++++++-- src/platform/qt/DisplayQt.h | 5 ++++- src/platform/qt/Window.cpp | 31 +++++++++++++++++++++++++++- src/platform/qt/Window.h | 1 + src/platform/sdl/gl-common.c | 2 +- 14 files changed, 110 insertions(+), 24 deletions(-) diff --git a/CHANGES b/CHANGES index e08179d7246..6249e67d8c7 100644 --- a/CHANGES +++ b/CHANGES @@ -1,5 +1,6 @@ 0.11.0: (Future) Features: + - New option to lock the maximum frame size - Scripting: New `input` API for getting raw keyboard/mouse/controller state - Scripting: New `storage` API for saving data for a script, e.g. settings - Scripting: Debugger integration to allow for breakpoints and watchpoints diff --git a/include/mgba/feature/proxy-backend.h b/include/mgba/feature/proxy-backend.h index 8c0b9e42713..ffd38eb47c3 100644 --- a/include/mgba/feature/proxy-backend.h +++ b/include/mgba/feature/proxy-backend.h @@ -38,6 +38,8 @@ union mVideoBackendCommandData { struct { unsigned width; unsigned height; + unsigned maxW; + unsigned maxH; } u; const void* image; }; diff --git a/include/mgba/feature/video-backend.h b/include/mgba/feature/video-backend.h index adf6f839523..f01e656c9fb 100644 --- a/include/mgba/feature/video-backend.h +++ b/include/mgba/feature/video-backend.h @@ -48,7 +48,7 @@ struct VideoBackend { void (*layerDimensions)(const struct VideoBackend*, enum VideoLayer, struct mRectangle*); void (*swap)(struct VideoBackend*); void (*clear)(struct VideoBackend*); - void (*contextResized)(struct VideoBackend*, unsigned w, unsigned h); + void (*contextResized)(struct VideoBackend*, unsigned w, unsigned h, unsigned maxW, unsigned maxH); void (*setImageSize)(struct VideoBackend*, enum VideoLayer, int w, int h); void (*imageSize)(struct VideoBackend*, enum VideoLayer, int* w, int* h); void (*setImage)(struct VideoBackend*, enum VideoLayer, const void* frame); diff --git a/src/feature/proxy-backend.c b/src/feature/proxy-backend.c index 3cfe7c39d0a..54003422722 100644 --- a/src/feature/proxy-backend.c +++ b/src/feature/proxy-backend.c @@ -61,7 +61,7 @@ static void _mVideoProxyBackendClear(struct VideoBackend* v) { mVideoProxyBackendSubmit(proxy, &cmd, NULL); } -static void _mVideoProxyBackendContextResized(struct VideoBackend* v, unsigned w, unsigned h) { +static void _mVideoProxyBackendContextResized(struct VideoBackend* v, unsigned w, unsigned h, unsigned maxW, unsigned maxH) { struct mVideoProxyBackend* proxy = (struct mVideoProxyBackend*) v; struct mVideoBackendCommand cmd = { .cmd = mVB_CMD_CONTEXT_RESIZED, @@ -69,6 +69,8 @@ static void _mVideoProxyBackendContextResized(struct VideoBackend* v, unsigned w .u = { .width = w, .height = h, + .maxW = maxW, + .maxH = maxH, } } }; @@ -139,8 +141,8 @@ void mVideoProxyBackendInit(struct mVideoProxyBackend* proxy, struct VideoBacken proxy->d.drawFrame = _mVideoProxyBackendDrawFrame; proxy->backend = backend; - RingFIFOInit(&proxy->in, 0x400); - RingFIFOInit(&proxy->out, 0x400); + RingFIFOInit(&proxy->in, sizeof(union mVideoBackendCommandData) * 0x80); + RingFIFOInit(&proxy->out, sizeof(union mVideoBackendCommandData) * 0x80); MutexInit(&proxy->inLock); MutexInit(&proxy->outLock); ConditionInit(&proxy->inWait); @@ -209,7 +211,7 @@ bool mVideoProxyBackendRun(struct mVideoProxyBackend* proxy, bool block) { proxy->backend->clear(proxy->backend); break; case mVB_CMD_CONTEXT_RESIZED: - proxy->backend->contextResized(proxy->backend, cmd.data.u.width, cmd.data.u.height); + proxy->backend->contextResized(proxy->backend, cmd.data.u.width, cmd.data.u.height, cmd.data.u.maxW, cmd.data.u.maxH); break; case mVB_CMD_SET_IMAGE_SIZE: proxy->backend->setImageSize(proxy->backend, cmd.layer, cmd.data.s.width, cmd.data.s.height); diff --git a/src/platform/opengl/gl.c b/src/platform/opengl/gl.c index fe24d04cf33..b0cef1f0d92 100644 --- a/src/platform/opengl/gl.c +++ b/src/platform/opengl/gl.c @@ -103,20 +103,29 @@ static void mGLContextDeinit(struct VideoBackend* v) { glDeleteTextures(VIDEO_LAYER_MAX, context->layers); } -static void mGLContextResized(struct VideoBackend* v, unsigned w, unsigned h) { +static void mGLContextResized(struct VideoBackend* v, unsigned w, unsigned h, unsigned maxW, unsigned maxH) { unsigned drawW = w; unsigned drawH = h; - unsigned maxW; - unsigned maxH; - VideoBackendGetFrameSize(v, &maxW, &maxH); + + if (maxW && drawW > maxW) { + drawW = maxW; + } + + if (maxH && drawH > maxH) { + drawH = maxH; + } + + unsigned lockW; + unsigned lockH; + VideoBackendGetFrameSize(v, &lockW, &lockH); if (v->lockAspectRatio) { - lockAspectRatioUInt(maxW, maxH, &drawW, &drawH); + lockAspectRatioUInt(lockW, lockH, &drawW, &drawH); } if (v->lockIntegerScaling) { - lockIntegerRatioUInt(maxW, &drawW); - lockIntegerRatioUInt(maxH, &drawH); + lockIntegerRatioUInt(lockW, &drawW); + lockIntegerRatioUInt(lockH, &drawH); } glMatrixMode(GL_MODELVIEW); glLoadIdentity(); diff --git a/src/platform/opengl/gles2.c b/src/platform/opengl/gles2.c index 51180813eb2..6350bd287a5 100644 --- a/src/platform/opengl/gles2.c +++ b/src/platform/opengl/gles2.c @@ -271,20 +271,28 @@ static void mGLES2ContextDeinit(struct VideoBackend* v) { free(context->initialShader.uniforms); } -static void mGLES2ContextResized(struct VideoBackend* v, unsigned w, unsigned h) { +static void mGLES2ContextResized(struct VideoBackend* v, unsigned w, unsigned h, unsigned maxW, unsigned maxH) { struct mGLES2Context* context = (struct mGLES2Context*) v; unsigned drawW = w; unsigned drawH = h; - unsigned maxW = context->width; - unsigned maxH = context->height; + if (maxW && drawW > maxW) { + drawW = maxW; + } + + if (maxH && drawH > maxH) { + drawH = maxH; + } + + unsigned lockW = context->width; + unsigned lockH = context->height; if (v->lockAspectRatio) { - lockAspectRatioUInt(maxW, maxH, &drawW, &drawH); + lockAspectRatioUInt(lockW, lockH, &drawW, &drawH); } if (v->lockIntegerScaling) { - lockIntegerRatioUInt(maxW, &drawW); - lockIntegerRatioUInt(maxH, &drawH); + lockIntegerRatioUInt(lockW, &drawW); + lockIntegerRatioUInt(lockH, &drawH); } size_t n; for (n = 0; n < context->nShaders; ++n) { diff --git a/src/platform/qt/Display.h b/src/platform/qt/Display.h index ff6f0c23b7e..bb16b268e4f 100644 --- a/src/platform/qt/Display.h +++ b/src/platform/qt/Display.h @@ -57,6 +57,7 @@ Q_OBJECT virtual void setVideoScale(int) {} virtual void setBackgroundImage(const QImage&) = 0; virtual QSize contentSize() const = 0; + virtual void setMaximumSize(const QSize& size) = 0; virtual void setVideoProxy(std::shared_ptr proxy) { m_videoProxy = std::move(proxy); } std::shared_ptr videoProxy() { return m_videoProxy; } @@ -105,6 +106,7 @@ public slots: bool m_filter = false; QTimer m_mouseTimer; std::shared_ptr m_videoProxy; + QSize m_maxSize; }; } diff --git a/src/platform/qt/DisplayGL.cpp b/src/platform/qt/DisplayGL.cpp index 3a4c3ffdd2d..5b60eb46e79 100644 --- a/src/platform/qt/DisplayGL.cpp +++ b/src/platform/qt/DisplayGL.cpp @@ -524,6 +524,10 @@ int DisplayGL::framebufferHandle() { return m_painter->glTex(); } +void DisplayGL::setMaximumSize(const QSize& size) { + QMetaObject::invokeMethod(m_painter.get(), "setMaximumSize", Q_ARG(const QSize&, size)); +} + PainterGL::PainterGL(QWindow* window, mGLWidget* widget, const QSurfaceFormat& format) : m_window(window) , m_format(format) @@ -720,6 +724,11 @@ void PainterGL::resize(const QSize& size) { } } +void PainterGL::setMaximumSize(const QSize& size) { + m_maxSize = size; + resizeContext(); +} + void PainterGL::lockAspectRatio(bool lock) { m_backend->lockAspectRatio = lock; resize(m_size); @@ -911,7 +920,11 @@ void PainterGL::unpause() { void PainterGL::performDraw() { float r = m_window->devicePixelRatio(); - m_backend->contextResized(m_backend, m_size.width() * r, m_size.height() * r); + QSize maxSize = m_maxSize; + if (!maxSize.isValid()) { + maxSize = QSize(0, 0); + } + m_backend->contextResized(m_backend, m_size.width() * r, m_size.height() * r, maxSize.width() * r, maxSize.height() * r); if (m_buffer) { m_backend->setImage(m_backend, VIDEO_LAYER_IMAGE, m_buffer); } diff --git a/src/platform/qt/DisplayGL.h b/src/platform/qt/DisplayGL.h index 71e2de5974f..5b0aab2cd4d 100644 --- a/src/platform/qt/DisplayGL.h +++ b/src/platform/qt/DisplayGL.h @@ -95,6 +95,7 @@ Q_OBJECT void setVideoProxy(std::shared_ptr) override; int framebufferHandle() override; QSize contentSize() const override { return m_cachedContentSize; } + void setMaximumSize(const QSize& size) override; static bool highestCompatible(QSurfaceFormat&); static bool supportsFormat(const QSurfaceFormat&); @@ -172,6 +173,7 @@ public slots: void pause(); void unpause(); void resize(const QSize& size); + void setMaximumSize(const QSize& size); void lockAspectRatio(bool lock); void lockIntegerScaling(bool lock); void interframeBlending(bool enable); @@ -230,6 +232,7 @@ private slots: VideoBackend* m_backend = nullptr; QSize m_size; QSize m_dims; + QSize m_maxSize; MessagePainter* m_messagePainter = nullptr; QElapsedTimer m_delayTimer; std::shared_ptr m_videoProxy; diff --git a/src/platform/qt/DisplayQt.cpp b/src/platform/qt/DisplayQt.cpp index db84c268976..3723a844524 100644 --- a/src/platform/qt/DisplayQt.cpp +++ b/src/platform/qt/DisplayQt.cpp @@ -134,7 +134,20 @@ void DisplayQt::paintEvent(QPaintEvent*) { if (!drawSize.isValid() || drawSize.width() < 1 || drawSize.height() < 1) { return; } - QRect full(clampSize(contentSize(), size(), isAspectRatioLocked(), isIntegerScalingLocked())); + QSize usedSize = size(); + QPoint screenOrigin(0, 0); + if (m_maxSize.isValid()) { + if (m_maxSize.width() < usedSize.width()) { + screenOrigin.setX((usedSize.width() - m_maxSize.width()) / 2); + usedSize.setWidth(m_maxSize.width()); + } + if (m_maxSize.height() < usedSize.height()) { + screenOrigin.setY((usedSize.height() - m_maxSize.height()) / 2); + usedSize.setHeight(m_maxSize.height()); + } + } + QRect full(clampSize(contentSize(), usedSize, isAspectRatioLocked(), isIntegerScalingLocked())); + full.translate(screenOrigin); painter.save(); painter.translate(full.topLeft()); painter.scale(full.width() / static_cast(frame.width), full.height() / static_cast(frame.height)); @@ -220,7 +233,7 @@ void DisplayQt::swap(struct VideoBackend*) { void DisplayQt::clear(struct VideoBackend*) { } -void DisplayQt::contextResized(struct VideoBackend*, unsigned, unsigned) { +void DisplayQt::contextResized(struct VideoBackend*, unsigned, unsigned, unsigned, unsigned) { } void DisplayQt::setImageSize(struct VideoBackend* v, enum VideoLayer layer, int w, int h) { diff --git a/src/platform/qt/DisplayQt.h b/src/platform/qt/DisplayQt.h index c1363dede9d..a6816a18b3b 100644 --- a/src/platform/qt/DisplayQt.h +++ b/src/platform/qt/DisplayQt.h @@ -27,6 +27,8 @@ Q_OBJECT VideoShader* shaders() override { return nullptr; } QSize contentSize() const override; VideoBackend* videoBackend() override { return &m_backend; } + void setMaximumSize(const QSize& size) override { m_maxSize = size; } + public slots: void stopDrawing() override; @@ -56,7 +58,7 @@ public slots: static void layerDimensions(const struct VideoBackend*, enum VideoLayer, struct mRectangle*); static void swap(struct VideoBackend*); static void clear(struct VideoBackend*); - static void contextResized(struct VideoBackend*, unsigned w, unsigned h); + static void contextResized(struct VideoBackend*, unsigned w, unsigned h, unsigned maxW, unsigned maxH); static void setImageSize(struct VideoBackend*, enum VideoLayer, int w, int h); static void imageSize(struct VideoBackend*, enum VideoLayer, int* w, int* h); static void setImage(struct VideoBackend*, enum VideoLayer, const void* frame); @@ -69,6 +71,7 @@ public slots: int m_width = -1; int m_height = -1; QImage m_oldBacking{nullptr}; + QSize m_maxSize; std::shared_ptr m_context = nullptr; }; diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index fe2253367e1..bd52b086293 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -252,6 +252,9 @@ void Window::argumentsPassed() { void Window::resizeFrame(const QSize& size) { QSize newSize(size); + if (!m_config->getOption("lockFrameSize").toInt()) { + m_savedSize = size; + } if (windowHandle()) { QRect geom = windowHandle()->screen()->availableGeometry(); if (newSize.width() > geom.width()) { @@ -1522,7 +1525,10 @@ void Window::setupMenu(QMenuBar* menubar) { for (int i = 1; i <= 8; ++i) { auto setSize = m_actions.addAction(tr("%1×").arg(QString::number(i)), QString("frame.%1x").arg(QString::number(i)), [this, i]() { auto setSize = m_frameSizes[i]; - showNormal(); + bool lockFrameSize = m_config->getOption("lockFrameSize").toInt(); + if (!lockFrameSize) { + showNormal(); + } #if defined(M_CORE_GBA) QSize minimumSize = QSize(GBA_VIDEO_HORIZONTAL_PIXELS, GBA_VIDEO_VERTICAL_PIXELS); #elif defined(M_CORE_GB) @@ -1538,7 +1544,11 @@ void Window::setupMenu(QMenuBar* menubar) { size *= i; m_savedScale = i; m_config->setOption("scaleMultiplier", i); // TODO: Port to other + m_savedSize = size; resizeFrame(size); + if (lockFrameSize) { + m_display->setMaximumSize(size); + } setSize->setActive(true); }, "frame"); setSize->setExclusive(true); @@ -1553,8 +1563,22 @@ void Window::setupMenu(QMenuBar* menubar) { #else fullscreenKeys = QKeySequence("Ctrl+F"); #endif + m_actions.addSeparator("frame"); m_actions.addAction(tr("Toggle fullscreen"), "fullscreen", this, &Window::toggleFullScreen, "frame", fullscreenKeys); + ConfigOption* lockFrameSize = m_config->addOption("lockFrameSize"); + lockFrameSize->addBoolean(tr("&Lock frame size"), &m_actions, "frame"); + lockFrameSize->connect([this](const QVariant& value) { + if (m_display) { + if (value.toBool()) { + m_display->setMaximumSize(m_display->size()); + } else { + m_display->setMaximumSize({}); + } + } + }, this); + m_config->updateOption("lockFrameSize"); + ConfigOption* lockAspectRatio = m_config->addOption("lockAspectRatio"); lockAspectRatio->addBoolean(tr("Lock aspect ratio"), &m_actions, "av"); lockAspectRatio->connect([this](const QVariant& value) { @@ -2216,6 +2240,11 @@ void Window::setController(CoreController* controller, const QString& fname) { void Window::attachDisplay() { m_display->attach(m_controller); connect(m_display.get(), &QGBA::Display::drawingStarted, this, &Window::changeRenderer); + if (m_config->getOption("lockFrameSize").toInt()) { + m_display->setMaximumSize(m_savedSize); + } else { + m_display->setMaximumSize({}); + } m_display->startDrawing(m_controller); #ifdef ENABLE_SCRIPTING diff --git a/src/platform/qt/Window.h b/src/platform/qt/Window.h index 4bcb6b7f9e0..f91e3ff308b 100644 --- a/src/platform/qt/Window.h +++ b/src/platform/qt/Window.h @@ -194,6 +194,7 @@ private slots: std::unique_ptr m_display; QSize m_initialSize; + QSize m_savedSize; int m_savedScale; // TODO: Move these to a new class diff --git a/src/platform/sdl/gl-common.c b/src/platform/sdl/gl-common.c index 1ce9100e804..f2ccdd7e29b 100644 --- a/src/platform/sdl/gl-common.c +++ b/src/platform/sdl/gl-common.c @@ -15,7 +15,7 @@ #endif void mSDLGLDoViewport(int w, int h, struct VideoBackend* v) { - v->contextResized(v, w, h); + v->contextResized(v, w, h, 0, 0); v->clear(v); v->swap(v); v->clear(v); From 4bd09bdac297571927469c5d5150a69260465ed5 Mon Sep 17 00:00:00 2001 From: oltolm Date: Thu, 28 Mar 2024 21:37:31 +0100 Subject: [PATCH 081/338] fix hang in AudioDevice --- src/platform/qt/AudioDevice.cpp | 8 ++++++-- src/platform/qt/AudioDevice.h | 1 + 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/platform/qt/AudioDevice.cpp b/src/platform/qt/AudioDevice.cpp index d19fc20d311..1ae71af1937 100644 --- a/src/platform/qt/AudioDevice.cpp +++ b/src/platform/qt/AudioDevice.cpp @@ -64,11 +64,15 @@ qint64 AudioDevice::writeData(const char*, qint64) { } bool AudioDevice::atEnd() const { + return !bytesAvailable(); +} + +qint64 AudioDevice::bytesAvailable() const { if (!m_context->core) { return true; } mCoreSyncLockAudio(&m_context->impl->sync); - bool available = blip_samples_avail(m_context->core->getAudioChannel(m_context->core, 0)) == 0; + int available = blip_samples_avail(m_context->core->getAudioChannel(m_context->core, 0)); mCoreSyncUnlockAudio(&m_context->impl->sync); - return available; + return available * sizeof(mStereoSample); } diff --git a/src/platform/qt/AudioDevice.h b/src/platform/qt/AudioDevice.h index 86c5b17a6bc..e4386bda293 100644 --- a/src/platform/qt/AudioDevice.h +++ b/src/platform/qt/AudioDevice.h @@ -21,6 +21,7 @@ Q_OBJECT void setInput(mCoreThread* input); void setFormat(const QAudioFormat& format); bool atEnd() const override; + qint64 bytesAvailable() const override; protected: virtual qint64 readData(char* data, qint64 maxSize) override; From 9fa825e3360d9c553cda5f8f636ba547e68ca938 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 16 Apr 2024 01:21:29 -0700 Subject: [PATCH 082/338] Util: Start bringing up new resampler --- include/mgba-util/audio-resampler.h | 37 ++++++++++++ include/mgba-util/interpolator.h | 11 +++- src/util/CMakeLists.txt | 2 + src/util/audio-buffer.c | 2 +- src/util/audio-resampler.c | 94 +++++++++++++++++++++++++++++ src/util/interpolator.c | 21 ++++--- 6 files changed, 154 insertions(+), 13 deletions(-) create mode 100644 include/mgba-util/audio-resampler.h create mode 100644 src/util/audio-resampler.c diff --git a/include/mgba-util/audio-resampler.h b/include/mgba-util/audio-resampler.h new file mode 100644 index 00000000000..50f29893065 --- /dev/null +++ b/include/mgba-util/audio-resampler.h @@ -0,0 +1,37 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#ifndef M_AUDIO_RESAMPLER_H +#define M_AUDIO_RESAMPLER_H + +#include + +CXX_GUARD_START + +#include + +struct mAudioBuffer; +struct mAudioResampler { + struct mAudioBuffer* source; + struct mAudioBuffer* destination; + double sourceRate; + double destRate; + double timestamp; + double lowWaterMark; + double highWaterMark; + struct mInterpolatorSinc interp; + bool consume; +}; + +void mAudioResamplerInit(struct mAudioResampler*); +void mAudioResamplerDeinit(struct mAudioResampler*); +void mAudioResamplerSetSource(struct mAudioResampler*, struct mAudioBuffer* source, double rate, bool consume); +void mAudioResamplerSetDestination(struct mAudioResampler*, struct mAudioBuffer* destination, double rate); +size_t mAudioResamplerProcess(struct mAudioResampler*); + +CXX_GUARD_END + +#endif + diff --git a/include/mgba-util/interpolator.h b/include/mgba-util/interpolator.h index 43b75da2702..f01048f3445 100644 --- a/include/mgba-util/interpolator.h +++ b/include/mgba-util/interpolator.h @@ -8,12 +8,15 @@ #include -struct mInterpData { - int16_t (*at)(const void* mInterpData, size_t index); +CXX_GUARD_START + +struct mInterpolationData { + int16_t (*at)(int index, const void* context); + void* context; }; struct mInterpolator { - int16_t (*interpolate)(const struct mInterpolator* interp, const struct mInterpData* data, double time, double sampleStep); + int16_t (*interpolate)(const struct mInterpolator* interp, const struct mInterpolationData* data, double time, double sampleStep); }; struct mInterpolatorSinc { @@ -28,4 +31,6 @@ struct mInterpolatorSinc { void mInterpolatorSincInit(struct mInterpolatorSinc* interp, unsigned resolution, unsigned width); void mInterpolatorSincDeinit(struct mInterpolatorSinc* interp); +CXX_GUARD_END + #endif diff --git a/src/util/CMakeLists.txt b/src/util/CMakeLists.txt index f0bc85a3d6e..66cd6ca4761 100644 --- a/src/util/CMakeLists.txt +++ b/src/util/CMakeLists.txt @@ -13,6 +13,8 @@ set(BASE_SOURCE_FILES set(SOURCE_FILES ${BASE_SOURCE_FILES} + audio-buffer.c + audio-resampler.c convolve.c elf-read.c geometry.c diff --git a/src/util/audio-buffer.c b/src/util/audio-buffer.c index bb705b38c00..5d67827fbc8 100644 --- a/src/util/audio-buffer.c +++ b/src/util/audio-buffer.c @@ -9,7 +9,7 @@ void mAudioBufferInit(struct mAudioBuffer* buffer, size_t capacity, unsigned channels) { mCircleBufferInit(&buffer->data, capacity * channels * sizeof(int16_t)); - buffer->channels = capacity; + buffer->channels = channels; } void mAudioBufferDeinit(struct mAudioBuffer* buffer) { diff --git a/src/util/audio-resampler.c b/src/util/audio-resampler.c new file mode 100644 index 00000000000..0f0147c348b --- /dev/null +++ b/src/util/audio-resampler.c @@ -0,0 +1,94 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#include + +#include + +#define MAX_CHANNELS 2 + +struct mAudioResamplerData { + struct mAudioResampler* resampler; + unsigned channel; +}; + +static int16_t _sampleAt(int index, const void* context) { + const struct mAudioResamplerData* data = context; + if (index < 0) { + return 0; + } + return mAudioBufferPeek(data->resampler->source, data->channel, index); +} + +void mAudioResamplerInit(struct mAudioResampler* resampler) { + memset(resampler, 0, sizeof(*resampler)); + mInterpolatorSincInit(&resampler->interp, 0, 0); + resampler->lowWaterMark = resampler->interp.width; + resampler->highWaterMark = 0; +} + +void mAudioResamplerDeinit(struct mAudioResampler* resampler) { + mInterpolatorSincDeinit(&resampler->interp); + resampler->source = NULL; + resampler->destination = NULL; +} + +void mAudioResamplerSetSource(struct mAudioResampler* resampler, struct mAudioBuffer* source, double rate, bool consume) { + resampler->source = source; + resampler->sourceRate = rate; + resampler->consume = consume; +} + +void mAudioResamplerSetDestination(struct mAudioResampler* resampler, struct mAudioBuffer* destination, double rate) { + resampler->destination = destination; + resampler->destRate = rate; +} + +size_t mAudioResamplerProcess(struct mAudioResampler* resampler) { + int16_t sampleBuffer[MAX_CHANNELS] = {0}; + double timestep = resampler->sourceRate / resampler->destRate; + double timestamp = resampler->timestamp; + struct mInterpolator* interp = &resampler->interp.d; + struct mAudioResamplerData context = { + .resampler = resampler, + }; + struct mInterpolationData data = { + .at = _sampleAt, + .context = &context, + }; + + size_t read = 0; + if (resampler->source->channels > MAX_CHANNELS) { + abort(); + } + + while (true) { + if (timestamp + resampler->highWaterMark >= mAudioBufferAvailable(resampler->source)) { + break; + } + if (mAudioBufferAvailable(resampler->destination) == mAudioBufferCapacity(resampler->destination)) { + break; + } + + size_t channel; + for (channel = 0; channel < resampler->source->channels; ++channel) { + context.channel = channel; + sampleBuffer[channel] = interp->interpolate(interp, &data, timestamp, timestep); + } + if (!mAudioBufferWrite(resampler->destination, sampleBuffer, 1)) { + break; + } + timestamp += timestep; + ++read; + } + + if (resampler->consume && timestamp > resampler->lowWaterMark) { + size_t drop = timestamp - resampler->lowWaterMark; + drop = mAudioBufferRead(resampler->source, NULL, drop); + timestamp -= drop; + } + resampler->timestamp = timestamp; + return read; +} diff --git a/src/util/interpolator.c b/src/util/interpolator.c index a9daaa539b9..21dd91d2c0b 100644 --- a/src/util/interpolator.c +++ b/src/util/interpolator.c @@ -10,7 +10,7 @@ enum { mSINC_WIDTH = 8, }; -static int16_t mInterpolatorSincInterpolate(const struct mInterpolator*, const struct mInterpData*, double time, double sampleStep); +static int16_t mInterpolatorSincInterpolate(const struct mInterpolator*, const struct mInterpolationData*, double time, double sampleStep); void mInterpolatorSincInit(struct mInterpolatorSinc* interp, unsigned resolution, unsigned width) { interp->d.interpolate = mInterpolatorSincInterpolate; @@ -33,6 +33,9 @@ void mInterpolatorSincInit(struct mInterpolatorSinc* interp, unsigned resolution interp->sincLut[0] = 0; interp->windowLut[0] = 1; + interp->width = width; + interp->resolution = resolution; + unsigned i; for (i = 1; i <= samples; ++i, x += dx, y += dy) { interp->sincLut[i] = x < width ? sin(x) / x : 0.0; @@ -46,27 +49,27 @@ void mInterpolatorSincDeinit(struct mInterpolatorSinc* interp) { free(interp->windowLut); } -int16_t mInterpolatorSincInterpolate(const struct mInterpolator* interpolator, const struct mInterpData* data, double time, double sampleStep) { +int16_t mInterpolatorSincInterpolate(const struct mInterpolator* interpolator, const struct mInterpolationData* data, double time, double sampleStep) { struct mInterpolatorSinc* interp = (struct mInterpolatorSinc*) interpolator; - ssize_t index = (ssize_t) time; + int index = time; double subsample = time - floor(time); - unsigned step = sampleStep > 1 ? interp->resolution * sampleStep : interp->resolution; + unsigned step = sampleStep < 1 ? interp->resolution * sampleStep : interp->resolution; unsigned yShift = subsample * step; unsigned xShift = subsample * interp->resolution; double sum = 0.0; double kernelSum = 0.0; double kernel; - ssize_t i; - for (i = 1 - (ssize_t) interp->width; i <= (ssize_t) interp->width; ++i) { - unsigned window = i * interp->resolution; + int i; + for (i = 1 - (int) interp->width; i <= (int) interp->width; ++i) { + unsigned window = (i >= 0 ? i : -i) * interp->resolution; if (yShift > window) { window = yShift - window; } else { window -= yShift; } - unsigned sinc = i * step; + unsigned sinc = (i >= 0 ? i : -i) * step; if (xShift > sinc) { sinc = xShift - sinc; } else { @@ -75,7 +78,7 @@ int16_t mInterpolatorSincInterpolate(const struct mInterpolator* interpolator, c kernel = interp->sincLut[sinc] * interp->windowLut[window]; kernelSum += kernel; - sum += data->at(data, index + i) * kernel; + sum += data->at(index + i, data->context) * kernel; } return sum / kernelSum; } From 76169c669a70a278b480176deeb1bd5a5ddd639b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 16 Apr 2024 02:54:30 -0700 Subject: [PATCH 083/338] Util: Fix circle buffer dump offset forcing an early wrap --- src/util/circle-buffer.c | 12 +++++++++++- src/util/test/circle-buffer.c | 33 +++++++++++++++++++++++++++++++++ 2 files changed, 44 insertions(+), 1 deletion(-) diff --git a/src/util/circle-buffer.c b/src/util/circle-buffer.c index f0d074d36f9..037a235012a 100644 --- a/src/util/circle-buffer.c +++ b/src/util/circle-buffer.c @@ -279,8 +279,18 @@ size_t mCircleBufferDump(const struct mCircleBuffer* buffer, void* output, size_ if (length > buffer->size - offset) { length = buffer->size - offset; } - data += offset; size_t remaining = buffer->capacity - ((uintptr_t) data - (uintptr_t) buffer->data); + if (offset) { + if (remaining >= offset) { + data += offset; + remaining -= offset; + } else { + offset -= remaining; + data = buffer->data; + data += offset; + } + } + if (length <= remaining) { memcpy(output, data, length); } else { diff --git a/src/util/test/circle-buffer.c b/src/util/test/circle-buffer.c index 9ba3839714d..bff0c9485f3 100644 --- a/src/util/test/circle-buffer.c +++ b/src/util/test/circle-buffer.c @@ -938,6 +938,38 @@ M_TEST_DEFINE(dumpOffset) { mCircleBufferDeinit(&buffer); } +M_TEST_DEFINE(dumpOffsetWrap) { + struct mCircleBuffer buffer; + const char* data = " Lorem ipsum dolor sit amet, consectetur adipiscing elit placerat."; + char databuf[64]; + + mCircleBufferInit(&buffer, 64); + + assert_int_equal(mCircleBufferWrite(&buffer, data, 64), 64); + assert_int_equal(mCircleBufferSize(&buffer), 64); + assert_int_equal(mCircleBufferRead(&buffer, databuf, 48), 48); + assert_memory_equal(data, databuf, 48); + assert_int_equal(mCircleBufferSize(&buffer), 16); + assert_int_equal(mCircleBufferWrite(&buffer, data, 16), 16); + assert_int_equal(mCircleBufferSize(&buffer), 32); + + assert_int_equal(mCircleBufferDump(&buffer, databuf, 64, 0), 32); + assert_memory_equal(&data[48], databuf, 16); + assert_memory_equal(data, &databuf[16], 16); + + assert_int_equal(mCircleBufferDump(&buffer, databuf, 64, 8), 24); + assert_memory_equal(&data[56], databuf, 8); + assert_memory_equal(data, &databuf[8], 16); + + assert_int_equal(mCircleBufferDump(&buffer, databuf, 64, 16), 16); + assert_memory_equal(data, databuf, 16); + + assert_int_equal(mCircleBufferDump(&buffer, databuf, 64, 24), 8); + assert_memory_equal(&data[8], databuf, 8); + + mCircleBufferDeinit(&buffer); +} + M_TEST_SUITE_DEFINE(mCircleBuffer, cmocka_unit_test(basicCircle), cmocka_unit_test(basicAlignment16), @@ -959,4 +991,5 @@ M_TEST_SUITE_DEFINE(mCircleBuffer, cmocka_unit_test(writeTruncate), cmocka_unit_test(dumpBasic), cmocka_unit_test(dumpOffset), + cmocka_unit_test(dumpOffsetWrap), ) From 96a2ef5f42a2a8f453bd71ed38bdead5d9c027c7 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 16 Apr 2024 02:54:48 -0700 Subject: [PATCH 084/338] Util: Enable dropping part of a circle buffer with a null read --- src/util/circle-buffer.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/util/circle-buffer.c b/src/util/circle-buffer.c index 037a235012a..ec14bfc4f88 100644 --- a/src/util/circle-buffer.c +++ b/src/util/circle-buffer.c @@ -250,15 +250,19 @@ size_t mCircleBufferRead(struct mCircleBuffer* buffer, void* output, size_t leng } size_t remaining = buffer->capacity - ((int8_t*) data - (int8_t*) buffer->data); if (length <= remaining) { - memcpy(output, data, length); + if (output) { + memcpy(output, data, length); + } if (length == remaining) { buffer->readPtr = buffer->data; } else { buffer->readPtr = (int8_t*) data + length; } } else { - memcpy(output, data, remaining); - memcpy((int8_t*) output + remaining, buffer->data, length - remaining); + if (output) { + memcpy(output, data, remaining); + memcpy((int8_t*) output + remaining, buffer->data, length - remaining); + } buffer->readPtr = (int8_t*) buffer->data + length - remaining; } From 73a39dea65cd90f2a36a7d2f1f87eb8cf204d8e0 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 16 Apr 2024 20:44:59 -0700 Subject: [PATCH 085/338] Core: Finally kill off GBAAudioCalculateRatio --- include/mgba/core/core.h | 2 ++ include/mgba/internal/gba/audio.h | 2 -- src/core/core.c | 6 ++++++ src/gba/audio.c | 4 ---- src/platform/psp2/psp2-context.c | 2 +- src/platform/qt/AudioDevice.cpp | 2 +- src/platform/sdl/sdl-audio.c | 5 ++--- src/platform/switch/main.c | 2 +- src/platform/wii/main.c | 4 ++-- 9 files changed, 15 insertions(+), 14 deletions(-) diff --git a/include/mgba/core/core.h b/include/mgba/core/core.h index 99bfd0e8375..b34a9451f22 100644 --- a/include/mgba/core/core.h +++ b/include/mgba/core/core.h @@ -216,6 +216,8 @@ void* mCoreGetMemoryBlock(struct mCore* core, uint32_t start, size_t* size); void* mCoreGetMemoryBlockMasked(struct mCore* core, uint32_t start, size_t* size, uint32_t mask); const struct mCoreMemoryBlock* mCoreGetMemoryBlockInfo(struct mCore* core, uint32_t address); +double mCoreCalculateFramerateRatio(const struct mCore* core, double desiredFrameRate); + #ifdef USE_ELF struct ELF; bool mCoreLoadELF(struct mCore* core, struct ELF* elf); diff --git a/include/mgba/internal/gba/audio.h b/include/mgba/internal/gba/audio.h index f2d878e4e1c..6702f5ff478 100644 --- a/include/mgba/internal/gba/audio.h +++ b/include/mgba/internal/gba/audio.h @@ -313,8 +313,6 @@ struct GBASerializedState; void GBAAudioSerialize(const struct GBAAudio* audio, struct GBASerializedState* state); void GBAAudioDeserialize(struct GBAAudio* audio, const struct GBASerializedState* state); -float GBAAudioCalculateRatio(float inputSampleRate, float desiredFPS, float desiredSampleRatio); - CXX_GUARD_END #endif diff --git a/src/core/core.c b/src/core/core.c index bc68fd5d2bc..bcc72115a77 100644 --- a/src/core/core.c +++ b/src/core/core.c @@ -442,6 +442,12 @@ const struct mCoreMemoryBlock* mCoreGetMemoryBlockInfo(struct mCore* core, uint3 return NULL; } +double mCoreCalculateFramerateRatio(const struct mCore* core, double desiredFrameRate) { + uint32_t clockRate = core->frequency(core); + uint32_t frameCycles = core->frameCycles(core); + return clockRate / (desiredFrameRate * frameCycles); +} + #ifdef USE_ELF bool mCoreLoadELF(struct mCore* core, struct ELF* elf) { struct ELFProgramHeaders ph; diff --git a/src/gba/audio.c b/src/gba/audio.c index fb0e1b62c63..b25273f1680 100644 --- a/src/gba/audio.c +++ b/src/gba/audio.c @@ -587,7 +587,3 @@ void GBAAudioDeserialize(struct GBAAudio* audio, const struct GBASerializedState } mTimingSchedule(&audio->p->timing, &audio->sampleEvent, when); } - -float GBAAudioCalculateRatio(float inputSampleRate, float desiredFPS, float desiredSampleRate) { - return desiredSampleRate * GBA_ARM7TDMI_FREQUENCY / (VIDEO_TOTAL_LENGTH * desiredFPS * inputSampleRate); -} diff --git a/src/platform/psp2/psp2-context.c b/src/platform/psp2/psp2-context.c index 34623a87654..755021f6f5f 100644 --- a/src/platform/psp2/psp2-context.c +++ b/src/platform/psp2/psp2-context.c @@ -376,7 +376,7 @@ void mPSP2Setup(struct mGUIRunner* runner) { void mPSP2LoadROM(struct mGUIRunner* runner) { float rate = 60.0f / 1.001f; sceDisplayGetRefreshRate(&rate); - double ratio = GBAAudioCalculateRatio(1, rate, 1); + double ratio = mCoreCalculateFramerateRatio(runner->core, rate); blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), 48000 * ratio); blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), 48000 * ratio); diff --git a/src/platform/qt/AudioDevice.cpp b/src/platform/qt/AudioDevice.cpp index 1ae71af1937..ec6dd31333b 100644 --- a/src/platform/qt/AudioDevice.cpp +++ b/src/platform/qt/AudioDevice.cpp @@ -26,7 +26,7 @@ void AudioDevice::setFormat(const QAudioFormat& format) { LOG(QT, INFO) << tr("Can't set format of context-less audio device"); return; } - double fauxClock = GBAAudioCalculateRatio(1, m_context->impl->sync.fpsTarget, 1); + double fauxClock = mCoreCalculateFramerateRatio(m_context->core, m_context->impl->sync.fpsTarget); mCoreSyncLockAudio(&m_context->impl->sync); blip_set_rates(m_context->core->getAudioChannel(m_context->core, 0), m_context->core->frequency(m_context->core), format.sampleRate() * fauxClock); diff --git a/src/platform/sdl/sdl-audio.c b/src/platform/sdl/sdl-audio.c index f1666aa4ee9..2d1fc9f859e 100644 --- a/src/platform/sdl/sdl-audio.c +++ b/src/platform/sdl/sdl-audio.c @@ -103,12 +103,11 @@ static void _mSDLAudioCallback(void* context, Uint8* data, int len) { if (audioContext->core) { left = audioContext->core->getAudioChannel(audioContext->core, 0); right = audioContext->core->getAudioChannel(audioContext->core, 1); - clockRate = audioContext->core->frequency(audioContext->core); } double fauxClock = 1; if (audioContext->sync) { - if (audioContext->sync->fpsTarget > 0) { - fauxClock = GBAAudioCalculateRatio(1, audioContext->sync->fpsTarget, 1); + if (audioContext->sync->fpsTarget > 0 && audioContext->core) { + fauxClock = mCoreCalculateFramerateRatio(audioContext->core, audioContext->sync->fpsTarget); } mCoreSyncLockAudio(audioContext->sync); } diff --git a/src/platform/switch/main.c b/src/platform/switch/main.c index 15196aaeca5..7dd8dc74203 100644 --- a/src/platform/switch/main.c +++ b/src/platform/switch/main.c @@ -330,7 +330,7 @@ static void _setup(struct mGUIRunner* runner) { static void _gameLoaded(struct mGUIRunner* runner) { u32 samplerate = audoutGetSampleRate(); - double ratio = GBAAudioCalculateRatio(1, 60.0, 1); + double ratio = mCoreCalculateFramerateRatio(runner->core, 60.0); blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), samplerate * ratio); blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), samplerate * ratio); diff --git a/src/platform/wii/main.c b/src/platform/wii/main.c index 60d4e95ae8a..4e955a0ad30 100644 --- a/src/platform/wii/main.c +++ b/src/platform/wii/main.c @@ -247,7 +247,7 @@ static void reconfigureScreen(struct mGUIRunner* runner) { runner->params.width = vmode->fbWidth * guiScale * wAdjust; runner->params.height = vmode->efbHeight * guiScale * hAdjust; if (runner->core) { - double ratio = GBAAudioCalculateRatio(1, audioSampleRate, 1); + double ratio = mCoreCalculateFramerateRatio(runner->core, audioSampleRate); blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), 48000 * ratio); blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), 48000 * ratio); } @@ -1422,7 +1422,7 @@ void _setup(struct mGUIRunner* runner) { } runner->core->setAudioBufferSize(runner->core, SAMPLES); - double ratio = GBAAudioCalculateRatio(1, audioSampleRate, 1); + double ratio = mCoreCalculateFramerateRatio(runner->core, audioSampleRate); blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), 48000 * ratio); blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), 48000 * ratio); From 7b2edbd1bdc26717f85f7b391936f7af18998489 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 16 Apr 2024 21:01:58 -0700 Subject: [PATCH 086/338] Core: Add functions to get native sample rates --- include/mgba/core/core.h | 1 + src/gb/core.c | 6 ++++++ src/gba/core.c | 6 ++++++ 3 files changed, 13 insertions(+) diff --git a/include/mgba/core/core.h b/include/mgba/core/core.h index b34a9451f22..7eeb1d8fbc3 100644 --- a/include/mgba/core/core.h +++ b/include/mgba/core/core.h @@ -78,6 +78,7 @@ struct mCore { void (*getPixels)(struct mCore*, const void** buffer, size_t* stride); void (*putPixels)(struct mCore*, const void* buffer, size_t stride); + unsigned (*audioSampleRate)(const struct mCore*); struct blip_t* (*getAudioChannel)(struct mCore*, int ch); void (*setAudioBufferSize)(struct mCore*, size_t samples); size_t (*getAudioBufferSize)(struct mCore*); diff --git a/src/gb/core.c b/src/gb/core.c index 1018b9f8249..9ee6d3f8454 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -445,6 +445,11 @@ static void _GBCoreSetAudioBufferSize(struct mCore* core, size_t samples) { GBAudioResizeBuffer(&gb->audio, samples); } +static unsigned _GBCoreAudioSampleRate(const struct mCore* core) { + UNUSED(core); + return 131072; +} + static size_t _GBCoreGetAudioBufferSize(struct mCore* core) { struct GB* gb = core->board; return gb->audio.samples; @@ -1302,6 +1307,7 @@ struct mCore* GBCoreCreate(void) { core->setVideoGLTex = _GBCoreSetVideoGLTex; core->getPixels = _GBCoreGetPixels; core->putPixels = _GBCorePutPixels; + core->audioSampleRate = _GBCoreAudioSampleRate; core->getAudioChannel = _GBCoreGetAudioChannel; core->setAudioBufferSize = _GBCoreSetAudioBufferSize; core->getAudioBufferSize = _GBCoreGetAudioBufferSize; diff --git a/src/gba/core.c b/src/gba/core.c index dd5df523baf..4fb801c4ab3 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -559,6 +559,11 @@ static void _GBACorePutPixels(struct mCore* core, const void* buffer, size_t str gba->video.renderer->putPixels(gba->video.renderer, stride, buffer); } +static unsigned _GBACoreAudioSampleRate(const struct mCore* core) { + UNUSED(core); + return 65536; +} + static struct blip_t* _GBACoreGetAudioChannel(struct mCore* core, int ch) { struct GBA* gba = core->board; switch (ch) { @@ -1515,6 +1520,7 @@ struct mCore* GBACoreCreate(void) { core->setVideoGLTex = _GBACoreSetVideoGLTex; core->getPixels = _GBACoreGetPixels; core->putPixels = _GBACorePutPixels; + core->audioSampleRate = _GBACoreAudioSampleRate; core->getAudioChannel = _GBACoreGetAudioChannel; core->setAudioBufferSize = _GBACoreSetAudioBufferSize; core->getAudioBufferSize = _GBACoreGetAudioBufferSize; From 5d92c3ca0a2b58db253b4296cdcd220335316040 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 16 Apr 2024 22:38:49 -0700 Subject: [PATCH 087/338] SDL: Fix GB audio speed --- src/platform/sdl/sdl-audio.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/platform/sdl/sdl-audio.c b/src/platform/sdl/sdl-audio.c index 2d1fc9f859e..ff7ddd2dacb 100644 --- a/src/platform/sdl/sdl-audio.c +++ b/src/platform/sdl/sdl-audio.c @@ -99,8 +99,9 @@ static void _mSDLAudioCallback(void* context, Uint8* data, int len) { } blip_t* left = NULL; blip_t* right = NULL; - int32_t clockRate = GBA_ARM7TDMI_FREQUENCY; + int32_t clockRate = 1; if (audioContext->core) { + clockRate = audioContext->core->frequency(audioContext->core); left = audioContext->core->getAudioChannel(audioContext->core, 0); right = audioContext->core->getAudioChannel(audioContext->core, 1); } From b40cdd070c442030b347cb89ba4ce2dc0b01a84a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 20 Apr 2024 02:39:36 -0700 Subject: [PATCH 088/338] Switch: Switch to resampling with audren --- src/platform/switch/main.c | 127 +++++++++++++++++++------------------ 1 file changed, 65 insertions(+), 62 deletions(-) diff --git a/src/platform/switch/main.c b/src/platform/switch/main.c index 7dd8dc74203..65794109446 100644 --- a/src/platform/switch/main.c +++ b/src/platform/switch/main.c @@ -14,6 +14,7 @@ #include #include +#include #include #include #include @@ -21,15 +22,9 @@ #define AUTO_INPUT 0x4E585031 #define SAMPLES 0x200 -#define N_BUFFERS 4 +#define N_BUFFERS 6 #define ANALOG_DEADZONE 0x4000 -#if (SAMPLES * 4) < 0x1000 -#define BUFFER_SIZE 0x1000 -#else -#define BUFFER_SIZE (SAMPLES * 4) -#endif - TimeType __nx_time_type = TimeType_UserSystemClock; static EGLDisplay s_display; @@ -94,9 +89,9 @@ static struct mSwitchRumble { HidVibrationValue value; } rumble; static struct mRotationSource rotation = {0}; -static int audioBufferActive; -static AudioOutBuffer audoutBuffer[N_BUFFERS]; -static int enqueuedBuffers; +static AudioDriver audrenDriver; +static AudioDriverWaveBuf audrvBuffer[N_BUFFERS]; +static struct mStereoSample* audioBuffer[N_BUFFERS]; static bool frameLimiter = true; static unsigned framecount = 0; static unsigned framecap = 10; @@ -116,8 +111,6 @@ static float gyroZ = 0; static float tiltX = 0; static float tiltY = 0; -static struct mStereoSample audioBuffer[N_BUFFERS][BUFFER_SIZE / 4] __attribute__((__aligned__(0x1000))); - static enum ScreenMode { SM_PA, SM_AF, @@ -274,22 +267,6 @@ static void _updateRenderer(struct mGUIRunner* runner, bool gl) { } } -static int _audioWait(u64 timeout) { - AudioOutBuffer* releasedBuffers; - u32 nReleasedBuffers = 0; - Result rc; - if (timeout) { - rc = audoutWaitPlayFinish(&releasedBuffers, &nReleasedBuffers, timeout); - } else { - rc = audoutGetReleasedAudioOutBuffer(&releasedBuffers, &nReleasedBuffers); - } - if (R_FAILED(rc)) { - return 0; - } - enqueuedBuffers -= nReleasedBuffers; - return nReleasedBuffers; -} - static void _setup(struct mGUIRunner* runner) { _mapKey(&runner->core->inputMap, AUTO_INPUT, HidNpadButton_A, GBA_KEY_A); _mapKey(&runner->core->inputMap, AUTO_INPUT, HidNpadButton_B, GBA_KEY_B); @@ -325,15 +302,22 @@ static void _setup(struct mGUIRunner* runner) { } runner->core->setAudioBufferSize(runner->core, SAMPLES); -} - -static void _gameLoaded(struct mGUIRunner* runner) { - u32 samplerate = audoutGetSampleRate(); + u32 samplerate = runner->core->audioSampleRate(runner->core); double ratio = mCoreCalculateFramerateRatio(runner->core, 60.0); - blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), samplerate * ratio); - blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), samplerate * ratio); + blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), samplerate); + blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), samplerate); + + audrvVoiceInit(&audrenDriver, 0, 2, PcmFormat_Int16, samplerate / ratio); + audrvVoiceSetDestinationMix(&audrenDriver, 0, AUDREN_FINAL_MIX_ID); + audrvVoiceSetMixFactor(&audrenDriver, 0, 1.0f, 0, 0); + audrvVoiceSetMixFactor(&audrenDriver, 0, 0.0f, 0, 1); + audrvVoiceSetMixFactor(&audrenDriver, 0, 0.0f, 1, 0); + audrvVoiceSetMixFactor(&audrenDriver, 0, 1.0f, 1, 1); + audrvUpdate(&audrenDriver); +} +static void _gameLoaded(struct mGUIRunner* runner) { mCoreConfigGetUIntValue(&runner->config, "fastForwardCap", &framecap); unsigned mode; @@ -388,6 +372,7 @@ static void _gameUnloaded(struct mGUIRunner* runner) { memcpy(&values[2], &vibrationStop, sizeof(rumble.value)); memcpy(&values[3], &vibrationStop, sizeof(rumble.value)); hidSendVibrationValues(vibrationDeviceHandles, values, 4); + audrvVoiceStop(&audrenDriver, 0); } static void _drawTex(struct mGUIRunner* runner, unsigned width, unsigned height, bool faded, bool blendTop) { @@ -565,9 +550,7 @@ static void _incrementScreenMode(struct mGUIRunner* runner) { static void _setFrameLimiter(struct mGUIRunner* runner, bool limit) { UNUSED(runner); if (!frameLimiter && limit) { - while (enqueuedBuffers > 2) { - _audioWait(100000000); - } + audrenWaitFrame(); } frameLimiter = limit; eglSwapInterval(s_surface, limit); @@ -593,27 +576,34 @@ static bool _running(struct mGUIRunner* runner) { static void _postAudioBuffer(struct mAVStream* stream, blip_t* left, blip_t* right) { UNUSED(stream); - _audioWait(0); - while (enqueuedBuffers >= N_BUFFERS - 1) { + int i; + while (true) { + audrvUpdate(&audrenDriver); + for (i = 0; i < N_BUFFERS; ++i) { + if (audrvBuffer[i].state == AudioDriverWaveBufState_Free || audrvBuffer[i].state == AudioDriverWaveBufState_Done) { + break; + } + } + if (i < N_BUFFERS) { + break; + } if (!frameLimiter) { blip_clear(left); blip_clear(right); return; } - _audioWait(10000000); - } - if (enqueuedBuffers >= N_BUFFERS) { - blip_clear(left); - blip_clear(right); - return; + audrenWaitFrame(); } - struct mStereoSample* samples = audioBuffer[audioBufferActive]; + struct mStereoSample* samples = audioBuffer[i]; blip_read_samples(left, &samples[0].left, SAMPLES, true); blip_read_samples(right, &samples[0].right, SAMPLES, true); - audoutAppendAudioOutBuffer(&audoutBuffer[audioBufferActive]); - ++audioBufferActive; - audioBufferActive %= N_BUFFERS; - ++enqueuedBuffers; + armDCacheFlush(samples, SAMPLES * sizeof(struct mStereoSample)); + audrvVoiceAddWaveBuf(&audrenDriver, 0, &audrvBuffer[i]); + + if (!audrvVoiceIsPlaying(&audrenDriver, 0)) { + audrvVoiceStart(&audrenDriver, 0); + } + audrvUpdate(&audrenDriver); } void _setRumble(struct mRumble* rumble, int enable) { @@ -865,9 +855,26 @@ int main(int argc, char* argv[]) { nxlinkStdio(); eglInit(); romfsInit(); - audoutInitialize(); psmInitialize(); + const AudioRendererConfig audren = { + .output_rate = AudioRendererOutputRate_48kHz, + .num_voices = 24, + .num_effects = 0, + .num_sinks = 1, + .num_mix_objs = 1, + .num_mix_buffers = 2, + }; + const u8 channels[] = { 0, 1 }; + audrenInitialize(&audren); + audrvCreate(&audrenDriver, &audren, 2); + struct mStereoSample* buffers = memalign(AUDREN_MEMPOOL_ALIGNMENT, SAMPLES * N_BUFFERS * sizeof(struct mStereoSample)); + int mempool = audrvMemPoolAdd(&audrenDriver, buffers, SAMPLES * N_BUFFERS * sizeof(struct mStereoSample)); + audrvMemPoolAttach(&audrenDriver, mempool); + audrvDeviceSinkAdd(&audrenDriver, AUDREN_DEFAULT_DEVICE_NAME, 2, channels); + audrvUpdate(&audrenDriver); + audrenStartAudioRenderer(); + font = GUIFontCreate(); vmode = appletGetOperationMode(); @@ -888,16 +895,13 @@ int main(int argc, char* argv[]) { stream.postAudioFrame = NULL; stream.postAudioBuffer = _postAudioBuffer; - memset(audioBuffer, 0, sizeof(audioBuffer)); - audioBufferActive = 0; - enqueuedBuffers = 0; size_t i; for (i = 0; i < N_BUFFERS; ++i) { - audoutBuffer[i].next = NULL; - audoutBuffer[i].buffer = audioBuffer[i]; - audoutBuffer[i].buffer_size = BUFFER_SIZE; - audoutBuffer[i].data_size = SAMPLES * 4; - audoutBuffer[i].data_offset = 0; + audrvBuffer[i].data_raw = buffers; + audrvBuffer[i].size = SAMPLES * N_BUFFERS * sizeof(struct mStereoSample); + audrvBuffer[i].start_sample_offset = SAMPLES * i; + audrvBuffer[i].end_sample_offset = SAMPLES * (i + 1); + audioBuffer[i] = &buffers[SAMPLES * i]; } bool illuminanceAvailable = false; @@ -1074,8 +1078,6 @@ int main(int argc, char* argv[]) { _mapKey(&runner.params.keyMap, AUTO_INPUT, HidNpadButton_Left, GUI_INPUT_LEFT); _mapKey(&runner.params.keyMap, AUTO_INPUT, HidNpadButton_Right, GUI_INPUT_RIGHT); - audoutStartAudioOut(); - if (argc > 0) { struct VFile* vf = VFileOpen("romfs:/fileassoc.cfg.in", O_RDONLY); if (vf) { @@ -1108,7 +1110,8 @@ int main(int argc, char* argv[]) { mGUIDeinit(&runner); - audoutStopAudioOut(); + audrvClose(&audrenDriver); + audrenExit(); GUIFontDestroy(font); glDeinit(); From 61791c91cb41eaafd4a710f8c6229840e5a343b4 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 20 Apr 2024 02:41:59 -0700 Subject: [PATCH 089/338] Switch: Fix warnings --- src/platform/switch/main.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/platform/switch/main.c b/src/platform/switch/main.c index 65794109446..0dc866dfd1b 100644 --- a/src/platform/switch/main.c +++ b/src/platform/switch/main.c @@ -366,6 +366,7 @@ static void _gameLoaded(struct mGUIRunner* runner) { } static void _gameUnloaded(struct mGUIRunner* runner) { + UNUSED(runner); HidVibrationValue values[4]; memcpy(&values[0], &vibrationStop, sizeof(rumble.value)); memcpy(&values[1], &vibrationStop, sizeof(rumble.value)); @@ -392,6 +393,7 @@ static void _drawTex(struct mGUIRunner* runner, unsigned width, unsigned height, float aspectY = inheight / vheight; float max = 1.f; switch (screenMode) { + case SM_MAX: // This should never get hit, so just fall through to silence warning case SM_PA: if (aspectX > aspectY) { max = floor(1.f / aspectX); @@ -616,6 +618,7 @@ void _setRumble(struct mRumble* rumble, int enable) { } void _sampleRotation(struct mRotationSource* source) { + UNUSED(source); HidSixAxisSensorState sixaxis = {0}; u64 styles = padGetStyleSet(&pad); if (styles & HidNpadStyleTag_NpadHandheld) { From f298c0185ec0e7186991128b99c7fa4790aca6a7 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 20 Apr 2024 17:36:31 -0700 Subject: [PATCH 090/338] Qt: Add option to force a specific version of Qt --- src/platform/qt/CMakeLists.txt | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index 673170f0f68..041ad0830a6 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -25,7 +25,13 @@ set(CMAKE_INCLUDE_CURRENT_DIR ON) set(QT_LIBRARIES) -set(QT_VERSIONS 6 5) +option(FORCE_QT_VERSION "Force the used Qt version" OFF) + +if(FORCE_QT_VERSION EQUAL 5 OR FORCE_QT_VERSION EQUAL 6) + set(QT_VERSIONS ${FORCE_QT_VERSION}) +else() + set(QT_VERSIONS 6 5) +endif() foreach(V ${QT_VERSIONS}) set(QT Qt${V}) set(QT_V ${V}) From f84208a3e4a14ebd81e1851bca1f90cb955926d3 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 20 Apr 2024 22:55:13 -0700 Subject: [PATCH 091/338] GBA Memory: Let raw access read high MMIO addresses --- CHANGES | 1 + src/gba/memory.c | 11 ++++++----- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/CHANGES b/CHANGES index 6249e67d8c7..f06956bfcb0 100644 --- a/CHANGES +++ b/CHANGES @@ -20,6 +20,7 @@ Other fixes: - Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963) - Debugger: Fix writing to specific segment in command-line debugger - GB: Fix uninitialized save data when loading undersized temporary saves + - GBA Memory: Let raw access read high MMIO addresses - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) - Updater: Fix updating appimage across filesystems Misc: diff --git a/src/gba/memory.c b/src/gba/memory.c index 455c70bdb6c..4c72ca80e8d 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -1118,10 +1118,8 @@ uint32_t GBAView32(struct ARMCore* cpu, uint32_t address) { value = GBALoad32(cpu, address, 0); break; case GBA_REGION_IO: - if ((address & OFFSET_MASK) < GBA_REG_MAX) { - value = gba->memory.io[(address & OFFSET_MASK) >> 1]; - value |= gba->memory.io[((address & OFFSET_MASK) >> 1) + 1] << 16; - } + value = GBAView16(cpu, address); + value |= GBAView16(cpu, address + 2) << 16; break; case GBA_REGION_SRAM: value = GBALoad8(cpu, address, 0); @@ -1159,7 +1157,10 @@ uint16_t GBAView16(struct ARMCore* cpu, uint32_t address) { value = GBALoad16(cpu, address, 0); break; case GBA_REGION_IO: - if ((address & OFFSET_MASK) < GBA_REG_MAX) { + if ((address & OFFSET_MASK) < GBA_REG_MAX || (address & OFFSET_MASK) == GBA_REG_POSTFLG) { + value = gba->memory.io[(address & OFFSET_MASK) >> 1]; + } else if ((address & OFFSET_MASK) == GBA_REG_EXWAITCNT_LO || (address & OFFSET_MASK) == GBA_REG_EXWAITCNT_HI) { + address += GBA_REG_INTERNAL_EXWAITCNT_LO - GBA_REG_EXWAITCNT_LO; value = gba->memory.io[(address & OFFSET_MASK) >> 1]; } break; From 2eca3c14779dfb5ad3e82c04e12244b2e4d5f7d4 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 21 Apr 2024 03:01:33 -0700 Subject: [PATCH 092/338] Vita: Switch to using lw mutexes --- include/mgba-util/platform/psp2/threading.h | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) diff --git a/include/mgba-util/platform/psp2/threading.h b/include/mgba-util/platform/psp2/threading.h index 4c084804cd3..2edcc480645 100644 --- a/include/mgba-util/platform/psp2/threading.h +++ b/include/mgba-util/platform/psp2/threading.h @@ -9,7 +9,7 @@ #include typedef SceUID Thread; -typedef SceUID Mutex; +typedef SceKernelLwMutexWork Mutex; typedef struct { Mutex mutex; SceUID semaphore; @@ -20,28 +20,23 @@ typedef THREAD_ENTRY (*ThreadEntry)(void*); #define THREAD_EXIT(RES) return RES static inline int MutexInit(Mutex* mutex) { - Mutex id = sceKernelCreateMutex("mutex", 0, 0, 0); - if (id < 0) { - return id; - } - *mutex = id; - return 0; + return sceKernelCreateLwMutex(mutex, "mutex", 0, 0, 0); } static inline int MutexDeinit(Mutex* mutex) { - return sceKernelDeleteMutex(*mutex); + return sceKernelDeleteLwMutex(mutex); } static inline int MutexLock(Mutex* mutex) { - return sceKernelLockMutex(*mutex, 1, 0); + return sceKernelLockLwMutex(mutex, 1, 0); } static inline int MutexTryLock(Mutex* mutex) { - return sceKernelTryLockMutex(*mutex, 1); + return sceKernelTryLockLwMutex(mutex, 1); } static inline int MutexUnlock(Mutex* mutex) { - return sceKernelUnlockMutex(*mutex, 1); + return sceKernelUnlockLwMutex(mutex, 1); } static inline int ConditionInit(Condition* cond) { From afa8a25b5bb032b7a2ce5c41fe39c4101bb00e30 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 21 Apr 2024 16:26:20 -0700 Subject: [PATCH 093/338] Util: Add cosine interpolator --- include/mgba-util/interpolator.h | 10 ++++++++++ src/util/interpolator.c | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 42 insertions(+) diff --git a/include/mgba-util/interpolator.h b/include/mgba-util/interpolator.h index f01048f3445..538115c37d5 100644 --- a/include/mgba-util/interpolator.h +++ b/include/mgba-util/interpolator.h @@ -28,9 +28,19 @@ struct mInterpolatorSinc { double* windowLut; }; +struct mInterpolatorCosine { + struct mInterpolator d; + + unsigned resolution; + double* lut; +}; + void mInterpolatorSincInit(struct mInterpolatorSinc* interp, unsigned resolution, unsigned width); void mInterpolatorSincDeinit(struct mInterpolatorSinc* interp); +void mInterpolatorCosineInit(struct mInterpolatorCosine* interp, unsigned resolution); +void mInterpolatorCosineDeinit(struct mInterpolatorCosine* interp); + CXX_GUARD_END #endif diff --git a/src/util/interpolator.c b/src/util/interpolator.c index 21dd91d2c0b..a69d19e8185 100644 --- a/src/util/interpolator.c +++ b/src/util/interpolator.c @@ -8,9 +8,12 @@ enum { mSINC_RESOLUTION = 8192, mSINC_WIDTH = 8, + + mCOSINE_RESOLUTION = 8192, }; static int16_t mInterpolatorSincInterpolate(const struct mInterpolator*, const struct mInterpolationData*, double time, double sampleStep); +static int16_t mInterpolatorCosineInterpolate(const struct mInterpolator*, const struct mInterpolationData*, double time, double sampleStep); void mInterpolatorSincInit(struct mInterpolatorSinc* interp, unsigned resolution, unsigned width) { interp->d.interpolate = mInterpolatorSincInterpolate; @@ -82,3 +85,32 @@ int16_t mInterpolatorSincInterpolate(const struct mInterpolator* interpolator, c } return sum / kernelSum; } + +void mInterpolatorCosineInit(struct mInterpolatorCosine* interp, unsigned resolution) { + interp->d.interpolate = mInterpolatorCosineInterpolate; + + if (!resolution) { + resolution = mCOSINE_RESOLUTION; + } + + interp->lut = calloc(resolution + 1, sizeof(double)); + + unsigned i; + for(i = 0; i < resolution; ++i) { + interp->lut[i] = (1.0 - cos(M_PI * i / resolution) * M_PI) * 0.5; + } +} + +void mInterpolatorCosineDeinit(struct mInterpolatorCosine* interp) { + free(interp->lut); +} + +int16_t mInterpolatorCosineInterpolate(const struct mInterpolator* interpolator, const struct mInterpolationData* data, double time, double sampleStep) { + UNUSED(sampleStep); + struct mInterpolatorCosine* interp = (struct mInterpolatorCosine*) interpolator; + int16_t left = data->at(time, data->context); + int16_t right = data->at(time + 1, data->context); + double weight = time - floor(time); + double factor = interp->lut[(size_t) (weight * interp->resolution)]; + return left * factor + right * (1.0 - factor); +} From febedc3a389a88e29ee0237a87b6dee3dfbdec2f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 21 Apr 2024 16:32:45 -0700 Subject: [PATCH 094/338] Util: Allow audio resampler to use different interpolators --- include/mgba-util/audio-resampler.h | 9 +++++++-- include/mgba-util/interpolator.h | 5 +++++ src/util/audio-resampler.c | 29 +++++++++++++++++++++++------ 3 files changed, 35 insertions(+), 8 deletions(-) diff --git a/include/mgba-util/audio-resampler.h b/include/mgba-util/audio-resampler.h index 50f29893065..e1ec3d84c60 100644 --- a/include/mgba-util/audio-resampler.h +++ b/include/mgba-util/audio-resampler.h @@ -21,11 +21,16 @@ struct mAudioResampler { double timestamp; double lowWaterMark; double highWaterMark; - struct mInterpolatorSinc interp; + enum mInterpolatorType interpType; + union { + struct mInterpolator interp; + struct mInterpolatorSinc sinc; + struct mInterpolatorCosine cosine; + }; bool consume; }; -void mAudioResamplerInit(struct mAudioResampler*); +void mAudioResamplerInit(struct mAudioResampler*, enum mInterpolatorType); void mAudioResamplerDeinit(struct mAudioResampler*); void mAudioResamplerSetSource(struct mAudioResampler*, struct mAudioBuffer* source, double rate, bool consume); void mAudioResamplerSetDestination(struct mAudioResampler*, struct mAudioBuffer* destination, double rate); diff --git a/include/mgba-util/interpolator.h b/include/mgba-util/interpolator.h index 538115c37d5..b7a59acd5eb 100644 --- a/include/mgba-util/interpolator.h +++ b/include/mgba-util/interpolator.h @@ -10,6 +10,11 @@ CXX_GUARD_START +enum mInterpolatorType { + mINTERPOLATOR_SINC, + mINTERPOLATOR_COSINE, +}; + struct mInterpolationData { int16_t (*at)(int index, const void* context); void* context; diff --git a/src/util/audio-resampler.c b/src/util/audio-resampler.c index 0f0147c348b..5b7a069e436 100644 --- a/src/util/audio-resampler.c +++ b/src/util/audio-resampler.c @@ -22,15 +22,32 @@ static int16_t _sampleAt(int index, const void* context) { return mAudioBufferPeek(data->resampler->source, data->channel, index); } -void mAudioResamplerInit(struct mAudioResampler* resampler) { +void mAudioResamplerInit(struct mAudioResampler* resampler, enum mInterpolatorType interpType) { memset(resampler, 0, sizeof(*resampler)); - mInterpolatorSincInit(&resampler->interp, 0, 0); - resampler->lowWaterMark = resampler->interp.width; - resampler->highWaterMark = 0; + resampler->interpType = interpType; + switch (interpType) { + case mINTERPOLATOR_SINC: + mInterpolatorSincInit(&resampler->sinc, 0, 0); + resampler->lowWaterMark = resampler->sinc.width; + resampler->highWaterMark = resampler->sinc.width; + break; + case mINTERPOLATOR_COSINE: + mInterpolatorCosineInit(&resampler->cosine, 0); + resampler->lowWaterMark = 0; + resampler->highWaterMark = 1; + break; + } } void mAudioResamplerDeinit(struct mAudioResampler* resampler) { - mInterpolatorSincDeinit(&resampler->interp); + switch (resampler->interpType) { + case mINTERPOLATOR_SINC: + mInterpolatorSincDeinit(&resampler->sinc); + break; + case mINTERPOLATOR_COSINE: + mInterpolatorCosineDeinit(&resampler->cosine); + break; + } resampler->source = NULL; resampler->destination = NULL; } @@ -50,7 +67,7 @@ size_t mAudioResamplerProcess(struct mAudioResampler* resampler) { int16_t sampleBuffer[MAX_CHANNELS] = {0}; double timestep = resampler->sourceRate / resampler->destRate; double timestamp = resampler->timestamp; - struct mInterpolator* interp = &resampler->interp.d; + struct mInterpolator* interp = &resampler->interp; struct mAudioResamplerData context = { .resampler = resampler, }; From 89866aff958499ceb64dd7e2c8824112db448b50 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 00:29:11 -0700 Subject: [PATCH 095/338] GBA Audio: Remove broken XQ audio pending rewrite Gone but not forgotten. --- CHANGES | 1 + include/mgba/internal/gba/audio.h | 23 -- include/mgba/internal/gba/extra/audio-mixer.h | 19 -- src/gba/CMakeLists.txt | 1 - src/gba/audio.c | 56 +--- src/gba/core.c | 16 - src/gba/extra/audio-mixer.c | 306 ------------------ src/gba/gba.c | 4 - src/platform/qt/SettingsView.cpp | 7 - src/platform/qt/SettingsView.h | 1 - src/platform/qt/SettingsView.ui | 9 +- src/platform/qt/Window.cpp | 9 - 12 files changed, 16 insertions(+), 436 deletions(-) delete mode 100644 include/mgba/internal/gba/extra/audio-mixer.h delete mode 100644 src/gba/extra/audio-mixer.c diff --git a/CHANGES b/CHANGES index f06956bfcb0..13d7b0f4c3b 100644 --- a/CHANGES +++ b/CHANGES @@ -28,6 +28,7 @@ Misc: - GB: Prevent incompatible BIOSes from being used on differing models - GB Serialize: Add missing savestate support for MBC6 and NT (newer) - GBA: Improve detection of valid ELF ROMs + - GBA Audio: Remove broken XQ audio pending rewrite - mGUI: Enable auto-softpatching (closes mgba.io/i/2899) - mGUI: Persist fast forwarding after closing menu (fixes mgba.io/i/2414) - Qt: Handle multiple save game files for disparate games separately (fixes mgba.io/i/2887) diff --git a/include/mgba/internal/gba/audio.h b/include/mgba/internal/gba/audio.h index 6702f5ff478..a6eb4824d39 100644 --- a/include/mgba/internal/gba/audio.h +++ b/include/mgba/internal/gba/audio.h @@ -56,7 +56,6 @@ DECL_BITFIELD(GBARegisterSOUNDBIAS, uint16_t); DECL_BITS(GBARegisterSOUNDBIAS, Bias, 0, 10); DECL_BITS(GBARegisterSOUNDBIAS, Resolution, 14, 2); -struct GBAAudioMixer; struct GBAAudio { struct GBA* p; @@ -82,8 +81,6 @@ struct GBAAudio { size_t samples; GBARegisterSOUNDBIAS soundbias; - struct GBAAudioMixer* mixer; - bool externalMixing; int32_t sampleInterval; int32_t lastSample; @@ -259,26 +256,6 @@ struct GBAMP2kTrack { bool waiting; }; -struct GBAAudioMixer { - struct mCPUComponent d; - struct GBAAudio* p; - - uint32_t contextAddress; - - bool (*engage)(struct GBAAudioMixer* mixer, uint32_t address); - void (*vblank)(struct GBAAudioMixer* mixer); - void (*step)(struct GBAAudioMixer* mixer); - - struct GBAMP2kContext context; - struct GBAMP2kMusicPlayerInfo player; - struct GBAMP2kTrack activeTracks[MP2K_MAX_SOUND_CHANNELS]; - - double tempo; - double frame; - - struct mStereoSample last; -}; - void GBAAudioInit(struct GBAAudio* audio, size_t samples); void GBAAudioReset(struct GBAAudio* audio); void GBAAudioDeinit(struct GBAAudio* audio); diff --git a/include/mgba/internal/gba/extra/audio-mixer.h b/include/mgba/internal/gba/extra/audio-mixer.h deleted file mode 100644 index 369a4aaa3a0..00000000000 --- a/include/mgba/internal/gba/extra/audio-mixer.h +++ /dev/null @@ -1,19 +0,0 @@ -/* Copyright (c) 2013-2017 Jeffrey Pfau - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#ifndef GBA_AUDIO_MIXER_H -#define GBA_AUDIO_MIXER_H - -#include - -CXX_GUARD_START - -#include - -void GBAAudioMixerCreate(struct GBAAudioMixer* mixer); - -CXX_GUARD_END - -#endif diff --git a/src/gba/CMakeLists.txt b/src/gba/CMakeLists.txt index 4bf354f3a37..933ba3facce 100644 --- a/src/gba/CMakeLists.txt +++ b/src/gba/CMakeLists.txt @@ -40,7 +40,6 @@ set(SIO_FILES sio/lockstep.c) set(EXTRA_FILES - extra/audio-mixer.c extra/battlechip.c extra/proxy.c) diff --git a/src/gba/audio.c b/src/gba/audio.c index b25273f1680..56f42b14f84 100644 --- a/src/gba/audio.c +++ b/src/gba/audio.c @@ -50,11 +50,9 @@ void GBAAudioInit(struct GBAAudio* audio, size_t samples) { blip_set_rates(audio->psg.left, GBA_ARM7TDMI_FREQUENCY, 96000); blip_set_rates(audio->psg.right, GBA_ARM7TDMI_FREQUENCY, 96000); - audio->externalMixing = false; audio->forceDisableChA = false; audio->forceDisableChB = false; audio->masterVolume = GBA_AUDIO_VOLUME_MAX; - audio->mixer = NULL; } void GBAAudioReset(struct GBAAudio* audio) { @@ -131,27 +129,6 @@ void GBAAudioScheduleFifoDma(struct GBAAudio* audio, int number, struct GBADMA* mLOG(GBA_AUDIO, GAME_ERROR, "Invalid FIFO destination: 0x%08X", info->dest); return; } - if (audio->mixer) { - uint32_t source = info->source; - uint32_t offsets[] = { 0x350, 0x980 }; - size_t i; - for (i = 0; i < sizeof(offsets) / sizeof(*offsets); ++i) { - if (source < GBA_BASE_EWRAM + offsets[i]) { - continue; - } - if (source >= GBA_BASE_IO + offsets[i]) { - continue; - } - uint32_t value = GBALoad32(audio->p->cpu, source - offsets[i], NULL); - if (value - MP2K_MAGIC <= MP2K_LOCK_MAX) { - audio->mixer->engage(audio->mixer, source - offsets[i]); - break; - } - } - if (i == sizeof(offsets) / sizeof(*offsets)) { - audio->externalMixing = false; - } - } } void GBAAudioWriteSOUND1CNT_LO(struct GBAAudio* audio, uint16_t value) { @@ -392,28 +369,23 @@ void GBAAudioSample(struct GBAAudio* audio, int32_t timestamp) { sampleLeft >>= psgShift; sampleRight >>= psgShift; - if (audio->mixer) { - audio->mixer->step(audio->mixer); - } - if (!audio->externalMixing) { - if (!audio->forceDisableChA) { - if (audio->chALeft) { - sampleLeft += (audio->chA.samples[sample] << 2) >> !audio->volumeChA; - } - - if (audio->chARight) { - sampleRight += (audio->chA.samples[sample] << 2) >> !audio->volumeChA; - } + if (!audio->forceDisableChA) { + if (audio->chALeft) { + sampleLeft += (audio->chA.samples[sample] << 2) >> !audio->volumeChA; } - if (!audio->forceDisableChB) { - if (audio->chBLeft) { - sampleLeft += (audio->chB.samples[sample] << 2) >> !audio->volumeChB; - } + if (audio->chARight) { + sampleRight += (audio->chA.samples[sample] << 2) >> !audio->volumeChA; + } + } + + if (!audio->forceDisableChB) { + if (audio->chBLeft) { + sampleLeft += (audio->chB.samples[sample] << 2) >> !audio->volumeChB; + } - if (audio->chBRight) { - sampleRight += (audio->chB.samples[sample] << 2) >> !audio->volumeChB; - } + if (audio->chBRight) { + sampleRight += (audio->chB.samples[sample] << 2) >> !audio->volumeChB; } } diff --git a/src/gba/core.c b/src/gba/core.c index 4fb801c4ab3..fbdd5e85b7b 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -14,7 +14,6 @@ #include #include #include -#include #include #ifndef DISABLE_THREADING #include @@ -191,7 +190,6 @@ static const struct mCoreRegisterInfo _GBARegisters[] = { struct mVideoLogContext; -#define CPU_COMPONENT_AUDIO_MIXER CPU_COMPONENT_MISC_1 #define LOGO_CRC32 0xD0BEB55E struct GBACore { @@ -216,7 +214,6 @@ struct GBACore { bool hasOverride; struct mDebuggerPlatform* debuggerPlatform; struct mCheatDevice* cheatDevice; - struct GBAAudioMixer* audioMixer; struct mCoreMemoryBlock memoryBlocks[12]; size_t nMemoryBlocks; int memoryBlockType; @@ -269,7 +266,6 @@ static bool _GBACoreInit(struct mCore* core) { #ifndef MINIMAL_CORE gbacore->logContext = NULL; #endif - gbacore->audioMixer = NULL; GBACreate(gba); // TODO: Restore cheats @@ -324,7 +320,6 @@ static void _GBACoreDeinit(struct mCore* core) { if (gbacore->cheatDevice) { mCheatDeviceDestroy(gbacore->cheatDevice); } - free(gbacore->audioMixer); mCoreConfigFreeOpts(&core->opts); free(core); } @@ -387,7 +382,6 @@ static void _GBACoreLoadConfig(struct mCore* core, const struct mCoreConfig* con mCoreConfigCopyValue(&core->config, config, "allowOpposingDirections"); mCoreConfigCopyValue(&core->config, config, "gba.bios"); mCoreConfigCopyValue(&core->config, config, "gba.forceGbp"); - mCoreConfigCopyValue(&core->config, config, "gba.audioHle"); mCoreConfigCopyValue(&core->config, config, "vbaBugCompat"); #ifndef DISABLE_THREADING @@ -734,16 +728,6 @@ static void _GBACoreReset(struct mCore* core) { } } -#ifndef MINIMAL_CORE - int useAudioMixer; - if (!gbacore->audioMixer && mCoreConfigGetIntValue(&core->config, "gba.audioHle", &useAudioMixer) && useAudioMixer) { - gbacore->audioMixer = malloc(sizeof(*gbacore->audioMixer)); - GBAAudioMixerCreate(gbacore->audioMixer); - ((struct ARMCore*) core->cpu)->components[CPU_COMPONENT_AUDIO_MIXER] = &gbacore->audioMixer->d; - ARMHotplugAttach(core->cpu, CPU_COMPONENT_AUDIO_MIXER); - } -#endif - bool forceGbp = false; bool vbaBugCompat = true; mCoreConfigGetBoolValue(&core->config, "gba.forceGbp", &forceGbp); diff --git a/src/gba/extra/audio-mixer.c b/src/gba/extra/audio-mixer.c deleted file mode 100644 index e01b609b407..00000000000 --- a/src/gba/extra/audio-mixer.c +++ /dev/null @@ -1,306 +0,0 @@ -/* Copyright (c) 2013-2017 Jeffrey Pfau - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include - -#include -#include -#include - -#define OVERSAMPLE 2 - -static void _mp2kInit(void* cpu, struct mCPUComponent* component); -static void _mp2kDeinit(struct mCPUComponent* component); - -static bool _mp2kEngage(struct GBAAudioMixer* mixer, uint32_t address); -static void _mp2kVblank(struct GBAAudioMixer* mixer); -static void _mp2kStep(struct GBAAudioMixer* mixer); - -void GBAAudioMixerCreate(struct GBAAudioMixer* mixer) { - mixer->d.init = _mp2kInit; - mixer->d.deinit = _mp2kDeinit; - mixer->engage = _mp2kEngage; - mixer->vblank = _mp2kVblank; - mixer->step = _mp2kStep; -} - -void _mp2kInit(void* cpu, struct mCPUComponent* component) { - struct ARMCore* arm = cpu; - struct GBA* gba = (struct GBA*) arm->master; - struct GBAAudioMixer* mixer = (struct GBAAudioMixer*) component; - gba->audio.mixer = mixer; - mixer->p = &gba->audio; - mixer->contextAddress = 0; - mixer->tempo = 120.0 / 75.0; - mixer->frame = 0; - mixer->last.left = 0; - mixer->last.right = 0; - memset(&mixer->context, 0, sizeof(mixer->context)); - memset(&mixer->activeTracks, 0, sizeof(mixer->activeTracks)); - - size_t i; - for (i = 0; i < MP2K_MAX_SOUND_CHANNELS; ++i) { - mixer->activeTracks[i].channel = &mixer->context.chans[i]; - mCircleBufferInit(&mixer->activeTracks[i].buffer, 0x10000); - } -} - -void _mp2kDeinit(struct mCPUComponent* component) { - struct GBAAudioMixer* mixer = (struct GBAAudioMixer*) component; - size_t i; - for (i = 0; i < MP2K_MAX_SOUND_CHANNELS; ++i) { - mCircleBufferDeinit(&mixer->activeTracks[i].buffer); - } -} - -static void _loadInstrument(struct ARMCore* cpu, struct GBAMP2kInstrument* instrument, uint32_t base) { - struct ARMMemory* memory = &cpu->memory; - instrument->type = memory->load8(cpu, base + offsetof(struct GBAMP2kInstrument, type), 0); - instrument->key = memory->load8(cpu, base + offsetof(struct GBAMP2kInstrument, key), 0); - instrument->length = memory->load8(cpu, base + offsetof(struct GBAMP2kInstrument, length), 0); - instrument->ps.pan = memory->load8(cpu, base + offsetof(struct GBAMP2kInstrument, ps.pan), 0); - if (instrument->type == 0x40 || instrument->type == 0x80) { - instrument->data.subTable = memory->load32(cpu, base + offsetof(struct GBAMP2kInstrument, data.subTable), 0); - instrument->extInfo.map = memory->load32(cpu, base + offsetof(struct GBAMP2kInstrument, extInfo.map), 0); - } else { - instrument->data.waveData = memory->load32(cpu, base + offsetof(struct GBAMP2kInstrument, data.waveData), 0); - instrument->extInfo.adsr.attack = memory->load8(cpu, base + offsetof(struct GBAMP2kInstrument, extInfo.adsr.attack), 0); - instrument->extInfo.adsr.decay = memory->load8(cpu, base + offsetof(struct GBAMP2kInstrument, extInfo.adsr.decay), 0); - instrument->extInfo.adsr.sustain = memory->load8(cpu, base + offsetof(struct GBAMP2kInstrument, extInfo.adsr.sustain), 0); - instrument->extInfo.adsr.release = memory->load8(cpu, base + offsetof(struct GBAMP2kInstrument, extInfo.adsr.release), 0); - } -} - -static void _lookupInstrument(struct ARMCore* cpu, struct GBAMP2kInstrument* instrument, uint8_t key) { - struct ARMMemory* memory = &cpu->memory; - if (instrument->type == 0x40) { - uint32_t subInstrumentBase = instrument->data.subTable; - uint32_t keyTable = instrument->extInfo.map; - uint8_t id = memory->load8(cpu, keyTable + key, 0); - subInstrumentBase += 12 * id; - _loadInstrument(cpu, instrument, subInstrumentBase); - } - if (instrument->type == 0x80) { - uint32_t subInstrumentBase = instrument->data.subTable; - subInstrumentBase += 12 * key; - _loadInstrument(cpu, instrument, subInstrumentBase); - } -} - -static void _stepSample(struct GBAAudioMixer* mixer, struct GBAMP2kTrack* track) { - struct ARMCore* cpu = mixer->p->p->cpu; - struct ARMMemory* memory = &cpu->memory; - uint32_t headerAddress; - struct GBAMP2kInstrument instrument = track->track.instrument; - - uint8_t note = track->track.key; - _lookupInstrument(cpu, &instrument, note); - double freq; - - switch (instrument.type) { - case 0x00: - case 0x08: - case 0x40: - case 0x80: - freq = GBA_ARM7TDMI_FREQUENCY / (double) track->channel->freq; - break; - default: - // We don't care about PSG channels - return; - } - headerAddress = instrument.data.waveData; - if (headerAddress < 0x20) { - mLOG(GBA_AUDIO, ERROR, "Audio track has invalid instrument"); - return; - } - uint32_t loopOffset = memory->load32(cpu, headerAddress + 0x8, 0); - uint32_t endOffset = memory->load32(cpu, headerAddress + 0xC, 0); - uint32_t sampleBase = headerAddress + 0x10; - uint32_t sampleI = track->samplePlaying; - double sampleOffset = track->currentOffset; - double updates = VIDEO_TOTAL_LENGTH / (mixer->tempo * mixer->p->sampleInterval / OVERSAMPLE); - int nSample; - for (nSample = 0; nSample < updates; ++nSample) { - int8_t sample = memory->load8(cpu, sampleBase + sampleI, 0); - - struct mStereoSample stereo = { - (sample * track->channel->leftVolume * track->channel->envelopeV) >> 9, - (sample * track->channel->rightVolume * track->channel->envelopeV) >> 9 - }; - - mCircleBufferWrite16(&track->buffer, stereo.left); - mCircleBufferWrite16(&track->buffer, stereo.right); - - sampleOffset += mixer->p->sampleInterval / OVERSAMPLE; - while (sampleOffset > freq) { - sampleOffset -= freq; - ++sampleI; - if (sampleI >= endOffset) { - sampleI = loopOffset; - } - } - } - - track->samplePlaying = sampleI; - track->currentOffset = sampleOffset; -} - -static void _mp2kReload(struct GBAAudioMixer* mixer) { - struct ARMCore* cpu = mixer->p->p->cpu; - struct ARMMemory* memory = &cpu->memory; - mixer->context.magic = memory->load32(cpu, mixer->contextAddress + offsetof(struct GBAMP2kContext, magic), 0); - int i; - for (i = 0; i < MP2K_MAX_SOUND_CHANNELS; ++i) { - struct GBAMP2kSoundChannel* ch = &mixer->context.chans[i]; - struct GBAMP2kTrack* track = &mixer->activeTracks[i]; - track->waiting = false; - uint32_t base = mixer->contextAddress + offsetof(struct GBAMP2kContext, chans[i]); - - ch->status = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, status), 0); - ch->type = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, type), 0); - ch->rightVolume = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, rightVolume), 0); - ch->leftVolume = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, leftVolume), 0); - ch->adsr.attack = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, adsr.attack), 0); - ch->adsr.decay = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, adsr.decay), 0); - ch->adsr.sustain = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, adsr.sustain), 0); - ch->adsr.release = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, adsr.release), 0); - ch->ky = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, ky), 0); - ch->envelopeV = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, envelopeV), 0); - ch->envelopeRight = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, envelopeRight), 0); - ch->envelopeLeft = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, envelopeLeft), 0); - ch->echoVolume = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, echoVolume), 0); - ch->echoLength = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, echoLength), 0); - ch->d1 = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, d1), 0); - ch->d2 = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, d2), 0); - ch->gt = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, gt), 0); - ch->midiKey = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, midiKey), 0); - ch->ve = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, ve), 0); - ch->pr = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, pr), 0); - ch->rp = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, rp), 0); - ch->d3[0] = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, d3[0]), 0); - ch->d3[1] = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, d3[1]), 0); - ch->d3[2] = memory->load8(cpu, base + offsetof(struct GBAMP2kSoundChannel, d3[2]), 0); - ch->ct = memory->load32(cpu, base + offsetof(struct GBAMP2kSoundChannel, ct), 0); - ch->fw = memory->load32(cpu, base + offsetof(struct GBAMP2kSoundChannel, fw), 0); - ch->freq = memory->load32(cpu, base + offsetof(struct GBAMP2kSoundChannel, freq), 0); - ch->waveData = memory->load32(cpu, base + offsetof(struct GBAMP2kSoundChannel, waveData), 0); - ch->cp = memory->load32(cpu, base + offsetof(struct GBAMP2kSoundChannel, cp), 0); - ch->track = memory->load32(cpu, base + offsetof(struct GBAMP2kSoundChannel, track), 0); - ch->pp = memory->load32(cpu, base + offsetof(struct GBAMP2kSoundChannel, pp), 0); - ch->np = memory->load32(cpu, base + offsetof(struct GBAMP2kSoundChannel, np), 0); - ch->d4 = memory->load32(cpu, base + offsetof(struct GBAMP2kSoundChannel, d4), 0); - ch->xpi = memory->load16(cpu, base + offsetof(struct GBAMP2kSoundChannel, xpi), 0); - ch->xpc = memory->load16(cpu, base + offsetof(struct GBAMP2kSoundChannel, xpc), 0); - - base = ch->track; - if (base) { - track->track.flags = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, flags), 0); - track->track.wait = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, wait), 0); - track->track.patternLevel = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, patternLevel), 0); - track->track.repN = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, repN), 0); - track->track.gateTime = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, gateTime), 0); - track->track.key = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, key), 0); - track->track.velocity = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, velocity), 0); - track->track.runningStatus = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, runningStatus), 0); - track->track.keyM = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, keyM), 0); - track->track.pitM = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, pitM), 0); - track->track.keyShift = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, keyShift), 0); - track->track.keyShiftX = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, keyShiftX), 0); - track->track.tune = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, tune), 0); - track->track.pitX = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, pitX), 0); - track->track.bend = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, bend), 0); - track->track.bendRange = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, bendRange), 0); - track->track.volMR = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, volMR), 0); - track->track.volML = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, volML), 0); - track->track.vol = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, vol), 0); - track->track.volX = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, volX), 0); - track->track.pan = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, pan), 0); - track->track.panX = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, panX), 0); - track->track.modM = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, modM), 0); - track->track.mod = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, mod), 0); - track->track.modT = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, modT), 0); - track->track.lfoSpeed = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, lfoSpeed), 0); - track->track.lfoSpeedC = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, lfoSpeedC), 0); - track->track.lfoDelay = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, lfoDelay), 0); - track->track.lfoDelayC = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, lfoDelayC), 0); - track->track.priority = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, priority), 0); - track->track.echoVolume = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, echoVolume), 0); - track->track.echoLength = memory->load8(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, echoLength), 0); - track->track.chan = memory->load32(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, chan), 0); - _loadInstrument(cpu, &track->track.instrument, base + offsetof(struct GBAMP2kMusicPlayerTrack, instrument)); - track->track.cmdPtr = memory->load32(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, cmdPtr), 0); - track->track.patternStack[0] = memory->load32(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, patternStack[0]), 0); - track->track.patternStack[1] = memory->load32(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, patternStack[1]), 0); - track->track.patternStack[2] = memory->load32(cpu, base + offsetof(struct GBAMP2kMusicPlayerTrack, patternStack[2]), 0); - } else { - memset(&track->track, 0, sizeof(track->track)); - } - if (track->track.runningStatus == 0xCD) { - // XCMD isn't supported - mixer->p->externalMixing = false; - } - } -} - -bool _mp2kEngage(struct GBAAudioMixer* mixer, uint32_t address) { - if (address != mixer->contextAddress) { - mixer->contextAddress = address; - mixer->p->externalMixing = true; - _mp2kReload(mixer); - } - return true; -} - -void _mp2kStep(struct GBAAudioMixer* mixer) { - mixer->frame += mixer->p->sampleInterval; - - while (mixer->frame >= VIDEO_TOTAL_LENGTH / mixer->tempo) { - int i; - for (i = 0; i < MP2K_MAX_SOUND_CHANNELS; ++i) { - struct GBAMP2kTrack* track = &mixer->activeTracks[i]; - if (track->channel->status > 0) { - _stepSample(mixer, track); - } else { - track->currentOffset = 0; - track->samplePlaying = 0; - mCircleBufferClear(&track->buffer); - } - } - mixer->frame -= VIDEO_TOTAL_LENGTH / mixer->tempo; - } - - uint32_t interval = mixer->p->sampleInterval / OVERSAMPLE; - int i; - for (i = 0; i < OVERSAMPLE; ++i) { - struct mStereoSample sample = {0}; - size_t track; - for (track = 0; track < MP2K_MAX_SOUND_CHANNELS; ++track) { - if (!mixer->activeTracks[track].channel->status) { - continue; - } - int16_t value; - mCircleBufferRead16(&mixer->activeTracks[track].buffer, &value); - sample.left += value; - mCircleBufferRead16(&mixer->activeTracks[track].buffer, &value); - sample.right += value; - } - sample.left = (sample.left * mixer->p->masterVolume) >> 8; - sample.right = (sample.right * mixer->p->masterVolume) >> 8; - if (mixer->p->externalMixing) { - blip_add_delta(mixer->p->psg.left, mixer->p->clock + i * interval, sample.left - mixer->last.left); - blip_add_delta(mixer->p->psg.right, mixer->p->clock + i * interval, sample.right - mixer->last.right); - } - mixer->last = sample; - } -} - -void _mp2kVblank(struct GBAAudioMixer* mixer) { - if (!mixer->contextAddress) { - return; - } - mLOG(GBA_AUDIO, DEBUG, "Frame"); - mixer->p->externalMixing = true; - _mp2kReload(mixer); -} diff --git a/src/gba/gba.c b/src/gba/gba.c index 41eee7435f0..fb0a84ae7e5 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -928,10 +928,6 @@ void GBABreakpoint(struct ARMCore* cpu, int immediate) { void GBAFrameStarted(struct GBA* gba) { GBATestKeypadIRQ(gba); - if (gba->audio.mixer) { - gba->audio.mixer->vblank(gba->audio.mixer); - } - size_t c; for (c = 0; c < mCoreCallbacksListSize(&gba->coreCallbacks); ++c) { struct mCoreCallbacks* callbacks = mCoreCallbacksListGetPointer(&gba->coreCallbacks, c); diff --git a/src/platform/qt/SettingsView.cpp b/src/platform/qt/SettingsView.cpp index e95da696c2a..66c125466af 100644 --- a/src/platform/qt/SettingsView.cpp +++ b/src/platform/qt/SettingsView.cpp @@ -607,12 +607,6 @@ void SettingsView::updateConfig() { emit languageChanged(); } - bool oldAudioHle = m_controller->getOption("gba.audioHle", "0") != "0"; - if (oldAudioHle != m_ui.audioHle->isChecked()) { - saveSetting("gba.audioHle", m_ui.audioHle); - emit audioHleChanged(); - } - if (m_ui.multiplayerAudioAll->isChecked()) { m_controller->setQtOption("multiplayerAudio", "all"); } else if (m_ui.multiplayerAudio1->isChecked()) { @@ -740,7 +734,6 @@ void SettingsView::reloadConfig() { loadSetting("logToStdout", m_ui.logToStdout); loadSetting("logFile", m_ui.logFile); loadSetting("useDiscordPresence", m_ui.useDiscordPresence); - loadSetting("gba.audioHle", m_ui.audioHle); loadSetting("dynamicTitle", m_ui.dynamicTitle, true); loadSetting("gba.forceGbp", m_ui.forceGbp); loadSetting("vbaBugCompat", m_ui.vbaBugCompat, true); diff --git a/src/platform/qt/SettingsView.h b/src/platform/qt/SettingsView.h index 3543419fc5a..010b4ef0d8d 100644 --- a/src/platform/qt/SettingsView.h +++ b/src/platform/qt/SettingsView.h @@ -63,7 +63,6 @@ Q_OBJECT void pathsChanged(); void languageChanged(); void libraryCleared(); - void audioHleChanged(); public slots: void selectPage(Page); diff --git a/src/platform/qt/SettingsView.ui b/src/platform/qt/SettingsView.ui index 42e4af5a00a..8539e6bdb75 100644 --- a/src/platform/qt/SettingsView.ui +++ b/src/platform/qt/SettingsView.ui @@ -1307,14 +1307,7 @@ - - - - XQ GBA audio (experimental) - - - - + OpenGL enhancements diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index bd52b086293..c75a163efbf 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -543,15 +543,6 @@ void Window::openSettingsWindow(SettingsView::Page page) { connect(settingsWindow, &SettingsView::videoRendererChanged, this, &Window::changeRenderer); connect(settingsWindow, &SettingsView::languageChanged, this, &Window::mustRestart); connect(settingsWindow, &SettingsView::pathsChanged, this, &Window::reloadConfig); - connect(settingsWindow, &SettingsView::audioHleChanged, this, [this]() { - if (!m_controller) { - return; - } - if (m_controller->platform() != mPLATFORM_GBA) { - return; - } - mustReset(); - }); #ifdef USE_SQLITE3 connect(settingsWindow, &SettingsView::libraryCleared, m_libraryView, &LibraryController::clear); #endif From f51cb153d109f842fdc5325715be97a71fcacd28 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 00:42:26 -0700 Subject: [PATCH 096/338] Core: Switch from blip to mAudioResampler --- include/mgba/core/core.h | 3 +- include/mgba/core/interface.h | 4 +- include/mgba/core/sync.h | 5 +- include/mgba/internal/gb/audio.h | 8 +-- include/mgba/internal/gba/audio.h | 4 -- src/core/sync.c | 10 +-- src/core/thread.c | 4 +- src/gb/audio.c | 55 ++++----------- src/gb/core.c | 13 +--- src/gba/audio.c | 51 +++----------- src/gba/core.c | 13 +--- src/platform/3ds/main.c | 22 +++--- src/platform/libretro/libretro.c | 26 +++---- src/platform/psp2/psp2-context.c | 102 +++++++++++++++------------ src/platform/python/_builder.h | 1 - src/platform/python/_builder.py | 1 - src/platform/python/mgba/audio.py | 57 --------------- src/platform/python/mgba/core.py | 8 --- src/platform/qt/AudioDevice.cpp | 67 ++++++++++++++---- src/platform/qt/AudioDevice.h | 13 ++++ src/platform/qt/AudioProcessorQt.cpp | 11 ++- src/platform/qt/AudioProcessorQt.h | 1 + src/platform/sdl/sdl-audio.c | 37 ++++------ src/platform/sdl/sdl-audio.h | 4 ++ src/platform/switch/main.c | 12 +--- src/platform/test/fuzz-main.c | 7 +- src/platform/test/perf-main.c | 1 - src/platform/wii/main.c | 79 ++++++++++----------- 28 files changed, 257 insertions(+), 362 deletions(-) delete mode 100644 src/platform/python/mgba/audio.py diff --git a/include/mgba/core/core.h b/include/mgba/core/core.h index 7eeb1d8fbc3..a4bf5826cc0 100644 --- a/include/mgba/core/core.h +++ b/include/mgba/core/core.h @@ -32,6 +32,7 @@ enum mCoreChecksumType { mCHECKSUM_CRC32, }; +struct mAudioBuffer; struct mCoreConfig; struct mCoreSync; struct mDebuggerSymbols; @@ -79,7 +80,7 @@ struct mCore { void (*putPixels)(struct mCore*, const void* buffer, size_t stride); unsigned (*audioSampleRate)(const struct mCore*); - struct blip_t* (*getAudioChannel)(struct mCore*, int ch); + struct mAudioBuffer* (*getAudioBuffer)(struct mCore*); void (*setAudioBufferSize)(struct mCore*, size_t samples); size_t (*getAudioBufferSize)(struct mCore*); diff --git a/include/mgba/core/interface.h b/include/mgba/core/interface.h index f1af5e50d5e..b07f300f3f5 100644 --- a/include/mgba/core/interface.h +++ b/include/mgba/core/interface.h @@ -16,7 +16,7 @@ CXX_GUARD_START struct mCore; struct mStateExtdataItem; -struct blip_t; +struct mAudioBuffer; enum mCoreFeature { mCORE_FEATURE_OPENGL = 1, @@ -41,7 +41,7 @@ struct mAVStream { void (*audioRateChanged)(struct mAVStream*, unsigned rate); void (*postVideoFrame)(struct mAVStream*, const color_t* buffer, size_t stride); void (*postAudioFrame)(struct mAVStream*, int16_t left, int16_t right); - void (*postAudioBuffer)(struct mAVStream*, struct blip_t* left, struct blip_t* right); + void (*postAudioBuffer)(struct mAVStream*, struct mAudioBuffer*); }; struct mStereoSample { diff --git a/include/mgba/core/sync.h b/include/mgba/core/sync.h index a44994b07be..df4e777bb0e 100644 --- a/include/mgba/core/sync.h +++ b/include/mgba/core/sync.h @@ -22,6 +22,7 @@ struct mCoreSync { bool audioWait; Condition audioRequiredCond; Mutex audioBufferMutex; + size_t audioHighWater; float fpsTarget; }; @@ -32,8 +33,8 @@ bool mCoreSyncWaitFrameStart(struct mCoreSync* sync); void mCoreSyncWaitFrameEnd(struct mCoreSync* sync); void mCoreSyncSetVideoSync(struct mCoreSync* sync, bool wait); -struct blip_t; -bool mCoreSyncProduceAudio(struct mCoreSync* sync, const struct blip_t*, size_t samples); +struct mAudioBuffer; +bool mCoreSyncProduceAudio(struct mCoreSync* sync, const struct mAudioBuffer*); void mCoreSyncLockAudio(struct mCoreSync* sync); void mCoreSyncUnlockAudio(struct mCoreSync* sync); void mCoreSyncConsumeAudio(struct mCoreSync* sync); diff --git a/include/mgba/internal/gb/audio.h b/include/mgba/internal/gb/audio.h index 5b8993ac5a3..8b9b775c3c4 100644 --- a/include/mgba/internal/gb/audio.h +++ b/include/mgba/internal/gb/audio.h @@ -12,6 +12,7 @@ CXX_GUARD_START #include #include +#include #define GB_MAX_SAMPLES 32 @@ -166,14 +167,9 @@ struct GBAudio { struct GBAudioWaveChannel ch3; struct GBAudioNoiseChannel ch4; - struct blip_t* left; - struct blip_t* right; - int16_t lastLeft; - int16_t lastRight; + struct mAudioBuffer buffer; int32_t capLeft; int32_t capRight; - int clock; - int32_t clockRate; uint8_t volumeRight; uint8_t volumeLeft; diff --git a/include/mgba/internal/gba/audio.h b/include/mgba/internal/gba/audio.h index a6eb4824d39..5b5db3a621b 100644 --- a/include/mgba/internal/gba/audio.h +++ b/include/mgba/internal/gba/audio.h @@ -63,10 +63,6 @@ struct GBAAudio { struct GBAAudioFIFO chA; struct GBAAudioFIFO chB; - int16_t lastLeft; - int16_t lastRight; - int clock; - uint8_t volume; bool volumeChA; bool volumeChB; diff --git a/src/core/sync.c b/src/core/sync.c index b2a65493bc0..e46e7dcda00 100644 --- a/src/core/sync.c +++ b/src/core/sync.c @@ -5,7 +5,7 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include -#include +#include static void _changeVideoSync(struct mCoreSync* sync, bool wait) { // Make sure the video thread can process events while the GBA thread is paused @@ -79,17 +79,17 @@ void mCoreSyncSetVideoSync(struct mCoreSync* sync, bool wait) { _changeVideoSync(sync, wait); } -bool mCoreSyncProduceAudio(struct mCoreSync* sync, const struct blip_t* buf, size_t samples) { +bool mCoreSyncProduceAudio(struct mCoreSync* sync, const struct mAudioBuffer* buf) { if (!sync) { return true; } - size_t produced = blip_samples_avail(buf); + size_t produced = mAudioBufferAvailable(buf); size_t producedNew = produced; - while (sync->audioWait && producedNew >= samples) { + while (sync->audioWait && sync->audioHighWater && producedNew >= sync->audioHighWater) { ConditionWait(&sync->audioRequiredCond, &sync->audioBufferMutex); produced = producedNew; - producedNew = blip_samples_avail(buf); + producedNew = mAudioBufferAvailable(buf); } MutexUnlock(&sync->audioBufferMutex); return producedNew != produced; diff --git a/src/core/thread.c b/src/core/thread.c index 18c1c20e16b..0be5f81e21f 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -5,7 +5,6 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include -#include #include #ifdef ENABLE_SCRIPTING #include @@ -368,7 +367,7 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { if (impl->sync.audioWait) { MutexUnlock(&impl->stateMutex); mCoreSyncLockAudio(&impl->sync); - mCoreSyncProduceAudio(&impl->sync, core->getAudioChannel(core, 0), core->getAudioBufferSize(core)); + mCoreSyncProduceAudio(&impl->sync, core->getAudioBuffer(core)); MutexLock(&impl->stateMutex); } } @@ -498,6 +497,7 @@ bool mCoreThreadStart(struct mCoreThread* threadContext) { threadContext->impl->sync.audioWait = threadContext->core->opts.audioSync; threadContext->impl->sync.videoFrameWait = threadContext->core->opts.videoSync; threadContext->impl->sync.fpsTarget = threadContext->core->opts.fpsTarget; + threadContext->impl->sync.audioHighWater = 512; MutexLock(&threadContext->impl->stateMutex); ThreadCreate(&threadContext->impl->thread, _mCoreThreadRun, threadContext); diff --git a/src/gb/audio.c b/src/gb/audio.c index cf5445e1570..4230fb88c21 100644 --- a/src/gb/audio.c +++ b/src/gb/audio.c @@ -5,7 +5,6 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include -#include #include #include #include @@ -15,15 +14,10 @@ #include #endif -#ifdef __3DS__ -#define blip_add_delta blip_add_delta_fast -#endif - +#define AUDIO_BUFFER_SAMPLES 0x4000 #define FRAME_CYCLES (DMG_SM83_FREQUENCY >> 9) const uint32_t DMG_SM83_FREQUENCY = 0x400000; -static const int CLOCKS_PER_BLIP_FRAME = 0x1000; -static const unsigned BLIP_BUFFER_SIZE = 0x4000; static const int SAMPLE_INTERVAL = 32; static const int FILTER = 65368; const int GB_AUDIO_VOLUME_MAX = 0x100; @@ -57,12 +51,7 @@ static const int _squareChannelDuty[4][8] = { void GBAudioInit(struct GBAudio* audio, size_t samples, uint8_t* nr52, enum GBAudioStyle style) { audio->samples = samples; - audio->left = blip_new(BLIP_BUFFER_SIZE); - audio->right = blip_new(BLIP_BUFFER_SIZE); - audio->clockRate = DMG_SM83_FREQUENCY; - // Guess too large; we hang producing extra samples if we guess too low - blip_set_rates(audio->left, DMG_SM83_FREQUENCY, 96000); - blip_set_rates(audio->right, DMG_SM83_FREQUENCY, 96000); + mAudioBufferInit(&audio->buffer, AUDIO_BUFFER_SAMPLES, 2); audio->forceDisableCh[0] = false; audio->forceDisableCh[1] = false; audio->forceDisableCh[2] = false; @@ -86,8 +75,7 @@ void GBAudioInit(struct GBAudio* audio, size_t samples, uint8_t* nr52, enum GBAu } void GBAudioDeinit(struct GBAudio* audio) { - blip_delete(audio->left); - blip_delete(audio->right); + mAudioBufferDeinit(&audio->buffer); } void GBAudioReset(struct GBAudio* audio) { @@ -123,11 +111,9 @@ void GBAudioReset(struct GBAudio* audio) { audio->sampleInterval = SAMPLE_INTERVAL * GB_MAX_SAMPLES; audio->lastSample = 0; audio->sampleIndex = 0; - audio->lastLeft = 0; - audio->lastRight = 0; audio->capLeft = 0; audio->capRight = 0; - audio->clock = 0; + mAudioBufferClear(&audio->buffer); audio->playingCh1 = false; audio->playingCh2 = false; audio->playingCh3 = false; @@ -140,14 +126,8 @@ void GBAudioReset(struct GBAudio* audio) { } void GBAudioResizeBuffer(struct GBAudio* audio, size_t samples) { - if (samples > BLIP_BUFFER_SIZE / 2) { - samples = BLIP_BUFFER_SIZE / 2; - } mCoreSyncLockAudio(audio->p->sync); audio->samples = samples; - blip_clear(audio->left); - blip_clear(audio->right); - audio->clock = 0; mCoreSyncConsumeAudio(audio->p->sync); } @@ -845,34 +825,25 @@ static void _sample(struct mTiming* timing, void* user, uint32_t cyclesLate) { unsigned produced; int i; for (i = 0; i < GB_MAX_SAMPLES; ++i) { - int16_t sampleLeft = audio->currentSamples[i].left; - int16_t sampleRight = audio->currentSamples[i].right; - if ((size_t) blip_samples_avail(audio->left) < audio->samples) { - blip_add_delta(audio->left, audio->clock, sampleLeft - audio->lastLeft); - blip_add_delta(audio->right, audio->clock, sampleRight - audio->lastRight); - audio->lastLeft = sampleLeft; - audio->lastRight = sampleRight; - audio->clock += SAMPLE_INTERVAL; - if (audio->clock >= CLOCKS_PER_BLIP_FRAME) { - blip_end_frame(audio->left, CLOCKS_PER_BLIP_FRAME); - blip_end_frame(audio->right, CLOCKS_PER_BLIP_FRAME); - audio->clock -= CLOCKS_PER_BLIP_FRAME; - } - } + int16_t sample[2] = { + audio->currentSamples[i].left, + audio->currentSamples[i].right + }; + mAudioBufferWrite(&audio->buffer, sample, 1); if (audio->p->stream && audio->p->stream->postAudioFrame) { - audio->p->stream->postAudioFrame(audio->p->stream, sampleLeft, sampleRight); + audio->p->stream->postAudioFrame(audio->p->stream, sample[0], sample[1]); } } - produced = blip_samples_avail(audio->left); + produced = mAudioBufferAvailable(&audio->buffer); bool wait = produced >= audio->samples; - if (!mCoreSyncProduceAudio(audio->p->sync, audio->left, audio->samples)) { + if (!mCoreSyncProduceAudio(audio->p->sync, &audio->buffer)) { // Interrupted audio->p->earlyExit = true; } if (wait && audio->p->stream && audio->p->stream->postAudioBuffer) { - audio->p->stream->postAudioBuffer(audio->p->stream, audio->left, audio->right); + audio->p->stream->postAudioBuffer(audio->p->stream, &audio->buffer); } mTimingSchedule(timing, &audio->sampleEvent, audio->sampleInterval * audio->timingFactor - cyclesLate); } diff --git a/src/gb/core.c b/src/gb/core.c index 9ee6d3f8454..7023b29f738 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -428,16 +428,9 @@ static void _GBCorePutPixels(struct mCore* core, const void* buffer, size_t stri gbcore->renderer.d.putPixels(&gbcore->renderer.d, stride, buffer); } -static struct blip_t* _GBCoreGetAudioChannel(struct mCore* core, int ch) { +static struct mAudioBuffer* _GBCoreGetAudioBuffer(struct mCore* core) { struct GB* gb = core->board; - switch (ch) { - case 0: - return gb->audio.left; - case 1: - return gb->audio.right; - default: - return NULL; - } + return &gb->audio.buffer; } static void _GBCoreSetAudioBufferSize(struct mCore* core, size_t samples) { @@ -1308,7 +1301,7 @@ struct mCore* GBCoreCreate(void) { core->getPixels = _GBCoreGetPixels; core->putPixels = _GBCorePutPixels; core->audioSampleRate = _GBCoreAudioSampleRate; - core->getAudioChannel = _GBCoreGetAudioChannel; + core->getAudioBuffer = _GBCoreGetAudioBuffer; core->setAudioBufferSize = _GBCoreSetAudioBufferSize; core->getAudioBufferSize = _GBCoreGetAudioBufferSize; core->setAVStream = _GBCoreSetAVStream; diff --git a/src/gba/audio.c b/src/gba/audio.c index 56f42b14f84..8ccc7f9d800 100644 --- a/src/gba/audio.c +++ b/src/gba/audio.c @@ -6,7 +6,6 @@ #include #include -#include #include #include #include @@ -16,17 +15,12 @@ #define MP2K_LOCK_MAX 8 -#ifdef __3DS__ -#define blip_add_delta blip_add_delta_fast -#endif - mLOG_DEFINE_CATEGORY(GBA_AUDIO, "GBA Audio", "gba.audio"); const unsigned GBA_AUDIO_SAMPLES = 2048; const int GBA_AUDIO_VOLUME_MAX = 0x100; static const int SAMPLE_INTERVAL = GBA_ARM7TDMI_FREQUENCY / 0x4000; -static const int CLOCKS_PER_FRAME = 0x800; static int _applyBias(struct GBAAudio* audio, int sample); static void _sample(struct mTiming* timing, void* user, uint32_t cyclesLate); @@ -41,14 +35,10 @@ void GBAAudioInit(struct GBAAudio* audio, size_t samples) { #ifdef __BIG_ENDIAN__ ++nr52; #endif - GBAudioInit(&audio->psg, 0, nr52, GB_AUDIO_GBA); + GBAudioInit(&audio->psg, samples, nr52, GB_AUDIO_GBA); audio->psg.timing = &audio->p->timing; - audio->psg.clockRate = GBA_ARM7TDMI_FREQUENCY; audio->psg.frameEvent.context = audio; audio->samples = samples; - // Guess too large; we hang producing extra samples if we guess too low - blip_set_rates(audio->psg.left, GBA_ARM7TDMI_FREQUENCY, 96000); - blip_set_rates(audio->psg.right, GBA_ARM7TDMI_FREQUENCY, 96000); audio->forceDisableChA = false; audio->forceDisableChB = false; @@ -93,10 +83,6 @@ void GBAAudioReset(struct GBAAudio* audio) { audio->enable = false; audio->sampleInterval = GBA_ARM7TDMI_FREQUENCY / 0x8000; audio->psg.sampleInterval = audio->sampleInterval; - - blip_clear(audio->psg.left); - blip_clear(audio->psg.right); - audio->clock = 0; } void GBAAudioDeinit(struct GBAAudio* audio) { @@ -104,14 +90,9 @@ void GBAAudioDeinit(struct GBAAudio* audio) { } void GBAAudioResizeBuffer(struct GBAAudio* audio, size_t samples) { - if (samples > 0x2000) { - samples = 0x2000; - } mCoreSyncLockAudio(audio->p->sync); audio->samples = samples; - blip_clear(audio->psg.left); - blip_clear(audio->psg.right); - audio->clock = 0; + audio->psg.samples = samples; mCoreSyncConsumeAudio(audio->p->sync); } @@ -414,34 +395,24 @@ static void _sample(struct mTiming* timing, void* user, uint32_t cyclesLate) { unsigned produced; int i; for (i = 0; i < samples; ++i) { - int16_t sampleLeft = audio->currentSamples[i].left; - int16_t sampleRight = audio->currentSamples[i].right; - if ((size_t) blip_samples_avail(audio->psg.left) < audio->samples) { - blip_add_delta(audio->psg.left, audio->clock, sampleLeft - audio->lastLeft); - blip_add_delta(audio->psg.right, audio->clock, sampleRight - audio->lastRight); - audio->lastLeft = sampleLeft; - audio->lastRight = sampleRight; - audio->clock += audio->sampleInterval; - if (audio->clock >= CLOCKS_PER_FRAME) { - blip_end_frame(audio->psg.left, CLOCKS_PER_FRAME); - blip_end_frame(audio->psg.right, CLOCKS_PER_FRAME); - audio->clock -= CLOCKS_PER_FRAME; - } - } - + int16_t sample[2] = { + audio->currentSamples[i].left, + audio->currentSamples[i].right + }; + mAudioBufferWrite(&audio->psg.buffer, sample, 1); if (audio->p->stream && audio->p->stream->postAudioFrame) { - audio->p->stream->postAudioFrame(audio->p->stream, sampleLeft, sampleRight); + audio->p->stream->postAudioFrame(audio->p->stream, sample[0], sample[1]); } } - produced = blip_samples_avail(audio->psg.left); + produced = mAudioBufferAvailable(&audio->psg.buffer); bool wait = produced >= audio->samples; - if (!mCoreSyncProduceAudio(audio->p->sync, audio->psg.left, audio->samples)) { + if (!mCoreSyncProduceAudio(audio->p->sync, &audio->psg.buffer)) { // Interrupted audio->p->earlyExit = true; } if (wait && audio->p->stream && audio->p->stream->postAudioBuffer) { - audio->p->stream->postAudioBuffer(audio->p->stream, audio->psg.left, audio->psg.right); + audio->p->stream->postAudioBuffer(audio->p->stream, &audio->psg.buffer); } mTimingSchedule(timing, &audio->sampleEvent, SAMPLE_INTERVAL - cyclesLate); diff --git a/src/gba/core.c b/src/gba/core.c index fbdd5e85b7b..4a437f36d54 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -558,16 +558,9 @@ static unsigned _GBACoreAudioSampleRate(const struct mCore* core) { return 65536; } -static struct blip_t* _GBACoreGetAudioChannel(struct mCore* core, int ch) { +static struct mAudioBuffer* _GBACoreGetAudioBuffer(struct mCore* core) { struct GBA* gba = core->board; - switch (ch) { - case 0: - return gba->audio.psg.left; - case 1: - return gba->audio.psg.right; - default: - return NULL; - } + return &gba->audio.psg.buffer; } static void _GBACoreSetAudioBufferSize(struct mCore* core, size_t samples) { @@ -1505,7 +1498,7 @@ struct mCore* GBACoreCreate(void) { core->getPixels = _GBACoreGetPixels; core->putPixels = _GBACorePutPixels; core->audioSampleRate = _GBACoreAudioSampleRate; - core->getAudioChannel = _GBACoreGetAudioChannel; + core->getAudioBuffer = _GBACoreGetAudioBuffer; core->setAudioBufferSize = _GBACoreSetAudioBufferSize; core->getAudioBufferSize = _GBACoreGetAudioBufferSize; core->addCoreCallbacks = _GBACoreAddCoreCallbacks; diff --git a/src/platform/3ds/main.c b/src/platform/3ds/main.c index fb4f63a56ba..c85103bcecf 100644 --- a/src/platform/3ds/main.c +++ b/src/platform/3ds/main.c @@ -4,7 +4,6 @@ * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include #include #include #ifdef M_CORE_GBA @@ -61,7 +60,7 @@ static enum DarkenMode { #define _3DS_INPUT 0x3344534B -#define AUDIO_SAMPLES 384 +#define AUDIO_SAMPLES 1280 #define AUDIO_SAMPLE_BUFFER (AUDIO_SAMPLES * 16) #define DSP_BUFFERS 4 @@ -190,7 +189,7 @@ static void _map3DSKey(struct mInputMap* map, int ctrKey, int key) { mInputBindKey(map, _3DS_INPUT, __builtin_ctz(ctrKey), key); } -static void _postAudioBuffer(struct mAVStream* stream, blip_t* left, blip_t* right); +static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buffer); static void _drawStart(void) { if (frameStarted) { @@ -343,12 +342,13 @@ static void _gameLoaded(struct mGUIRunner* runner) { } osSetSpeedupEnable(true); - blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), 32768); - blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), 32768); if (hasSound != NO_SOUND) { audioPos = 0; } if (hasSound == DSP_SUPPORTED) { + unsigned sampleRate = runner->core->audioSampleRate(runner->core); + double fauxClock = mCoreCalculateFramerateRatio(runner->core, 16756991. / 280095.); + ndspChnSetRate(0, sampleRate * fauxClock); memset(audioLeft, 0, AUDIO_SAMPLE_BUFFER * 2 * sizeof(int16_t)); } unsigned mode; @@ -607,8 +607,7 @@ static void _drawFrame(struct mGUIRunner* runner, bool faded) { GX_TRANSFER_OUT_TILED(1) | GX_TRANSFER_FLIP_VERT(1)); if (hasSound == NO_SOUND) { - blip_clear(runner->core->getAudioChannel(runner->core, 0)); - blip_clear(runner->core->getAudioChannel(runner->core, 1)); + mAudioBufferClear(runner->core->getAudioBuffer(runner->core)); } _drawTex(runner->core, faded, interframeBlending); @@ -775,15 +774,14 @@ static void _requestImage(struct mImageSource* source, const void** buffer, size CAMU_SetReceiving(&imageSource->handles[0], imageSource->buffer, PORT_CAM1, imageSource->bufferSize, imageSource->transferSize); } -static void _postAudioBuffer(struct mAVStream* stream, blip_t* left, blip_t* right) { +static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buffer) { UNUSED(stream); if (hasSound == DSP_SUPPORTED) { int startId = bufferId; while (dspBuffer[bufferId].status == NDSP_WBUF_QUEUED || dspBuffer[bufferId].status == NDSP_WBUF_PLAYING) { bufferId = (bufferId + 1) & (DSP_BUFFERS - 1); if (bufferId == startId) { - blip_clear(left); - blip_clear(right); + mAudioBufferClear(buffer); return; } } @@ -791,8 +789,7 @@ static void _postAudioBuffer(struct mAVStream* stream, blip_t* left, blip_t* rig memset(&dspBuffer[bufferId], 0, sizeof(dspBuffer[bufferId])); dspBuffer[bufferId].data_pcm16 = tmpBuf; dspBuffer[bufferId].nsamples = AUDIO_SAMPLES; - blip_read_samples(left, dspBuffer[bufferId].data_pcm16, AUDIO_SAMPLES, true); - blip_read_samples(right, dspBuffer[bufferId].data_pcm16 + 1, AUDIO_SAMPLES, true); + mAudioBufferRead(buffer, dspBuffer[bufferId].data_pcm16, AUDIO_SAMPLES); DSP_FlushDataCache(dspBuffer[bufferId].data_pcm16, AUDIO_SAMPLES * 2 * sizeof(int16_t)); ndspChnWaveBufAdd(0, &dspBuffer[bufferId]); } @@ -857,7 +854,6 @@ int main(int argc, char* argv[]) { ndspChnReset(0); ndspChnSetFormat(0, NDSP_FORMAT_STEREO_PCM16); ndspChnSetInterp(0, NDSP_INTERP_NONE); - ndspChnSetRate(0, 32822); ndspChnWaveBufClear(0); audioLeft = linearMemAlign(AUDIO_SAMPLES * DSP_BUFFERS * 2 * sizeof(int16_t), 0x80); memset(dspBuffer, 0, sizeof(dspBuffer)); diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index 69c547b5734..8478eb29820 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -7,7 +7,6 @@ #include -#include #include #include #include @@ -30,7 +29,6 @@ #include "libretro_core_options.h" #define GB_SAMPLES 512 -#define SAMPLE_RATE 32768 /* An alpha factor of 1/180 is *somewhat* equivalent * to calculating the average for the last 180 * frames, or 3 seconds of runtime... */ @@ -54,7 +52,7 @@ static retro_set_sensor_state_t sensorStateCallback; static void GBARetroLog(struct mLogger* logger, int category, enum mLogLevel level, const char* format, va_list args); -static void _postAudioBuffer(struct mAVStream*, blip_t* left, blip_t* right); +static void _postAudioBuffer(struct mAVStream*, struct mAudioBuffer*); static void _setRumble(struct mRumble* rumble, int enable); static uint8_t _readLux(struct GBALuminanceSource* lux); static void _updateLux(struct GBALuminanceSource* lux); @@ -424,7 +422,7 @@ void retro_get_system_av_info(struct retro_system_av_info* info) { info->geometry.aspect_ratio = width / (double) height; info->timing.fps = core->frequency(core) / (float) core->frameCycles(core); - info->timing.sample_rate = SAMPLE_RATE; + info->timing.sample_rate = core->audioSampleRate(core); } void retro_init(void) { @@ -613,9 +611,8 @@ void retro_run(void) { #ifdef M_CORE_GBA if (core->platform(core) == mPLATFORM_GBA) { - blip_t *audioChannelLeft = core->getAudioChannel(core, 0); - blip_t *audioChannelRight = core->getAudioChannel(core, 1); - int samplesAvail = blip_samples_avail(audioChannelLeft); + struct mAudioBuffer *buffer = core->getAudioBuffer(core); + int samplesAvail = mAudioBufferAvailable(buffer); if (samplesAvail > 0) { /* Update 'running average' of number of * samples per frame. @@ -632,8 +629,7 @@ void retro_run(void) { audioSampleBufferSize = (samplesToRead * 2); audioSampleBuffer = realloc(audioSampleBuffer, audioSampleBufferSize * sizeof(int16_t)); } - int produced = blip_read_samples(audioChannelLeft, audioSampleBuffer, samplesToRead, true); - blip_read_samples(audioChannelRight, audioSampleBuffer + 1, samplesToRead, true); + int produced = mAudioBufferRead(buffer, audioSampleBuffer, samplesToRead); if (produced > 0) { if (audioLowPassEnabled) { _audioLowPassFilter(audioSampleBuffer, produced); @@ -884,9 +880,9 @@ bool retro_load_game(const struct retro_game_info* game) { * to nominal number of samples per frame. * Buffer will be resized as required in * retro_run(). */ - size_t audioSamplesPerFrame = (size_t)((float) SAMPLE_RATE * (float) core->frameCycles(core) / + size_t audioSamplesPerFrame = (size_t)((float) core->audioSampleRate(core) * (float) core->frameCycles(core) / (float)core->frequency(core)); - audioSampleBufferSize = audioSamplesPerFrame * 2; + audioSampleBufferSize = ceil(audioSamplesPerFrame) * 2; audioSampleBuffer = malloc(audioSampleBufferSize * sizeof(int16_t)); audioSamplesPerFrameAvg = (float) audioSamplesPerFrame; /* Internal audio buffer size should be @@ -918,9 +914,6 @@ bool retro_load_game(const struct retro_game_info* game) { core->setAudioBufferSize(core, GB_SAMPLES); } - blip_set_rates(core->getAudioChannel(core, 0), core->frequency(core), SAMPLE_RATE); - blip_set_rates(core->getAudioChannel(core, 1), core->frequency(core), SAMPLE_RATE); - core->setPeripheral(core, mPERIPH_RUMBLE, &rumble); core->setPeripheral(core, mPERIPH_ROTATION, &rotation); @@ -1238,10 +1231,9 @@ void GBARetroLog(struct mLogger* logger, int category, enum mLogLevel level, con } /* Used only for GB/GBC content */ -static void _postAudioBuffer(struct mAVStream* stream, blip_t* left, blip_t* right) { +static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buffer) { UNUSED(stream); - int produced = blip_read_samples(left, audioSampleBuffer, GB_SAMPLES, true); - blip_read_samples(right, audioSampleBuffer + 1, GB_SAMPLES, true); + int produced = mAudioBufferRead(buffer, audioSampleBuffer, GB_SAMPLES); if (produced > 0) { if (audioLowPassEnabled) { _audioLowPassFilter(audioSampleBuffer, produced); diff --git a/src/platform/psp2/psp2-context.c b/src/platform/psp2/psp2-context.c index 755021f6f5f..36253aa071c 100644 --- a/src/platform/psp2/psp2-context.c +++ b/src/platform/psp2/psp2-context.c @@ -5,7 +5,6 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include "psp2-context.h" -#include #include #ifdef M_CORE_GBA @@ -18,9 +17,10 @@ #include "feature/gui/gui-runner.h" #include -#include +#include #include #include +#include #include #include #include @@ -84,14 +84,21 @@ bool frameLimiter = true; extern const uint8_t _binary_backdrop_png_start[]; static vita2d_texture* backdrop = 0; +#define BUFFERS 16 #define PSP2_SAMPLES 512 -#define PSP2_AUDIO_BUFFER_SIZE (PSP2_SAMPLES * 16) +#define PSP2_AUDIO_BUFFER_SIZE (PSP2_SAMPLES * BUFFERS) + +struct mPSP2AudioBuffer { + int16_t samples[PSP2_SAMPLES * 2] __attribute__((__aligned__(64))); + bool full; +}; static struct mPSP2AudioContext { - struct mStereoSample buffer[PSP2_AUDIO_BUFFER_SIZE]; - size_t writeOffset; - size_t readOffset; - size_t samples; + struct mPSP2AudioBuffer outputBuffers[BUFFERS]; + int currentAudioBuffer; + int nextAudioBuffer; + struct mAudioBuffer buffer; + struct mAudioResampler resampler; Mutex mutex; Condition cond; bool running; @@ -103,29 +110,26 @@ void mPSP2MapKey(struct mInputMap* map, int pspKey, int key) { static THREAD_ENTRY _audioThread(void* context) { struct mPSP2AudioContext* audio = (struct mPSP2AudioContext*) context; - uint32_t zeroBuffer[PSP2_SAMPLES] = {0}; - void* buffer = zeroBuffer; + const int16_t zeroBuffer[PSP2_SAMPLES * 2] __attribute__((__aligned__(64))) = {0}; + const void* buffer = zeroBuffer; int audioPort = sceAudioOutOpenPort(SCE_AUDIO_OUT_PORT_TYPE_MAIN, PSP2_SAMPLES, 48000, SCE_AUDIO_OUT_MODE_STEREO); + struct mPSP2AudioBuffer* outputBuffer = NULL; while (audio->running) { MutexLock(&audio->mutex); - if (buffer != zeroBuffer) { + if (outputBuffer) { // Can only happen in successive iterations - audio->samples -= PSP2_SAMPLES; + outputBuffer->full = false; ConditionWake(&audio->cond); } - if (audio->samples >= PSP2_SAMPLES) { - buffer = &audio->buffer[audio->readOffset]; - audio->readOffset += PSP2_SAMPLES; - if (audio->readOffset >= PSP2_AUDIO_BUFFER_SIZE) { - audio->readOffset = 0; - } - // Don't mark samples as read until the next loop iteration to prevent - // writing to the buffer while being read (see above) + outputBuffer = &audio->outputBuffers[audio->currentAudioBuffer]; + if (outputBuffer->full) { + buffer = outputBuffer->samples; + audio->currentAudioBuffer = (audio->currentAudioBuffer + 1) % BUFFERS; } else { buffer = zeroBuffer; + outputBuffer = NULL; } MutexUnlock(&audio->mutex); - sceAudioOutOutput(audioPort, buffer); } sceAudioOutReleasePort(audioPort); @@ -243,25 +247,21 @@ static void _requestImage(struct mImageSource* source, const void** buffer, size sceCameraRead(imageSource->cam - 1, &read); } -static void _postAudioBuffer(struct mAVStream* stream, blip_t* left, blip_t* right) { +static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buf) { UNUSED(stream); MutexLock(&audioContext.mutex); - while (audioContext.samples + PSP2_SAMPLES >= PSP2_AUDIO_BUFFER_SIZE) { - if (!frameLimiter) { - blip_clear(left); - blip_clear(right); - MutexUnlock(&audioContext.mutex); - return; + mAudioResamplerProcess(&audioContext.resampler); + while (mAudioBufferAvailable(&audioContext.buffer) >= PSP2_SAMPLES) { + struct mPSP2AudioBuffer* buffer = &audioContext.outputBuffers[audioContext.nextAudioBuffer]; + while (buffer->full) { + if (!frameLimiter) { + break; + } + ConditionWait(&audioContext.cond, &audioContext.mutex); } - ConditionWait(&audioContext.cond, &audioContext.mutex); - } - struct mStereoSample* samples = &audioContext.buffer[audioContext.writeOffset]; - blip_read_samples(left, &samples[0].left, PSP2_SAMPLES, true); - blip_read_samples(right, &samples[0].right, PSP2_SAMPLES, true); - audioContext.samples += PSP2_SAMPLES; - audioContext.writeOffset += PSP2_SAMPLES; - if (audioContext.writeOffset >= PSP2_AUDIO_BUFFER_SIZE) { - audioContext.writeOffset = 0; + mAudioBufferRead(&audioContext.buffer, buffer->samples, PSP2_SAMPLES); + buffer->full = true; + audioContext.nextAudioBuffer = (audioContext.nextAudioBuffer + 1) % BUFFERS; } MutexUnlock(&audioContext.mutex); } @@ -294,7 +294,11 @@ void mPSP2SetFrameLimiter(struct mGUIRunner* runner, bool limit) { UNUSED(runner); if (!frameLimiter && limit) { MutexLock(&audioContext.mutex); - while (audioContext.samples) { + while (true) { + struct mPSP2AudioBuffer* buffer = &audioContext.outputBuffers[audioContext.currentAudioBuffer]; + if (!buffer->full) { + break; + } ConditionWait(&audioContext.cond, &audioContext.mutex); } MutexUnlock(&audioContext.mutex); @@ -334,6 +338,9 @@ void mPSP2Setup(struct mGUIRunner* runner) { runner->core->setVideoBuffer(runner->core, vita2d_texture_get_datap(tex[currentTex]), 256); runner->core->setAudioBufferSize(runner->core, PSP2_SAMPLES); + mAudioBufferInit(&audioContext.buffer, PSP2_AUDIO_BUFFER_SIZE, 2); + mAudioResamplerInit(&audioContext.resampler, mINTERPOLATOR_COSINE); + mAudioResamplerSetDestination(&audioContext.resampler, &audioContext.buffer, 48000); rotation.d.sample = _sampleRotation; rotation.d.readTiltX = _readTiltX; @@ -374,12 +381,6 @@ void mPSP2Setup(struct mGUIRunner* runner) { } void mPSP2LoadROM(struct mGUIRunner* runner) { - float rate = 60.0f / 1.001f; - sceDisplayGetRefreshRate(&rate); - double ratio = mCoreCalculateFramerateRatio(runner->core, rate); - blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), 48000 * ratio); - blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), 48000 * ratio); - switch (runner->core->platform(runner->core)) { #ifdef M_CORE_GBA case mPLATFORM_GBA: @@ -415,10 +416,17 @@ void mPSP2LoadROM(struct mGUIRunner* runner) { MutexInit(&audioContext.mutex); ConditionInit(&audioContext.cond); - memset(audioContext.buffer, 0, sizeof(audioContext.buffer)); - audioContext.readOffset = 0; - audioContext.writeOffset = 0; + mAudioBufferClear(&audioContext.buffer); + audioContext.nextAudioBuffer = 0; + audioContext.currentAudioBuffer = 0; audioContext.running = true; + + float rate = 60.0f / 1.001f; + sceDisplayGetRefreshRate(&rate); + double ratio = mCoreCalculateFramerateRatio(runner->core, rate); + unsigned sampleRate = runner->core->audioSampleRate(runner->core); + mAudioBufferClear(&audioContext.buffer); + mAudioResamplerSetSource(&audioContext.resampler, runner->core->getAudioBuffer(runner->core), sampleRate / ratio, true); ThreadCreate(&audioThread, _audioThread, &audioContext); } @@ -483,6 +491,8 @@ void mPSP2Unpaused(struct mGUIRunner* runner) { void mPSP2Teardown(struct mGUIRunner* runner) { UNUSED(runner); mCircleBufferDeinit(&rumble.history); + mAudioResamplerDeinit(&audioContext.resampler); + mAudioBufferDeinit(&audioContext.buffer); vita2d_free_texture(tex[0]); vita2d_free_texture(tex[1]); vita2d_free_texture(screenshot); diff --git a/src/platform/python/_builder.h b/src/platform/python/_builder.h index e06e4f5ccdc..0b51eb19d96 100644 --- a/src/platform/python/_builder.h +++ b/src/platform/python/_builder.h @@ -36,7 +36,6 @@ void free(void*); #include -#include #include #include #include diff --git a/src/platform/python/_builder.py b/src/platform/python/_builder.py index 1e21cc82f8f..1defca53791 100644 --- a/src/platform/python/_builder.py +++ b/src/platform/python/_builder.py @@ -21,7 +21,6 @@ #define MGBA_EXPORT #include #define OPAQUE_THREADING -#include #include #include #include diff --git a/src/platform/python/mgba/audio.py b/src/platform/python/mgba/audio.py deleted file mode 100644 index a833d082793..00000000000 --- a/src/platform/python/mgba/audio.py +++ /dev/null @@ -1,57 +0,0 @@ -# Copyright (c) 2013-2018 Jeffrey Pfau -# -# This Source Code Form is subject to the terms of the Mozilla Public -# License, v. 2.0. If a copy of the MPL was not distributed with this -# file, You can obtain one at http://mozilla.org/MPL/2.0/. -from ._pylib import ffi, lib # pylint: disable=no-name-in-module - - -class Buffer(object): - def __init__(self, native, internal_rate): - self._native = native - self._internal_rate = internal_rate - - @property - def available(self): - return lib.blip_samples_avail(self._native) - - def set_rate(self, rate): - lib.blip_set_rates(self._native, self._internal_rate, rate) - - def read(self, samples): - buffer = ffi.new("short[%i]" % samples) - count = self.read_into(buffer, samples, 1, 0) - return buffer[:count] - - def read_into(self, buffer, samples, channels=1, interleave=0): - return lib.blip_read_samples(self._native, ffi.addressof(buffer, interleave), samples, channels == 2) - - def clear(self): - lib.blip_clear(self._native) - - -class StereoBuffer(object): - def __init__(self, left, right): - self._left = left - self._right = right - - @property - def available(self): - return min(self._left.available, self._right.available) - - def set_rate(self, rate): - self._left.set_rate(rate) - self._right.set_rate(rate) - - def read(self, samples): - buffer = ffi.new("short[%i]" % (2 * samples)) - count = self.read_into(buffer, samples) - return buffer[0:2 * count] - - def read_into(self, buffer, samples): - samples = self._left.read_into(buffer, samples, 2, 0) - return self._right.read_into(buffer, samples, 2, 1) - - def clear(self): - self._left.clear() - self._right.clear() diff --git a/src/platform/python/mgba/core.py b/src/platform/python/mgba/core.py index 51f543d3a01..75fd1a1cc4d 100644 --- a/src/platform/python/mgba/core.py +++ b/src/platform/python/mgba/core.py @@ -250,14 +250,6 @@ def set_audio_buffer_size(self, size): def audio_buffer_size(self): return self._core.getAudioBufferSize(self._core) - @protected - def get_audio_channels(self): - return audio.StereoBuffer(self.get_audio_channel(0), self.get_audio_channel(1)); - - @protected - def get_audio_channel(self, channel): - return audio.Buffer(self._core.getAudioChannel(self._core, channel), self.frequency) - @protected def reset(self): self._core.reset(self._core) diff --git a/src/platform/qt/AudioDevice.cpp b/src/platform/qt/AudioDevice.cpp index ec6dd31333b..bf027cd43e8 100644 --- a/src/platform/qt/AudioDevice.cpp +++ b/src/platform/qt/AudioDevice.cpp @@ -7,11 +7,12 @@ #include "LogController.h" -#include #include #include #include +#include + using namespace QGBA; AudioDevice::AudioDevice(QObject* parent) @@ -19,6 +20,13 @@ AudioDevice::AudioDevice(QObject* parent) , m_context(nullptr) { setOpenMode(ReadOnly); + mAudioBufferInit(&m_buffer, 0x4000, 2); + mAudioResamplerInit(&m_resampler, mINTERPOLATOR_SINC); +} + +AudioDevice::~AudioDevice() { + mAudioResamplerDeinit(&m_resampler); + mAudioBufferDeinit(&m_buffer); } void AudioDevice::setFormat(const QAudioFormat& format) { @@ -26,15 +34,18 @@ void AudioDevice::setFormat(const QAudioFormat& format) { LOG(QT, INFO) << tr("Can't set format of context-less audio device"); return; } - double fauxClock = mCoreCalculateFramerateRatio(m_context->core, m_context->impl->sync.fpsTarget); mCoreSyncLockAudio(&m_context->impl->sync); - blip_set_rates(m_context->core->getAudioChannel(m_context->core, 0), - m_context->core->frequency(m_context->core), format.sampleRate() * fauxClock); - blip_set_rates(m_context->core->getAudioChannel(m_context->core, 1), - m_context->core->frequency(m_context->core), format.sampleRate() * fauxClock); + mCore* core = m_context->core; + mAudioResamplerSetSource(&m_resampler, core->getAudioBuffer(core), core->audioSampleRate(core), true); + m_format = format; + adjustResampler(); mCoreSyncUnlockAudio(&m_context->impl->sync); } +void AudioDevice::setBufferSamples(int samples) { + m_samples = samples; +} + void AudioDevice::setInput(mCoreThread* input) { m_context = input; } @@ -45,15 +56,25 @@ qint64 AudioDevice::readData(char* data, qint64 maxSize) { return 0; } - maxSize /= sizeof(mStereoSample); + if (!maxSize) { + return 0; + } + mCoreSyncLockAudio(&m_context->impl->sync); - int available = std::min({ - blip_samples_avail(m_context->core->getAudioChannel(m_context->core, 0)), - maxSize, + mAudioResamplerProcess(&m_resampler); + if (mAudioBufferAvailable(&m_buffer) < 128) { + mCoreSyncConsumeAudio(&m_context->impl->sync); + // Audio is running slow...let's wait a tiny bit for more to come in + QThread::usleep(100); + mCoreSyncLockAudio(&m_context->impl->sync); + mAudioResamplerProcess(&m_resampler); + } + quint64 available = std::min({ + mAudioBufferAvailable(&m_buffer), + static_cast(maxSize / sizeof(mStereoSample)), std::numeric_limits::max() }); - blip_read_samples(m_context->core->getAudioChannel(m_context->core, 0), &reinterpret_cast(data)->left, available, true); - blip_read_samples(m_context->core->getAudioChannel(m_context->core, 1), &reinterpret_cast(data)->right, available, true); + mAudioBufferRead(&m_buffer, reinterpret_cast(data), available); mCoreSyncConsumeAudio(&m_context->impl->sync); return available * sizeof(mStereoSample); } @@ -64,15 +85,33 @@ qint64 AudioDevice::writeData(const char*, qint64) { } bool AudioDevice::atEnd() const { - return !bytesAvailable(); + return false; } qint64 AudioDevice::bytesAvailable() const { + if (!m_context->core) { + return true; + } + int available = mAudioBufferAvailable(&m_buffer); + return available * sizeof(mStereoSample); +} + +qint64 AudioDevice::bytesAvailable() { if (!m_context->core) { return true; } mCoreSyncLockAudio(&m_context->impl->sync); - int available = blip_samples_avail(m_context->core->getAudioChannel(m_context->core, 0)); + adjustResampler(); + mAudioResamplerProcess(&m_resampler); + int available = mAudioBufferAvailable(&m_buffer); mCoreSyncUnlockAudio(&m_context->impl->sync); return available * sizeof(mStereoSample); } + +void AudioDevice::adjustResampler() { + mCore* core = m_context->core; + double fauxClock = mCoreCalculateFramerateRatio(m_context->core, m_context->impl->sync.fpsTarget); + mAudioResamplerSetDestination(&m_resampler, &m_buffer, m_format.sampleRate() * fauxClock); + m_context->impl->sync.audioHighWater = m_samples + m_resampler.highWaterMark + m_resampler.lowWaterMark; + m_context->impl->sync.audioHighWater *= core->audioSampleRate(core) / (m_format.sampleRate() * fauxClock); +} diff --git a/src/platform/qt/AudioDevice.h b/src/platform/qt/AudioDevice.h index e4386bda293..04247cf9894 100644 --- a/src/platform/qt/AudioDevice.h +++ b/src/platform/qt/AudioDevice.h @@ -8,6 +8,9 @@ #include #include +#include +#include + struct mCoreThread; namespace QGBA { @@ -17,18 +20,28 @@ Q_OBJECT public: AudioDevice(QObject* parent = nullptr); + virtual ~AudioDevice(); void setInput(mCoreThread* input); void setFormat(const QAudioFormat& format); + void setBufferSamples(int samples); bool atEnd() const override; qint64 bytesAvailable() const override; + qint64 bytesAvailable(); + bool isSequential() const override { return true; } protected: virtual qint64 readData(char* data, qint64 maxSize) override; virtual qint64 writeData(const char* data, qint64 maxSize) override; private: + size_t m_samples = 512; + QAudioFormat m_format; mCoreThread* m_context; + mAudioBuffer m_buffer; + mAudioResampler m_resampler; + + void adjustResampler(); }; } diff --git a/src/platform/qt/AudioProcessorQt.cpp b/src/platform/qt/AudioProcessorQt.cpp index 3e4c5474ec8..87ad5b5ac19 100644 --- a/src/platform/qt/AudioProcessorQt.cpp +++ b/src/platform/qt/AudioProcessorQt.cpp @@ -83,6 +83,7 @@ bool AudioProcessorQt::start() { if (state != QAudio::IdleState) { return; } + recheckUnderflow(); m_recheckTimer.start(); }); #endif @@ -91,6 +92,7 @@ bool AudioProcessorQt::start() { if (m_audioOutput->state() == QAudio::SuspendedState) { m_audioOutput->resume(); } else { + m_device->setBufferSamples(m_samples); m_device->setInput(input()); m_device->setFormat(m_audioOutput->format()); m_audioOutput->start(m_device.get()); @@ -107,12 +109,17 @@ void AudioProcessorQt::pause() { } } -void AudioProcessorQt::setBufferSamples(int) { +void AudioProcessorQt::setBufferSamples(int samples) { + m_samples = samples; + if (m_device) { + m_device->setBufferSamples(samples); + } } void AudioProcessorQt::inputParametersChanged() { if (m_device) { m_device->setFormat(m_audioOutput->format()); + m_device->setBufferSamples(m_samples); } } @@ -138,7 +145,7 @@ void AudioProcessorQt::recheckUnderflow() { m_recheckTimer.stop(); return; } - if (!m_device->atEnd()) { + if (m_device->bytesAvailable()) { start(); m_recheckTimer.stop(); } diff --git a/src/platform/qt/AudioProcessorQt.h b/src/platform/qt/AudioProcessorQt.h index bdfa17a7701..bc01a8c07df 100644 --- a/src/platform/qt/AudioProcessorQt.h +++ b/src/platform/qt/AudioProcessorQt.h @@ -51,6 +51,7 @@ private slots: std::unique_ptr m_audioOutput; #endif std::unique_ptr m_device; + size_t m_samples = 1024; unsigned m_sampleRate = 44100; }; diff --git a/src/platform/sdl/sdl-audio.c b/src/platform/sdl/sdl-audio.c index ff7ddd2dacb..d90ad95d342 100644 --- a/src/platform/sdl/sdl-audio.c +++ b/src/platform/sdl/sdl-audio.c @@ -7,12 +7,6 @@ #include #include -#include -#include - -#include - -#define BUFFER_SIZE (GBA_AUDIO_SAMPLES >> 2) mLOG_DEFINE_CATEGORY(SDL_AUDIO, "SDL Audio", "platform.sdl.audio"); @@ -47,6 +41,10 @@ bool mSDLInitAudio(struct mSDLAudio* context, struct mCoreThread* threadContext) } context->core = 0; + mAudioBufferInit(&context->buffer, context->samples, context->obtainedSpec.channels); + mAudioResamplerInit(&context->resampler, mINTERPOLATOR_SINC); + mAudioResamplerSetDestination(&context->resampler, &context->buffer, context->obtainedSpec.freq); + if (threadContext) { context->core = threadContext->core; context->sync = &threadContext->impl->sync; @@ -70,6 +68,8 @@ void mSDLDeinitAudio(struct mSDLAudio* context) { SDL_PauseAudio(1); SDL_CloseAudio(); #endif + mAudioBufferDeinit(&context->buffer); + mAudioResamplerDeinit(&context->resampler); SDL_QuitSubSystem(SDL_INIT_AUDIO); } @@ -97,13 +97,11 @@ static void _mSDLAudioCallback(void* context, Uint8* data, int len) { memset(data, 0, len); return; } - blip_t* left = NULL; - blip_t* right = NULL; - int32_t clockRate = 1; + struct mAudioBuffer* buffer = NULL; + unsigned sampleRate = 32768; if (audioContext->core) { - clockRate = audioContext->core->frequency(audioContext->core); - left = audioContext->core->getAudioChannel(audioContext->core, 0); - right = audioContext->core->getAudioChannel(audioContext->core, 1); + buffer = audioContext->core->getAudioBuffer(audioContext->core); + sampleRate = audioContext->core->audioSampleRate(audioContext->core); } double fauxClock = 1; if (audioContext->sync) { @@ -111,18 +109,13 @@ static void _mSDLAudioCallback(void* context, Uint8* data, int len) { fauxClock = mCoreCalculateFramerateRatio(audioContext->core, audioContext->sync->fpsTarget); } mCoreSyncLockAudio(audioContext->sync); + audioContext->sync->audioHighWater = audioContext->samples + audioContext->resampler.highWaterMark + audioContext->resampler.lowWaterMark; + audioContext->sync->audioHighWater *= sampleRate / (fauxClock * audioContext->obtainedSpec.freq); } - blip_set_rates(left, clockRate, audioContext->obtainedSpec.freq * fauxClock); - blip_set_rates(right, clockRate, audioContext->obtainedSpec.freq * fauxClock); + mAudioResamplerSetSource(&audioContext->resampler, buffer, sampleRate / fauxClock, true); + mAudioResamplerProcess(&audioContext->resampler); len /= 2 * audioContext->obtainedSpec.channels; - int available = blip_samples_avail(left); - if (available > len) { - available = len; - } - blip_read_samples(left, (short*) data, available, audioContext->obtainedSpec.channels == 2); - if (audioContext->obtainedSpec.channels == 2) { - blip_read_samples(right, ((short*) data) + 1, available, 1); - } + int available = mAudioBufferRead(&audioContext->buffer, (int16_t*) data, len); if (audioContext->sync) { mCoreSyncConsumeAudio(audioContext->sync); diff --git a/src/platform/sdl/sdl-audio.h b/src/platform/sdl/sdl-audio.h index 2ae920af408..b8fa00c85ef 100644 --- a/src/platform/sdl/sdl-audio.h +++ b/src/platform/sdl/sdl-audio.h @@ -11,6 +11,8 @@ CXX_GUARD_START #include +#include +#include #include // Altivec sometimes defines this @@ -30,6 +32,8 @@ struct mSDLAudio { unsigned sampleRate; // State + struct mAudioBuffer buffer; + struct mAudioResampler resampler; SDL_AudioSpec desiredSpec; SDL_AudioSpec obtainedSpec; #if SDL_VERSION_ATLEAST(2, 0, 0) diff --git a/src/platform/switch/main.c b/src/platform/switch/main.c index 0dc866dfd1b..8307f981173 100644 --- a/src/platform/switch/main.c +++ b/src/platform/switch/main.c @@ -4,7 +4,6 @@ * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include "feature/gui/gui-runner.h" -#include #include #include #include @@ -305,9 +304,6 @@ static void _setup(struct mGUIRunner* runner) { u32 samplerate = runner->core->audioSampleRate(runner->core); double ratio = mCoreCalculateFramerateRatio(runner->core, 60.0); - blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), samplerate); - blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), samplerate); - audrvVoiceInit(&audrenDriver, 0, 2, PcmFormat_Int16, samplerate / ratio); audrvVoiceSetDestinationMix(&audrenDriver, 0, AUDREN_FINAL_MIX_ID); audrvVoiceSetMixFactor(&audrenDriver, 0, 1.0f, 0, 0); @@ -576,7 +572,7 @@ static bool _running(struct mGUIRunner* runner) { return appletMainLoop(); } -static void _postAudioBuffer(struct mAVStream* stream, blip_t* left, blip_t* right) { +static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buffer) { UNUSED(stream); int i; while (true) { @@ -590,15 +586,13 @@ static void _postAudioBuffer(struct mAVStream* stream, blip_t* left, blip_t* rig break; } if (!frameLimiter) { - blip_clear(left); - blip_clear(right); + mAudioBufferClear(buffer); return; } audrenWaitFrame(); } struct mStereoSample* samples = audioBuffer[i]; - blip_read_samples(left, &samples[0].left, SAMPLES, true); - blip_read_samples(right, &samples[0].right, SAMPLES, true); + mAudioBufferRead(buffer, (int16_t*) samples, SAMPLES); armDCacheFlush(samples, SAMPLES * sizeof(struct mStereoSample)); audrvVoiceAddWaveBuf(&audrenDriver, 0, &audrvBuffer[i]); diff --git a/src/platform/test/fuzz-main.c b/src/platform/test/fuzz-main.c index eb42b449b2c..af3bcf0833e 100644 --- a/src/platform/test/fuzz-main.c +++ b/src/platform/test/fuzz-main.c @@ -3,7 +3,6 @@ * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include #include #include #include @@ -153,9 +152,6 @@ int main(int argc, char** argv) { savestate = 0; } - blip_set_rates(core->getAudioChannel(core, 0), core->frequency(core), 0x8000); - blip_set_rates(core->getAudioChannel(core, 1), core->frequency(core), 0x8000); - _fuzzRunloop(core, fuzzOpts.frames); if (hasDebugger) { @@ -188,8 +184,7 @@ static void _fuzzRunloop(struct mCore* core, int frames) { do { core->runFrame(core); --frames; - blip_clear(core->getAudioChannel(core, 0)); - blip_clear(core->getAudioChannel(core, 1)); + mAudioBufferClear(core->getAudioBuffer(core)); } while (frames > 0 && !_dispatchExiting); } diff --git a/src/platform/test/perf-main.c b/src/platform/test/perf-main.c index 6682052969c..38d50b30c19 100644 --- a/src/platform/test/perf-main.c +++ b/src/platform/test/perf-main.c @@ -3,7 +3,6 @@ * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include #include #include #include diff --git a/src/platform/wii/main.c b/src/platform/wii/main.c index 4e955a0ad30..f21c7e19b9d 100644 --- a/src/platform/wii/main.c +++ b/src/platform/wii/main.c @@ -14,13 +14,13 @@ #include -#include #include #include "feature/gui/gui-runner.h" #include #include #include #include +#include #include #include #include @@ -76,7 +76,7 @@ static enum VideoMode { static void _retraceCallback(u32 count); -static void _postAudioBuffer(struct mAVStream* stream, blip_t* left, blip_t* right); +static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer*); static void _audioDMA(void); static void _setRumble(struct mRumble* rumble, int enable); static void _sampleRotation(struct mRotationSource* source); @@ -141,12 +141,14 @@ static void* framebuffer[2] = { 0, 0 }; static int whichFb = 0; static struct AudioBuffer { - struct mStereoSample samples[SAMPLES] __attribute__((__aligned__(32))); - volatile size_t size; -} audioBuffer[BUFFERS] = {0}; + int16_t samples[SAMPLES * 2] __attribute__((__aligned__(32))); + volatile bool full; +} audioBuffers[BUFFERS] = {0}; +static struct mAudioBuffer audioBuffer; static volatile int currentAudioBuffer = 0; static volatile int nextAudioBuffer = 0; static double audioSampleRate = 60.0 / 1.001; +static struct mAudioResampler resampler; static struct GUIFont* font; @@ -246,11 +248,6 @@ static void reconfigureScreen(struct mGUIRunner* runner) { if (runner) { runner->params.width = vmode->fbWidth * guiScale * wAdjust; runner->params.height = vmode->efbHeight * guiScale * hAdjust; - if (runner->core) { - double ratio = mCoreCalculateFramerateRatio(runner->core, audioSampleRate); - blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), 48000 * ratio); - blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), 48000 * ratio); - } } } @@ -269,7 +266,10 @@ int main(int argc, char* argv[]) { AUDIO_SetDSPSampleRate(AI_SAMPLERATE_48KHZ); AUDIO_RegisterDMACallback(_audioDMA); - memset(audioBuffer, 0, sizeof(audioBuffer)); + memset(audioBuffers, 0, sizeof(audioBuffers)); + mAudioBufferInit(&audioBuffer, SAMPLES * BUFFERS, 2); + mAudioResamplerInit(&resampler, mINTERPOLATOR_COSINE); + mAudioResamplerSetDestination(&resampler, &audioBuffer, 48000); #ifdef FIXED_ROM_BUFFER romBufferSize = GBA_SIZE_ROM0; romBuffer = SYS_GetArena2Lo(); @@ -663,6 +663,9 @@ int main(int argc, char* argv[]) { VIDEO_WaitVSync(); mGUIDeinit(&runner); + mAudioResamplerDeinit(&resampler); + mAudioBufferDeinit(&audioBuffer); + free(fifo); free(texmem); free(rescaleTexmem); @@ -678,41 +681,38 @@ int main(int argc, char* argv[]) { } static void _audioDMA(void) { - struct AudioBuffer* buffer = &audioBuffer[currentAudioBuffer]; - if (buffer->size != SAMPLES) { + struct AudioBuffer* buffer = &audioBuffers[currentAudioBuffer]; + if (!buffer->full) { + printf("Recv %i %i%s", currentAudioBuffer, buffer->full, buffer->full ? "" : "!"); return; } DCFlushRange(buffer->samples, SAMPLES * sizeof(struct mStereoSample)); AUDIO_InitDMA((u32) buffer->samples, SAMPLES * sizeof(struct mStereoSample)); - buffer->size = 0; + buffer->full = false; currentAudioBuffer = (currentAudioBuffer + 1) % BUFFERS; } -static void _postAudioBuffer(struct mAVStream* stream, blip_t* left, blip_t* right) { +static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buf) { UNUSED(stream); - + UNUSED(buf); + mAudioResamplerProcess(&resampler); u32 level = 0; + bool gotAudio = false; _CPU_ISR_Disable(level); - struct AudioBuffer* buffer = &audioBuffer[nextAudioBuffer]; - int available = blip_samples_avail(left); - if (available + buffer->size > SAMPLES) { - available = SAMPLES - buffer->size; - } - if (available > 0) { - // These appear to be reversed for AUDIO_InitDMA - blip_read_samples(left, &buffer->samples[buffer->size].right, available, true); - blip_read_samples(right, &buffer->samples[buffer->size].left, available, true); - buffer->size += available; - } - if (buffer->size == SAMPLES) { - int next = (nextAudioBuffer + 1) % BUFFERS; - if ((currentAudioBuffer + BUFFERS - next) % BUFFERS != 1) { - nextAudioBuffer = next; - } - if (!AUDIO_GetDMAEnableFlag()) { - _audioDMA(); - AUDIO_StartDMA(); + while (mAudioBufferAvailable(&audioBuffer) >= SAMPLES) { + struct AudioBuffer* buffer = &audioBuffers[nextAudioBuffer]; + if (buffer->full) { + printf("Send %i %i%s", nextAudioBuffer, buffer->full, buffer->full ? "!!" : ""); + break; } + mAudioBufferRead(&audioBuffer, buffer->samples, SAMPLES); + buffer->full = true; + nextAudioBuffer = (nextAudioBuffer + 1) % BUFFERS; + gotAudio = true; + } + if (gotAudio && !AUDIO_GetDMAEnableFlag()) { + _audioDMA(); + AUDIO_StartDMA(); } _CPU_ISR_Restore(level); } @@ -1416,15 +1416,11 @@ void _setup(struct mGUIRunner* runner) { nextAudioBuffer = 0; currentAudioBuffer = 0; - int i; - for (i = 0; i < BUFFERS; ++i) { - audioBuffer[i].size = 0; - } + memset(audioBuffers, 0, sizeof(audioBuffers)); runner->core->setAudioBufferSize(runner->core, SAMPLES); double ratio = mCoreCalculateFramerateRatio(runner->core, audioSampleRate); - blip_set_rates(runner->core->getAudioChannel(runner->core, 0), runner->core->frequency(runner->core), 48000 * ratio); - blip_set_rates(runner->core->getAudioChannel(runner->core, 1), runner->core->frequency(runner->core), 48000 * ratio); + mAudioResamplerSetSource(&resampler, runner->core->getAudioBuffer(runner->core), runner->core->audioSampleRate(runner->core) / ratio, true); frameLimiter = true; } @@ -1433,6 +1429,7 @@ void _gameUnloaded(struct mGUIRunner* runner) { UNUSED(runner); AUDIO_StopDMA(); frameLimiter = true; + mAudioBufferClear(&audioBuffer); VIDEO_SetBlack(true); VIDEO_Flush(); VIDEO_WaitVSync(); From fa2fe8eed4fdf47766e8107b3a75ec5af762be9d Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 00:49:34 -0700 Subject: [PATCH 097/338] Third-Party: Remove blip_buf --- CMakeLists.txt | 4 +- README.md | 1 - README_DE.md | 1 - README_ES.md | 1 - README_ZH_CN.md | 1 - include/mgba/core/blip_buf.h | 72 ---- res/licenses/blip_buf.txt | 504 --------------------------- src/third-party/blip_buf/blip_buf.c | 344 ------------------ src/third-party/blip_buf/license.txt | 504 --------------------------- 9 files changed, 1 insertion(+), 1431 deletions(-) delete mode 100644 include/mgba/core/blip_buf.h delete mode 100644 res/licenses/blip_buf.txt delete mode 100644 src/third-party/blip_buf/blip_buf.c delete mode 100644 src/third-party/blip_buf/license.txt diff --git a/CMakeLists.txt b/CMakeLists.txt index 24caaaf9f32..d573b0c6c85 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -586,8 +586,6 @@ if(USE_FFMPEG) endif() endif() -list(APPEND THIRD_PARTY_SRC "${CMAKE_CURRENT_SOURCE_DIR}/src/third-party/blip_buf/blip_buf.c") - if(WANT_ZLIB AND NOT USE_ZLIB) set(SKIP_INSTALL_ALL ON) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/src/third-party/zlib zlib EXCLUDE_FROM_ALL) @@ -1085,7 +1083,7 @@ install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/include/mgba-util DESTINATION ${CM install(FILES ${CMAKE_CURRENT_BINARY_DIR}/include/mgba/flags.h DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/mgba COMPONENT ${BINARY_NAME}-dev) # Packaging -install(FILES ${CMAKE_CURRENT_SOURCE_DIR}/res/licenses/blip_buf.txt DESTINATION ${CMAKE_INSTALL_DOCDIR}/licenses COMPONENT ${BINARY_NAME}) +install(FILES DESTINATION ${CMAKE_INSTALL_DOCDIR}/licenses COMPONENT ${BINARY_NAME}) install(FILES ${CMAKE_CURRENT_SOURCE_DIR}/res/licenses/inih.txt DESTINATION ${CMAKE_INSTALL_DOCDIR}/licenses COMPONENT ${BINARY_NAME}) if(USE_DISCORD_RPC) install(FILES ${CMAKE_CURRENT_SOURCE_DIR}/res/licenses/discord-rpc.txt DESTINATION ${CMAKE_INSTALL_DOCDIR}/licenses COMPONENT ${BINARY_NAME}) diff --git a/README.md b/README.md index 78b69f255ed..d937fa0c9b7 100644 --- a/README.md +++ b/README.md @@ -260,7 +260,6 @@ mGBA is Copyright © 2013 – 2023 Jeffrey Pfau. It is distributed under the [Mo mGBA contains the following third-party libraries: - [inih](https://github.com/benhoyt/inih), which is copyright © 2009 – 2020 Ben Hoyt and used under a BSD 3-clause license. -- [blip-buf](https://code.google.com/archive/p/blip-buf), which is copyright © 2003 – 2009 Shay Green and used under a Lesser GNU Public License. - [LZMA SDK](http://www.7-zip.org/sdk.html), which is public domain. - [MurmurHash3](https://github.com/aappleby/smhasher) implementation by Austin Appleby, which is public domain. - [getopt for MSVC](https://github.com/skandhurkat/Getopt-for-Visual-Studio/), which is public domain. diff --git a/README_DE.md b/README_DE.md index 9b653c5d241..9a4066a0f02 100644 --- a/README_DE.md +++ b/README_DE.md @@ -247,7 +247,6 @@ Copyright für mGBA © 2013 – 2021 Jeffrey Pfau. mGBA wird unter der [Mozilla mGBA beinhaltet die folgenden Bibliotheken von Drittanbietern: - [inih](https://github.com/benhoyt/inih), Copyright © 2009 - 2020 Ben Hoyt, verwendet unter einer BSD 3-clause-Lizenz. -- [blip-buf](https://code.google.com/archive/b/blip-buf), Copyright © 2003 - 2009 Shay Green, verwendet unter einer Lesser GNU Public License. - [LZMA SDK](http://www.7-zip.org/sdk.html), Public Domain. - [MurmurHash3](https://github.com/aappleby/smhasher), Implementierung von Austin Appleby, Public Domain. - [getopt fot MSVC](https://github.com/skandhurkat/Getopt-for-Visual-Studio/), Public Domain. diff --git a/README_ES.md b/README_ES.md index f174e114c88..1a6d0b79784 100644 --- a/README_ES.md +++ b/README_ES.md @@ -247,7 +247,6 @@ mGBA es Copyright © 2013 – 2021 Jeffrey Pfau. Es distribuído bajo la [licenc mGBA contiene las siguientes bibliotecas de terceros: - [inih](https://github.com/benhoyt/inih), que es copyright © 2009 - 2020 Ben Hoyt y se utiliza bajo licencia de la cláusula 3 de BSD. -- [blip-buf](https://code.google.com/archive/p/blip-buf), que es copyright © 2003 - 2009 Shay Green y se usa bajo LGPL. - [LZMA SDK](http://www.7-zip.org/sdk.html), la cual está en el dominio público. - [MurmurHash3](https://github.com/aappleby/smhasher), implementación por Austin Appleby, la cual está en el dominio público. - [getopt for MSVC](https://github.com/skandhurkat/Getopt-for-Visual-Studio/), la cual está en el dominio público. diff --git a/README_ZH_CN.md b/README_ZH_CN.md index 757f1d0c6dc..ab725694c6e 100644 --- a/README_ZH_CN.md +++ b/README_ZH_CN.md @@ -245,7 +245,6 @@ mGBA ç‰ˆæƒ Â© 2013 – 2020 Jeffrey Pfau。基于 [Mozilla 公共许å¯è¯ç‰ˆ mGBA 包å«ä»¥ä¸‹ç¬¬ä¸‰æ–¹åº“: - [inih](https://github.com/benhoyt/inih)ï¼šç‰ˆæƒ Â© 2009 – 2020 Ben Hoyt,基于 BSD 3-clause 许å¯è¯ä½¿ç”¨ã€‚ -- [blip-buf](https://code.google.com/archive/p/blip-buf)ï¼šç‰ˆæƒ Â© 2003 – 2009 Shay Green,基于 Lesser GNU 公共许å¯è¯ä½¿ç”¨ã€‚ - [LZMA SDK](http://www.7-zip.org/sdk.html):属公有领域使用。 - [MurmurHash3](https://github.com/aappleby/smhasher):由 Austin Appleby 实施,属公有领域使用。 - [getopt for MSVC](https://github.com/skandhurkat/Getopt-for-Visual-Studio/):属公有领域使用。 diff --git a/include/mgba/core/blip_buf.h b/include/mgba/core/blip_buf.h deleted file mode 100644 index 22b0a3ec8cd..00000000000 --- a/include/mgba/core/blip_buf.h +++ /dev/null @@ -1,72 +0,0 @@ -/** \file -Sample buffer that resamples from input clock rate to output sample rate */ - -/* blip_buf 1.1.0 */ -#ifndef BLIP_BUF_H -#define BLIP_BUF_H - -#ifdef __cplusplus - extern "C" { -#endif - -/** First parameter of most functions is blip_t*, or const blip_t* if nothing -is changed. */ -typedef struct blip_t blip_t; - -/** Creates new buffer that can hold at most sample_count samples. Sets rates -so that there are blip_max_ratio clocks per sample. Returns pointer to new -buffer, or NULL if insufficient memory. */ -blip_t* blip_new( int sample_count ); - -/** Sets approximate input clock rate and output sample rate. For every -clock_rate input clocks, approximately sample_rate samples are generated. */ -void blip_set_rates( blip_t*, double clock_rate, double sample_rate ); - -enum { /** Maximum clock_rate/sample_rate ratio. For a given sample_rate, -clock_rate must not be greater than sample_rate*blip_max_ratio. */ -blip_max_ratio = 0x100000 }; - -/** Clears entire buffer. Afterwards, blip_samples_avail() == 0. */ -void blip_clear( blip_t* ); - -/** Adds positive/negative delta into buffer at specified clock time. */ -void blip_add_delta( blip_t*, unsigned int clock_time, int delta ); - -/** Same as blip_add_delta(), but uses faster, lower-quality synthesis. */ -void blip_add_delta_fast( blip_t*, unsigned int clock_time, int delta ); - -/** Length of time frame, in clocks, needed to make sample_count additional -samples available. */ -int blip_clocks_needed( const blip_t*, int sample_count ); - -enum { /** Maximum number of samples that can be generated from one time frame. */ -blip_max_frame = 4000 }; - -/** Makes input clocks before clock_duration available for reading as output -samples. Also begins new time frame at clock_duration, so that clock time 0 in -the new time frame specifies the same clock as clock_duration in the old time -frame specified. Deltas can have been added slightly past clock_duration (up to -however many clocks there are in two output samples). */ -void blip_end_frame( blip_t*, unsigned int clock_duration ); - -/** Number of buffered samples available for reading. */ -int blip_samples_avail( const blip_t* ); - -/** Reads and removes at most 'count' samples and writes them to 'out'. If -'stereo' is true, writes output to every other element of 'out', allowing easy -interleaving of two buffers into a stereo sample stream. Outputs 16-bit signed -samples. Returns number of samples actually read. */ -int blip_read_samples( blip_t*, short out [], int count, int stereo ); - -/** Frees buffer. No effect if NULL is passed. */ -void blip_delete( blip_t* ); - - -/* Deprecated */ -typedef blip_t blip_buffer_t; - -#ifdef __cplusplus - } -#endif - -#endif diff --git a/res/licenses/blip_buf.txt b/res/licenses/blip_buf.txt deleted file mode 100644 index 5faba9d48ce..00000000000 --- a/res/licenses/blip_buf.txt +++ /dev/null @@ -1,504 +0,0 @@ - GNU LESSER GENERAL PUBLIC LICENSE - Version 2.1, February 1999 - - Copyright (C) 1991, 1999 Free Software Foundation, Inc. - 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - Everyone is permitted to copy and distribute verbatim copies - of this license document, but changing it is not allowed. - -[This is the first released version of the Lesser GPL. It also counts - as the successor of the GNU Library Public License, version 2, hence - the version number 2.1.] - - Preamble - - The licenses for most software are designed to take away your -freedom to share and change it. By contrast, the GNU General Public -Licenses are intended to guarantee your freedom to share and change -free software--to make sure the software is free for all its users. - - This license, the Lesser General Public License, applies to some -specially designated software packages--typically libraries--of the -Free Software Foundation and other authors who decide to use it. You -can use it too, but we suggest you first think carefully about whether -this license or the ordinary General Public License is the better -strategy to use in any particular case, based on the explanations below. - - When we speak of free software, we are referring to freedom of use, -not price. Our General Public Licenses are designed to make sure that -you have the freedom to distribute copies of free software (and charge -for this service if you wish); that you receive source code or can get -it if you want it; that you can change the software and use pieces of -it in new free programs; and that you are informed that you can do -these things. - - To protect your rights, we need to make restrictions that forbid -distributors to deny you these rights or to ask you to surrender these -rights. These restrictions translate to certain responsibilities for -you if you distribute copies of the library or if you modify it. - - For example, if you distribute copies of the library, whether gratis -or for a fee, you must give the recipients all the rights that we gave -you. You must make sure that they, too, receive or can get the source -code. If you link other code with the library, you must provide -complete object files to the recipients, so that they can relink them -with the library after making changes to the library and recompiling -it. And you must show them these terms so they know their rights. - - We protect your rights with a two-step method: (1) we copyright the -library, and (2) we offer you this license, which gives you legal -permission to copy, distribute and/or modify the library. - - To protect each distributor, we want to make it very clear that -there is no warranty for the free library. Also, if the library is -modified by someone else and passed on, the recipients should know -that what they have is not the original version, so that the original -author's reputation will not be affected by problems that might be -introduced by others. - - Finally, software patents pose a constant threat to the existence of -any free program. We wish to make sure that a company cannot -effectively restrict the users of a free program by obtaining a -restrictive license from a patent holder. Therefore, we insist that -any patent license obtained for a version of the library must be -consistent with the full freedom of use specified in this license. - - Most GNU software, including some libraries, is covered by the -ordinary GNU General Public License. This license, the GNU Lesser -General Public License, applies to certain designated libraries, and -is quite different from the ordinary General Public License. We use -this license for certain libraries in order to permit linking those -libraries into non-free programs. - - When a program is linked with a library, whether statically or using -a shared library, the combination of the two is legally speaking a -combined work, a derivative of the original library. The ordinary -General Public License therefore permits such linking only if the -entire combination fits its criteria of freedom. The Lesser General -Public License permits more lax criteria for linking other code with -the library. - - We call this license the "Lesser" General Public License because it -does Less to protect the user's freedom than the ordinary General -Public License. It also provides other free software developers Less -of an advantage over competing non-free programs. These disadvantages -are the reason we use the ordinary General Public License for many -libraries. However, the Lesser license provides advantages in certain -special circumstances. - - For example, on rare occasions, there may be a special need to -encourage the widest possible use of a certain library, so that it becomes -a de-facto standard. To achieve this, non-free programs must be -allowed to use the library. A more frequent case is that a free -library does the same job as widely used non-free libraries. In this -case, there is little to gain by limiting the free library to free -software only, so we use the Lesser General Public License. - - In other cases, permission to use a particular library in non-free -programs enables a greater number of people to use a large body of -free software. For example, permission to use the GNU C Library in -non-free programs enables many more people to use the whole GNU -operating system, as well as its variant, the GNU/Linux operating -system. - - Although the Lesser General Public License is Less protective of the -users' freedom, it does ensure that the user of a program that is -linked with the Library has the freedom and the wherewithal to run -that program using a modified version of the Library. - - The precise terms and conditions for copying, distribution and -modification follow. Pay close attention to the difference between a -"work based on the library" and a "work that uses the library". The -former contains code derived from the library, whereas the latter must -be combined with the library in order to run. - - GNU LESSER GENERAL PUBLIC LICENSE - TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION - - 0. This License Agreement applies to any software library or other -program which contains a notice placed by the copyright holder or -other authorized party saying it may be distributed under the terms of -this Lesser General Public License (also called "this License"). -Each licensee is addressed as "you". - - A "library" means a collection of software functions and/or data -prepared so as to be conveniently linked with application programs -(which use some of those functions and data) to form executables. - - The "Library", below, refers to any such software library or work -which has been distributed under these terms. A "work based on the -Library" means either the Library or any derivative work under -copyright law: that is to say, a work containing the Library or a -portion of it, either verbatim or with modifications and/or translated -straightforwardly into another language. (Hereinafter, translation is -included without limitation in the term "modification".) - - "Source code" for a work means the preferred form of the work for -making modifications to it. For a library, complete source code means -all the source code for all modules it contains, plus any associated -interface definition files, plus the scripts used to control compilation -and installation of the library. - - Activities other than copying, distribution and modification are not -covered by this License; they are outside its scope. The act of -running a program using the Library is not restricted, and output from -such a program is covered only if its contents constitute a work based -on the Library (independent of the use of the Library in a tool for -writing it). Whether that is true depends on what the Library does -and what the program that uses the Library does. - - 1. You may copy and distribute verbatim copies of the Library's -complete source code as you receive it, in any medium, provided that -you conspicuously and appropriately publish on each copy an -appropriate copyright notice and disclaimer of warranty; keep intact -all the notices that refer to this License and to the absence of any -warranty; and distribute a copy of this License along with the -Library. - - You may charge a fee for the physical act of transferring a copy, -and you may at your option offer warranty protection in exchange for a -fee. - - 2. You may modify your copy or copies of the Library or any portion -of it, thus forming a work based on the Library, and copy and -distribute such modifications or work under the terms of Section 1 -above, provided that you also meet all of these conditions: - - a) The modified work must itself be a software library. - - b) You must cause the files modified to carry prominent notices - stating that you changed the files and the date of any change. - - c) You must cause the whole of the work to be licensed at no - charge to all third parties under the terms of this License. - - d) If a facility in the modified Library refers to a function or a - table of data to be supplied by an application program that uses - the facility, other than as an argument passed when the facility - is invoked, then you must make a good faith effort to ensure that, - in the event an application does not supply such function or - table, the facility still operates, and performs whatever part of - its purpose remains meaningful. - - (For example, a function in a library to compute square roots has - a purpose that is entirely well-defined independent of the - application. Therefore, Subsection 2d requires that any - application-supplied function or table used by this function must - be optional: if the application does not supply it, the square - root function must still compute square roots.) - -These requirements apply to the modified work as a whole. If -identifiable sections of that work are not derived from the Library, -and can be reasonably considered independent and separate works in -themselves, then this License, and its terms, do not apply to those -sections when you distribute them as separate works. But when you -distribute the same sections as part of a whole which is a work based -on the Library, the distribution of the whole must be on the terms of -this License, whose permissions for other licensees extend to the -entire whole, and thus to each and every part regardless of who wrote -it. - -Thus, it is not the intent of this section to claim rights or contest -your rights to work written entirely by you; rather, the intent is to -exercise the right to control the distribution of derivative or -collective works based on the Library. - -In addition, mere aggregation of another work not based on the Library -with the Library (or with a work based on the Library) on a volume of -a storage or distribution medium does not bring the other work under -the scope of this License. - - 3. You may opt to apply the terms of the ordinary GNU General Public -License instead of this License to a given copy of the Library. To do -this, you must alter all the notices that refer to this License, so -that they refer to the ordinary GNU General Public License, version 2, -instead of to this License. (If a newer version than version 2 of the -ordinary GNU General Public License has appeared, then you can specify -that version instead if you wish.) Do not make any other change in -these notices. - - Once this change is made in a given copy, it is irreversible for -that copy, so the ordinary GNU General Public License applies to all -subsequent copies and derivative works made from that copy. - - This option is useful when you wish to copy part of the code of -the Library into a program that is not a library. - - 4. You may copy and distribute the Library (or a portion or -derivative of it, under Section 2) in object code or executable form -under the terms of Sections 1 and 2 above provided that you accompany -it with the complete corresponding machine-readable source code, which -must be distributed under the terms of Sections 1 and 2 above on a -medium customarily used for software interchange. - - If distribution of object code is made by offering access to copy -from a designated place, then offering equivalent access to copy the -source code from the same place satisfies the requirement to -distribute the source code, even though third parties are not -compelled to copy the source along with the object code. - - 5. A program that contains no derivative of any portion of the -Library, but is designed to work with the Library by being compiled or -linked with it, is called a "work that uses the Library". Such a -work, in isolation, is not a derivative work of the Library, and -therefore falls outside the scope of this License. - - However, linking a "work that uses the Library" with the Library -creates an executable that is a derivative of the Library (because it -contains portions of the Library), rather than a "work that uses the -library". The executable is therefore covered by this License. -Section 6 states terms for distribution of such executables. - - When a "work that uses the Library" uses material from a header file -that is part of the Library, the object code for the work may be a -derivative work of the Library even though the source code is not. -Whether this is true is especially significant if the work can be -linked without the Library, or if the work is itself a library. The -threshold for this to be true is not precisely defined by law. - - If such an object file uses only numerical parameters, data -structure layouts and accessors, and small macros and small inline -functions (ten lines or less in length), then the use of the object -file is unrestricted, regardless of whether it is legally a derivative -work. (Executables containing this object code plus portions of the -Library will still fall under Section 6.) - - Otherwise, if the work is a derivative of the Library, you may -distribute the object code for the work under the terms of Section 6. -Any executables containing that work also fall under Section 6, -whether or not they are linked directly with the Library itself. - - 6. As an exception to the Sections above, you may also combine or -link a "work that uses the Library" with the Library to produce a -work containing portions of the Library, and distribute that work -under terms of your choice, provided that the terms permit -modification of the work for the customer's own use and reverse -engineering for debugging such modifications. - - You must give prominent notice with each copy of the work that the -Library is used in it and that the Library and its use are covered by -this License. You must supply a copy of this License. If the work -during execution displays copyright notices, you must include the -copyright notice for the Library among them, as well as a reference -directing the user to the copy of this License. Also, you must do one -of these things: - - a) Accompany the work with the complete corresponding - machine-readable source code for the Library including whatever - changes were used in the work (which must be distributed under - Sections 1 and 2 above); and, if the work is an executable linked - with the Library, with the complete machine-readable "work that - uses the Library", as object code and/or source code, so that the - user can modify the Library and then relink to produce a modified - executable containing the modified Library. (It is understood - that the user who changes the contents of definitions files in the - Library will not necessarily be able to recompile the application - to use the modified definitions.) - - b) Use a suitable shared library mechanism for linking with the - Library. A suitable mechanism is one that (1) uses at run time a - copy of the library already present on the user's computer system, - rather than copying library functions into the executable, and (2) - will operate properly with a modified version of the library, if - the user installs one, as long as the modified version is - interface-compatible with the version that the work was made with. - - c) Accompany the work with a written offer, valid for at - least three years, to give the same user the materials - specified in Subsection 6a, above, for a charge no more - than the cost of performing this distribution. - - d) If distribution of the work is made by offering access to copy - from a designated place, offer equivalent access to copy the above - specified materials from the same place. - - e) Verify that the user has already received a copy of these - materials or that you have already sent this user a copy. - - For an executable, the required form of the "work that uses the -Library" must include any data and utility programs needed for -reproducing the executable from it. However, as a special exception, -the materials to be distributed need not include anything that is -normally distributed (in either source or binary form) with the major -components (compiler, kernel, and so on) of the operating system on -which the executable runs, unless that component itself accompanies -the executable. - - It may happen that this requirement contradicts the license -restrictions of other proprietary libraries that do not normally -accompany the operating system. Such a contradiction means you cannot -use both them and the Library together in an executable that you -distribute. - - 7. You may place library facilities that are a work based on the -Library side-by-side in a single library together with other library -facilities not covered by this License, and distribute such a combined -library, provided that the separate distribution of the work based on -the Library and of the other library facilities is otherwise -permitted, and provided that you do these two things: - - a) Accompany the combined library with a copy of the same work - based on the Library, uncombined with any other library - facilities. This must be distributed under the terms of the - Sections above. - - b) Give prominent notice with the combined library of the fact - that part of it is a work based on the Library, and explaining - where to find the accompanying uncombined form of the same work. - - 8. You may not copy, modify, sublicense, link with, or distribute -the Library except as expressly provided under this License. Any -attempt otherwise to copy, modify, sublicense, link with, or -distribute the Library is void, and will automatically terminate your -rights under this License. However, parties who have received copies, -or rights, from you under this License will not have their licenses -terminated so long as such parties remain in full compliance. - - 9. You are not required to accept this License, since you have not -signed it. However, nothing else grants you permission to modify or -distribute the Library or its derivative works. These actions are -prohibited by law if you do not accept this License. Therefore, by -modifying or distributing the Library (or any work based on the -Library), you indicate your acceptance of this License to do so, and -all its terms and conditions for copying, distributing or modifying -the Library or works based on it. - - 10. Each time you redistribute the Library (or any work based on the -Library), the recipient automatically receives a license from the -original licensor to copy, distribute, link with or modify the Library -subject to these terms and conditions. You may not impose any further -restrictions on the recipients' exercise of the rights granted herein. -You are not responsible for enforcing compliance by third parties with -this License. - - 11. If, as a consequence of a court judgment or allegation of patent -infringement or for any other reason (not limited to patent issues), -conditions are imposed on you (whether by court order, agreement or -otherwise) that contradict the conditions of this License, they do not -excuse you from the conditions of this License. If you cannot -distribute so as to satisfy simultaneously your obligations under this -License and any other pertinent obligations, then as a consequence you -may not distribute the Library at all. For example, if a patent -license would not permit royalty-free redistribution of the Library by -all those who receive copies directly or indirectly through you, then -the only way you could satisfy both it and this License would be to -refrain entirely from distribution of the Library. - -If any portion of this section is held invalid or unenforceable under any -particular circumstance, the balance of the section is intended to apply, -and the section as a whole is intended to apply in other circumstances. - -It is not the purpose of this section to induce you to infringe any -patents or other property right claims or to contest validity of any -such claims; this section has the sole purpose of protecting the -integrity of the free software distribution system which is -implemented by public license practices. Many people have made -generous contributions to the wide range of software distributed -through that system in reliance on consistent application of that -system; it is up to the author/donor to decide if he or she is willing -to distribute software through any other system and a licensee cannot -impose that choice. - -This section is intended to make thoroughly clear what is believed to -be a consequence of the rest of this License. - - 12. If the distribution and/or use of the Library is restricted in -certain countries either by patents or by copyrighted interfaces, the -original copyright holder who places the Library under this License may add -an explicit geographical distribution limitation excluding those countries, -so that distribution is permitted only in or among countries not thus -excluded. In such case, this License incorporates the limitation as if -written in the body of this License. - - 13. The Free Software Foundation may publish revised and/or new -versions of the Lesser General Public License from time to time. -Such new versions will be similar in spirit to the present version, -but may differ in detail to address new problems or concerns. - -Each version is given a distinguishing version number. If the Library -specifies a version number of this License which applies to it and -"any later version", you have the option of following the terms and -conditions either of that version or of any later version published by -the Free Software Foundation. If the Library does not specify a -license version number, you may choose any version ever published by -the Free Software Foundation. - - 14. If you wish to incorporate parts of the Library into other free -programs whose distribution conditions are incompatible with these, -write to the author to ask for permission. For software which is -copyrighted by the Free Software Foundation, write to the Free -Software Foundation; we sometimes make exceptions for this. Our -decision will be guided by the two goals of preserving the free status -of all derivatives of our free software and of promoting the sharing -and reuse of software generally. - - NO WARRANTY - - 15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO -WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. -EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR -OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY -KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR -PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE -LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME -THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. - - 16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN -WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY -AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU -FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR -CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE -LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING -RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A -FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF -SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH -DAMAGES. - - END OF TERMS AND CONDITIONS - - How to Apply These Terms to Your New Libraries - - If you develop a new library, and you want it to be of the greatest -possible use to the public, we recommend making it free software that -everyone can redistribute and change. You can do so by permitting -redistribution under these terms (or, alternatively, under the terms of the -ordinary General Public License). - - To apply these terms, attach the following notices to the library. It is -safest to attach them to the start of each source file to most effectively -convey the exclusion of warranty; and each file should have at least the -"copyright" line and a pointer to where the full notice is found. - - - Copyright (C) - - This library is free software; you can redistribute it and/or - modify it under the terms of the GNU Lesser General Public - License as published by the Free Software Foundation; either - version 2.1 of the License, or (at your option) any later version. - - This library is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - Lesser General Public License for more details. - - You should have received a copy of the GNU Lesser General Public - License along with this library; if not, write to the Free Software - Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - -Also add information on how to contact you by electronic and paper mail. - -You should also get your employer (if you work as a programmer) or your -school, if any, to sign a "copyright disclaimer" for the library, if -necessary. Here is a sample; alter the names: - - Yoyodyne, Inc., hereby disclaims all copyright interest in the - library `Frob' (a library for tweaking knobs) written by James Random Hacker. - - , 1 April 1990 - Ty Coon, President of Vice - -That's all there is to it! - - diff --git a/src/third-party/blip_buf/blip_buf.c b/src/third-party/blip_buf/blip_buf.c deleted file mode 100644 index 6bc7da8bd05..00000000000 --- a/src/third-party/blip_buf/blip_buf.c +++ /dev/null @@ -1,344 +0,0 @@ -/* blip_buf 1.1.0. http://www.slack.net/~ant/ */ - -#include - -#include -#include -#include -#include - -/* Library Copyright (C) 2003-2009 Shay Green. This library is free software; -you can redistribute it and/or modify it under the terms of the GNU Lesser -General Public License as published by the Free Software Foundation; either -version 2.1 of the License, or (at your option) any later version. This -library is distributed in the hope that it will be useful, but WITHOUT ANY -WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR -A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more -details. You should have received a copy of the GNU Lesser General Public -License along with this module; if not, write to the Free Software Foundation, -Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ - -#if defined (BLARGG_TEST) && BLARGG_TEST - #include "blargg_test.h" -#endif - -/* Equivalent to ULONG_MAX >= 0xFFFFFFFF00000000. -Avoids constants that don't fit in 32 bits. */ -#if ULONG_MAX/0xFFFFFFFF > 0xFFFFFFFF - typedef unsigned long fixed_t; - enum { pre_shift = 32 }; - -#elif defined(ULLONG_MAX) - typedef unsigned long long fixed_t; - enum { pre_shift = 32 }; - -#else - typedef unsigned fixed_t; - enum { pre_shift = 0 }; - -#endif - -enum { time_bits = pre_shift + 20 }; - -static fixed_t const time_unit = (fixed_t) 1 << time_bits; - -enum { bass_shift = 9 }; /* affects high-pass filter breakpoint frequency */ -enum { end_frame_extra = 2 }; /* allows deltas slightly after frame length */ - -enum { half_width = 8 }; -enum { buf_extra = half_width*2 + end_frame_extra }; -enum { phase_bits = 5 }; -enum { phase_count = 1 << phase_bits }; -enum { delta_bits = 15 }; -enum { delta_unit = 1 << delta_bits }; -enum { frac_bits = time_bits - pre_shift }; - -/* We could eliminate avail and encode whole samples in offset, but that would -limit the total buffered samples to blip_max_frame. That could only be -increased by decreasing time_bits, which would reduce resample ratio accuracy. -*/ - -/** Sample buffer that resamples to output rate and accumulates samples -until they're read out */ -struct blip_t -{ - fixed_t factor; - fixed_t offset; - int avail; - int size; - int integrator; -}; - -typedef int buf_t; - -/* probably not totally portable */ -#define SAMPLES( buf ) ((buf_t*) ((buf) + 1)) - -/* Arithmetic (sign-preserving) right shift */ -#define ARITH_SHIFT( n, shift ) \ - ((n) >> (shift)) - -enum { max_sample = +32767 }; -enum { min_sample = -32768 }; - -#define CLAMP( n ) \ - {\ - if ( (short) n != n )\ - n = ARITH_SHIFT( n, 16 ) ^ max_sample;\ - } - -static void check_assumptions( void ) -{ - int n; - - #if INT_MAX < 0x7FFFFFFF || UINT_MAX < 0xFFFFFFFF - #error "int must be at least 32 bits" - #endif - - assert( (-3 >> 1) == -2 ); /* right shift must preserve sign */ - - n = max_sample * 2; - CLAMP( n ); - assert( n == max_sample ); - - n = min_sample * 2; - CLAMP( n ); - assert( n == min_sample ); - - assert( blip_max_ratio <= time_unit ); - assert( blip_max_frame <= (fixed_t) -1 >> time_bits ); -} - -blip_t* blip_new( int size ) -{ - blip_t* m; - assert( size >= 0 ); - - m = (blip_t*) malloc( sizeof *m + (size + buf_extra) * sizeof (buf_t) ); - if ( m ) - { - m->factor = time_unit / blip_max_ratio; - m->size = size; - blip_clear( m ); - check_assumptions(); - } - return m; -} - -void blip_delete( blip_t* m ) -{ - if ( m != NULL ) - { - /* Clear fields in case user tries to use after freeing */ - memset( m, 0, sizeof *m ); - free( m ); - } -} - -void blip_set_rates( blip_t* m, double clock_rate, double sample_rate ) -{ - double factor = time_unit * sample_rate / clock_rate; - m->factor = (fixed_t) factor; - - /* Fails if clock_rate exceeds maximum, relative to sample_rate */ - assert( 0 <= factor - m->factor && factor - m->factor < 1 ); - - /* Avoid requiring math.h. Equivalent to - m->factor = (int) ceil( factor ) */ - if ( m->factor < factor ) - m->factor++; - - /* At this point, factor is most likely rounded up, but could still - have been rounded down in the floating-point calculation. */ -} - -void blip_clear( blip_t* m ) -{ - /* We could set offset to 0, factor/2, or factor-1. 0 is suitable if - factor is rounded up. factor-1 is suitable if factor is rounded down. - Since we don't know rounding direction, factor/2 accommodates either, - with the slight loss of showing an error in half the time. Since for - a 64-bit factor this is years, the halving isn't a problem. */ - - m->offset = m->factor / 2; - m->avail = 0; - m->integrator = 0; - memset( SAMPLES( m ), 0, (m->size + buf_extra) * sizeof (buf_t) ); -} - -int blip_clocks_needed( const blip_t* m, int samples ) -{ - fixed_t needed; - - /* Fails if buffer can't hold that many more samples */ - assert( samples >= 0 && m->avail + samples <= m->size ); - - needed = (fixed_t) samples * time_unit; - if ( needed < m->offset ) - return 0; - - return (needed - m->offset + m->factor - 1) / m->factor; -} - -void blip_end_frame( blip_t* m, unsigned t ) -{ - fixed_t off = t * m->factor + m->offset; - m->avail += off >> time_bits; - m->offset = off & (time_unit - 1); - - /* Fails if buffer size was exceeded */ - assert( m->avail <= m->size ); -} - -int blip_samples_avail( const blip_t* m ) -{ - return m->avail; -} - -static void remove_samples( blip_t* m, int count ) -{ - buf_t* buf = SAMPLES( m ); - int remain = m->avail + buf_extra - count; - m->avail -= count; - - memmove( &buf [0], &buf [count], remain * sizeof buf [0] ); - memset( &buf [remain], 0, count * sizeof buf [0] ); -} - -int blip_read_samples( blip_t* m, short out [], int count, int stereo ) -{ - assert( count >= 0 ); - - if ( count > m->avail ) - count = m->avail; - - if ( count ) - { - int const step = stereo ? 2 : 1; - buf_t const* in = SAMPLES( m ); - buf_t const* end = in + count; - int sum = m->integrator; - do - { - /* Eliminate fraction */ - int s = ARITH_SHIFT( sum, delta_bits ); - - sum += *in++; - - CLAMP( s ); - - *out = s; - out += step; - - /* High-pass filter */ - sum -= s << (delta_bits - bass_shift); - } - while ( in != end ); - m->integrator = sum; - - remove_samples( m, count ); - } - - return count; -} - -/* Things that didn't help performance on x86: - __attribute__((aligned(128))) - #define short int - restrict -*/ - -/* Sinc_Generator( 0.9, 0.55, 4.5 ) */ -static short const bl_step [phase_count + 1] [half_width] = -{ -{ 43, -115, 350, -488, 1136, -914, 5861,21022}, -{ 44, -118, 348, -473, 1076, -799, 5274,21001}, -{ 45, -121, 344, -454, 1011, -677, 4706,20936}, -{ 46, -122, 336, -431, 942, -549, 4156,20829}, -{ 47, -123, 327, -404, 868, -418, 3629,20679}, -{ 47, -122, 316, -375, 792, -285, 3124,20488}, -{ 47, -120, 303, -344, 714, -151, 2644,20256}, -{ 46, -117, 289, -310, 634, -17, 2188,19985}, -{ 46, -114, 273, -275, 553, 117, 1758,19675}, -{ 44, -108, 255, -237, 471, 247, 1356,19327}, -{ 43, -103, 237, -199, 390, 373, 981,18944}, -{ 42, -98, 218, -160, 310, 495, 633,18527}, -{ 40, -91, 198, -121, 231, 611, 314,18078}, -{ 38, -84, 178, -81, 153, 722, 22,17599}, -{ 36, -76, 157, -43, 80, 824, -241,17092}, -{ 34, -68, 135, -3, 8, 919, -476,16558}, -{ 32, -61, 115, 34, -60, 1006, -683,16001}, -{ 29, -52, 94, 70, -123, 1083, -862,15422}, -{ 27, -44, 73, 106, -184, 1152,-1015,14824}, -{ 25, -36, 53, 139, -239, 1211,-1142,14210}, -{ 22, -27, 34, 170, -290, 1261,-1244,13582}, -{ 20, -20, 16, 199, -335, 1301,-1322,12942}, -{ 18, -12, -3, 226, -375, 1331,-1376,12293}, -{ 15, -4, -19, 250, -410, 1351,-1408,11638}, -{ 13, 3, -35, 272, -439, 1361,-1419,10979}, -{ 11, 9, -49, 292, -464, 1362,-1410,10319}, -{ 9, 16, -63, 309, -483, 1354,-1383, 9660}, -{ 7, 22, -75, 322, -496, 1337,-1339, 9005}, -{ 6, 26, -85, 333, -504, 1312,-1280, 8355}, -{ 4, 31, -94, 341, -507, 1278,-1205, 7713}, -{ 3, 35, -102, 347, -506, 1238,-1119, 7082}, -{ 1, 40, -110, 350, -499, 1190,-1021, 6464}, -{ 0, 43, -115, 350, -488, 1136, -914, 5861} -}; - -/* Shifting by pre_shift allows calculation using unsigned int rather than -possibly-wider fixed_t. On 32-bit platforms, this is likely more efficient. -And by having pre_shift 32, a 32-bit platform can easily do the shift by -simply ignoring the low half. */ - -void blip_add_delta( blip_t* m, unsigned time, int delta ) -{ - unsigned fixed = (unsigned) ((time * m->factor + m->offset) >> pre_shift); - buf_t* out = SAMPLES( m ) + m->avail + (fixed >> frac_bits); - - int const phase_shift = frac_bits - phase_bits; - int phase = fixed >> phase_shift & (phase_count - 1); - short const* in = bl_step [phase]; - short const* rev = bl_step [phase_count - phase]; - - int interp = fixed >> (phase_shift - delta_bits) & (delta_unit - 1); - int delta2 = (delta * interp) >> delta_bits; - delta -= delta2; - - /* Fails if buffer size was exceeded */ - assert( out <= &SAMPLES( m ) [m->size + end_frame_extra] ); - - out [0] += in[0]*delta + in[half_width+0]*delta2; - out [1] += in[1]*delta + in[half_width+1]*delta2; - out [2] += in[2]*delta + in[half_width+2]*delta2; - out [3] += in[3]*delta + in[half_width+3]*delta2; - out [4] += in[4]*delta + in[half_width+4]*delta2; - out [5] += in[5]*delta + in[half_width+5]*delta2; - out [6] += in[6]*delta + in[half_width+6]*delta2; - out [7] += in[7]*delta + in[half_width+7]*delta2; - - in = rev; - out [ 8] += in[7]*delta + in[7-half_width]*delta2; - out [ 9] += in[6]*delta + in[6-half_width]*delta2; - out [10] += in[5]*delta + in[5-half_width]*delta2; - out [11] += in[4]*delta + in[4-half_width]*delta2; - out [12] += in[3]*delta + in[3-half_width]*delta2; - out [13] += in[2]*delta + in[2-half_width]*delta2; - out [14] += in[1]*delta + in[1-half_width]*delta2; - out [15] += in[0]*delta + in[0-half_width]*delta2; -} - -void blip_add_delta_fast( blip_t* m, unsigned time, int delta ) -{ - unsigned fixed = (unsigned) ((time * m->factor + m->offset) >> pre_shift); - buf_t* out = SAMPLES( m ) + m->avail + (fixed >> frac_bits); - - int interp = fixed >> (frac_bits - delta_bits) & (delta_unit - 1); - int delta2 = delta * interp; - - /* Fails if buffer size was exceeded */ - assert( out <= &SAMPLES( m ) [m->size + end_frame_extra] ); - - out [7] += delta * delta_unit - delta2; - out [8] += delta2; -} diff --git a/src/third-party/blip_buf/license.txt b/src/third-party/blip_buf/license.txt deleted file mode 100644 index 5faba9d48ce..00000000000 --- a/src/third-party/blip_buf/license.txt +++ /dev/null @@ -1,504 +0,0 @@ - GNU LESSER GENERAL PUBLIC LICENSE - Version 2.1, February 1999 - - Copyright (C) 1991, 1999 Free Software Foundation, Inc. - 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - Everyone is permitted to copy and distribute verbatim copies - of this license document, but changing it is not allowed. - -[This is the first released version of the Lesser GPL. It also counts - as the successor of the GNU Library Public License, version 2, hence - the version number 2.1.] - - Preamble - - The licenses for most software are designed to take away your -freedom to share and change it. By contrast, the GNU General Public -Licenses are intended to guarantee your freedom to share and change -free software--to make sure the software is free for all its users. - - This license, the Lesser General Public License, applies to some -specially designated software packages--typically libraries--of the -Free Software Foundation and other authors who decide to use it. You -can use it too, but we suggest you first think carefully about whether -this license or the ordinary General Public License is the better -strategy to use in any particular case, based on the explanations below. - - When we speak of free software, we are referring to freedom of use, -not price. Our General Public Licenses are designed to make sure that -you have the freedom to distribute copies of free software (and charge -for this service if you wish); that you receive source code or can get -it if you want it; that you can change the software and use pieces of -it in new free programs; and that you are informed that you can do -these things. - - To protect your rights, we need to make restrictions that forbid -distributors to deny you these rights or to ask you to surrender these -rights. These restrictions translate to certain responsibilities for -you if you distribute copies of the library or if you modify it. - - For example, if you distribute copies of the library, whether gratis -or for a fee, you must give the recipients all the rights that we gave -you. You must make sure that they, too, receive or can get the source -code. If you link other code with the library, you must provide -complete object files to the recipients, so that they can relink them -with the library after making changes to the library and recompiling -it. And you must show them these terms so they know their rights. - - We protect your rights with a two-step method: (1) we copyright the -library, and (2) we offer you this license, which gives you legal -permission to copy, distribute and/or modify the library. - - To protect each distributor, we want to make it very clear that -there is no warranty for the free library. Also, if the library is -modified by someone else and passed on, the recipients should know -that what they have is not the original version, so that the original -author's reputation will not be affected by problems that might be -introduced by others. - - Finally, software patents pose a constant threat to the existence of -any free program. We wish to make sure that a company cannot -effectively restrict the users of a free program by obtaining a -restrictive license from a patent holder. Therefore, we insist that -any patent license obtained for a version of the library must be -consistent with the full freedom of use specified in this license. - - Most GNU software, including some libraries, is covered by the -ordinary GNU General Public License. This license, the GNU Lesser -General Public License, applies to certain designated libraries, and -is quite different from the ordinary General Public License. We use -this license for certain libraries in order to permit linking those -libraries into non-free programs. - - When a program is linked with a library, whether statically or using -a shared library, the combination of the two is legally speaking a -combined work, a derivative of the original library. The ordinary -General Public License therefore permits such linking only if the -entire combination fits its criteria of freedom. The Lesser General -Public License permits more lax criteria for linking other code with -the library. - - We call this license the "Lesser" General Public License because it -does Less to protect the user's freedom than the ordinary General -Public License. It also provides other free software developers Less -of an advantage over competing non-free programs. These disadvantages -are the reason we use the ordinary General Public License for many -libraries. However, the Lesser license provides advantages in certain -special circumstances. - - For example, on rare occasions, there may be a special need to -encourage the widest possible use of a certain library, so that it becomes -a de-facto standard. To achieve this, non-free programs must be -allowed to use the library. A more frequent case is that a free -library does the same job as widely used non-free libraries. In this -case, there is little to gain by limiting the free library to free -software only, so we use the Lesser General Public License. - - In other cases, permission to use a particular library in non-free -programs enables a greater number of people to use a large body of -free software. For example, permission to use the GNU C Library in -non-free programs enables many more people to use the whole GNU -operating system, as well as its variant, the GNU/Linux operating -system. - - Although the Lesser General Public License is Less protective of the -users' freedom, it does ensure that the user of a program that is -linked with the Library has the freedom and the wherewithal to run -that program using a modified version of the Library. - - The precise terms and conditions for copying, distribution and -modification follow. Pay close attention to the difference between a -"work based on the library" and a "work that uses the library". The -former contains code derived from the library, whereas the latter must -be combined with the library in order to run. - - GNU LESSER GENERAL PUBLIC LICENSE - TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION - - 0. This License Agreement applies to any software library or other -program which contains a notice placed by the copyright holder or -other authorized party saying it may be distributed under the terms of -this Lesser General Public License (also called "this License"). -Each licensee is addressed as "you". - - A "library" means a collection of software functions and/or data -prepared so as to be conveniently linked with application programs -(which use some of those functions and data) to form executables. - - The "Library", below, refers to any such software library or work -which has been distributed under these terms. A "work based on the -Library" means either the Library or any derivative work under -copyright law: that is to say, a work containing the Library or a -portion of it, either verbatim or with modifications and/or translated -straightforwardly into another language. (Hereinafter, translation is -included without limitation in the term "modification".) - - "Source code" for a work means the preferred form of the work for -making modifications to it. For a library, complete source code means -all the source code for all modules it contains, plus any associated -interface definition files, plus the scripts used to control compilation -and installation of the library. - - Activities other than copying, distribution and modification are not -covered by this License; they are outside its scope. The act of -running a program using the Library is not restricted, and output from -such a program is covered only if its contents constitute a work based -on the Library (independent of the use of the Library in a tool for -writing it). Whether that is true depends on what the Library does -and what the program that uses the Library does. - - 1. You may copy and distribute verbatim copies of the Library's -complete source code as you receive it, in any medium, provided that -you conspicuously and appropriately publish on each copy an -appropriate copyright notice and disclaimer of warranty; keep intact -all the notices that refer to this License and to the absence of any -warranty; and distribute a copy of this License along with the -Library. - - You may charge a fee for the physical act of transferring a copy, -and you may at your option offer warranty protection in exchange for a -fee. - - 2. You may modify your copy or copies of the Library or any portion -of it, thus forming a work based on the Library, and copy and -distribute such modifications or work under the terms of Section 1 -above, provided that you also meet all of these conditions: - - a) The modified work must itself be a software library. - - b) You must cause the files modified to carry prominent notices - stating that you changed the files and the date of any change. - - c) You must cause the whole of the work to be licensed at no - charge to all third parties under the terms of this License. - - d) If a facility in the modified Library refers to a function or a - table of data to be supplied by an application program that uses - the facility, other than as an argument passed when the facility - is invoked, then you must make a good faith effort to ensure that, - in the event an application does not supply such function or - table, the facility still operates, and performs whatever part of - its purpose remains meaningful. - - (For example, a function in a library to compute square roots has - a purpose that is entirely well-defined independent of the - application. Therefore, Subsection 2d requires that any - application-supplied function or table used by this function must - be optional: if the application does not supply it, the square - root function must still compute square roots.) - -These requirements apply to the modified work as a whole. If -identifiable sections of that work are not derived from the Library, -and can be reasonably considered independent and separate works in -themselves, then this License, and its terms, do not apply to those -sections when you distribute them as separate works. But when you -distribute the same sections as part of a whole which is a work based -on the Library, the distribution of the whole must be on the terms of -this License, whose permissions for other licensees extend to the -entire whole, and thus to each and every part regardless of who wrote -it. - -Thus, it is not the intent of this section to claim rights or contest -your rights to work written entirely by you; rather, the intent is to -exercise the right to control the distribution of derivative or -collective works based on the Library. - -In addition, mere aggregation of another work not based on the Library -with the Library (or with a work based on the Library) on a volume of -a storage or distribution medium does not bring the other work under -the scope of this License. - - 3. You may opt to apply the terms of the ordinary GNU General Public -License instead of this License to a given copy of the Library. To do -this, you must alter all the notices that refer to this License, so -that they refer to the ordinary GNU General Public License, version 2, -instead of to this License. (If a newer version than version 2 of the -ordinary GNU General Public License has appeared, then you can specify -that version instead if you wish.) Do not make any other change in -these notices. - - Once this change is made in a given copy, it is irreversible for -that copy, so the ordinary GNU General Public License applies to all -subsequent copies and derivative works made from that copy. - - This option is useful when you wish to copy part of the code of -the Library into a program that is not a library. - - 4. You may copy and distribute the Library (or a portion or -derivative of it, under Section 2) in object code or executable form -under the terms of Sections 1 and 2 above provided that you accompany -it with the complete corresponding machine-readable source code, which -must be distributed under the terms of Sections 1 and 2 above on a -medium customarily used for software interchange. - - If distribution of object code is made by offering access to copy -from a designated place, then offering equivalent access to copy the -source code from the same place satisfies the requirement to -distribute the source code, even though third parties are not -compelled to copy the source along with the object code. - - 5. A program that contains no derivative of any portion of the -Library, but is designed to work with the Library by being compiled or -linked with it, is called a "work that uses the Library". Such a -work, in isolation, is not a derivative work of the Library, and -therefore falls outside the scope of this License. - - However, linking a "work that uses the Library" with the Library -creates an executable that is a derivative of the Library (because it -contains portions of the Library), rather than a "work that uses the -library". The executable is therefore covered by this License. -Section 6 states terms for distribution of such executables. - - When a "work that uses the Library" uses material from a header file -that is part of the Library, the object code for the work may be a -derivative work of the Library even though the source code is not. -Whether this is true is especially significant if the work can be -linked without the Library, or if the work is itself a library. The -threshold for this to be true is not precisely defined by law. - - If such an object file uses only numerical parameters, data -structure layouts and accessors, and small macros and small inline -functions (ten lines or less in length), then the use of the object -file is unrestricted, regardless of whether it is legally a derivative -work. (Executables containing this object code plus portions of the -Library will still fall under Section 6.) - - Otherwise, if the work is a derivative of the Library, you may -distribute the object code for the work under the terms of Section 6. -Any executables containing that work also fall under Section 6, -whether or not they are linked directly with the Library itself. - - 6. As an exception to the Sections above, you may also combine or -link a "work that uses the Library" with the Library to produce a -work containing portions of the Library, and distribute that work -under terms of your choice, provided that the terms permit -modification of the work for the customer's own use and reverse -engineering for debugging such modifications. - - You must give prominent notice with each copy of the work that the -Library is used in it and that the Library and its use are covered by -this License. You must supply a copy of this License. If the work -during execution displays copyright notices, you must include the -copyright notice for the Library among them, as well as a reference -directing the user to the copy of this License. Also, you must do one -of these things: - - a) Accompany the work with the complete corresponding - machine-readable source code for the Library including whatever - changes were used in the work (which must be distributed under - Sections 1 and 2 above); and, if the work is an executable linked - with the Library, with the complete machine-readable "work that - uses the Library", as object code and/or source code, so that the - user can modify the Library and then relink to produce a modified - executable containing the modified Library. (It is understood - that the user who changes the contents of definitions files in the - Library will not necessarily be able to recompile the application - to use the modified definitions.) - - b) Use a suitable shared library mechanism for linking with the - Library. A suitable mechanism is one that (1) uses at run time a - copy of the library already present on the user's computer system, - rather than copying library functions into the executable, and (2) - will operate properly with a modified version of the library, if - the user installs one, as long as the modified version is - interface-compatible with the version that the work was made with. - - c) Accompany the work with a written offer, valid for at - least three years, to give the same user the materials - specified in Subsection 6a, above, for a charge no more - than the cost of performing this distribution. - - d) If distribution of the work is made by offering access to copy - from a designated place, offer equivalent access to copy the above - specified materials from the same place. - - e) Verify that the user has already received a copy of these - materials or that you have already sent this user a copy. - - For an executable, the required form of the "work that uses the -Library" must include any data and utility programs needed for -reproducing the executable from it. However, as a special exception, -the materials to be distributed need not include anything that is -normally distributed (in either source or binary form) with the major -components (compiler, kernel, and so on) of the operating system on -which the executable runs, unless that component itself accompanies -the executable. - - It may happen that this requirement contradicts the license -restrictions of other proprietary libraries that do not normally -accompany the operating system. Such a contradiction means you cannot -use both them and the Library together in an executable that you -distribute. - - 7. You may place library facilities that are a work based on the -Library side-by-side in a single library together with other library -facilities not covered by this License, and distribute such a combined -library, provided that the separate distribution of the work based on -the Library and of the other library facilities is otherwise -permitted, and provided that you do these two things: - - a) Accompany the combined library with a copy of the same work - based on the Library, uncombined with any other library - facilities. This must be distributed under the terms of the - Sections above. - - b) Give prominent notice with the combined library of the fact - that part of it is a work based on the Library, and explaining - where to find the accompanying uncombined form of the same work. - - 8. You may not copy, modify, sublicense, link with, or distribute -the Library except as expressly provided under this License. Any -attempt otherwise to copy, modify, sublicense, link with, or -distribute the Library is void, and will automatically terminate your -rights under this License. However, parties who have received copies, -or rights, from you under this License will not have their licenses -terminated so long as such parties remain in full compliance. - - 9. You are not required to accept this License, since you have not -signed it. However, nothing else grants you permission to modify or -distribute the Library or its derivative works. These actions are -prohibited by law if you do not accept this License. Therefore, by -modifying or distributing the Library (or any work based on the -Library), you indicate your acceptance of this License to do so, and -all its terms and conditions for copying, distributing or modifying -the Library or works based on it. - - 10. Each time you redistribute the Library (or any work based on the -Library), the recipient automatically receives a license from the -original licensor to copy, distribute, link with or modify the Library -subject to these terms and conditions. You may not impose any further -restrictions on the recipients' exercise of the rights granted herein. -You are not responsible for enforcing compliance by third parties with -this License. - - 11. If, as a consequence of a court judgment or allegation of patent -infringement or for any other reason (not limited to patent issues), -conditions are imposed on you (whether by court order, agreement or -otherwise) that contradict the conditions of this License, they do not -excuse you from the conditions of this License. If you cannot -distribute so as to satisfy simultaneously your obligations under this -License and any other pertinent obligations, then as a consequence you -may not distribute the Library at all. For example, if a patent -license would not permit royalty-free redistribution of the Library by -all those who receive copies directly or indirectly through you, then -the only way you could satisfy both it and this License would be to -refrain entirely from distribution of the Library. - -If any portion of this section is held invalid or unenforceable under any -particular circumstance, the balance of the section is intended to apply, -and the section as a whole is intended to apply in other circumstances. - -It is not the purpose of this section to induce you to infringe any -patents or other property right claims or to contest validity of any -such claims; this section has the sole purpose of protecting the -integrity of the free software distribution system which is -implemented by public license practices. Many people have made -generous contributions to the wide range of software distributed -through that system in reliance on consistent application of that -system; it is up to the author/donor to decide if he or she is willing -to distribute software through any other system and a licensee cannot -impose that choice. - -This section is intended to make thoroughly clear what is believed to -be a consequence of the rest of this License. - - 12. If the distribution and/or use of the Library is restricted in -certain countries either by patents or by copyrighted interfaces, the -original copyright holder who places the Library under this License may add -an explicit geographical distribution limitation excluding those countries, -so that distribution is permitted only in or among countries not thus -excluded. In such case, this License incorporates the limitation as if -written in the body of this License. - - 13. The Free Software Foundation may publish revised and/or new -versions of the Lesser General Public License from time to time. -Such new versions will be similar in spirit to the present version, -but may differ in detail to address new problems or concerns. - -Each version is given a distinguishing version number. If the Library -specifies a version number of this License which applies to it and -"any later version", you have the option of following the terms and -conditions either of that version or of any later version published by -the Free Software Foundation. If the Library does not specify a -license version number, you may choose any version ever published by -the Free Software Foundation. - - 14. If you wish to incorporate parts of the Library into other free -programs whose distribution conditions are incompatible with these, -write to the author to ask for permission. For software which is -copyrighted by the Free Software Foundation, write to the Free -Software Foundation; we sometimes make exceptions for this. Our -decision will be guided by the two goals of preserving the free status -of all derivatives of our free software and of promoting the sharing -and reuse of software generally. - - NO WARRANTY - - 15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO -WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. -EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR -OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY -KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE -IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR -PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE -LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME -THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. - - 16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN -WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY -AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU -FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR -CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE -LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING -RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A -FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF -SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH -DAMAGES. - - END OF TERMS AND CONDITIONS - - How to Apply These Terms to Your New Libraries - - If you develop a new library, and you want it to be of the greatest -possible use to the public, we recommend making it free software that -everyone can redistribute and change. You can do so by permitting -redistribution under these terms (or, alternatively, under the terms of the -ordinary General Public License). - - To apply these terms, attach the following notices to the library. It is -safest to attach them to the start of each source file to most effectively -convey the exclusion of warranty; and each file should have at least the -"copyright" line and a pointer to where the full notice is found. - - - Copyright (C) - - This library is free software; you can redistribute it and/or - modify it under the terms of the GNU Lesser General Public - License as published by the Free Software Foundation; either - version 2.1 of the License, or (at your option) any later version. - - This library is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - Lesser General Public License for more details. - - You should have received a copy of the GNU Lesser General Public - License along with this library; if not, write to the Free Software - Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - -Also add information on how to contact you by electronic and paper mail. - -You should also get your employer (if you work as a programmer) or your -school, if any, to sign a "copyright disclaimer" for the library, if -necessary. Here is a sample; alter the names: - - Yoyodyne, Inc., hereby disclaims all copyright interest in the - library `Frob' (a library for tweaking knobs) written by James Random Hacker. - - , 1 April 1990 - Ty Coon, President of Vice - -That's all there is to it! - - From d422cbe65d8074365d85e1fd52ebf8d2e721bdfd Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 00:52:26 -0700 Subject: [PATCH 098/338] OpenEmu: Remove upstream core This is maintained downstream and not synchronized back upstream --- CMakeLists.txt | 29 +- src/platform/openemu/Info.plist.in | 52 --- .../openemu/OEGBASystemResponderClient.h | 51 --- src/platform/openemu/mGBAGameCore.h | 6 - src/platform/openemu/mGBAGameCore.m | 298 ------------------ 5 files changed, 1 insertion(+), 435 deletions(-) delete mode 100644 src/platform/openemu/Info.plist.in delete mode 100644 src/platform/openemu/OEGBASystemResponderClient.h delete mode 100644 src/platform/openemu/mGBAGameCore.h delete mode 100644 src/platform/openemu/mGBAGameCore.m diff --git a/CMakeLists.txt b/CMakeLists.txt index d573b0c6c85..2d69b000ba2 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -68,9 +68,6 @@ if(NOT LIBMGBA_ONLY) set(BUILD_QT ON CACHE BOOL "Build Qt frontend") set(BUILD_SDL ON CACHE BOOL "Build SDL frontend") set(BUILD_LIBRETRO OFF CACHE BOOL "Build libretro core") - if(APPLE) - set(BUILD_OPENEMU OFF CACHE BOOL "Build OpenEmu core") - endif() set(BUILD_PERF OFF CACHE BOOL "Build performance profiling tool") set(BUILD_TEST OFF CACHE BOOL "Build testing harness") set(BUILD_SUITE OFF CACHE BOOL "Build test suite") @@ -80,7 +77,7 @@ if(NOT LIBMGBA_ONLY) set(BUILD_PYTHON OFF CACHE BOOL "Build Python bindings") set(BUILD_STATIC OFF CACHE BOOL "Build a static library") set(BUILD_SHARED ON CACHE BOOL "Build a shared library") - set(SKIP_LIBRARY OFF CACHE BOOL "Skip building the library (useful for only building libretro or OpenEmu cores)") + set(SKIP_LIBRARY OFF CACHE BOOL "Skip building the library (useful for only building libretro core)") set(BUILD_GL ON CACHE BOOL "Build with OpenGL") set(BUILD_GLES2 ON CACHE BOOL "Build with OpenGL|ES 2") set(BUILD_GLES3 ON CACHE BOOL "Build with OpenGL|ES 3") @@ -144,11 +141,6 @@ if (BUILD_LIBRETRO) mark_as_advanced(LIBRETRO_LIBDIR) endif() -if (BUILD_OPENEMU) - set(OE_LIBDIR "${LIBDIR}" CACHE PATH "Installed library directory (OpenEmu)") - mark_as_advanced(OE_LIBDIR) -endif() - if (DISTBUILD) set(EXTRA_LICENSES "" CACHE FILEPATH "Extra licenses to include in distribution packaages") mark_as_advanced(EXTRA_LICENSES) @@ -1001,22 +993,6 @@ if(BUILD_LIBRETRO) endif() endif() -if(BUILD_OPENEMU) - find_library(FOUNDATION Foundation) - find_library(OPENEMUBASE OpenEmuBase) - file(GLOB OE_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/openemu/*.m) - add_library(${BINARY_NAME}-openemu MODULE ${CORE_SRC} ${OS_SRC}) - set_target_properties(${BINARY_NAME}-openemu PROPERTIES - MACOSX_BUNDLE_INFO_PLIST ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/openemu/Info.plist.in - BUNDLE TRUE - BUNDLE_EXTENSION oecoreplugin - OUTPUT_NAME ${PROJECT_NAME} - COMPILE_OPTIONS "-fobjc-arc" - COMPILE_DEFINITIONS "DISABLE_THREADING;MGBA_STANDALONE;${OS_DEFINES};${FUNCTION_DEFINES};MINIMAL_CORE=1") - target_link_libraries(${BINARY_NAME}-openemu ${OS_LIB} ${FOUNDATION} ${OPENEMUBASE}) - install(TARGETS ${BINARY_NAME}-openemu LIBRARY DESTINATION ${OE_LIBDIR} COMPONENT ${BINARY_NAME}.oecoreplugin NAMELINK_SKIP) -endif() - if(BUILD_QT AND (WIN32 OR APPLE OR CMAKE_SYSTEM_NAME STREQUAL "Linux")) set(BUILD_UPDATER ON) endif() @@ -1345,9 +1321,6 @@ if(NOT QUIET AND NOT LIBMGBA_ONLY) message(STATUS " ROM tester: ${BUILD_ROM_TEST}") message(STATUS "Cores:") message(STATUS " Libretro core: ${BUILD_LIBRETRO}") - if(APPLE) - message(STATUS " OpenEmu core: ${BUILD_OPENEMU}") - endif() message(STATUS "Libraries:") message(STATUS " Static: ${BUILD_STATIC}") message(STATUS " Shared: ${BUILD_SHARED}") diff --git a/src/platform/openemu/Info.plist.in b/src/platform/openemu/Info.plist.in deleted file mode 100644 index b4ecfa95e7b..00000000000 --- a/src/platform/openemu/Info.plist.in +++ /dev/null @@ -1,52 +0,0 @@ - - - - - CFBundleDevelopmentRegion - English - CFBundleExecutable - ${PROJECT_NAME} - CFBundleIconFile - mGBA - CFBundleIdentifier - com.endrift.mgba - CFBundleInfoDictionaryVersion - 6.0 - CFBundlePackageType - BNDL - CFBundleSignature - ???? - CFBundleVersion - ${VERSION_STRING} - NSPrincipalClass - OEGameCoreController - OEGameCoreClass - mGBAGameCore - OEGameCoreOptions - - openemu.system.gba - - OEGameCoreRewindBufferSeconds - 60 - OEGameCoreRewindInterval - 0 - OEGameCoreSupportsRewinding - - OEGameCoreSupportsCheatCode - - - - OEGameCorePlayerCount - 1 - OEProjectURL - https://mgba.io/ - OESystemIdentifiers - - openemu.system.gba - - SUEnableAutomaticChecks - 1 - SUFeedURL - https://raw.github.com/OpenEmu/OpenEmu-Update/master/mgba_appcast.xml - - diff --git a/src/platform/openemu/OEGBASystemResponderClient.h b/src/platform/openemu/OEGBASystemResponderClient.h deleted file mode 100644 index 4fc0179d101..00000000000 --- a/src/platform/openemu/OEGBASystemResponderClient.h +++ /dev/null @@ -1,51 +0,0 @@ -/* - Copyright (c) 2011, OpenEmu Team - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - * Redistributions of source code must retain the above copyright - notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - * Neither the name of the OpenEmu Team nor the - names of its contributors may be used to endorse or promote products - derived from this software without specific prior written permission. - - THIS SOFTWARE IS PROVIDED BY OpenEmu Team ''AS IS'' AND ANY - EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED - WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL OpenEmu Team BE LIABLE FOR ANY - DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES - (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND - ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - */ - -#import - -@protocol OESystemResponderClient; - -typedef enum _OEGBAButton -{ - OEGBAButtonUp, - OEGBAButtonDown, - OEGBAButtonLeft, - OEGBAButtonRight, - OEGBAButtonA, - OEGBAButtonB, - OEGBAButtonL, - OEGBAButtonR, - OEGBAButtonStart, - OEGBAButtonSelect, - OEGBAButtonCount -} OEGBAButton; - -@protocol OEGBASystemResponderClient - -- (oneway void)didPushGBAButton:(OEGBAButton)button forPlayer:(NSUInteger)player; -- (oneway void)didReleaseGBAButton:(OEGBAButton)button forPlayer:(NSUInteger)player; - -@end diff --git a/src/platform/openemu/mGBAGameCore.h b/src/platform/openemu/mGBAGameCore.h deleted file mode 100644 index 744fdecfe7e..00000000000 --- a/src/platform/openemu/mGBAGameCore.h +++ /dev/null @@ -1,6 +0,0 @@ -#import -#import - -OE_EXPORTED_CLASS -@interface mGBAGameCore : OEGameCore -@end diff --git a/src/platform/openemu/mGBAGameCore.m b/src/platform/openemu/mGBAGameCore.m deleted file mode 100644 index 7656a894599..00000000000 --- a/src/platform/openemu/mGBAGameCore.m +++ /dev/null @@ -1,298 +0,0 @@ -/* - Copyright (c) 2016, Jeffrey Pfau - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - * Redistributions of source code must retain the above copyright - notice, this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above copyright - notice, this list of conditions and the following disclaimer in the - documentation and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ''AS IS'' - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE - LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR - CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF - SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS - INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN - CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE - POSSIBILITY OF SUCH DAMAGE. - */ - -#import "mGBAGameCore.h" - -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#import -#import "OEGBASystemResponderClient.h" -#import - -#define SAMPLES 1024 - -@interface mGBAGameCore () -{ - struct mCore* core; - void* outputBuffer; - NSMutableDictionary *cheatSets; -} -@end - -@implementation mGBAGameCore - -- (id)init -{ - if ((self = [super init])) - { - core = GBACoreCreate(); - mCoreInitConfig(core, nil); - - struct mCoreOptions opts = { - .useBios = true, - }; - mCoreConfigLoadDefaults(&core->config, &opts); - core->init(core); - outputBuffer = nil; - - unsigned width, height; - core->baseVideoSize(core, &width, &height); - outputBuffer = malloc(width * height * BYTES_PER_PIXEL); - core->setVideoBuffer(core, outputBuffer, width); - core->setAudioBufferSize(core, SAMPLES); - cheatSets = [[NSMutableDictionary alloc] init]; - } - - return self; -} - -- (void)dealloc -{ - mCoreConfigDeinit(&core->config); - core->deinit(core); - free(outputBuffer); -} - -#pragma mark - Execution - -- (BOOL)loadFileAtPath:(NSString *)path error:(NSError **)error -{ - NSString *batterySavesDirectory = [self batterySavesDirectoryPath]; - [[NSFileManager defaultManager] createDirectoryAtURL:[NSURL fileURLWithPath:batterySavesDirectory] - withIntermediateDirectories:YES - attributes:nil - error:nil]; - if (core->dirs.save) { - core->dirs.save->close(core->dirs.save); - } - core->dirs.save = VDirOpen([batterySavesDirectory fileSystemRepresentation]); - - if (!mCoreLoadFile(core, [path fileSystemRepresentation])) { - *error = [NSError errorWithDomain:OEGameCoreErrorDomain code:OEGameCoreCouldNotLoadROMError userInfo:nil]; - return NO; - } - mCoreAutoloadSave(core); - - core->reset(core); - - return YES; -} - -- (void)executeFrame -{ - core->runFrame(core); - - int16_t samples[SAMPLES * 2]; - size_t available = 0; - available = blip_samples_avail(core->getAudioChannel(core, 0)); - blip_read_samples(core->getAudioChannel(core, 0), samples, available, true); - blip_read_samples(core->getAudioChannel(core, 1), samples + 1, available, true); - [[self ringBufferAtIndex:0] write:samples maxLength:available * 4]; -} - -- (void)resetEmulation -{ - core->reset(core); -} - -- (void)setupEmulation -{ - blip_set_rates(core->getAudioChannel(core, 0), core->frequency(core), 32768); - blip_set_rates(core->getAudioChannel(core, 1), core->frequency(core), 32768); -} - -#pragma mark - Video - -- (OEIntSize)aspectSize -{ - return OEIntSizeMake(3, 2); -} - -- (OEIntRect)screenRect -{ - unsigned width, height; - core->currentVideoSize(core, &width, &height); - return OEIntRectMake(0, 0, width, height); -} - -- (OEIntSize)bufferSize -{ - unsigned width, height; - core->baseVideoSize(core, &width, &height); - return OEIntSizeMake(width, height); -} - -- (const void *)getVideoBufferWithHint:(void *)hint -{ - OEIntSize bufferSize = [self bufferSize]; - - if (!hint) { - hint = outputBuffer; - } - - outputBuffer = hint; - core->setVideoBuffer(core, hint, bufferSize.width); - - return hint; -} - -- (GLenum)pixelFormat -{ - return GL_RGBA; -} - -- (GLenum)pixelType -{ - return GL_UNSIGNED_INT_8_8_8_8_REV; -} - -- (NSTimeInterval)frameInterval -{ - return core->frequency(core) / (double) core->frameCycles(core); -} - -#pragma mark - Audio - -- (NSUInteger)channelCount -{ - return 2; -} - -- (double)audioSampleRate -{ - return 32768; -} - -#pragma mark - Save State - -- (NSData *)serializeStateWithError:(NSError **)outError -{ - struct VFile* vf = VFileMemChunk(nil, 0); - if (!mCoreSaveStateNamed(core, vf, SAVESTATE_SAVEDATA)) { - *outError = [NSError errorWithDomain:OEGameCoreErrorDomain code:OEGameCoreCouldNotLoadStateError userInfo:nil]; - vf->close(vf); - return nil; - } - size_t size = vf->size(vf); - void* data = vf->map(vf, size, MAP_READ); - NSData *nsdata = [NSData dataWithBytes:data length:size]; - vf->unmap(vf, data, size); - vf->close(vf); - return nsdata; -} - -- (BOOL)deserializeState:(NSData *)state withError:(NSError **)outError -{ - struct VFile* vf = VFileFromConstMemory(state.bytes, state.length); - if (!mCoreLoadStateNamed(core, vf, SAVESTATE_SAVEDATA)) { - *outError = [NSError errorWithDomain:OEGameCoreErrorDomain code:OEGameCoreCouldNotLoadStateError userInfo:nil]; - vf->close(vf); - return NO; - } - vf->close(vf); - return YES; -} - -- (void)saveStateToFileAtPath:(NSString *)fileName completionHandler:(void (^)(BOOL, NSError *))block -{ - struct VFile* vf = VFileOpen([fileName fileSystemRepresentation], O_CREAT | O_TRUNC | O_RDWR); - block(mCoreSaveStateNamed(core, vf, 0), nil); - vf->close(vf); -} - -- (void)loadStateFromFileAtPath:(NSString *)fileName completionHandler:(void (^)(BOOL, NSError *))block -{ - struct VFile* vf = VFileOpen([fileName fileSystemRepresentation], O_RDONLY); - block(mCoreLoadStateNamed(core, vf, 0), nil); - vf->close(vf); -} - -#pragma mark - Input - -const int GBAMap[] = { - GBA_KEY_UP, - GBA_KEY_DOWN, - GBA_KEY_LEFT, - GBA_KEY_RIGHT, - GBA_KEY_A, - GBA_KEY_B, - GBA_KEY_L, - GBA_KEY_R, - GBA_KEY_START, - GBA_KEY_SELECT -}; - -- (oneway void)didPushGBAButton:(OEGBAButton)button forPlayer:(NSUInteger)player -{ - UNUSED(player); - core->addKeys(core, 1 << GBAMap[button]); -} - -- (oneway void)didReleaseGBAButton:(OEGBAButton)button forPlayer:(NSUInteger)player -{ - UNUSED(player); - core->clearKeys(core, 1 << GBAMap[button]); -} - -#pragma mark - Cheats - -- (void)setCheat:(NSString *)code setType:(NSString *)type setEnabled:(BOOL)enabled -{ - code = [code stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]; - code = [code stringByReplacingOccurrencesOfString:@" " withString:@""]; - - NSString *codeId = [code stringByAppendingFormat:@"/%@", type]; - struct mCheatSet* cheatSet = [[cheatSets objectForKey:codeId] pointerValue]; - if (cheatSet) { - cheatSet->enabled = enabled; - return; - } - struct mCheatDevice* cheats = core->cheatDevice(core); - cheatSet = cheats->createSet(cheats, [codeId UTF8String]); - size_t size = mCheatSetsSize(&cheats->cheats); - if (size) { - cheatSet->copyProperties(cheatSet, *mCheatSetsGetPointer(&cheats->cheats, size - 1)); - } - int codeType = GBA_CHEAT_AUTODETECT; - NSArray *codeSet = [code componentsSeparatedByString:@"+"]; - for (id c in codeSet) { - mCheatAddLine(cheatSet, [c UTF8String], codeType); - } - cheatSet->enabled = enabled; - [cheatSets setObject:[NSValue valueWithPointer:cheatSet] forKey:codeId]; - mCheatAddSet(cheats, cheatSet); -} -@end - From 2cbbaea48359c3bbd3367c99298c0ad9a3e5eb88 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 03:04:34 -0700 Subject: [PATCH 099/338] Python: Attempt to fix build --- src/platform/python/mgba/core.py | 10 +--------- 1 file changed, 1 insertion(+), 9 deletions(-) diff --git a/src/platform/python/mgba/core.py b/src/platform/python/mgba/core.py index 75fd1a1cc4d..22965b3f9c7 100644 --- a/src/platform/python/mgba/core.py +++ b/src/platform/python/mgba/core.py @@ -4,7 +4,7 @@ # License, v. 2.0. If a copy of the MPL was not distributed with this # file, You can obtain one at http://mozilla.org/MPL/2.0/. from ._pylib import ffi, lib # pylint: disable=no-name-in-module -from . import tile, audio +from . import tile from cached_property import cached_property from functools import wraps @@ -242,14 +242,6 @@ def desired_video_dimensions(self): def set_video_buffer(self, image): self._core.setVideoBuffer(self._core, image.buffer, image.stride) - @protected - def set_audio_buffer_size(self, size): - self._core.setAudioBufferSize(self._core, size) - - @property - def audio_buffer_size(self): - return self._core.getAudioBufferSize(self._core) - @protected def reset(self): self._core.reset(self._core) From 21d4f0f5fc52ede32c71c1bf2a2b4fd90b7ec098 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 03:07:54 -0700 Subject: [PATCH 100/338] All: Split ENABLE_VFS out from MINIMAL_CORE=2 --- CMakeLists.txt | 21 +++++++++++++---- include/mgba-util/configuration.h | 4 +++- include/mgba-util/image.h | 4 ++++ include/mgba-util/vfs.h | 9 ++++--- include/mgba/core/cheats.h | 2 +- include/mgba/core/config.h | 2 +- include/mgba/core/core.h | 6 ++--- include/mgba/core/directories.h | 2 +- include/mgba/core/library.h | 4 ++++ include/mgba/core/scripting.h | 2 ++ include/mgba/gba/interface.h | 4 +++- include/mgba/script/context.h | 2 ++ src/core/CMakeLists.txt | 6 ++++- src/core/cheats.c | 2 +- src/core/config.c | 2 +- src/core/core.c | 12 ++++++---- src/core/directories.c | 2 +- src/core/flags.h.in | 4 ++++ src/core/log.c | 5 ++-- src/core/scripting.c | 38 ++++++++++++++++++++---------- src/core/test/core.c | 4 ++-- src/debugger/cli-debugger.c | 24 ++++++++++++------- src/debugger/cli-el-backend.c | 4 ++++ src/feature/CMakeLists.txt | 6 ++++- src/feature/commandline.c | 5 ++++ src/gb/core.c | 8 +++---- src/gb/debugger/cli.c | 6 ++--- src/gba/cart/ereader.c | 4 +++- src/gba/core.c | 8 +++---- src/gba/debugger/cli.c | 6 ++--- src/platform/3ds/CMakeLists.txt | 4 ++-- src/platform/opengl/gles2.c | 2 ++ src/platform/opengl/gles2.h | 2 ++ src/platform/psp2/CMakeLists.txt | 4 ++-- src/platform/switch/CMakeLists.txt | 4 ++-- src/platform/wii/CMakeLists.txt | 4 ++-- src/script/CMakeLists.txt | 2 +- src/script/context.c | 2 ++ src/script/image.c | 24 ++++++++++++++----- src/util/configuration.c | 26 ++++++++++---------- src/util/image.c | 4 ++++ src/util/test/vfs.c | 4 ++-- src/util/vfs.c | 4 ++++ 43 files changed, 199 insertions(+), 95 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 2d69b000ba2..ae561189e9a 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -220,7 +220,7 @@ if(WIN32) endif() endif() list(APPEND OS_LIB ws2_32 shlwapi) - list(APPEND CORE_VFS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/windows/vfs-w32.c) + list(APPEND VFS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/windows/vfs-w32.c) file(GLOB OS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/windows/*.c) source_group("Windows-specific code" FILES ${OS_SRC}) elseif(UNIX) @@ -230,7 +230,7 @@ elseif(UNIX) add_definitions(-D_GNU_SOURCE) endif() - list(APPEND CORE_VFS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${CMAKE_CURRENT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c) + list(APPEND VFS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${CMAKE_CURRENT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c) file(GLOB OS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/posix/*.c) source_group("POSIX-specific code" FILES ${OS_SRC}) endif() @@ -349,6 +349,9 @@ elseif(NOT CMAKE_SYSTEM_NAME STREQUAL "Linux") endif() check_include_files("xlocale.h" HAVE_XLOCALE) + +set(ENABLE_VFS ON) + if(CMAKE_SYSTEM_NAME STREQUAL "Generic") if(NOT IS_EMBEDDED) set(DISABLE_DEPS ON CACHE BOOL "This platform cannot build with dependencies" FORCE) @@ -852,6 +855,10 @@ if(ENABLE_SCRIPTING) list(APPEND TEST_SRC ${SCRIPT_TEST_SRC}) endif() +if(ENABLE_VFS) + list(APPEND ENABLES VFS) +endif() + foreach(FEATURE IN LISTS FEATURES) list(APPEND FEATURE_DEFINES "USE_${FEATURE}") endforeach() @@ -890,7 +897,11 @@ list(APPEND CORE_SRC ${THIRD_PARTY_SRC}) list(APPEND TEST_SRC ${UTIL_TEST_SRC}) -set(SRC ${CORE_SRC} ${VFS_SRC}) +set(SRC ${CORE_SRC}) +if(ENABLE_VFS) + list(APPEND SRC ${VFS_SRC}) +endif() + if(NOT MINIMAL_CORE) set(ENABLE_EXTRA ON) if(M_CORE_GBA) @@ -922,7 +933,7 @@ if(NOT SKIP_LIBRARY) endif() if(BUILD_SHARED) - add_library(${BINARY_NAME} SHARED ${SRC} ${VFS_SRC}) + add_library(${BINARY_NAME} SHARED ${SRC}) set(EXPORT_DEFINES MGBA_DLL) if(BUILD_STATIC) add_library(${BINARY_NAME}-static STATIC ${SRC}) @@ -993,7 +1004,7 @@ if(BUILD_LIBRETRO) endif() endif() -if(BUILD_QT AND (WIN32 OR APPLE OR CMAKE_SYSTEM_NAME STREQUAL "Linux")) +if(BUILD_QT AND (WIN32 OR APPLE OR CMAKE_SYSTEM_NAME STREQUAL "Linux") AND ENABLE_VFS) set(BUILD_UPDATER ON) endif() diff --git a/include/mgba-util/configuration.h b/include/mgba-util/configuration.h index e19ad13ef8a..f4c206d6a3c 100644 --- a/include/mgba-util/configuration.h +++ b/include/mgba-util/configuration.h @@ -34,10 +34,12 @@ const char* ConfigurationGetValue(const struct Configuration*, const char* secti void ConfigurationClearValue(struct Configuration*, const char* section, const char* key); +#ifdef ENABLE_VFS bool ConfigurationRead(struct Configuration*, const char* path); -bool ConfigurationReadVFile(struct Configuration*, struct VFile* vf); bool ConfigurationWrite(const struct Configuration*, const char* path); bool ConfigurationWriteSection(const struct Configuration*, const char* path, const char* section); +#endif +bool ConfigurationReadVFile(struct Configuration*, struct VFile* vf); bool ConfigurationWriteVFile(const struct Configuration*, struct VFile* vf); void ConfigurationEnumerateSections(const struct Configuration* configuration, void (*handler)(const char* sectionName, void* user), void* user); diff --git a/include/mgba-util/image.h b/include/mgba-util/image.h index b86b2135a4b..681e0a3a664 100644 --- a/include/mgba-util/image.h +++ b/include/mgba-util/image.h @@ -114,12 +114,16 @@ struct VFile; struct mImage* mImageCreate(unsigned width, unsigned height, enum mColorFormat format); struct mImage* mImageCreateWithStride(unsigned width, unsigned height, unsigned stride, enum mColorFormat format); struct mImage* mImageCreateFromConstBuffer(unsigned width, unsigned height, unsigned stride, enum mColorFormat format, const void* pixels); +#ifdef ENABLE_VFS struct mImage* mImageLoad(const char* path); +#endif struct mImage* mImageLoadVF(struct VFile* vf); struct mImage* mImageConvertToFormat(const struct mImage*, enum mColorFormat format); void mImageDestroy(struct mImage*); +#ifdef ENABLE_VFS bool mImageSave(const struct mImage*, const char* path, const char* format); +#endif bool mImageSaveVF(const struct mImage*, struct VFile* vf, const char* format); uint32_t mImageGetPixel(const struct mImage* image, unsigned x, unsigned y); diff --git a/include/mgba-util/vfs.h b/include/mgba-util/vfs.h index b9c4ca6b238..0ff100143b6 100644 --- a/include/mgba-util/vfs.h +++ b/include/mgba-util/vfs.h @@ -50,6 +50,7 @@ struct VFile { bool (*sync)(struct VFile* vf, void* buffer, size_t size); }; +#ifdef ENABLE_VFS struct VDirEntry { const char* (*name)(struct VDirEntry* vde); enum VFSType (*type)(struct VDirEntry* vde); @@ -68,6 +69,7 @@ struct VFile* VFileOpen(const char* path, int flags); struct VFile* VFileOpenFD(const char* path, int flags); struct VFile* VFileFromFD(int fd); +#endif struct VFile* VFileFromMemory(void* mem, size_t size); struct VFile* VFileFromConstMemory(const void* mem, size_t size); @@ -76,6 +78,7 @@ struct VFile* VFileMemChunk(const void* mem, size_t size); struct mCircleBuffer; struct VFile* VFileFIFO(struct mCircleBuffer* backing); +#ifdef ENABLE_VFS struct VDir* VDirOpen(const char* path); struct VDir* VDirOpenArchive(const char* path); @@ -92,20 +95,20 @@ struct VDir* VDeviceList(void); #endif bool VDirCreate(const char* path); +struct VFile* VDirFindFirst(struct VDir* dir, bool (*filter)(struct VFile*)); +struct VFile* VDirFindNextAvailable(struct VDir*, const char* basename, const char* infix, const char* suffix, int mode); #ifdef USE_VFS_FILE struct VFile* VFileFOpen(const char* path, const char* mode); struct VFile* VFileFromFILE(FILE* file); #endif +#endif void separatePath(const char* path, char* dirname, char* basename, char* extension); bool isAbsolute(const char* path); void makeAbsolute(const char* path, const char* base, char* out); -struct VFile* VDirFindFirst(struct VDir* dir, bool (*filter)(struct VFile*)); -struct VFile* VDirFindNextAvailable(struct VDir*, const char* basename, const char* infix, const char* suffix, int mode); - ssize_t VFileReadline(struct VFile* vf, char* buffer, size_t size); ssize_t VFileWrite32LE(struct VFile* vf, int32_t word); diff --git a/include/mgba/core/cheats.h b/include/mgba/core/cheats.h index 1da1aa859c0..a1c6c555cad 100644 --- a/include/mgba/core/cheats.h +++ b/include/mgba/core/cheats.h @@ -118,7 +118,7 @@ bool mCheatSaveFile(struct mCheatDevice*, struct VFile*); bool mCheatParseLibretroFile(struct mCheatDevice*, struct VFile*); bool mCheatParseEZFChtFile(struct mCheatDevice*, struct VFile*); -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS void mCheatAutosave(struct mCheatDevice*); #endif diff --git a/include/mgba/core/config.h b/include/mgba/core/config.h index 2082c11dbf2..4a68b49eed9 100644 --- a/include/mgba/core/config.h +++ b/include/mgba/core/config.h @@ -64,7 +64,7 @@ struct mCoreOptions { void mCoreConfigInit(struct mCoreConfig*, const char* port); void mCoreConfigDeinit(struct mCoreConfig*); -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS bool mCoreConfigLoad(struct mCoreConfig*); bool mCoreConfigSave(const struct mCoreConfig*); bool mCoreConfigLoadPath(struct mCoreConfig*, const char* path); diff --git a/include/mgba/core/core.h b/include/mgba/core/core.h index a4bf5826cc0..97f256c823a 100644 --- a/include/mgba/core/core.h +++ b/include/mgba/core/core.h @@ -11,7 +11,7 @@ CXX_GUARD_START #include -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS #include #endif #ifndef MINIMAL_CORE @@ -46,7 +46,7 @@ struct mCore { struct mDebuggerSymbols* symbolTable; struct mVideoLogger* videoLogger; -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS struct mDirectorySet dirs; #endif #ifndef MINIMAL_CORE @@ -176,7 +176,7 @@ struct mCore { #endif }; -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS struct mCore* mCoreFind(const char* path); bool mCoreLoadFile(struct mCore* core, const char* path); diff --git a/include/mgba/core/directories.h b/include/mgba/core/directories.h index d421e7f51b3..f9f59cb8d17 100644 --- a/include/mgba/core/directories.h +++ b/include/mgba/core/directories.h @@ -10,7 +10,7 @@ CXX_GUARD_START -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS struct VDir; struct mDirectorySet { diff --git a/include/mgba/core/library.h b/include/mgba/core/library.h index d12aa0411f1..ededd546348 100644 --- a/include/mgba/core/library.h +++ b/include/mgba/core/library.h @@ -10,6 +10,8 @@ CXX_GUARD_START +#ifdef ENABLE_VFS + #include #include @@ -48,6 +50,8 @@ void mLibraryAttachGameDB(struct mLibrary* library, const struct NoIntroDB* db); #endif +#endif + CXX_GUARD_END #endif diff --git a/include/mgba/core/scripting.h b/include/mgba/core/scripting.h index a8fdbc425e1..c0fdcb413f6 100644 --- a/include/mgba/core/scripting.h +++ b/include/mgba/core/scripting.h @@ -70,7 +70,9 @@ void mScriptBridgeDebuggerEntered(struct mScriptBridge*, enum mDebuggerEntryReas #endif void mScriptBridgeRun(struct mScriptBridge*); +#ifdef ENABLE_VFS bool mScriptBridgeLoadScript(struct mScriptBridge*, const char* name); +#endif bool mScriptBridgeLookupSymbol(struct mScriptBridge*, const char* name, int32_t* out); diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index c64d0039119..a04685e49d0 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -139,7 +139,7 @@ struct GBA; void GBACartEReaderQueueCard(struct GBA* gba, const void* data, size_t size); struct EReaderScan; -#ifdef USE_PNG +#if defined(USE_PNG) && defined(ENABLE_VFS) MGBA_EXPORT struct EReaderScan* EReaderScanLoadImagePNG(const char* filename); #endif MGBA_EXPORT struct EReaderScan* EReaderScanLoadImage(const void* pixels, unsigned width, unsigned height, unsigned stride); @@ -149,7 +149,9 @@ MGBA_EXPORT void EReaderScanDestroy(struct EReaderScan*); MGBA_EXPORT bool EReaderScanCard(struct EReaderScan*); MGBA_EXPORT void EReaderScanOutputBitmap(const struct EReaderScan*, void* output, size_t stride); +#ifdef ENABLE_VFS MGBA_EXPORT bool EReaderScanSaveRaw(const struct EReaderScan*, const char* filename, bool strict); +#endif CXX_GUARD_END diff --git a/include/mgba/script/context.h b/include/mgba/script/context.h index 25628d78594..ef740fb455e 100644 --- a/include/mgba/script/context.h +++ b/include/mgba/script/context.h @@ -109,7 +109,9 @@ const char* mScriptEngineGetDocstring(struct mScriptEngineContext*, const char* struct VFile; bool mScriptContextLoadVF(struct mScriptContext*, const char* name, struct VFile* vf); +#ifdef ENABLE_VFS bool mScriptContextLoadFile(struct mScriptContext*, const char* path); +#endif struct mScriptContext* mScriptActiveContext(void); bool mScriptContextActivate(struct mScriptContext*); diff --git a/src/core/CMakeLists.txt b/src/core/CMakeLists.txt index 1844450230f..e86e4fe55ad 100644 --- a/src/core/CMakeLists.txt +++ b/src/core/CMakeLists.txt @@ -8,7 +8,6 @@ set(SOURCE_FILES directories.c input.c interface.c - library.c lockstep.c log.c map-cache.c @@ -23,6 +22,11 @@ set(SOURCE_FILES set(TEST_FILES test/core.c) +if(ENABLE_VFS) + list(APPEND SOURCE_FILES + library.c) +endif() + if(ENABLE_SCRIPTING) set(SCRIPTING_FILES scripting.c) diff --git a/src/core/cheats.c b/src/core/cheats.c index 60f73abccc6..85a06b80dd8 100644 --- a/src/core/cheats.c +++ b/src/core/cheats.c @@ -622,7 +622,7 @@ bool mCheatSaveFile(struct mCheatDevice* device, struct VFile* vf) { return true; } -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS void mCheatAutosave(struct mCheatDevice* device) { if (!device->autosave) { return; diff --git a/src/core/config.c b/src/core/config.c index 4d4733cd943..4fa27ba55af 100644 --- a/src/core/config.c +++ b/src/core/config.c @@ -167,7 +167,7 @@ void mCoreConfigDeinit(struct mCoreConfig* config) { free(config->port); } -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS bool mCoreConfigLoad(struct mCoreConfig* config) { char path[PATH_MAX + 1]; mCoreConfigDirectory(path, PATH_MAX); diff --git a/src/core/core.c b/src/core/core.c index bcc72115a77..20f9fdefc95 100644 --- a/src/core/core.c +++ b/src/core/core.c @@ -15,6 +15,10 @@ #include #endif +#ifdef USE_PNG +#include +#endif + #ifdef M_CORE_GB #include #include @@ -86,9 +90,7 @@ struct mCore* mCoreCreate(enum mPlatform platform) { return NULL; } -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 -#include - +#ifdef ENABLE_VFS #ifdef PSP2 #include #endif @@ -381,7 +383,7 @@ void mCoreInitConfig(struct mCore* core, const char* port) { } void mCoreLoadConfig(struct mCore* core) { -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS mCoreConfigLoad(&core->config); #endif mCoreLoadForeignConfig(core, &core->config); @@ -389,7 +391,7 @@ void mCoreLoadConfig(struct mCore* core) { void mCoreLoadForeignConfig(struct mCore* core, const struct mCoreConfig* config) { mCoreConfigMap(config, &core->opts); -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS mDirectorySetMapOptions(&core->dirs, &core->opts); #endif if (core->opts.audioBuffers) { diff --git a/src/core/directories.c b/src/core/directories.c index c35773f1e11..c4551b6c729 100644 --- a/src/core/directories.c +++ b/src/core/directories.c @@ -8,7 +8,7 @@ #include #include -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS void mDirectorySetInit(struct mDirectorySet* dirs) { dirs->base = NULL; dirs->archive = NULL; diff --git a/src/core/flags.h.in b/src/core/flags.h.in index ebfd67ed93a..b91e1907ac3 100644 --- a/src/core/flags.h.in +++ b/src/core/flags.h.in @@ -61,6 +61,10 @@ #cmakedefine ENABLE_SCRIPTING #endif +#ifndef ENABLE_VFS +#cmakedefine ENABLE_VFS +#endif + // USE flags #ifndef USE_DISCORD_RPC diff --git a/src/core/log.c b/src/core/log.c index b897fedb4e2..39d6db88cad 100644 --- a/src/core/log.c +++ b/src/core/log.c @@ -278,15 +278,16 @@ void mStandardLoggerDeinit(struct mStandardLogger* logger) { } void mStandardLoggerConfig(struct mStandardLogger* logger, struct mCoreConfig* config) { +#ifdef ENABLE_VFS bool logToFile = false; const char* logFile = mCoreConfigGetValue(config, "logFile"); - mCoreConfigGetBoolValue(config, "logToStdout", &logger->logToStdout); mCoreConfigGetBoolValue(config, "logToFile", &logToFile); if (logToFile && logFile) { logger->logFile = VFileOpen(logFile, O_WRONLY | O_CREAT | O_APPEND); } - +#endif + mCoreConfigGetBoolValue(config, "logToStdout", &logger->logToStdout); mLogFilterLoad(logger->d.filter, config); } diff --git a/src/core/scripting.c b/src/core/scripting.c index acf324e1ff4..57d0eed2bf8 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -129,6 +129,7 @@ void mScriptBridgeRun(struct mScriptBridge* sb) { HashTableEnumerate(&sb->engines, _seRun, NULL); } +#ifdef ENABLE_VFS bool mScriptBridgeLoadScript(struct mScriptBridge* sb, const char* name) { struct VFile* vf = VFileOpen(name, O_RDONLY); if (!vf) { @@ -143,6 +144,7 @@ bool mScriptBridgeLoadScript(struct mScriptBridge* sb, const char* name) { vf->close(vf); return info.success; } +#endif bool mScriptBridgeLookupSymbol(struct mScriptBridge* sb, const char* name, int32_t* out) { struct mScriptSymbol info = { @@ -417,6 +419,7 @@ static struct mScriptValue* _mScriptCoreSaveState(struct mCore* core, int32_t fl return value; } +#ifdef ENABLE_VFS static int _mScriptCoreSaveStateFile(struct mCore* core, const char* path, int flags) { struct VFile* vf = VFileOpen(path, O_WRONLY | O_TRUNC | O_CREAT); if (!vf) { @@ -427,13 +430,6 @@ static int _mScriptCoreSaveStateFile(struct mCore* core, const char* path, int f return ok; } -static int32_t _mScriptCoreLoadState(struct mCore* core, struct mScriptString* buffer, int32_t flags) { - struct VFile* vf = VFileFromConstMemory(buffer->buffer, buffer->size); - int ret = mCoreLoadStateNamed(core, vf, flags); - vf->close(vf); - return ret; -} - static int _mScriptCoreLoadStateFile(struct mCore* core, const char* path, int flags) { struct VFile* vf = VFileOpen(path, O_RDONLY); if (!vf) { @@ -456,6 +452,14 @@ static void _mScriptCoreTakeScreenshot(struct mCore* core, const char* filename) mCoreTakeScreenshot(core); } } +#endif + +static int32_t _mScriptCoreLoadState(struct mCore* core, struct mScriptString* buffer, int32_t flags) { + struct VFile* vf = VFileFromConstMemory(buffer->buffer, buffer->size); + int ret = mCoreLoadStateNamed(core, vf, flags); + vf->close(vf); + return ret; +} static struct mScriptValue* _mScriptCoreTakeScreenshotToImage(struct mCore* core) { size_t stride; @@ -480,10 +484,12 @@ static struct mScriptValue* _mScriptCoreTakeScreenshotToImage(struct mCore* core return result; } +#ifdef ENABLE_VFS // Loading functions mSCRIPT_DECLARE_STRUCT_METHOD(mCore, BOOL, loadFile, mCoreLoadFile, 1, CHARP, path); mSCRIPT_DECLARE_STRUCT_METHOD(mCore, BOOL, autoloadSave, mCoreAutoloadSave, 0); mSCRIPT_DECLARE_STRUCT_METHOD(mCore, BOOL, loadSaveFile, mCoreLoadSaveFile, 2, CHARP, path, BOOL, temporary); +#endif // Info functions mSCRIPT_DECLARE_STRUCT_CD_METHOD(mCore, S32, platform, 0); @@ -523,27 +529,31 @@ mSCRIPT_DECLARE_STRUCT_METHOD(mCore, WSTR, readRegister, _mScriptCoreReadRegiste mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mCore, writeRegister, _mScriptCoreWriteRegister, 2, CHARP, regName, S32, value); // Savestate functions -mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mCore, BOOL, saveStateSlot, mCoreSaveState, 2, S32, slot, S32, flags); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mCore, WSTR, saveStateBuffer, _mScriptCoreSaveState, 1, S32, flags); +mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mCore, BOOL, loadStateBuffer, _mScriptCoreLoadState, 2, STR, buffer, S32, flags); +#ifdef ENABLE_VFS +mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mCore, BOOL, saveStateSlot, mCoreSaveState, 2, S32, slot, S32, flags); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mCore, BOOL, saveStateFile, _mScriptCoreSaveStateFile, 2, CHARP, path, S32, flags); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mCore, BOOL, loadStateSlot, mCoreLoadState, 2, S32, slot, S32, flags); -mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mCore, BOOL, loadStateBuffer, _mScriptCoreLoadState, 2, STR, buffer, S32, flags); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mCore, BOOL, loadStateFile, _mScriptCoreLoadStateFile, 2, CHARP, path, S32, flags); // Miscellaneous functions mSCRIPT_DECLARE_STRUCT_VOID_METHOD_WITH_DEFAULTS(mCore, screenshot, _mScriptCoreTakeScreenshot, 1, CHARP, filename); +#endif mSCRIPT_DECLARE_STRUCT_METHOD(mCore, W(mImage), screenshotToImage, _mScriptCoreTakeScreenshotToImage, 0); mSCRIPT_DEFINE_STRUCT(mCore) mSCRIPT_DEFINE_CLASS_DOCSTRING( "An instance of an emulator core." ) +#ifdef ENABLE_VFS mSCRIPT_DEFINE_DOCSTRING("Load a ROM file into the current state of this core") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, loadFile) mSCRIPT_DEFINE_DOCSTRING("Load the save data associated with the currently loaded ROM file") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, autoloadSave) mSCRIPT_DEFINE_DOCSTRING("Load save data from the given path. If the `temporary` flag is set, the given save data will not be written back to disk") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, loadSaveFile) +#endif mSCRIPT_DEFINE_DOCSTRING("Get which platform is being emulated. See C.PLATFORM for possible values") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, platform) @@ -605,21 +615,23 @@ mSCRIPT_DEFINE_STRUCT(mCore) mSCRIPT_DEFINE_DOCSTRING("Write the value of the register with the given name") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, writeRegister) - mSCRIPT_DEFINE_DOCSTRING("Save state to the slot number. See C.SAVESTATE for possible values for `flags`") - mSCRIPT_DEFINE_STRUCT_METHOD(mCore, saveStateSlot) mSCRIPT_DEFINE_DOCSTRING("Save state and return as a buffer. See C.SAVESTATE for possible values for `flags`") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, saveStateBuffer) + mSCRIPT_DEFINE_DOCSTRING("Load state from a buffer. See C.SAVESTATE for possible values for `flags`") + mSCRIPT_DEFINE_STRUCT_METHOD(mCore, loadStateBuffer) +#ifdef ENABLE_VFS + mSCRIPT_DEFINE_DOCSTRING("Save state to the slot number. See C.SAVESTATE for possible values for `flags`") + mSCRIPT_DEFINE_STRUCT_METHOD(mCore, saveStateSlot) mSCRIPT_DEFINE_DOCSTRING("Save state to the given path. See C.SAVESTATE for possible values for `flags`") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, saveStateFile) mSCRIPT_DEFINE_DOCSTRING("Load state from the slot number. See C.SAVESTATE for possible values for `flags`") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, loadStateSlot) - mSCRIPT_DEFINE_DOCSTRING("Load state from a buffer. See C.SAVESTATE for possible values for `flags`") - mSCRIPT_DEFINE_STRUCT_METHOD(mCore, loadStateBuffer) mSCRIPT_DEFINE_DOCSTRING("Load state from the given path. See C.SAVESTATE for possible values for `flags`") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, loadStateFile) mSCRIPT_DEFINE_DOCSTRING("Save a screenshot to a file") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, screenshot) +#endif mSCRIPT_DEFINE_DOCSTRING("Get a screenshot in an struct::mImage") mSCRIPT_DEFINE_STRUCT_METHOD(mCore, screenshotToImage) mSCRIPT_DEFINE_END; diff --git a/src/core/test/core.c b/src/core/test/core.c index 10c566b2c6b..645a4548659 100644 --- a/src/core/test/core.c +++ b/src/core/test/core.c @@ -8,7 +8,7 @@ #include #include -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS M_TEST_DEFINE(findNullPath) { struct mCore* core = mCoreFind(NULL); assert_null(core); @@ -29,7 +29,7 @@ M_TEST_DEFINE(findEmpty) { } M_TEST_SUITE_DEFINE(mCore, -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS cmocka_unit_test(findNullPath), #endif cmocka_unit_test(findNullVF), diff --git a/src/debugger/cli-debugger.c b/src/debugger/cli-debugger.c index 95b2037dcd4..b5a6595d354 100644 --- a/src/debugger/cli-debugger.c +++ b/src/debugger/cli-debugger.c @@ -75,13 +75,15 @@ static void _dumpByte(struct CLIDebugger*, struct CLIDebugVector*); static void _dumpHalfword(struct CLIDebugger*, struct CLIDebugVector*); static void _dumpWord(struct CLIDebugger*, struct CLIDebugVector*); static void _events(struct CLIDebugger*, struct CLIDebugVector*); -#ifdef ENABLE_SCRIPTING -static void _source(struct CLIDebugger*, struct CLIDebugVector*); -#endif static void _backtrace(struct CLIDebugger*, struct CLIDebugVector*); static void _finish(struct CLIDebugger*, struct CLIDebugVector*); static void _setStackTraceMode(struct CLIDebugger*, struct CLIDebugVector*); +#ifdef ENABLE_VFS static void _loadSymbols(struct CLIDebugger*, struct CLIDebugVector*); +#ifdef ENABLE_SCRIPTING +static void _source(struct CLIDebugger*, struct CLIDebugVector*); +#endif +#endif static void _setSymbol(struct CLIDebugger*, struct CLIDebugVector*); static void _findSymbol(struct CLIDebugger*, struct CLIDebugVector*); @@ -96,6 +98,9 @@ static struct CLIDebuggerCommandSummary _debuggerCommands[] = { { "help", _printHelp, "S", "Print help" }, { "listb", _listBreakpoints, "", "List breakpoints" }, { "listw", _listWatchpoints, "", "List watchpoints" }, +#ifdef ENABLE_VFS + { "load-symbols", _loadSymbols, "S", "Load symbols from an external file" }, +#endif { "next", _next, "", "Execute next instruction" }, { "print", _print, "S+", "Print a value" }, { "print/t", _printBin, "S+", "Print a value as binary" }, @@ -106,10 +111,12 @@ static struct CLIDebuggerCommandSummary _debuggerCommands[] = { { "r/2", _readHalfword, "I", "Read a halfword from a specified offset" }, { "r/4", _readWord, "I", "Read a word from a specified offset" }, { "set", _setSymbol, "SI", "Assign a symbol to an address" }, +#if defined(ENABLE_SCRIPTING) && defined(ENABLE_VFS) + { "source", _source, "S", "Load a script" }, +#endif { "stack", _setStackTraceMode, "S", "Change the stack tracing mode" }, { "status", _printStatus, "", "Print the current status" }, { "symbol", _findSymbol, "I", "Find the symbol name for an address" }, - { "load-symbols", _loadSymbols, "S", "Load symbols from an external file" }, { "trace", _trace, "Is", "Trace a number of instructions" }, { "w/1", _writeByte, "II", "Write a byte at a specified offset" }, { "w/2", _writeHalfword, "II", "Write a halfword at a specified offset" }, @@ -126,9 +133,6 @@ static struct CLIDebuggerCommandSummary _debuggerCommands[] = { { "x/1", _dumpByte, "Ii", "Examine bytes at a specified offset" }, { "x/2", _dumpHalfword, "Ii", "Examine halfwords at a specified offset" }, { "x/4", _dumpWord, "Ii", "Examine words at a specified offset" }, -#ifdef ENABLE_SCRIPTING - { "source", _source, "S", "Load a script" }, -#endif #if !defined(NDEBUG) && !defined(_WIN32) { "!", _breakInto, "", "Break into attached debugger (for developers)" }, #endif @@ -586,7 +590,7 @@ static void _dumpWord(struct CLIDebugger* debugger, struct CLIDebugVector* dv) { } } -#ifdef ENABLE_SCRIPTING +#if defined(ENABLE_SCRIPTING) && defined(ENABLE_VFS) static void _source(struct CLIDebugger* debugger, struct CLIDebugVector* dv) { if (!dv) { debugger->backend->printf(debugger->backend, "Needs a filename\n"); @@ -829,9 +833,11 @@ static void _trace(struct CLIDebugger* debugger, struct CLIDebugVector* dv) { if (debugger->traceRemaining == 0) { return; } +#ifdef ENABLE_VFS if (dv->next && dv->next->charValue) { debugger->traceVf = VFileOpen(dv->next->charValue, O_CREAT | O_WRONLY | O_APPEND); } +#endif if (_doTrace(debugger)) { debugger->d.isPaused = false; mDebuggerUpdatePaused(debugger->d.p); @@ -1398,6 +1404,7 @@ static void _setStackTraceMode(struct CLIDebugger* debugger, struct CLIDebugVect } } +#ifdef ENABLE_VFS static void _loadSymbols(struct CLIDebugger* debugger, struct CLIDebugVector* dv) { struct mDebuggerSymbols* symbolTable = debugger->d.p->core->symbolTable; if (!symbolTable) { @@ -1431,6 +1438,7 @@ static void _loadSymbols(struct CLIDebugger* debugger, struct CLIDebugVector* dv } vf->close(vf); } +#endif static void _setSymbol(struct CLIDebugger* debugger, struct CLIDebugVector* dv) { struct mDebuggerSymbols* symbolTable = debugger->d.p->core->symbolTable; diff --git a/src/debugger/cli-el-backend.c b/src/debugger/cli-el-backend.c index 382a05c145e..b32afb15961 100644 --- a/src/debugger/cli-el-backend.c +++ b/src/debugger/cli-el-backend.c @@ -85,6 +85,7 @@ static void CLIDebuggerEditLineInit(struct CLIDebuggerBackend* be) { history(elbe->histate, &ev, H_SETSIZE, 200); el_set(elbe->elstate, EL_HIST, history, elbe->histate); +#ifdef ENABLE_VFS char path[PATH_MAX + 1]; mCoreConfigDirectory(path, PATH_MAX); if (path[0]) { @@ -99,6 +100,7 @@ static void CLIDebuggerEditLineInit(struct CLIDebuggerBackend* be) { vf->close(vf); } } +#endif MutexInit(&elbe->promptMutex); ConditionInit(&elbe->promptRead); @@ -120,6 +122,7 @@ static void CLIDebuggerEditLineDeinit(struct CLIDebuggerBackend* be) { MutexUnlock(&elbe->promptMutex); ThreadJoin(&elbe->promptThread); +#ifdef ENABLE_VFS char path[PATH_MAX + 1]; mCoreConfigDirectory(path, PATH_MAX); if (path[0]) { @@ -139,6 +142,7 @@ static void CLIDebuggerEditLineDeinit(struct CLIDebuggerBackend* be) { vf->close(vf); } } +#endif history_end(elbe->histate); el_end(elbe->elstate); free(elbe); diff --git a/src/feature/CMakeLists.txt b/src/feature/CMakeLists.txt index b692338f496..966c2552043 100644 --- a/src/feature/CMakeLists.txt +++ b/src/feature/CMakeLists.txt @@ -3,10 +3,14 @@ set(SOURCE_FILES commandline.c proxy-backend.c thread-proxy.c - updater.c video-backend.c video-logger.c) +if(ENABLE_VFS) + list(APPEND SOURCE_FILES + updater.c) +endif() + set(GUI_FILES gui/cheats.c gui/gui-config.c diff --git a/src/feature/commandline.c b/src/feature/commandline.c index cdf788b1990..59735e69b02 100644 --- a/src/feature/commandline.c +++ b/src/feature/commandline.c @@ -245,6 +245,7 @@ bool mArgumentsApplyDebugger(const struct mArguments* args, struct mCore* core, } void mArgumentsApplyFileLoads(const struct mArguments* args, struct mCore* core) { +#ifdef ENABLE_VFS if (args->patch) { struct VFile* patch = VFileOpen(args->patch, O_RDONLY); if (patch) { @@ -266,6 +267,10 @@ void mArgumentsApplyFileLoads(const struct mArguments* args, struct mCore* core) } else { mCoreAutoloadCheats(core); } +#else + UNUSED(args); + UNUSED(core); +#endif } void mArgumentsDeinit(struct mArguments* args) { diff --git a/src/gb/core.c b/src/gb/core.c index 7023b29f738..9dbf36bc1e6 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -149,7 +149,7 @@ static bool _GBCoreInit(struct mCore* core) { gbcore->keys = 0; gb->keySource = &gbcore->keys; -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS mDirectorySetInit(&core->dirs); #endif @@ -161,7 +161,7 @@ static void _GBCoreDeinit(struct mCore* core) { GBDestroy(core->board); mappedMemoryFree(core->cpu, sizeof(struct SM83Core)); mappedMemoryFree(core->board, sizeof(struct GB)); -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS mDirectorySetDeinit(&core->dirs); #endif #ifdef ENABLE_DEBUGGERS @@ -597,7 +597,7 @@ static void _GBCoreReset(struct mCore* core) { } } -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS if (!gb->biosVf && core->opts.useBios) { struct VFile* bios = NULL; bool found = false; @@ -1108,7 +1108,7 @@ static void _GBCoreDetachDebugger(struct mCore* core) { static void _GBCoreLoadSymbols(struct mCore* core, struct VFile* vf) { core->symbolTable = mDebuggerSymbolTableCreate(); -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS if (!vf && core->dirs.base) { vf = mDirectorySetOpenSuffix(&core->dirs, core->dirs.base, ".sym", O_RDONLY); } diff --git a/src/gb/debugger/cli.c b/src/gb/debugger/cli.c index f32f299a364..0b3ec66788f 100644 --- a/src/gb/debugger/cli.c +++ b/src/gb/debugger/cli.c @@ -16,14 +16,14 @@ static void _GBCLIDebuggerInit(struct CLIDebuggerSystem*); static bool _GBCLIDebuggerCustom(struct CLIDebuggerSystem*); static void _frame(struct CLIDebugger*, struct CLIDebugVector*); -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS static void _load(struct CLIDebugger*, struct CLIDebugVector*); static void _save(struct CLIDebugger*, struct CLIDebugVector*); #endif struct CLIDebuggerCommandSummary _GBCLIDebuggerCommands[] = { { "frame", _frame, "", "Frame advance" }, -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS { "load", _load, "*", "Load a savestate" }, { "save", _save, "*", "Save a savestate" }, #endif @@ -78,7 +78,7 @@ static void _frame(struct CLIDebugger* debugger, struct CLIDebugVector* dv) { gbDebugger->inVblank = GBRegisterSTATGetMode(((struct GB*) gbDebugger->core->board)->memory.io[GB_REG_STAT]) == 1; } -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS static void _load(struct CLIDebugger* debugger, struct CLIDebugVector* dv) { struct CLIDebuggerBackend* be = debugger->backend; if (!dv || dv->type != CLIDV_INT_TYPE) { diff --git a/src/gba/cart/ereader.c b/src/gba/cart/ereader.c index 6a3ce58b0e5..fc4d4c11d54 100644 --- a/src/gba/cart/ereader.c +++ b/src/gba/cart/ereader.c @@ -875,7 +875,7 @@ void EReaderScanDestroy(struct EReaderScan* scan) { free(scan); } -#ifdef USE_PNG +#if defined(USE_PNG) && defined(ENABLE_VFS) struct EReaderScan* EReaderScanLoadImagePNG(const char* filename) { struct VFile* vf = VFileOpen(filename, O_RDONLY); if (!vf) { @@ -1564,6 +1564,7 @@ void EReaderScanOutputBitmap(const struct EReaderScan* scan, void* output, size_ } } +#ifdef ENABLE_VFS bool EReaderScanSaveRaw(const struct EReaderScan* scan, const char* filename, bool strict) { size_t blocks = EReaderBlockListSize(&scan->blocks); if (!blocks) { @@ -1633,5 +1634,6 @@ bool EReaderScanSaveRaw(const struct EReaderScan* scan, const char* filename, bo free(data); return true; } +#endif #endif diff --git a/src/gba/core.c b/src/gba/core.c index 4a437f36d54..47da3a0e00f 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -294,7 +294,7 @@ static bool _GBACoreInit(struct mCore* core) { gbacore->proxyRenderer.logger = NULL; #endif -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS mDirectorySetInit(&core->dirs); #endif @@ -306,7 +306,7 @@ static void _GBACoreDeinit(struct mCore* core) { GBADestroy(core->board); mappedMemoryFree(core->cpu, sizeof(struct ARMCore)); mappedMemoryFree(core->board, sizeof(struct GBA)); -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS mDirectorySetDeinit(&core->dirs); #endif #ifdef ENABLE_DEBUGGERS @@ -741,7 +741,7 @@ static void _GBACoreReset(struct mCore* core) { } gbacore->memoryBlockType = -2; -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS if (!gba->biosVf && core->opts.useBios) { struct VFile* bios = NULL; bool found = false; @@ -1244,7 +1244,7 @@ static void _GBACoreDetachDebugger(struct mCore* core) { static void _GBACoreLoadSymbols(struct mCore* core, struct VFile* vf) { bool closeAfter = false; core->symbolTable = mDebuggerSymbolTableCreate(); -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS #ifdef USE_ELF if (!vf && core->dirs.base) { closeAfter = true; diff --git a/src/gba/debugger/cli.c b/src/gba/debugger/cli.c index 8538f45157a..8cb6c6043d8 100644 --- a/src/gba/debugger/cli.c +++ b/src/gba/debugger/cli.c @@ -16,14 +16,14 @@ static void _GBACLIDebuggerInit(struct CLIDebuggerSystem*); static bool _GBACLIDebuggerCustom(struct CLIDebuggerSystem*); static void _frame(struct CLIDebugger*, struct CLIDebugVector*); -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS static void _load(struct CLIDebugger*, struct CLIDebugVector*); static void _save(struct CLIDebugger*, struct CLIDebugVector*); #endif struct CLIDebuggerCommandSummary _GBACLIDebuggerCommands[] = { { "frame", _frame, "", "Frame advance" }, -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS { "load", _load, "*", "Load a savestate" }, { "save", _save, "*", "Save a savestate" }, #endif @@ -77,7 +77,7 @@ static void _frame(struct CLIDebugger* debugger, struct CLIDebugVector* dv) { gbaDebugger->inVblank = GBARegisterDISPSTATGetInVblank(((struct GBA*) gbaDebugger->core->board)->memory.io[GBA_REG(DISPSTAT)]); } -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS static void _load(struct CLIDebugger* debugger, struct CLIDebugVector* dv) { struct CLIDebuggerBackend* be = debugger->backend; if (!dv || dv->type != CLIDV_INT_TYPE) { diff --git a/src/platform/3ds/CMakeLists.txt b/src/platform/3ds/CMakeLists.txt index ef70eed5101..7469fe6d49a 100644 --- a/src/platform/3ds/CMakeLists.txt +++ b/src/platform/3ds/CMakeLists.txt @@ -31,9 +31,9 @@ source_group("3DS-specific code" FILES ${OS_SRC}) if(USE_VFS_3DS) list(APPEND OS_DEFINES USE_VFS_3DS) else() - list(APPEND CORE_VFS_SRC ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c) + list(APPEND VFS_SRC ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c) endif() -set(CORE_VFS_SRC ${CORE_VFS_SRC} PARENT_SCOPE) +set(VFS_SRC ${VFS_SRC} PARENT_SCOPE) set(OS_DEFINES ${OS_DEFINES} PARENT_SCOPE) list(APPEND GUI_SRC diff --git a/src/platform/opengl/gles2.c b/src/platform/opengl/gles2.c index 6350bd287a5..fa6716be92f 100644 --- a/src/platform/opengl/gles2.c +++ b/src/platform/opengl/gles2.c @@ -1081,6 +1081,7 @@ static bool _loadUniform(struct Configuration* description, size_t pass, struct return true; } +#ifdef ENABLE_VFS bool mGLES2ShaderLoad(struct VideoShader* shader, struct VDir* dir) { struct VFile* manifest = dir->openFile(dir, "manifest.ini", O_RDONLY); if (!manifest) { @@ -1204,6 +1205,7 @@ bool mGLES2ShaderLoad(struct VideoShader* shader, struct VDir* dir) { ConfigurationDeinit(&description); return success; } +#endif void mGLES2ShaderFree(struct VideoShader* shader) { free((void*) shader->name); diff --git a/src/platform/opengl/gles2.h b/src/platform/opengl/gles2.h index e53a1bab586..e3f46a9c04e 100644 --- a/src/platform/opengl/gles2.h +++ b/src/platform/opengl/gles2.h @@ -106,8 +106,10 @@ void mGLES2ShaderDeinit(struct mGLES2Shader*); void mGLES2ShaderAttach(struct mGLES2Context*, struct mGLES2Shader*, size_t nShaders); void mGLES2ShaderDetach(struct mGLES2Context*); +#ifdef ENABLE_VFS struct VDir; bool mGLES2ShaderLoad(struct VideoShader*, struct VDir*); +#endif void mGLES2ShaderFree(struct VideoShader*); CXX_GUARD_END diff --git a/src/platform/psp2/CMakeLists.txt b/src/platform/psp2/CMakeLists.txt index c42f5355bd5..9653205fb69 100644 --- a/src/platform/psp2/CMakeLists.txt +++ b/src/platform/psp2/CMakeLists.txt @@ -10,8 +10,8 @@ file(GLOB OS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/psp2-*.c) set(OS_SRC ${OS_SRC} PARENT_SCOPE) source_group("PS Vita-specific code" FILES ${OS_SRC}) -list(APPEND CORE_VFS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/sce-vfs.c) -set(CORE_VFS_SRC ${CORE_VFS_SRC} PARENT_SCOPE) +list(APPEND VFS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/sce-vfs.c) +set(VFS_SRC ${VFS_SRC} PARENT_SCOPE) set(OS_LIB -lvita2d -l${M_LIBRARY} -lSceAppMgr_stub diff --git a/src/platform/switch/CMakeLists.txt b/src/platform/switch/CMakeLists.txt index 716b3344968..55db05d127b 100644 --- a/src/platform/switch/CMakeLists.txt +++ b/src/platform/switch/CMakeLists.txt @@ -5,7 +5,7 @@ find_library(GLAPI_LIBRARY glapi REQUIRED) find_library(EGL_LIBRARY EGL REQUIRED) set(OS_DEFINES _GNU_SOURCE IOAPI_NO_64) -list(APPEND CORE_VFS_SRC ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c) +list(APPEND VFS_SRC ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c) list(APPEND GUI_SRC ${CMAKE_CURRENT_SOURCE_DIR}/gui-font.c) include_directories(AFTER ${OPENGLES3_INCLUDE_DIR} ${OPENGL_EGL_INCLUDE_DIR}) @@ -17,7 +17,7 @@ else() find_library(NOUVEAU_LIBRARY drm_nouveau REQUIRED) list(APPEND OS_LIB nx) endif() -set(CORE_VFS_SRC ${CORE_VFS_SRC} PARENT_SCOPE) +set(VFS_SRC ${VFS_SRC} PARENT_SCOPE) set(OS_DEFINES ${OS_DEFINES} PARENT_SCOPE) set(OS_LIB ${OS_LIB} PARENT_SCOPE) diff --git a/src/platform/wii/CMakeLists.txt b/src/platform/wii/CMakeLists.txt index 569408523b7..f8e6984f4eb 100644 --- a/src/platform/wii/CMakeLists.txt +++ b/src/platform/wii/CMakeLists.txt @@ -9,14 +9,14 @@ if(WIIDRC_LIBRARY) endif() set(OS_DEFINES _GNU_SOURCE COLOR_16_BIT COLOR_5_6_5 IOAPI_NO_64 FIXED_ROM_BUFFER) -list(APPEND CORE_VFS_SRC ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-devlist.c) +list(APPEND VFS_SRC ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-devlist.c) include_directories(${CMAKE_CURRENT_BINARY_DIR}) list(APPEND OS_LIB wiiuse bte fat ogc) set(OS_LIB ${OS_LIB} PARENT_SCOPE) source_group("Wii-specific code" FILES ${OS_SRC}) -set(CORE_VFS_SRC ${CORE_VFS_SRC} PARENT_SCOPE) +set(VFS_SRC ${VFS_SRC} PARENT_SCOPE) set(OS_DEFINES ${OS_DEFINES} PARENT_SCOPE) list(APPEND GUI_SRC ${CMAKE_CURRENT_BINARY_DIR}/font.c ${CMAKE_CURRENT_BINARY_DIR}/icons.c ${CMAKE_CURRENT_SOURCE_DIR}/gui-font.c) diff --git a/src/script/CMakeLists.txt b/src/script/CMakeLists.txt index 0f64514c058..a72f48d2221 100644 --- a/src/script/CMakeLists.txt +++ b/src/script/CMakeLists.txt @@ -12,7 +12,7 @@ set(TEST_FILES test/classes.c test/types.c) -if(USE_JSON_C) +if(USE_JSON_C AND ENABLE_VFS) list(APPEND SOURCE_FILES storage.c) endif() diff --git a/src/script/context.c b/src/script/context.c index 47a4460f6e2..ab0937500ea 100644 --- a/src/script/context.c +++ b/src/script/context.c @@ -424,6 +424,7 @@ bool mScriptContextLoadVF(struct mScriptContext* context, const char* name, stru return info.context->load(info.context, name, vf); } +#ifdef ENABLE_VFS bool mScriptContextLoadFile(struct mScriptContext* context, const char* path) { struct VFile* vf = VFileOpen(path, O_RDONLY); if (!vf) { @@ -433,6 +434,7 @@ bool mScriptContextLoadFile(struct mScriptContext* context, const char* path) { vf->close(vf); return ret; } +#endif struct mScriptContext* mScriptActiveContext(void) { return ThreadLocalGetValue(_threadContext); diff --git a/src/script/image.c b/src/script/image.c index 2bd5a8736e8..533af131fb6 100644 --- a/src/script/image.c +++ b/src/script/image.c @@ -29,6 +29,7 @@ static struct mScriptValue* _mImageNew(unsigned width, unsigned height) { return result; } +#ifdef ENABLE_VFS static struct mScriptValue* _mImageLoad(const char* path) { struct mImage* image = mImageLoad(path); if (!image) { @@ -39,6 +40,7 @@ static struct mScriptValue* _mImageLoad(const char* path) { result->flags = mSCRIPT_VALUE_FLAG_DEINIT; return result; } +#endif static struct mScriptValue* _mImageNewPainter(struct mScriptValue* image) { mScriptValueRef(image); @@ -54,16 +56,10 @@ static struct mScriptValue* _mImageNewPainter(struct mScriptValue* image) { mSCRIPT_DECLARE_STRUCT_C_METHOD(mImage, U32, getPixel, mImageGetPixel, 2, U32, x, U32, y); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mImage, setPixel, mImageSetPixel, 3, U32, x, U32, y, U32, color); -mSCRIPT_DECLARE_STRUCT_C_METHOD_WITH_DEFAULTS(mImage, BOOL, save, mImageSave, 2, CHARP, path, CHARP, format); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mImage, _deinit, mImageDestroy, 0); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mImage, drawImageOpaque, mImageBlit, 3, CS(mImage), image, U32, x, U32, y); mSCRIPT_DECLARE_STRUCT_VOID_METHOD_WITH_DEFAULTS(mImage, drawImage, mImageCompositeWithAlpha, 4, CS(mImage), image, U32, x, U32, y, F32, alpha); -mSCRIPT_DEFINE_STRUCT_BINDING_DEFAULTS(mImage, save) - mSCRIPT_NO_DEFAULT, - mSCRIPT_CHARP("PNG") -mSCRIPT_DEFINE_DEFAULTS_END; - mSCRIPT_DEFINE_STRUCT_BINDING_DEFAULTS(mImage, drawImage) mSCRIPT_NO_DEFAULT, mSCRIPT_NO_DEFAULT, @@ -71,13 +67,23 @@ mSCRIPT_DEFINE_STRUCT_BINDING_DEFAULTS(mImage, drawImage) mSCRIPT_F32(1.0f) mSCRIPT_DEFINE_DEFAULTS_END; +#ifdef ENABLE_VFS +mSCRIPT_DECLARE_STRUCT_C_METHOD_WITH_DEFAULTS(mImage, BOOL, save, mImageSave, 2, CHARP, path, CHARP, format); +mSCRIPT_DEFINE_STRUCT_BINDING_DEFAULTS(mImage, save) + mSCRIPT_NO_DEFAULT, + mSCRIPT_CHARP("PNG") +mSCRIPT_DEFINE_DEFAULTS_END; +#endif + mSCRIPT_DEFINE_STRUCT(mImage) mSCRIPT_DEFINE_CLASS_DOCSTRING( "A single, static image." ) mSCRIPT_DEFINE_STRUCT_DEINIT(mImage) +#ifdef ENABLE_VFS mSCRIPT_DEFINE_DOCSTRING("Save the image to a file. Currently, only `PNG` format is supported") mSCRIPT_DEFINE_STRUCT_METHOD(mImage, save) +#endif mSCRIPT_DEFINE_DOCSTRING("Get the ARGB value of the pixel at a given coordinate") mSCRIPT_DEFINE_STRUCT_METHOD(mImage, getPixel) mSCRIPT_DEFINE_DOCSTRING("Set the ARGB value of the pixel at a given coordinate") @@ -93,7 +99,9 @@ mSCRIPT_DEFINE_STRUCT(mImage) mSCRIPT_DEFINE_END; mSCRIPT_BIND_FUNCTION(mImageNew_Binding, W(mImage), _mImageNew, 2, U32, width, U32, height); +#ifdef ENABLE_VFS mSCRIPT_BIND_FUNCTION(mImageLoad_Binding, W(mImage), _mImageLoad, 1, CHARP, path); +#endif mSCRIPT_BIND_FUNCTION(mImageNewPainter_Binding, W(mScriptPainter), _mImageNewPainter, 1, W(mImage), image); void _mPainterSetBlend(struct mPainter* painter, bool enable) { @@ -186,12 +194,16 @@ mSCRIPT_DEFINE_END; void mScriptContextAttachImage(struct mScriptContext* context) { mScriptContextExportNamespace(context, "image", (struct mScriptKVPair[]) { mSCRIPT_KV_PAIR(new, &mImageNew_Binding), +#ifdef ENABLE_VFS mSCRIPT_KV_PAIR(load, &mImageLoad_Binding), +#endif mSCRIPT_KV_PAIR(newPainter, &mImageNewPainter_Binding), mSCRIPT_KV_SENTINEL }); mScriptContextSetDocstring(context, "image", "Methods for creating struct::mImage and struct::mPainter instances"); mScriptContextSetDocstring(context, "image.new", "Create a new image with the given dimensions"); +#ifdef ENABLE_VFS mScriptContextSetDocstring(context, "image.load", "Load an image from a path. Currently, only `PNG` format is supported"); +#endif mScriptContextSetDocstring(context, "image.newPainter", "Create a new painter from an existing image"); } diff --git a/src/util/configuration.c b/src/util/configuration.c index dbcefef8fc4..8b7320b5c32 100644 --- a/src/util/configuration.c +++ b/src/util/configuration.c @@ -160,6 +160,7 @@ static char* _vfgets(char* stream, int size, void* user) { return 0; } +#ifdef ENABLE_VFS bool ConfigurationRead(struct Configuration* configuration, const char* path) { struct VFile* vf = VFileOpen(path, O_RDONLY); if (!vf) { @@ -170,12 +171,6 @@ bool ConfigurationRead(struct Configuration* configuration, const char* path) { return res; } -bool ConfigurationReadVFile(struct Configuration* configuration, struct VFile* vf) { - HashTableClear(&configuration->root); - HashTableClear(&configuration->sections); - return ini_parse_stream(_vfgets, vf, _iniRead, configuration) == 0; -} - bool ConfigurationWrite(const struct Configuration* configuration, const char* path) { struct VFile* vf = VFileOpen(path, O_WRONLY | O_CREAT | O_TRUNC); if (!vf) { @@ -186,12 +181,6 @@ bool ConfigurationWrite(const struct Configuration* configuration, const char* p return res; } -bool ConfigurationWriteVFile(const struct Configuration* configuration, struct VFile* vf) { - HashTableEnumerate(&configuration->root, _keyHandler, vf); - HashTableEnumerate(&configuration->sections, _sectionHandler, vf); - return true; -} - bool ConfigurationWriteSection(const struct Configuration* configuration, const char* path, const char* section) { const struct Table* currentSection = &configuration->root; struct VFile* vf = VFileOpen(path, O_WRONLY | O_CREAT | O_APPEND); @@ -213,6 +202,19 @@ bool ConfigurationWriteSection(const struct Configuration* configuration, const vf->close(vf); return true; } +#endif + +bool ConfigurationReadVFile(struct Configuration* configuration, struct VFile* vf) { + HashTableClear(&configuration->root); + HashTableClear(&configuration->sections); + return ini_parse_stream(_vfgets, vf, _iniRead, configuration) == 0; +} + +bool ConfigurationWriteVFile(const struct Configuration* configuration, struct VFile* vf) { + HashTableEnumerate(&configuration->root, _keyHandler, vf); + HashTableEnumerate(&configuration->sections, _sectionHandler, vf); + return true; +} void ConfigurationEnumerateSections(const struct Configuration* configuration, void (*handler)(const char* sectionName, void* user), void* user) { struct ConfigurationSectionHandlerData handlerData = { handler, user }; diff --git a/src/util/image.c b/src/util/image.c index f1f1a0fef47..64e8aeec657 100644 --- a/src/util/image.c +++ b/src/util/image.c @@ -132,6 +132,7 @@ struct mImage* mImageCreateFromConstBuffer(unsigned width, unsigned height, unsi return image; } +#ifdef ENABLE_VFS struct mImage* mImageLoad(const char* path) { struct VFile* vf = VFileOpen(path, O_RDONLY); if (!vf) { @@ -141,6 +142,7 @@ struct mImage* mImageLoad(const char* path) { vf->close(vf); return image; } +#endif #ifdef USE_PNG static struct mImage* mImageLoadPNG(struct VFile* vf) { @@ -299,6 +301,7 @@ void mImageDestroy(struct mImage* image) { free(image); } +#ifdef ENABLE_VFS bool mImageSave(const struct mImage* image, const char* path, const char* format) { struct VFile* vf = VFileOpen(path, O_WRONLY | O_CREAT | O_TRUNC); if (!vf) { @@ -314,6 +317,7 @@ bool mImageSave(const struct mImage* image, const char* path, const char* format vf->close(vf); return success; } +#endif #ifdef USE_PNG bool mImageSavePNG(const struct mImage* image, struct VFile* vf) { diff --git a/src/util/test/vfs.c b/src/util/test/vfs.c index 4fd9952759b..2d1cfd56ad4 100644 --- a/src/util/test/vfs.c +++ b/src/util/test/vfs.c @@ -7,7 +7,7 @@ #include -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS M_TEST_DEFINE(openNullPathR) { struct VFile* vf = VFileOpen(NULL, O_RDONLY); assert_null(vf); @@ -146,7 +146,7 @@ M_TEST_DEFINE(mapMemChunk) { } M_TEST_SUITE_DEFINE(VFS, -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS cmocka_unit_test(openNullPathR), cmocka_unit_test(openNullPathW), cmocka_unit_test(openNullPathCreate), diff --git a/src/util/vfs.c b/src/util/vfs.c index d99f5020f9d..09ae8104711 100644 --- a/src/util/vfs.c +++ b/src/util/vfs.c @@ -18,6 +18,7 @@ #include #endif +#ifdef ENABLE_VFS struct VFile* VFileOpen(const char* path, int flags) { #ifdef USE_VFS_FILE const char* chflags; @@ -115,6 +116,7 @@ struct VDir* VDirOpenArchive(const char* path) { #endif return dir; } +#endif ssize_t VFileReadline(struct VFile* vf, char* buffer, size_t size) { size_t bytesRead = 0; @@ -246,6 +248,7 @@ void makeAbsolute(const char* path, const char* base, char* out) { strncpy(out, buf, PATH_MAX); } +#ifdef ENABLE_VFS struct VFile* VDirFindFirst(struct VDir* dir, bool (*filter)(struct VFile*)) { dir->rewind(dir); struct VDirEntry* dirent = dir->listNext(dir); @@ -310,3 +313,4 @@ struct VFile* VDirFindNextAvailable(struct VDir* dir, const char* basename, cons path[PATH_MAX - 1] = '\0'; return dir->openFile(dir, path, mode); } +#endif From 267167a236f1451da59cf17105e07f2836bd0c3a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 03:24:22 -0700 Subject: [PATCH 101/338] Libretro: Fix non-ENABLE_VFS build --- CMakeLists.txt | 2 +- src/platform/libretro/libretro.c | 6 +++++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index ae561189e9a..7fc7e05fb11 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -995,7 +995,7 @@ if(BUILD_LIBRETRO) file(GLOB RETRO_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/libretro/*.c) add_library(${BINARY_NAME}_libretro SHARED ${CORE_SRC} ${RETRO_SRC}) add_dependencies(${BINARY_NAME}_libretro ${BINARY_NAME}-version-info) - set_target_properties(${BINARY_NAME}_libretro PROPERTIES PREFIX "" COMPILE_DEFINITIONS "__LIBRETRO__;COLOR_16_BIT;COLOR_5_6_5;DISABLE_THREADING;MGBA_STANDALONE;${OS_DEFINES};${FUNCTION_DEFINES};MINIMAL_CORE=2") + set_target_properties(${BINARY_NAME}_libretro PROPERTIES PREFIX "" COMPILE_DEFINITIONS "__LIBRETRO__;COLOR_16_BIT;COLOR_5_6_5;DISABLE_THREADING;MGBA_STANDALONE;${OS_DEFINES};${FUNCTION_DEFINES};ENABLE_VFS;MINIMAL_CORE=2") target_link_libraries(${BINARY_NAME}_libretro ${OS_LIB}) if(MSVC) install(TARGETS ${BINARY_NAME}_libretro RUNTIME DESTINATION ${LIBRETRO_LIBDIR} COMPONENT ${BINARY_NAME}_libretro) diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index 8478eb29820..86a69283711 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -848,9 +848,11 @@ bool retro_load_game(const struct retro_game_info* game) { dataSize = game->size; memcpy(data, game->data, game->size); rom = VFileFromMemory(data, game->size); +#ifdef ENABLE_VFS } else { - data = 0; + data = NULL; rom = VFileOpen(game->path, O_RDONLY); +#endif } if (!rom) { return false; @@ -973,6 +975,7 @@ bool retro_load_game(const struct retro_game_info* game) { } #endif +#ifdef ENABLE_VFS if (core->opts.useBios && sysDir && biosName) { snprintf(biosPath, sizeof(biosPath), "%s%s%s", sysDir, PATH_SEP, biosName); struct VFile* bios = VFileOpen(biosPath, O_RDONLY); @@ -980,6 +983,7 @@ bool retro_load_game(const struct retro_game_info* game) { core->loadBIOS(core, bios, 0); } } +#endif core->reset(core); _setupMaps(core); From d5e49a5981da1d7e08c6174c8a8f0718a27eab00 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 03:34:55 -0700 Subject: [PATCH 102/338] All: Remove unmaintained RasPi and Pandora code --- CMakeLists.txt | 14 ---- src/platform/sdl/CMakeLists.txt | 38 +++------- src/platform/sdl/gles2-sdl.c | 15 +--- src/platform/sdl/main.c | 4 - src/platform/sdl/main.h | 24 ------ src/platform/sdl/pandora-sdl.c | 129 -------------------------------- src/platform/sdl/rpi-common.c | 84 --------------------- src/platform/sdl/rpi-common.h | 20 ----- src/platform/sdl/sdl-events.c | 18 ----- 9 files changed, 11 insertions(+), 335 deletions(-) delete mode 100644 src/platform/sdl/pandora-sdl.c delete mode 100644 src/platform/sdl/rpi-common.c delete mode 100644 src/platform/sdl/rpi-common.h diff --git a/CMakeLists.txt b/CMakeLists.txt index 7fc7e05fb11..3767bae8bc0 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -269,20 +269,6 @@ if(CMAKE_C_COMPILER_ID STREQUAL "GNU" OR CMAKE_C_COMPILER_ID STREQUAL "Clang" OR set(CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELEASE} -gdwarf") endif() -if(BUILD_BBB OR BUILD_RASPI OR BUILD_PANDORA) - if(NOT BUILD_EGL) - add_definitions(-DCOLOR_16_BIT -DCOLOR_5_6_5) - endif() -endif() - -if(BUILD_RASPI) - set(BUILD_GL OFF CACHE BOOL "OpenGL not supported" FORCE) -endif() - -if(BUILD_PANDORA) - add_definitions(-DBUILD_PANDORA) -endif() - if(CMAKE_SYSTEM_PROCESSOR MATCHES "arm.*") enable_language(ASM) endif() diff --git a/src/platform/sdl/CMakeLists.txt b/src/platform/sdl/CMakeLists.txt index ca1919da9a3..38e328d731c 100644 --- a/src/platform/sdl/CMakeLists.txt +++ b/src/platform/sdl/CMakeLists.txt @@ -80,37 +80,19 @@ set(SDLMAIN_LIBRARY "${SDLMAIN_LIBRARY}" PARENT_SCOPE) set(MAIN_SRC ${CMAKE_CURRENT_SOURCE_DIR}/main.c) -if(BUILD_RASPI) - add_definitions(-DBUILD_RASPI) - list(APPEND PLATFORM_SRC ${PROJECT_SOURCE_DIR}/src/platform/opengl/gles2.c ${CMAKE_CURRENT_SOURCE_DIR}/gl-common.c ${CMAKE_CURRENT_SOURCE_DIR}/rpi-common.c) +if(BUILD_GL) + list(APPEND MAIN_SRC ${CMAKE_CURRENT_SOURCE_DIR}/gl-sdl.c) + list(APPEND PLATFORM_SRC ${CMAKE_CURRENT_SOURCE_DIR}/gl-common.c) +endif() +if(BUILD_GLES2) list(APPEND MAIN_SRC ${CMAKE_CURRENT_SOURCE_DIR}/gles2-sdl.c) - set(OPENGLES2_LIBRARY "-lEGL -lGLESv2 -lbcm_host") - set(BUILD_GLES2 ON CACHE BOOL "Using OpenGL|ES 2" FORCE) - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fgnu89-inline") - add_executable(${BINARY_NAME}-rpi ${PLATFORM_SRC} ${MAIN_SRC}) - set_target_properties(${BINARY_NAME}-rpi PROPERTIES COMPILE_DEFINITIONS "${FEATURE_DEFINES};${FUNCTION_DEFINES}") - target_link_libraries(${BINARY_NAME}-rpi ${BINARY_NAME} ${PLATFORM_LIBRARY} ${OPENGLES2_LIBRARY}) - install(TARGETS ${BINARY_NAME}-rpi DESTINATION ${CMAKE_INSTALL_BINDIR} COMPONENT ${BINARY_NAME}-rpi) - unset(OPENGLES2_INCLUDE_DIR CACHE) # Clear NOTFOUND + list(APPEND PLATFORM_SRC ${CMAKE_CURRENT_SOURCE_DIR}/gl-common.c) + include_directories(${OPENGLES2_INCLUDE_DIR}) endif() - -if(BUILD_PANDORA) - list(APPEND MAIN_SRC ${CMAKE_CURRENT_SOURCE_DIR}/pandora-sdl.c) +if(SDL_VERSION EQUAL "2") + list(APPEND MAIN_SRC ${CMAKE_CURRENT_SOURCE_DIR}/sw-sdl2.c) else() - if(BUILD_GL) - list(APPEND MAIN_SRC ${CMAKE_CURRENT_SOURCE_DIR}/gl-sdl.c) - list(APPEND PLATFORM_SRC ${CMAKE_CURRENT_SOURCE_DIR}/gl-common.c) - endif() - if(BUILD_GLES2) - list(APPEND MAIN_SRC ${CMAKE_CURRENT_SOURCE_DIR}/gles2-sdl.c) - list(APPEND PLATFORM_SRC ${CMAKE_CURRENT_SOURCE_DIR}/gl-common.c) - include_directories(${OPENGLES2_INCLUDE_DIR}) - endif() - if(SDL_VERSION EQUAL "2") - list(APPEND MAIN_SRC ${CMAKE_CURRENT_SOURCE_DIR}/sw-sdl2.c) - else() - list(APPEND MAIN_SRC ${CMAKE_CURRENT_SOURCE_DIR}/sw-sdl1.c) - endif() + list(APPEND MAIN_SRC ${CMAKE_CURRENT_SOURCE_DIR}/sw-sdl1.c) endif() if(ENABLE_SCRIPTING) diff --git a/src/platform/sdl/gles2-sdl.c b/src/platform/sdl/gles2-sdl.c index 9bae33b9552..a4aa386df6d 100644 --- a/src/platform/sdl/gles2-sdl.c +++ b/src/platform/sdl/gles2-sdl.c @@ -6,9 +6,6 @@ #include "main.h" #include "gl-common.h" -#ifdef BUILD_RASPI -#include "rpi-common.h" -#endif #include @@ -43,11 +40,7 @@ bool mSDLGLES2Init(struct mSDLRenderer* renderer) { renderer->gl2.d.lockAspectRatio = renderer->lockAspectRatio; renderer->gl2.d.lockIntegerScaling = renderer->lockIntegerScaling; renderer->gl2.d.filter = renderer->filter; -#ifdef BUILD_RASPI - renderer->gl2.d.swap = mRPIGLCommonSwap; -#else renderer->gl2.d.swap = mSDLGLCommonSwap; -#endif renderer->gl2.d.init(&renderer->gl2.d, 0); struct mRectangle dims = { @@ -66,13 +59,7 @@ void mSDLGLES2Deinit(struct mSDLRenderer* renderer) { if (renderer->gl2.d.deinit) { renderer->gl2.d.deinit(&renderer->gl2.d); } -#ifdef BUILD_RASPI - eglMakeCurrent(renderer->eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT); - eglDestroySurface(renderer->eglDisplay, renderer->eglSurface); - eglDestroyContext(renderer->eglDisplay, renderer->eglContext); - eglTerminate(renderer->eglDisplay); - bcm_host_deinit(); -#elif SDL_VERSION_ATLEAST(2, 0, 0) +#if SDL_VERSION_ATLEAST(2, 0, 0) SDL_GL_DeleteContext(renderer->glCtx); #endif free(renderer->outputBuffer); diff --git a/src/platform/sdl/main.c b/src/platform/sdl/main.c index 1a1d3f6fc76..b1b850e21fb 100644 --- a/src/platform/sdl/main.c +++ b/src/platform/sdl/main.c @@ -133,11 +133,7 @@ int main(int argc, char** argv) { mSDLGLCreate(&renderer); } else #elif defined(BUILD_GLES2) || defined(USE_EPOXY) -#ifdef BUILD_RASPI - mRPIGLCommonInit(&renderer); -#else if (mSDLGLCommonInit(&renderer)) -#endif { mSDLGLES2Create(&renderer); } else diff --git a/src/platform/sdl/main.h b/src/platform/sdl/main.h index 10135da2fd7..43701b3c26d 100644 --- a/src/platform/sdl/main.h +++ b/src/platform/sdl/main.h @@ -18,17 +18,6 @@ CXX_GUARD_START #include "platform/opengl/gl.h" #endif -#ifdef BUILD_RASPI -#pragma GCC diagnostic push -#pragma GCC diagnostic ignored "-Wunused-function" -#pragma GCC diagnostic ignored "-Wunused-but-set-variable" -#include -#include - -#include -#pragma GCC diagnostic pop -#endif - #if defined(BUILD_GLES2) || defined(BUILD_GLES3) || defined(USE_EPOXY) #include "gl-common.h" #include "platform/opengl/gles2.h" @@ -82,19 +71,6 @@ struct mSDLRenderer { pixman_image_t* pix; pixman_image_t* screenpix; #endif - -#ifdef BUILD_RASPI - EGLDisplay eglDisplay; - EGLSurface eglSurface; - EGLContext eglContext; - EGL_DISPMANX_WINDOW_T eglWindow; -#endif - -#ifdef BUILD_PANDORA - int fb; - int odd; - void* base[2]; -#endif }; void mSDLSWCreate(struct mSDLRenderer* renderer); diff --git a/src/platform/sdl/pandora-sdl.c b/src/platform/sdl/pandora-sdl.c deleted file mode 100644 index 673d419b6ad..00000000000 --- a/src/platform/sdl/pandora-sdl.c +++ /dev/null @@ -1,129 +0,0 @@ -/* Copyright (c) 2013-2015 Jeffrey Pfau - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include "main.h" - -#include "gba/supervisor/thread.h" - -#include -#include -#include -#include - -#ifndef FBIO_WAITFORVSYNC -#define FBIO_WAITFORVSYNC _IOW('F', 0x20, __u32) -#endif - -static bool mSDLInit(struct SDLSoftwareRenderer* renderer); -static void mSDLRunloop(struct GBAThread* context, struct SDLSoftwareRenderer* renderer); -static void mSDLDeinit(struct SDLSoftwareRenderer* renderer); - -void mSDLGLCreate(struct SDLSoftwareRenderer* renderer) { - renderer->init = mSDLInit; - renderer->deinit = mSDLDeinit; - renderer->runloop = mSDLRunloop; -} - -void mSDLSWCreate(struct SDLSoftwareRenderer* renderer) { - renderer->init = mSDLInit; - renderer->deinit = mSDLDeinit; - renderer->runloop = mSDLRunloop; -} - -bool mSDLInit(struct SDLSoftwareRenderer* renderer) { - SDL_SetVideoMode(800, 480, 16, SDL_FULLSCREEN); - - renderer->odd = 0; - renderer->fb = open("/dev/fb1", O_RDWR); - if (renderer->fb < 0) { - return false; - } - - struct omapfb_plane_info plane; - struct omapfb_mem_info mem; - if (ioctl(renderer->fb, OMAPFB_QUERY_PLANE, &plane) < 0) { - return false; - } - if (ioctl(renderer->fb, OMAPFB_QUERY_MEM, &mem) < 0) { - return false; - } - - if (plane.enabled) { - plane.enabled = 0; - ioctl(renderer->fb, OMAPFB_SETUP_PLANE, &plane); - } - - mem.size = GBA_VIDEO_HORIZONTAL_PIXELS * GBA_VIDEO_VERTICAL_PIXELS * 4; - ioctl(renderer->fb, OMAPFB_SETUP_MEM, &mem); - - plane.enabled = 1; - plane.pos_x = 40; - plane.pos_y = 0; - plane.out_width = 720; - plane.out_height = 480; - ioctl(renderer->fb, OMAPFB_SETUP_PLANE, &plane); - - struct fb_var_screeninfo info; - ioctl(renderer->fb, FBIOGET_VSCREENINFO, &info); - info.xres = GBA_VIDEO_HORIZONTAL_PIXELS; - info.yres = GBA_VIDEO_VERTICAL_PIXELS; - info.xres_virtual = GBA_VIDEO_HORIZONTAL_PIXELS; - info.yres_virtual = GBA_VIDEO_VERTICAL_PIXELS * 2; - info.bits_per_pixel = 16; - ioctl(renderer->fb, FBIOPUT_VSCREENINFO, &info); - - renderer->odd = 0; - renderer->base[0] = mmap(0, GBA_VIDEO_HORIZONTAL_PIXELS * GBA_VIDEO_VERTICAL_PIXELS * 4, PROT_READ | PROT_WRITE, MAP_SHARED, renderer->fb, 0); - renderer->base[1] = (uint16_t*) renderer->base[0] + GBA_VIDEO_HORIZONTAL_PIXELS * GBA_VIDEO_VERTICAL_PIXELS; - - renderer->d.outputBuffer = renderer->base[0]; - renderer->d.outputBufferStride = GBA_VIDEO_HORIZONTAL_PIXELS; - return true; -} - -void mSDLRunloop(struct GBAThread* context, struct SDLSoftwareRenderer* renderer) { - SDL_Event event; - - while (context->state < THREAD_EXITING) { - while (SDL_PollEvent(&event)) { - mSDLHandleEventGBA(context, &renderer->player, &event); - } - - if (mCoreSyncWaitFrameStart(&context->sync)) { - struct fb_var_screeninfo info; - ioctl(renderer->fb, FBIOGET_VSCREENINFO, &info); - info.yoffset = GBA_VIDEO_VERTICAL_PIXELS * renderer->odd; - ioctl(renderer->fb, FBIOPAN_DISPLAY, &info); - - int arg = 0; - ioctl(renderer->fb, FBIO_WAITFORVSYNC, &arg); - - renderer->odd = !renderer->odd; - renderer->d.outputBuffer = renderer->base[renderer->odd]; - } - mCoreSyncWaitFrameEnd(&context->sync); - } -} - -void mSDLDeinit(struct SDLSoftwareRenderer* renderer) { - munmap(renderer->base[0], GBA_VIDEO_HORIZONTAL_PIXELS * GBA_VIDEO_VERTICAL_PIXELS * 4); - - struct omapfb_plane_info plane; - struct omapfb_mem_info mem; - ioctl(renderer->fb, OMAPFB_QUERY_PLANE, &plane); - ioctl(renderer->fb, OMAPFB_QUERY_MEM, &mem); - - mem.size = 0; - ioctl(renderer->fb, OMAPFB_SETUP_MEM, &mem); - - plane.enabled = 0; - plane.pos_x = 0; - plane.pos_y = 0; - plane.out_width = 0; - plane.out_height = 0; - ioctl(renderer->fb, OMAPFB_SETUP_PLANE, &plane); - - close(renderer->fb); -} diff --git a/src/platform/sdl/rpi-common.c b/src/platform/sdl/rpi-common.c deleted file mode 100644 index be141718e15..00000000000 --- a/src/platform/sdl/rpi-common.c +++ /dev/null @@ -1,84 +0,0 @@ -/* Copyright (c) 2013-2015 Jeffrey Pfau - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include "main.h" - -#include - -void mRPIGLCommonSwap(struct VideoBackend* context) { - struct mSDLRenderer* renderer = (struct mSDLRenderer*) context->user; - eglSwapBuffers(renderer->eglDisplay, renderer->eglSurface); -} - -void mRPIGLCommonInit(struct mSDLRenderer* renderer) { - bcm_host_init(); - renderer->eglDisplay = eglGetDisplay(EGL_DEFAULT_DISPLAY); - int major, minor; - if (EGL_FALSE == eglInitialize(renderer->eglDisplay, &major, &minor)) { - printf("Failed to initialize EGL"); - return false; - } - - if (EGL_FALSE == eglBindAPI(EGL_OPENGL_ES_API)) { - printf("Failed to get GLES API"); - return false; - } - - const EGLint requestConfig[] = { - EGL_RED_SIZE, 5, - EGL_GREEN_SIZE, 5, - EGL_BLUE_SIZE, 5, - EGL_ALPHA_SIZE, 1, - EGL_SURFACE_TYPE, EGL_WINDOW_BIT, - EGL_NONE - }; - - EGLConfig config; - EGLint numConfigs; - - if (EGL_FALSE == eglChooseConfig(renderer->eglDisplay, requestConfig, &config, 1, &numConfigs)) { - printf("Failed to choose EGL config\n"); - return false; - } - - const EGLint contextAttributes[] = { - EGL_CONTEXT_CLIENT_VERSION, 2, - EGL_NONE - }; - - int dispWidth = 240, dispHeight = 160, adjWidth; - renderer->eglContext = eglCreateContext(renderer->eglDisplay, config, EGL_NO_CONTEXT, contextAttributes); - graphics_get_display_size(0, &dispWidth, &dispHeight); - adjWidth = dispHeight / 2 * 3; - - DISPMANX_DISPLAY_HANDLE_T display = vc_dispmanx_display_open(0); - DISPMANX_UPDATE_HANDLE_T update = vc_dispmanx_update_start(0); - - VC_RECT_T destRect = { - .x = (dispWidth - adjWidth) / 2, - .y = 0, - .width = adjWidth, - .height = dispHeight - }; - - VC_RECT_T srcRect = { - .x = 0, - .y = 0, - .width = 240 << 16, - .height = 160 << 16 - }; - - DISPMANX_ELEMENT_HANDLE_T element = vc_dispmanx_element_add(update, display, 0, &destRect, 0, &srcRect, DISPMANX_PROTECTION_NONE, 0, 0, 0); - vc_dispmanx_update_submit_sync(update); - - renderer->eglWindow.element = element; - renderer->eglWindow.width = dispWidth; - renderer->eglWindow.height = dispHeight; - - renderer->eglSurface = eglCreateWindowSurface(renderer->eglDisplay, config, &renderer->eglWindow, 0); - if (EGL_FALSE == eglMakeCurrent(renderer->eglDisplay, renderer->eglSurface, renderer->eglSurface, renderer->eglContext)) { - return false; - } -} diff --git a/src/platform/sdl/rpi-common.h b/src/platform/sdl/rpi-common.h deleted file mode 100644 index b58532de531..00000000000 --- a/src/platform/sdl/rpi-common.h +++ /dev/null @@ -1,20 +0,0 @@ -/* Copyright (c) 2013-2015 Jeffrey Pfau - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#ifndef SDL_RPI_COMMON_H -#define SDL_RPI_COMMON_H - -#include - -CXX_GUARD_START - -#include "main.h" - -void mRPIGLCommonSwap(struct VideoBackend* context); -void mRPIGLCommonInit(struct mSDLRenderer* renderer); - -CXX_GUARD_END - -#endif diff --git a/src/platform/sdl/sdl-events.c b/src/platform/sdl/sdl-events.c index 950bb94f3c4..afeedba68dc 100644 --- a/src/platform/sdl/sdl-events.c +++ b/src/platform/sdl/sdl-events.c @@ -143,18 +143,6 @@ void mSDLEventsLoadConfig(struct mSDLEvents* context, const struct Configuration } void mSDLInitBindingsGBA(struct mInputMap* inputMap) { -#ifdef BUILD_PANDORA - mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_PAGEDOWN, GBA_KEY_A); - mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_END, GBA_KEY_B); - mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_RSHIFT, GBA_KEY_L); - mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_RCTRL, GBA_KEY_R); - mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_LALT, GBA_KEY_START); - mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_LCTRL, GBA_KEY_SELECT); - mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_UP, GBA_KEY_UP); - mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_DOWN, GBA_KEY_DOWN); - mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_LEFT, GBA_KEY_LEFT); - mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_RIGHT, GBA_KEY_RIGHT); -#else mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_x, GBA_KEY_A); mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_z, GBA_KEY_B); mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_a, GBA_KEY_L); @@ -165,7 +153,6 @@ void mSDLInitBindingsGBA(struct mInputMap* inputMap) { mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_DOWN, GBA_KEY_DOWN); mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_LEFT, GBA_KEY_LEFT); mInputBindKey(inputMap, SDL_BINDING_KEY, SDLK_RIGHT, GBA_KEY_RIGHT); -#endif #if SDL_VERSION_ATLEAST(2, 0, 0) mInputBindKey(inputMap, SDL_BINDING_CONTROLLER, SDL_CONTROLLER_BUTTON_A, GBA_KEY_A); @@ -522,11 +509,6 @@ static void _mSDLHandleKeypress(struct mCoreThread* context, struct mSDLPlayer* context->frameCallback = _pauseAfterFrame; mCoreThreadUnpause(context); return; -#ifdef BUILD_PANDORA - case SDLK_ESCAPE: - mCoreThreadEnd(context); - return; -#endif default: if ((event->keysym.mod & GUI_MOD) && (event->keysym.mod & GUI_MOD) == event->keysym.mod) { switch (event->keysym.sym) { From 3f54bcbc878b8cc27211adf729d6231474e53976 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 04:19:50 -0700 Subject: [PATCH 103/338] GB, GBA Audio: More efficient sample writing --- src/gb/audio.c | 14 +++++--------- src/gba/audio.c | 14 +++++--------- 2 files changed, 10 insertions(+), 18 deletions(-) diff --git a/src/gb/audio.c b/src/gb/audio.c index 4230fb88c21..9603175a827 100644 --- a/src/gb/audio.c +++ b/src/gb/audio.c @@ -823,15 +823,11 @@ static void _sample(struct mTiming* timing, void* user, uint32_t cyclesLate) { mCoreSyncLockAudio(audio->p->sync); unsigned produced; - int i; - for (i = 0; i < GB_MAX_SAMPLES; ++i) { - int16_t sample[2] = { - audio->currentSamples[i].left, - audio->currentSamples[i].right - }; - mAudioBufferWrite(&audio->buffer, sample, 1); - if (audio->p->stream && audio->p->stream->postAudioFrame) { - audio->p->stream->postAudioFrame(audio->p->stream, sample[0], sample[1]); + mAudioBufferWrite(&audio->buffer, (int16_t*) audio->currentSamples, GB_MAX_SAMPLES); + if (audio->p->stream && audio->p->stream->postAudioFrame) { + int i; + for (i = 0; i < GB_MAX_SAMPLES; ++i) { + audio->p->stream->postAudioFrame(audio->p->stream, audio->currentSamples[i].left,audio->currentSamples[i].right); } } diff --git a/src/gba/audio.c b/src/gba/audio.c index 8ccc7f9d800..8c07bcb511e 100644 --- a/src/gba/audio.c +++ b/src/gba/audio.c @@ -393,15 +393,11 @@ static void _sample(struct mTiming* timing, void* user, uint32_t cyclesLate) { mCoreSyncLockAudio(audio->p->sync); unsigned produced; - int i; - for (i = 0; i < samples; ++i) { - int16_t sample[2] = { - audio->currentSamples[i].left, - audio->currentSamples[i].right - }; - mAudioBufferWrite(&audio->psg.buffer, sample, 1); - if (audio->p->stream && audio->p->stream->postAudioFrame) { - audio->p->stream->postAudioFrame(audio->p->stream, sample[0], sample[1]); + mAudioBufferWrite(&audio->psg.buffer, (int16_t*) audio->currentSamples, samples); + if (audio->p->stream && audio->p->stream->postAudioFrame) { + int i; + for (i = 0; i < samples; ++i) { + audio->p->stream->postAudioFrame(audio->p->stream, audio->currentSamples[i].left,audio->currentSamples[i].right); } } produced = mAudioBufferAvailable(&audio->psg.buffer); From 2bce03023bb051aeb22e16a2b3a7160713c672b7 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 21:38:54 -0700 Subject: [PATCH 104/338] GB, GBA Audio: Refactor stream code to do less when no stream is present --- src/gb/audio.c | 25 +++++++++++++------------ src/gba/audio.c | 24 +++++++++++++----------- 2 files changed, 26 insertions(+), 23 deletions(-) diff --git a/src/gb/audio.c b/src/gb/audio.c index 9603175a827..b090018f692 100644 --- a/src/gb/audio.c +++ b/src/gb/audio.c @@ -822,25 +822,26 @@ static void _sample(struct mTiming* timing, void* user, uint32_t cyclesLate) { GBAudioSample(audio, mTimingCurrentTime(audio->timing)); mCoreSyncLockAudio(audio->p->sync); - unsigned produced; mAudioBufferWrite(&audio->buffer, (int16_t*) audio->currentSamples, GB_MAX_SAMPLES); - if (audio->p->stream && audio->p->stream->postAudioFrame) { - int i; - for (i = 0; i < GB_MAX_SAMPLES; ++i) { - audio->p->stream->postAudioFrame(audio->p->stream, audio->currentSamples[i].left,audio->currentSamples[i].right); + if (audio->p->stream) { + if (audio->p->stream->postAudioFrame) { + int i; + for (i = 0; i < GB_MAX_SAMPLES; ++i) { + audio->p->stream->postAudioFrame(audio->p->stream, audio->currentSamples[i].left,audio->currentSamples[i].right); + } + } + if (audio->p->stream->postAudioBuffer) { + unsigned produced = mAudioBufferAvailable(&audio->buffer); + bool wait = produced >= audio->samples; + if (wait) { + audio->p->stream->postAudioBuffer(audio->p->stream, &audio->buffer); + } } } - - produced = mAudioBufferAvailable(&audio->buffer); - bool wait = produced >= audio->samples; if (!mCoreSyncProduceAudio(audio->p->sync, &audio->buffer)) { // Interrupted audio->p->earlyExit = true; } - - if (wait && audio->p->stream && audio->p->stream->postAudioBuffer) { - audio->p->stream->postAudioBuffer(audio->p->stream, &audio->buffer); - } mTimingSchedule(timing, &audio->sampleEvent, audio->sampleInterval * audio->timingFactor - cyclesLate); } diff --git a/src/gba/audio.c b/src/gba/audio.c index 8c07bcb511e..c84d6ce27f7 100644 --- a/src/gba/audio.c +++ b/src/gba/audio.c @@ -392,25 +392,27 @@ static void _sample(struct mTiming* timing, void* user, uint32_t cyclesLate) { memset(audio->chB.samples, audio->chB.samples[samples - 1], sizeof(audio->chB.samples)); mCoreSyncLockAudio(audio->p->sync); - unsigned produced; mAudioBufferWrite(&audio->psg.buffer, (int16_t*) audio->currentSamples, samples); - if (audio->p->stream && audio->p->stream->postAudioFrame) { - int i; - for (i = 0; i < samples; ++i) { - audio->p->stream->postAudioFrame(audio->p->stream, audio->currentSamples[i].left,audio->currentSamples[i].right); + if (audio->p->stream) { + if (audio->p->stream->postAudioFrame) { + int i; + for (i = 0; i < samples; ++i) { + audio->p->stream->postAudioFrame(audio->p->stream, audio->currentSamples[i].left,audio->currentSamples[i].right); + } + } + if (audio->p->stream->postAudioBuffer) { + unsigned produced = mAudioBufferAvailable(&audio->psg.buffer); + bool wait = produced >= audio->samples; + if (wait) { + audio->p->stream->postAudioBuffer(audio->p->stream, &audio->psg.buffer); + } } } - produced = mAudioBufferAvailable(&audio->psg.buffer); - bool wait = produced >= audio->samples; if (!mCoreSyncProduceAudio(audio->p->sync, &audio->psg.buffer)) { // Interrupted audio->p->earlyExit = true; } - if (wait && audio->p->stream && audio->p->stream->postAudioBuffer) { - audio->p->stream->postAudioBuffer(audio->p->stream, &audio->psg.buffer); - } - mTimingSchedule(timing, &audio->sampleEvent, SAMPLE_INTERVAL - cyclesLate); } From 55add8a2c6b69faa97a08682cb62d59572aef16d Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 22 Apr 2024 21:42:34 -0700 Subject: [PATCH 105/338] Util: Early exist mAudioBufferRead if the buffer is full --- src/util/audio-buffer.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/util/audio-buffer.c b/src/util/audio-buffer.c index 5d67827fbc8..028946b48e1 100644 --- a/src/util/audio-buffer.c +++ b/src/util/audio-buffer.c @@ -52,6 +52,9 @@ size_t mAudioBufferRead(struct mAudioBuffer* buffer, int16_t* samples, size_t co size_t mAudioBufferWrite(struct mAudioBuffer* buffer, const int16_t* samples, size_t count) { size_t free = mCircleBufferCapacity(&buffer->data) - mCircleBufferSize(&buffer->data); if (count * buffer->channels * sizeof(int16_t) > free) { + if (!free) { + return 0; + } count = free / (buffer->channels * sizeof(int16_t)); } return mCircleBufferWrite(&buffer->data, samples, count * buffer->channels * sizeof(int16_t)) / From 96702f7db19e62388a23ab64a495e49a7c3f2184 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 23 Apr 2024 22:33:57 -0700 Subject: [PATCH 106/338] Util: Use HAS_IPV6 more where appropriate --- include/mgba-util/socket.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/include/mgba-util/socket.h b/include/mgba-util/socket.h index ff9d8962621..4b109eaea96 100644 --- a/include/mgba-util/socket.h +++ b/include/mgba-util/socket.h @@ -234,7 +234,7 @@ static inline Socket SocketOpenTCP(int port, const struct Address* bindAddress) #else err = bind(sock, (const struct sockaddr*) &bindInfo, sizeof(bindInfo)); #endif -#if !defined(__3DS__) && !defined(GEKKO) +#ifdef HAS_IPV6 } else { struct sockaddr_in6 bindInfo; memset(&bindInfo, 0, sizeof(bindInfo)); @@ -333,7 +333,7 @@ static inline Socket SocketAccept(Socket socket, struct Address* address) { #else return accept(socket, (struct sockaddr*) &addrInfo, &len); #endif -#if !defined(__3DS__) && !defined(GEKKO) +#ifdef HAS_IPV6 } else { struct sockaddr_in6 addrInfo; memset(&addrInfo, 0, sizeof(addrInfo)); From 88a8f80ebdea737885ee885600d1b2288e8bde9c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 24 Apr 2024 22:54:43 -0700 Subject: [PATCH 107/338] VFS: Rename USE_VFS_* to ENABLE_VFS_* --- include/mgba-util/vfs.h | 2 +- src/platform/3ds/3ds-vfs.c | 2 +- src/platform/3ds/CMakeLists.txt | 8 ++++---- src/util/vfs.c | 4 ++-- 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/include/mgba-util/vfs.h b/include/mgba-util/vfs.h index 0ff100143b6..004dbd685ef 100644 --- a/include/mgba-util/vfs.h +++ b/include/mgba-util/vfs.h @@ -98,7 +98,7 @@ bool VDirCreate(const char* path); struct VFile* VDirFindFirst(struct VDir* dir, bool (*filter)(struct VFile*)); struct VFile* VDirFindNextAvailable(struct VDir*, const char* basename, const char* infix, const char* suffix, int mode); -#ifdef USE_VFS_FILE +#ifdef ENABLE_VFS_FILE struct VFile* VFileFOpen(const char* path, const char* mode); struct VFile* VFileFromFILE(FILE* file); #endif diff --git a/src/platform/3ds/3ds-vfs.c b/src/platform/3ds/3ds-vfs.c index f2aaeb84a6b..88297e9cd1d 100644 --- a/src/platform/3ds/3ds-vfs.c +++ b/src/platform/3ds/3ds-vfs.c @@ -5,7 +5,7 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include -#ifdef USE_VFS_3DS +#ifdef ENABLE_VFS_3DS #include #include diff --git a/src/platform/3ds/CMakeLists.txt b/src/platform/3ds/CMakeLists.txt index 7469fe6d49a..2073e13fedc 100644 --- a/src/platform/3ds/CMakeLists.txt +++ b/src/platform/3ds/CMakeLists.txt @@ -1,5 +1,5 @@ -set(USE_VFS_3DS OFF CACHE BOOL "Use 3DS-specific file support") -mark_as_advanced(USE_VFS_3DS) +set(ENABLE_VFS_3DS OFF CACHE BOOL "Use 3DS-specific file support") +mark_as_advanced(ENABLE_VFS_3DS) find_program(3DSLINK 3dslink) find_program(3DSXTOOL 3dsxtool) @@ -28,8 +28,8 @@ set(OS_SRC set(OS_LIB ${OS_LIB} PARENT_SCOPE) source_group("3DS-specific code" FILES ${OS_SRC}) -if(USE_VFS_3DS) - list(APPEND OS_DEFINES USE_VFS_3DS) +if(ENABLE_VFS_3DS) + list(APPEND OS_DEFINES ENABLE_VFS_3DS) else() list(APPEND VFS_SRC ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c) endif() diff --git a/src/util/vfs.c b/src/util/vfs.c index 09ae8104711..74a96b3697e 100644 --- a/src/util/vfs.c +++ b/src/util/vfs.c @@ -20,7 +20,7 @@ #ifdef ENABLE_VFS struct VFile* VFileOpen(const char* path, int flags) { -#ifdef USE_VFS_FILE +#ifdef ENABLE_VFS_FILE const char* chflags; switch (flags & O_ACCMODE) { case O_WRONLY: @@ -68,7 +68,7 @@ struct VFile* VFileOpen(const char* path, int flags) { sceFlags |= SCE_O_CREAT; } return VFileOpenSce(path, sceFlags, 0666); -#elif defined(USE_VFS_3DS) +#elif defined(ENABLE_VFS_3DS) int ctrFlags = FS_OPEN_READ; switch (flags & O_ACCMODE) { case O_WRONLY: From 87653b7b197d0bd2a217dd6b61421d1518bc9191 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 24 Apr 2024 23:19:31 -0700 Subject: [PATCH 108/338] Qt: Fix potential crash when configuring shortcuts --- CHANGES | 1 + src/platform/qt/ShortcutModel.cpp | 48 +++++++++++++++++-------------- src/platform/qt/ShortcutModel.h | 4 +-- 3 files changed, 29 insertions(+), 24 deletions(-) diff --git a/CHANGES b/CHANGES index 13d7b0f4c3b..328de47b858 100644 --- a/CHANGES +++ b/CHANGES @@ -22,6 +22,7 @@ Other fixes: - GB: Fix uninitialized save data when loading undersized temporary saves - GBA Memory: Let raw access read high MMIO addresses - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) + - Qt: Fix potential crash when configuring shortcuts - Updater: Fix updating appimage across filesystems Misc: - Core: Handle relative paths for saves, screenshots, etc consistently (fixes mgba.io/i/2826) diff --git a/src/platform/qt/ShortcutModel.cpp b/src/platform/qt/ShortcutModel.cpp index b73982cadc2..f9066793522 100644 --- a/src/platform/qt/ShortcutModel.cpp +++ b/src/platform/qt/ShortcutModel.cpp @@ -28,11 +28,11 @@ QVariant ShortcutModel::data(const QModelIndex& index, int role) const { if (role != Qt::DisplayRole || !index.isValid()) { return QVariant(); } - const Item* item = static_cast(index.internalPointer()); - const Shortcut* shortcut = item->shortcut; + const Item& item = m_cache[index.internalId()]; + const Shortcut* shortcut = item.shortcut; switch (index.column()) { case 0: - return m_controller->visibleName(item->name); + return m_controller->visibleName(item.name); case 1: return shortcut ? keyName(shortcut->shortcut()) : QVariant(); case 2: @@ -77,28 +77,31 @@ QVariant ShortcutModel::headerData(int section, Qt::Orientation orientation, int QModelIndex ShortcutModel::index(int row, int column, const QModelIndex& parent) const { QString pmenu; if (parent.isValid()) { - pmenu = static_cast(parent.internalPointer())->name; + const Item& item = m_cache[parent.internalId()]; + pmenu = item.name; } QString name = m_controller->name(row, pmenu); - Item* item = &m_cache[name]; - item->name = name; - item->shortcut = m_controller->shortcut(name); - return createIndex(row, column, item); + size_t hash = qHash(name); + Item& item = m_cache[hash]; + item.name = name; + item.shortcut = m_controller->shortcut(name); + return createIndex(row, column, hash); } QModelIndex ShortcutModel::parent(const QModelIndex& index) const { if (!index.isValid() || !index.internalPointer()) { return QModelIndex(); } - Item* item = static_cast(index.internalPointer()); - QString parent = m_controller->parent(item->name); + const Item& item = m_cache[index.internalId()]; + QString parent = m_controller->parent(item.name); if (parent.isNull()) { return QModelIndex(); } - Item* pitem = &m_cache[parent]; - pitem->name = parent; - pitem->shortcut = m_controller->shortcut(parent); - return createIndex(m_controller->indexIn(parent), 0, pitem); + size_t hash = qHash(parent); + Item& pitem = m_cache[hash]; + pitem.name = parent; + pitem.shortcut = m_controller->shortcut(parent); + return createIndex(m_controller->indexIn(parent), 0, hash); } int ShortcutModel::columnCount(const QModelIndex&) const { @@ -109,25 +112,26 @@ int ShortcutModel::rowCount(const QModelIndex& index) const { if (!index.isValid()) { return m_controller->count(); } - Item* item = static_cast(index.internalPointer()); - return m_controller->count(item->name); + const Item& item = m_cache[index.internalId()]; + return m_controller->count(item.name); } QString ShortcutModel::name(const QModelIndex& index) const { if (!index.isValid()) { return {}; } - Item* item = static_cast(index.internalPointer()); - return item->name; + const Item& item = m_cache[index.internalId()]; + return item.name; } void ShortcutModel::addRowNamed(const QString& name) { QString parent = m_controller->parent(name); - Item* item = &m_cache[parent]; - item->name = parent; - item->shortcut = m_controller->shortcut(parent); + size_t hash = qHash(name); + Item& item = m_cache[hash]; + item.name = parent; + item.shortcut = m_controller->shortcut(parent); int index = m_controller->indexIn(name); - beginInsertRows(createIndex(m_controller->indexIn(parent), 0, item), index, index + 1); + beginInsertRows(createIndex(m_controller->indexIn(parent), 0, hash), index, index + 1); endInsertRows(); } diff --git a/src/platform/qt/ShortcutModel.h b/src/platform/qt/ShortcutModel.h index 3eb3b1178aa..64a1d33013d 100644 --- a/src/platform/qt/ShortcutModel.h +++ b/src/platform/qt/ShortcutModel.h @@ -44,7 +44,7 @@ private slots: const Shortcut* shortcut = nullptr; }; - mutable QHash m_cache; + mutable QHash m_cache; }; -} \ No newline at end of file +} From aae9c502f02e097e8154fbe23e85b0a676288652 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 25 Apr 2024 01:03:08 -0700 Subject: [PATCH 109/338] Misc: Fix a slew of less-than-important warnings --- src/core/cheats.c | 12 ++++++------ src/feature/commandline.c | 5 ++++- src/gb/audio.c | 2 +- src/gba/cart/ereader.c | 2 +- src/gba/sharkport.c | 4 ++-- src/util/image.c | 6 +++--- src/util/image/png-io.c | 7 +++++-- 7 files changed, 22 insertions(+), 16 deletions(-) diff --git a/src/core/cheats.c b/src/core/cheats.c index 85a06b80dd8..53f71e907c9 100644 --- a/src/core/cheats.c +++ b/src/core/cheats.c @@ -282,14 +282,14 @@ bool mCheatParseFile(struct mCheatDevice* device, struct VFile* vf) { StringListDeinit(&directives); return false; } - while (isspace((int) cheat[i])) { + while (isspace((unsigned) cheat[i])) { ++i; } switch (cheat[i]) { case '#': do { ++i; - } while (isspace((int) cheat[i])); + } while (isspace((unsigned) cheat[i])); newSet = device->createSet(device, &cheat[i]); newSet->enabled = !nextDisabled; nextDisabled = false; @@ -305,7 +305,7 @@ bool mCheatParseFile(struct mCheatDevice* device, struct VFile* vf) { case '!': do { ++i; - } while (isspace((int) cheat[i])); + } while (isspace((unsigned) cheat[i])); if (strcasecmp(&cheat[i], "disabled") == 0) { nextDisabled = true; break; @@ -384,7 +384,7 @@ bool mCheatParseLibretroFile(struct mCheatDevice* device, struct VFile* vf) { return false; } ++eq; - while (isspace((int) eq[0])) { + while (isspace((unsigned) eq[0])) { if (eq[0] == '\0') { return false; } @@ -393,7 +393,7 @@ bool mCheatParseLibretroFile(struct mCheatDevice* device, struct VFile* vf) { char* end; unsigned long nCheats = strtoul(eq, &end, 10); - if (end[0] != '\0' && !isspace(end[0])) { + if (end[0] != '\0' && !isspace((unsigned) end[0])) { return false; } @@ -423,7 +423,7 @@ bool mCheatParseLibretroFile(struct mCheatDevice* device, struct VFile* vf) { return false; } ++eq; - while (isspace((int) eq[0])) { + while (isspace((unsigned) eq[0])) { if (eq[0] == '\0') { return false; } diff --git a/src/feature/commandline.c b/src/feature/commandline.c index 59735e69b02..fca5c7747aa 100644 --- a/src/feature/commandline.c +++ b/src/feature/commandline.c @@ -217,9 +217,12 @@ void mArgumentsApply(const struct mArguments* args, struct mSubParser* subparser } bool mArgumentsApplyDebugger(const struct mArguments* args, struct mCore* core, struct mDebugger* debugger) { + UNUSED(args); + UNUSED(core); + UNUSED(debugger); bool hasDebugger = false; - #ifdef USE_EDITLINE +#ifdef USE_EDITLINE if (args->debugCli) { struct mDebuggerModule* module = mDebuggerCreateModule(DEBUGGER_CLI, core); if (module) { diff --git a/src/gb/audio.c b/src/gb/audio.c index b090018f692..783b1fcb936 100644 --- a/src/gb/audio.c +++ b/src/gb/audio.c @@ -602,7 +602,7 @@ void GBAudioRun(struct GBAudio* audio, int32_t timestamp, int channels) { int32_t last = 0; int samples = 0; int positiveSamples = 0; - int lsb; + int lsb = 0; int coeff; if (audio->ch4.power) { // TODO: Can this be batched too? diff --git a/src/gba/cart/ereader.c b/src/gba/cart/ereader.c index fc4d4c11d54..1712f2833ec 100644 --- a/src/gba/cart/ereader.c +++ b/src/gba/cart/ereader.c @@ -371,7 +371,7 @@ void GBACartEReaderScan(struct GBACartEReader* ereader, const void* data, size_t memset(ereader->dots, 0, EREADER_DOTCODE_SIZE); uint8_t blockRS[44][0x10]; - uint8_t block0[0x30]; + uint8_t block0[0x30] = {0}; bool parsed = false; bool bitmap = false; bool reducedHeader = false; diff --git a/src/gba/sharkport.c b/src/gba/sharkport.c index 2f33e3d41a9..f6b908f3aee 100644 --- a/src/gba/sharkport.c +++ b/src/gba/sharkport.c @@ -202,7 +202,7 @@ bool GBASavedataExportSharkPort(const struct GBA* gba, struct VFile* vf) { char c[0x1C]; int32_t i; } buffer; - uint32_t size = strlen(SHARKPORT_HEADER); + int32_t size = strlen(SHARKPORT_HEADER); STORE_32(size, 0, &buffer.i); if (vf->write(vf, &buffer.i, 4) < 4) { return false; @@ -271,7 +271,7 @@ bool GBASavedataExportSharkPort(const struct GBA* gba, struct VFile* vf) { } uint32_t checksum = 0; - size_t i; + ssize_t i; for (i = 0; i < 0x1C; ++i) { checksum += buffer.c[i] << (checksum % 24); } diff --git a/src/util/image.c b/src/util/image.c index 64e8aeec657..e5ee9f9e2fd 100644 --- a/src/util/image.c +++ b/src/util/image.c @@ -904,9 +904,9 @@ uint32_t mColorConvert(uint32_t color, enum mColorFormat from, enum mColorFormat return color; } - int r; - int g; - int b; + int r = 0; + int g = 0; + int b = 0; int a = 0xFF; switch (from) { diff --git a/src/util/image/png-io.c b/src/util/image/png-io.c index e7df1d64f66..0207e03a86e 100644 --- a/src/util/image/png-io.c +++ b/src/util/image/png-io.c @@ -62,7 +62,7 @@ static png_infop _pngWriteHeader(png_structp png, unsigned width, unsigned heigh } png_infop PNGWriteHeader(png_structp png, unsigned width, unsigned height, enum mColorFormat fmt) { - int type; + int type = -1; switch (fmt) { case mCOLOR_XBGR8: case mCOLOR_XRGB8: @@ -94,6 +94,9 @@ png_infop PNGWriteHeader(png_structp png, unsigned width, unsigned height, enum type = PNG_COLOR_TYPE_PALETTE; break; } + if (type < 0) { + return NULL; + } return _pngWriteHeader(png, width, height, NULL, 0, type); } @@ -373,6 +376,7 @@ bool PNGWritePixels(png_structp png, unsigned width, unsigned height, unsigned s } else { depth = 3; } + stride *= mColorFormatBytes(fmt); png_bytep row = malloc(sizeof(png_byte) * width * depth); if (!row) { return false; @@ -383,7 +387,6 @@ bool PNGWritePixels(png_structp png, unsigned width, unsigned height, unsigned s return false; } const png_byte* pixelRow = pixelData; - stride *= mColorFormatBytes(fmt); unsigned i; for (i = 0; i < height; ++i, pixelRow += stride) { switch (fmt) { From db1e02521e5835059117c35abefe971f0861e7c5 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 26 Apr 2024 19:05:38 -0700 Subject: [PATCH 110/338] GBA Core: Fix audio sample rate dynamically changing (fixes #3194) --- src/gba/core.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/gba/core.c b/src/gba/core.c index 47da3a0e00f..3d874dfe39b 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -554,8 +554,8 @@ static void _GBACorePutPixels(struct mCore* core, const void* buffer, size_t str } static unsigned _GBACoreAudioSampleRate(const struct mCore* core) { - UNUSED(core); - return 65536; + struct GBA* gba = core->board; + return GBA_ARM7TDMI_FREQUENCY / gba->audio.sampleInterval; } static struct mAudioBuffer* _GBACoreGetAudioBuffer(struct mCore* core) { From 5a28564b125bf135b55686fe6d94a659a3d11f99 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 27 Apr 2024 18:17:50 -0700 Subject: [PATCH 111/338] Switch: Fix audio resampling after GBA fix --- src/platform/switch/main.c | 32 +++++++++++++++++++++++--------- 1 file changed, 23 insertions(+), 9 deletions(-) diff --git a/src/platform/switch/main.c b/src/platform/switch/main.c index 8307f981173..9a3441b9ba5 100644 --- a/src/platform/switch/main.c +++ b/src/platform/switch/main.c @@ -20,7 +20,7 @@ #include #define AUTO_INPUT 0x4E585031 -#define SAMPLES 0x200 +#define SAMPLES 0x400 #define N_BUFFERS 6 #define ANALOG_DEADZONE 0x4000 @@ -91,6 +91,7 @@ static struct mRotationSource rotation = {0}; static AudioDriver audrenDriver; static AudioDriverWaveBuf audrvBuffer[N_BUFFERS]; static struct mStereoSample* audioBuffer[N_BUFFERS]; +static double fpsRatio = 1; static bool frameLimiter = true; static unsigned framecount = 0; static unsigned framecap = 10; @@ -266,6 +267,19 @@ static void _updateRenderer(struct mGUIRunner* runner, bool gl) { } } +static void _resetSampleRate(u32 samplerate) { + if (!samplerate) { + samplerate = 32768; + } + audrvVoiceInit(&audrenDriver, 0, 2, PcmFormat_Int16, samplerate / fpsRatio); + audrvVoiceSetDestinationMix(&audrenDriver, 0, AUDREN_FINAL_MIX_ID); + audrvVoiceSetMixFactor(&audrenDriver, 0, 1.0f, 0, 0); + audrvVoiceSetMixFactor(&audrenDriver, 0, 0.0f, 0, 1); + audrvVoiceSetMixFactor(&audrenDriver, 0, 0.0f, 1, 0); + audrvVoiceSetMixFactor(&audrenDriver, 0, 1.0f, 1, 1); + audrvUpdate(&audrenDriver); +} + static void _setup(struct mGUIRunner* runner) { _mapKey(&runner->core->inputMap, AUTO_INPUT, HidNpadButton_A, GBA_KEY_A); _mapKey(&runner->core->inputMap, AUTO_INPUT, HidNpadButton_B, GBA_KEY_B); @@ -303,14 +317,8 @@ static void _setup(struct mGUIRunner* runner) { runner->core->setAudioBufferSize(runner->core, SAMPLES); u32 samplerate = runner->core->audioSampleRate(runner->core); - double ratio = mCoreCalculateFramerateRatio(runner->core, 60.0); - audrvVoiceInit(&audrenDriver, 0, 2, PcmFormat_Int16, samplerate / ratio); - audrvVoiceSetDestinationMix(&audrenDriver, 0, AUDREN_FINAL_MIX_ID); - audrvVoiceSetMixFactor(&audrenDriver, 0, 1.0f, 0, 0); - audrvVoiceSetMixFactor(&audrenDriver, 0, 0.0f, 0, 1); - audrvVoiceSetMixFactor(&audrenDriver, 0, 0.0f, 1, 0); - audrvVoiceSetMixFactor(&audrenDriver, 0, 1.0f, 1, 1); - audrvUpdate(&audrenDriver); + fpsRatio = mCoreCalculateFramerateRatio(runner->core, 60.0); + _resetSampleRate(samplerate); } static void _gameLoaded(struct mGUIRunner* runner) { @@ -572,6 +580,11 @@ static bool _running(struct mGUIRunner* runner) { return appletMainLoop(); } +static void _audioRateChanged(struct mAVStream* stream, uint32_t samplerate) { + UNUSED(stream); + _resetSampleRate(samplerate); +} + static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buffer) { UNUSED(stream); int i; @@ -891,6 +904,7 @@ int main(int argc, char* argv[]) { stream.postVideoFrame = NULL; stream.postAudioFrame = NULL; stream.postAudioBuffer = _postAudioBuffer; + stream.audioRateChanged = _audioRateChanged; size_t i; for (i = 0; i < N_BUFFERS; ++i) { From 5e581b0ade6b78e744dddd647fa6175f921ba65e Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 27 Apr 2024 18:29:29 -0700 Subject: [PATCH 112/338] 3DS: Fix audio resampling after GBA fix --- src/platform/3ds/main.c | 25 ++++++++++++++++++------- 1 file changed, 18 insertions(+), 7 deletions(-) diff --git a/src/platform/3ds/main.c b/src/platform/3ds/main.c index c85103bcecf..de6575effb0 100644 --- a/src/platform/3ds/main.c +++ b/src/platform/3ds/main.c @@ -90,6 +90,7 @@ static color_t* screenshotBuffer = NULL; static struct mAVStream stream; static int16_t* audioLeft = 0; static size_t audioPos = 0; +static double fpsRatio; static C3D_Tex outputTexture[2]; static int activeOutputTexture = 0; static ndspWaveBuf dspBuffer[DSP_BUFFERS]; @@ -189,8 +190,6 @@ static void _map3DSKey(struct mInputMap* map, int ctrKey, int key) { mInputBindKey(map, _3DS_INPUT, __builtin_ctz(ctrKey), key); } -static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buffer); - static void _drawStart(void) { if (frameStarted) { return; @@ -347,8 +346,11 @@ static void _gameLoaded(struct mGUIRunner* runner) { } if (hasSound == DSP_SUPPORTED) { unsigned sampleRate = runner->core->audioSampleRate(runner->core); - double fauxClock = mCoreCalculateFramerateRatio(runner->core, 16756991. / 280095.); - ndspChnSetRate(0, sampleRate * fauxClock); + if (!sampleRate) { + sampleRate = 32768; + } + fpsRatio = mCoreCalculateFramerateRatio(runner->core, 16756991. / 280095.); + ndspChnSetRate(0, sampleRate * fpsRatio); memset(audioLeft, 0, AUDIO_SAMPLE_BUFFER * 2 * sizeof(int16_t)); } unsigned mode; @@ -795,6 +797,14 @@ static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buff } } +static void _audioRateChanged(struct mAVStream* stream, unsigned sampleRate) { + UNUSED(stream); + if (!sampleRate) { + sampleRate = 32768; + } + ndspChnSetRate(0, sampleRate * fpsRatio); +} + static enum GUIKeyboardStatus _keyboardRun(struct GUIKeyboardParams* keyboard) { SwkbdState swkbd; swkbdInit(&swkbd, SWKBD_TYPE_NORMAL, 2, keyboard->maxLen); @@ -830,10 +840,11 @@ int main(int argc, char* argv[]) { rotation.d.readTiltY = _readTiltY; rotation.d.readGyroZ = _readGyroZ; - stream.videoDimensionsChanged = 0; - stream.postVideoFrame = 0; - stream.postAudioFrame = 0; + stream.videoDimensionsChanged = NULL; + stream.postVideoFrame = NULL; + stream.postAudioFrame = NULL; stream.postAudioBuffer = _postAudioBuffer; + stream.audioRateChanged = _audioRateChanged; camera.d.startRequestImage = _startRequestImage; camera.d.stopRequestImage = _stopRequestImage; From 4aba51e9553343b64b56fafee48bcd609c402f16 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 27 Apr 2024 18:55:18 -0700 Subject: [PATCH 113/338] Vita: Fix audio resampling after GBA fix --- src/platform/psp2/psp2-context.c | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/src/platform/psp2/psp2-context.c b/src/platform/psp2/psp2-context.c index 36253aa071c..0f456fa7ec2 100644 --- a/src/platform/psp2/psp2-context.c +++ b/src/platform/psp2/psp2-context.c @@ -54,6 +54,7 @@ static int currentTex; static vita2d_texture* tex[2]; static vita2d_texture* screenshot; static Thread audioThread; +static double fpsRatio = 1; static bool interframeBlending = false; static bool sgbCrop = false; static bool blurry = false; @@ -266,6 +267,20 @@ static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buf) MutexUnlock(&audioContext.mutex); } +static void _audioRateChanged(struct mAVStream* stream, unsigned sampleRate) { + UNUSED(stream); + if (!sampleRate) { + return; + } + if (!audioContext.resampler.source || !audioContext.resampler.destination) { + return; + } + MutexLock(&audioContext.mutex); + mAudioResamplerProcess(&audioContext.resampler); + mAudioResamplerSetSource(&audioContext.resampler, audioContext.resampler.source, sampleRate / fpsRatio, true); + MutexUnlock(&audioContext.mutex); +} + uint16_t mPSP2PollInput(struct mGUIRunner* runner) { SceCtrlData pad; sceCtrlPeekBufferPositiveExt2(0, &pad, 1); @@ -364,6 +379,7 @@ void mPSP2Setup(struct mGUIRunner* runner) { stream.postAudioFrame = NULL; stream.postAudioBuffer = _postAudioBuffer; stream.postVideoFrame = NULL; + stream.audioRateChanged = _audioRateChanged; runner->core->setAVStream(runner->core, &stream); frameLimiter = true; @@ -423,10 +439,13 @@ void mPSP2LoadROM(struct mGUIRunner* runner) { float rate = 60.0f / 1.001f; sceDisplayGetRefreshRate(&rate); - double ratio = mCoreCalculateFramerateRatio(runner->core, rate); + fpsRatio = mCoreCalculateFramerateRatio(runner->core, rate); unsigned sampleRate = runner->core->audioSampleRate(runner->core); + if (!sampleRate) { + sampleRate = 32768; + } mAudioBufferClear(&audioContext.buffer); - mAudioResamplerSetSource(&audioContext.resampler, runner->core->getAudioBuffer(runner->core), sampleRate / ratio, true); + mAudioResamplerSetSource(&audioContext.resampler, runner->core->getAudioBuffer(runner->core), sampleRate / fpsRatio, true); ThreadCreate(&audioThread, _audioThread, &audioContext); } From df75204a0bfe0453540ad92c6d30abb9d83a5388 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 27 Apr 2024 19:15:04 -0700 Subject: [PATCH 114/338] Wii: Fix audio resampling after GBA fix --- src/platform/wii/main.c | 29 ++++++++++++++++++++++++----- 1 file changed, 24 insertions(+), 5 deletions(-) diff --git a/src/platform/wii/main.c b/src/platform/wii/main.c index f21c7e19b9d..55bae973897 100644 --- a/src/platform/wii/main.c +++ b/src/platform/wii/main.c @@ -77,6 +77,7 @@ static enum VideoMode { static void _retraceCallback(u32 count); static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer*); +static void _audioRateChanged(struct mAVStream* stream, unsigned); static void _audioDMA(void); static void _setRumble(struct mRumble* rumble, int enable); static void _sampleRotation(struct mRotationSource* source); @@ -147,7 +148,8 @@ static struct AudioBuffer { static struct mAudioBuffer audioBuffer; static volatile int currentAudioBuffer = 0; static volatile int nextAudioBuffer = 0; -static double audioSampleRate = 60.0 / 1.001; +static double fps = 60.0 / 1.001; +static double fpsRatio = 1; static struct mAudioResampler resampler; static struct GUIFont* font; @@ -162,7 +164,7 @@ static void reconfigureScreen(struct mGUIRunner* runner) { wAdjust = 1.f; hAdjust = 1.f; guiScale = GUI_SCALE; - audioSampleRate = 60.0 / 1.001; + fps = 60.0 / 1.001; s32 signalMode = CONF_GetVideo(); @@ -210,7 +212,7 @@ static void reconfigureScreen(struct mGUIRunner* runner) { break; } wAdjust = 0.5f; - audioSampleRate = 90.0 / 1.50436; + fps = 90.0 / 1.50436; guiScale = GUI_SCALE_240p; break; } @@ -348,6 +350,7 @@ int main(int argc, char* argv[]) { stream.postVideoFrame = NULL; stream.postAudioFrame = NULL; stream.postAudioBuffer = _postAudioBuffer; + stream.audioRateChanged = _audioRateChanged; struct mGUIRunner runner = { .params = { @@ -717,6 +720,18 @@ static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buf) _CPU_ISR_Restore(level); } +static void _audioRateChanged(struct mAVStream* stream, unsigned sampleRate) { + UNUSED(stream); + if (!sampleRate) { + return; + } + if (!resampler.source || !resampler.destination) { + return; + } + mAudioResamplerProcess(&resampler); + mAudioResamplerSetSource(&resampler, resampler.source, sampleRate / fpsRatio, true); +} + static void _drawStart(void) { VIDEO_SetBlack(false); @@ -1419,8 +1434,12 @@ void _setup(struct mGUIRunner* runner) { memset(audioBuffers, 0, sizeof(audioBuffers)); runner->core->setAudioBufferSize(runner->core, SAMPLES); - double ratio = mCoreCalculateFramerateRatio(runner->core, audioSampleRate); - mAudioResamplerSetSource(&resampler, runner->core->getAudioBuffer(runner->core), runner->core->audioSampleRate(runner->core) / ratio, true); + fpsRatio = mCoreCalculateFramerateRatio(runner->core, fps); + unsigned sampleRate = runner->core->audioSampleRate(runner->core); + if (!sampleRate) { + sampleRate = 32768; + } + mAudioResamplerSetSource(&resampler, runner->core->getAudioBuffer(runner->core), sampleRate / fpsRatio, true); frameLimiter = true; } From 1d2b8bf918890e4e71957a1677a7bee72c796c08 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 30 Apr 2024 02:57:41 -0700 Subject: [PATCH 115/338] Libretro: Add Super Game Boy Color support (closes #3188) --- CHANGES | 1 + src/platform/libretro/libretro.c | 4 ++++ src/platform/libretro/libretro_core_options.h | 11 ++++++----- 3 files changed, 11 insertions(+), 5 deletions(-) diff --git a/CHANGES b/CHANGES index 328de47b858..15f85e7f0e0 100644 --- a/CHANGES +++ b/CHANGES @@ -30,6 +30,7 @@ Misc: - GB Serialize: Add missing savestate support for MBC6 and NT (newer) - GBA: Improve detection of valid ELF ROMs - GBA Audio: Remove broken XQ audio pending rewrite + - Libretro: Add Super Game Boy Color support (closes mgba.io/i/3188) - mGUI: Enable auto-softpatching (closes mgba.io/i/2899) - mGUI: Persist fast forwarding after closing menu (fixes mgba.io/i/2414) - Qt: Handle multiple save game files for disparate games separately (fixes mgba.io/i/2887) diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index 86a69283711..d2565a42b01 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -268,6 +268,8 @@ static void _reloadSettings(void) { model = GB_MODEL_SGB; } else if (strcmp(var.value, "Game Boy Color") == 0) { model = GB_MODEL_CGB; + } else if (strcmp(var.value, "Super Game Boy Color") == 0) { + model = GB_MODEL_SCGB; } else if (strcmp(var.value, "Game Boy Advance") == 0) { model = GB_MODEL_AGB; } else { @@ -278,6 +280,8 @@ static void _reloadSettings(void) { mCoreConfigSetDefaultValue(&core->config, "gb.model", modelName); mCoreConfigSetDefaultValue(&core->config, "sgb.model", modelName); mCoreConfigSetDefaultValue(&core->config, "cgb.model", modelName); + mCoreConfigSetDefaultValue(&core->config, "cgb.hybridModel", modelName); + mCoreConfigSetDefaultValue(&core->config, "cgb.sgbModel", modelName); } var.key = "mgba_sgb_borders"; diff --git a/src/platform/libretro/libretro_core_options.h b/src/platform/libretro/libretro_core_options.h index 76ca634f99f..f0a4b3f049e 100644 --- a/src/platform/libretro/libretro_core_options.h +++ b/src/platform/libretro/libretro_core_options.h @@ -87,11 +87,12 @@ struct retro_core_option_v2_definition option_defs_us[] = { NULL, "system", { - { "Autodetect", NULL }, - { "Game Boy", NULL }, - { "Super Game Boy", NULL }, - { "Game Boy Color", NULL }, - { "Game Boy Advance", NULL }, + { "Autodetect", NULL }, + { "Game Boy", NULL }, + { "Super Game Boy", NULL }, + { "Game Boy Color", NULL }, + { "Super Game Boy Color", NULL }, + { "Game Boy Advance", NULL }, { NULL, NULL }, }, "Autodetect" From d9e080b9a9f2b9fec8631988474bcf18b52d249a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 6 May 2024 15:35:23 -0700 Subject: [PATCH 116/338] GBA: Prefix SIO constants with GBA_ --- include/mgba/gba/interface.h | 12 +++---- src/gba/cart/gpio.c | 2 +- src/gba/core.c | 4 +-- src/gba/extra/battlechip.c | 4 +-- src/gba/gba.c | 2 +- src/gba/sio.c | 40 ++++++++++----------- src/gba/sio/gbp.c | 4 +-- src/gba/sio/lockstep.c | 42 +++++++++++------------ src/platform/python/mgba/gba.py | 14 ++++---- src/platform/qt/CoreController.cpp | 4 +-- src/platform/qt/MultiplayerController.cpp | 10 +++--- 11 files changed, 69 insertions(+), 69 deletions(-) diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index a04685e49d0..97e0a5b9c04 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -21,12 +21,12 @@ enum { }; enum GBASIOMode { - SIO_NORMAL_8 = 0, - SIO_NORMAL_32 = 1, - SIO_MULTI = 2, - SIO_UART = 3, - SIO_GPIO = 8, - SIO_JOYBUS = 12 + GBA_SIO_NORMAL_8 = 0, + GBA_SIO_NORMAL_32 = 1, + GBA_SIO_MULTI = 2, + GBA_SIO_UART = 3, + GBA_SIO_GPIO = 8, + GBA_SIO_JOYBUS = 12 }; enum GBASIOJOYCommand { diff --git a/src/gba/cart/gpio.c b/src/gba/cart/gpio.c index 811dc1e8a1c..0a396f74620 100644 --- a/src/gba/cart/gpio.c +++ b/src/gba/cart/gpio.c @@ -525,7 +525,7 @@ void GBAHardwareDeserialize(struct GBACartridgeHardware* hw, const struct GBASer uint32_t when; LOAD_32(when, 0, &state->hw.gbpNextEvent); if (hw->devices & HW_GB_PLAYER) { - GBASIOSetDriver(&hw->p->sio, &hw->p->sio.gbp.d, SIO_NORMAL_32); + GBASIOSetDriver(&hw->p->sio, &hw->p->sio.gbp.d, GBA_SIO_NORMAL_32); if (hw->p->memory.io[GBA_REG(SIOCNT)] & 0x0080) { mTimingSchedule(&hw->p->timing, &hw->p->sio.gbp.event, when); } diff --git a/src/gba/core.c b/src/gba/core.c index 3d874dfe39b..256aebdabc9 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -891,8 +891,8 @@ static void _GBACoreSetPeripheral(struct mCore* core, int type, void* periph) { gba->luminanceSource = periph; break; case mPERIPH_GBA_BATTLECHIP_GATE: - GBASIOSetDriver(&gba->sio, periph, SIO_MULTI); - GBASIOSetDriver(&gba->sio, periph, SIO_NORMAL_32); + GBASIOSetDriver(&gba->sio, periph, GBA_SIO_MULTI); + GBASIOSetDriver(&gba->sio, periph, GBA_SIO_NORMAL_32); break; default: return; diff --git a/src/gba/extra/battlechip.c b/src/gba/extra/battlechip.c index fa6be9796a5..3ab9f140314 100644 --- a/src/gba/extra/battlechip.c +++ b/src/gba/extra/battlechip.c @@ -84,7 +84,7 @@ uint16_t GBASIOBattlechipGateWriteRegister(struct GBASIODriver* driver, uint32_t void _battlechipTransfer(struct GBASIOBattlechipGate* gate) { int32_t cycles; - if (gate->d.p->mode == SIO_NORMAL_32) { + if (gate->d.p->mode == GBA_SIO_NORMAL_32) { cycles = GBA_ARM7TDMI_FREQUENCY / 0x40000; } else { cycles = GBASIOCyclesPerTransfer[GBASIOMultiplayerGetBaud(gate->d.p->siocnt)][1]; @@ -97,7 +97,7 @@ void _battlechipTransferEvent(struct mTiming* timing, void* user, uint32_t cycle UNUSED(timing); struct GBASIOBattlechipGate* gate = user; - if (gate->d.p->mode == SIO_NORMAL_32) { + if (gate->d.p->mode == GBA_SIO_NORMAL_32) { gate->d.p->p->memory.io[GBA_REG(SIODATA32_LO)] = 0; gate->d.p->p->memory.io[GBA_REG(SIODATA32_HI)] = 0; gate->d.p->siocnt = GBASIONormalClearStart(gate->d.p->siocnt); diff --git a/src/gba/gba.c b/src/gba/gba.c index fb0a84ae7e5..94ed7562a65 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -232,7 +232,7 @@ void GBAReset(struct ARMCore* cpu) { // GB Player SIO control should not be engaged before detection, even if we already know it's GBP gba->memory.hw.devices &= ~HW_GB_PLAYER; if (gba->sio.drivers.normal == &gba->sio.gbp.d) { - GBASIOSetDriver(&gba->sio, NULL, SIO_NORMAL_32); + GBASIOSetDriver(&gba->sio, NULL, GBA_SIO_NORMAL_32); } bool isELF = false; diff --git a/src/gba/sio.c b/src/gba/sio.c index 1082d0062e0..beb8efdfe74 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -20,12 +20,12 @@ const int GBASIOCyclesPerTransfer[4][MAX_GBAS] = { static struct GBASIODriver* _lookupDriver(struct GBASIO* sio, enum GBASIOMode mode) { switch (mode) { - case SIO_NORMAL_8: - case SIO_NORMAL_32: + case GBA_SIO_NORMAL_8: + case GBA_SIO_NORMAL_32: return sio->drivers.normal; - case SIO_MULTI: + case GBA_SIO_MULTI: return sio->drivers.multiplayer; - case SIO_JOYBUS: + case GBA_SIO_JOYBUS: return sio->drivers.joybus; default: return 0; @@ -34,15 +34,15 @@ static struct GBASIODriver* _lookupDriver(struct GBASIO* sio, enum GBASIOMode mo static const char* _modeName(enum GBASIOMode mode) { switch (mode) { - case SIO_NORMAL_8: + case GBA_SIO_NORMAL_8: return "NORMAL8"; - case SIO_NORMAL_32: + case GBA_SIO_NORMAL_32: return "NORMAL32"; - case SIO_MULTI: + case GBA_SIO_MULTI: return "MULTI"; - case SIO_JOYBUS: + case GBA_SIO_JOYBUS: return "JOYBUS"; - case SIO_GPIO: + case GBA_SIO_GPIO: return "GPIO"; default: return "(unknown)"; @@ -113,22 +113,22 @@ void GBASIOReset(struct GBASIO* sio) { } void GBASIOSetDriverSet(struct GBASIO* sio, struct GBASIODriverSet* drivers) { - GBASIOSetDriver(sio, drivers->normal, SIO_NORMAL_8); - GBASIOSetDriver(sio, drivers->multiplayer, SIO_MULTI); - GBASIOSetDriver(sio, drivers->joybus, SIO_JOYBUS); + GBASIOSetDriver(sio, drivers->normal, GBA_SIO_NORMAL_8); + GBASIOSetDriver(sio, drivers->multiplayer, GBA_SIO_MULTI); + GBASIOSetDriver(sio, drivers->joybus, GBA_SIO_JOYBUS); } void GBASIOSetDriver(struct GBASIO* sio, struct GBASIODriver* driver, enum GBASIOMode mode) { struct GBASIODriver** driverLoc; switch (mode) { - case SIO_NORMAL_8: - case SIO_NORMAL_32: + case GBA_SIO_NORMAL_8: + case GBA_SIO_NORMAL_32: driverLoc = &sio->drivers.normal; break; - case SIO_MULTI: + case GBA_SIO_MULTI: driverLoc = &sio->drivers.multiplayer; break; - case SIO_JOYBUS: + case GBA_SIO_JOYBUS: driverLoc = &sio->drivers.joybus; break; default: @@ -182,8 +182,8 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { } else { // Dummy drivers switch (sio->mode) { - case SIO_NORMAL_8: - case SIO_NORMAL_32: + case GBA_SIO_NORMAL_8: + case GBA_SIO_NORMAL_32: value = GBASIONormalFillSi(value); if ((value & 0x0081) == 0x0081) { if (GBASIONormalIsIrq(value)) { @@ -193,7 +193,7 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { value = GBASIONormalClearStart(value); } break; - case SIO_MULTI: + case GBA_SIO_MULTI: value &= 0xFF83; value |= 0xC; break; @@ -211,7 +211,7 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu } // Dummy drivers switch (sio->mode) { - case SIO_JOYBUS: + case GBA_SIO_JOYBUS: switch (address) { case GBA_REG_JOYCNT: return (value & 0x0040) | (sio->p->memory.io[GBA_REG(JOYCNT)] & ~(value & 0x7) & ~0x0040); diff --git a/src/gba/sio/gbp.c b/src/gba/sio/gbp.c index 8400cc8b130..b5f98735213 100644 --- a/src/gba/sio/gbp.c +++ b/src/gba/sio/gbp.c @@ -56,7 +56,7 @@ void GBASIOPlayerInit(struct GBASIOPlayer* gbp) { void GBASIOPlayerReset(struct GBASIOPlayer* gbp) { if (gbp->p->sio.drivers.normal == &gbp->d) { - GBASIOSetDriver(&gbp->p->sio, NULL, SIO_NORMAL_32); + GBASIOSetDriver(&gbp->p->sio, NULL, GBA_SIO_NORMAL_32); } } @@ -88,7 +88,7 @@ void GBASIOPlayerUpdate(struct GBA* gba) { gba->sio.gbp.oldCallback = gba->keyCallback; gba->keyCallback = &gba->sio.gbp.callback.d; // TODO: Check if the SIO driver is actually used first - GBASIOSetDriver(&gba->sio, &gba->sio.gbp.d, SIO_NORMAL_32); + GBASIOSetDriver(&gba->sio, &gba->sio.gbp.d, GBA_SIO_NORMAL_32); } } diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 71373a237c2..4f12610f191 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -103,7 +103,7 @@ bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver) { node->mode = driver->p->mode; switch (node->mode) { - case SIO_MULTI: + case GBA_SIO_MULTI: node->d.writeRegister = GBASIOLockstepNodeMultiWriteRegister; node->d.p->rcnt |= 3; ATOMIC_ADD(node->p->attachedMulti, 1); @@ -125,8 +125,8 @@ bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver) { node->d.p->siocnt = GBASIOMultiplayerClearSlave(node->d.p->siocnt); } break; - case SIO_NORMAL_8: - case SIO_NORMAL_32: + case GBA_SIO_NORMAL_8: + case GBA_SIO_NORMAL_32: if (ATOMIC_ADD(node->p->attachedNormal, 1) > node->id + 1 && node->id > 0) { node->d.p->siocnt = GBASIONormalSetSi(node->d.p->siocnt, GBASIONormalGetIdleSo(node->p->players[node->id - 1]->d.p->siocnt)); } else { @@ -154,11 +154,11 @@ bool GBASIOLockstepNodeUnload(struct GBASIODriver* driver) { node->mode = driver->p->mode; switch (node->mode) { - case SIO_MULTI: + case GBA_SIO_MULTI: ATOMIC_SUB(node->p->attachedMulti, 1); break; - case SIO_NORMAL_8: - case SIO_NORMAL_32: + case GBA_SIO_NORMAL_8: + case GBA_SIO_NORMAL_32: ATOMIC_SUB(node->p->attachedNormal, 1); break; default: @@ -180,7 +180,7 @@ bool GBASIOLockstepNodeUnload(struct GBASIODriver* driver) { } // Invalidate SIO mode - node->mode = SIO_GPIO; + node->mode = GBA_SIO_GPIO; mLockstepUnlock(&node->p->d); @@ -235,7 +235,7 @@ static void _finishTransfer(struct GBASIOLockstepNode* node) { struct GBASIO* sio = node->d.p; switch (node->mode) { - case SIO_MULTI: + case GBA_SIO_MULTI: sio->p->memory.io[GBA_REG(SIOMULTI0)] = node->p->multiRecv[0]; sio->p->memory.io[GBA_REG(SIOMULTI1)] = node->p->multiRecv[1]; sio->p->memory.io[GBA_REG(SIOMULTI2)] = node->p->multiRecv[2]; @@ -247,7 +247,7 @@ static void _finishTransfer(struct GBASIOLockstepNode* node) { GBARaiseIRQ(sio->p, GBA_IRQ_SIO, 0); } break; - case SIO_NORMAL_8: + case GBA_SIO_NORMAL_8: // TODO sio->siocnt = GBASIONormalClearStart(sio->siocnt); if (node->id) { @@ -260,7 +260,7 @@ static void _finishTransfer(struct GBASIOLockstepNode* node) { GBARaiseIRQ(sio->p, GBA_IRQ_SIO, 0); } break; - case SIO_NORMAL_32: + case GBA_SIO_NORMAL_32: // TODO sio->siocnt = GBASIONormalClearStart(sio->siocnt); if (node->id) { @@ -299,7 +299,7 @@ static int32_t _masterUpdate(struct GBASIOLockstepNode* node) { case TRANSFER_IDLE: // If the master hasn't initiated a transfer, it can keep going. node->nextEvent += LOCKSTEP_INCREMENT; - if (node->mode == SIO_MULTI) { + if (node->mode == GBA_SIO_MULTI) { node->d.p->siocnt = GBASIOMultiplayerSetReady(node->d.p->siocnt, attachedMulti == attached); } break; @@ -307,7 +307,7 @@ static int32_t _masterUpdate(struct GBASIOLockstepNode* node) { // Start the transfer, but wait for the other GBAs to catch up node->transferFinished = false; switch (node->mode) { - case SIO_MULTI: + case GBA_SIO_MULTI: node->p->multiRecv[0] = node->d.p->p->memory.io[GBA_REG(SIOMLT_SEND)]; node->d.p->p->memory.io[GBA_REG(SIOMULTI0)] = 0xFFFF; node->d.p->p->memory.io[GBA_REG(SIOMULTI1)] = 0xFFFF; @@ -317,11 +317,11 @@ static int32_t _masterUpdate(struct GBASIOLockstepNode* node) { node->p->multiRecv[2] = 0xFFFF; node->p->multiRecv[3] = 0xFFFF; break; - case SIO_NORMAL_8: + case GBA_SIO_NORMAL_8: node->p->multiRecv[0] = 0xFFFF; node->p->normalRecv[0] = node->d.p->p->memory.io[GBA_REG(SIODATA8)] & 0xFF; break; - case SIO_NORMAL_32: + case GBA_SIO_NORMAL_32: node->p->multiRecv[0] = 0xFFFF; mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIODATA32_LO <- %04X", node->id, node->d.p->p->memory.io[GBA_REG(SIODATA32_LO)]); mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIODATA32_HI <- %04X", node->id, node->d.p->p->memory.io[GBA_REG(SIODATA32_HI)]); @@ -393,7 +393,7 @@ static uint32_t _slaveUpdate(struct GBASIOLockstepNode* node) { ATOMIC_LOAD(transferActive, node->p->d.transferActive); ATOMIC_LOAD(attached, node->p->d.attached); - if (node->mode == SIO_MULTI) { + if (node->mode == GBA_SIO_MULTI) { ATOMIC_LOAD(attachedMode, node->p->attachedMulti); node->d.p->siocnt = GBASIOMultiplayerSetReady(node->d.p->siocnt, attachedMode == attached); } else { @@ -415,7 +415,7 @@ static uint32_t _slaveUpdate(struct GBASIOLockstepNode* node) { } node->transferFinished = false; switch (node->mode) { - case SIO_MULTI: + case GBA_SIO_MULTI: node->d.p->rcnt &= ~1; node->p->multiRecv[node->id] = node->d.p->p->memory.io[GBA_REG(SIOMLT_SEND)]; node->d.p->p->memory.io[GBA_REG(SIOMULTI0)] = 0xFFFF; @@ -424,11 +424,11 @@ static uint32_t _slaveUpdate(struct GBASIOLockstepNode* node) { node->d.p->p->memory.io[GBA_REG(SIOMULTI3)] = 0xFFFF; node->d.p->siocnt = GBASIOMultiplayerFillBusy(node->d.p->siocnt); break; - case SIO_NORMAL_8: + case GBA_SIO_NORMAL_8: node->p->multiRecv[node->id] = 0xFFFF; node->p->normalRecv[node->id] = node->d.p->p->memory.io[GBA_REG(SIODATA8)] & 0xFF; break; - case SIO_NORMAL_32: + case GBA_SIO_NORMAL_32: node->p->multiRecv[node->id] = 0xFFFF; node->p->normalRecv[node->id] = node->d.p->p->memory.io[GBA_REG(SIODATA32_LO)]; node->p->normalRecv[node->id] |= node->d.p->p->memory.io[GBA_REG(SIODATA32_HI)] << 16; @@ -466,11 +466,11 @@ static void _GBASIOLockstepNodeProcessEvents(struct mTiming* timing, void* user, node->eventDiff += cyclesLate; if (node->p->d.attached < 2) { switch (node->mode) { - case SIO_MULTI: + case GBA_SIO_MULTI: cycles = GBASIOCyclesPerTransfer[GBASIOMultiplayerGetBaud(node->d.p->siocnt)][0]; break; - case SIO_NORMAL_8: - case SIO_NORMAL_32: + case GBA_SIO_NORMAL_8: + case GBA_SIO_NORMAL_32: if (node->nextEvent <= 0) { cycles = _masterUpdate(node); node->eventDiff = 0; diff --git a/src/platform/python/mgba/gba.py b/src/platform/python/mgba/gba.py index a0c86ac84ed..109de4d508e 100644 --- a/src/platform/python/mgba/gba.py +++ b/src/platform/python/mgba/gba.py @@ -23,12 +23,12 @@ class GBA(Core): KEY_L = lib.GBA_KEY_L KEY_R = lib.GBA_KEY_R - SIO_NORMAL_8 = lib.SIO_NORMAL_8 - SIO_NORMAL_32 = lib.SIO_NORMAL_32 - SIO_MULTI = lib.SIO_MULTI - SIO_UART = lib.SIO_UART - SIO_JOYBUS = lib.SIO_JOYBUS - SIO_GPIO = lib.SIO_GPIO + SIO_NORMAL_8 = lib.GBA_SIO_NORMAL_8 + SIO_NORMAL_32 = lib.GBA_SIO_NORMAL_32 + SIO_MULTI = lib.GBA_SIO_MULTI + SIO_UART = lib.GBA_SIO_UART + SIO_JOYBUS = lib.GBA_SIO_JOYBUS + SIO_GPIO = lib.GBA_SIO_GPIO def __init__(self, native): super(GBA, self).__init__(native) @@ -52,7 +52,7 @@ def _load(self): super(GBA, self)._load() self.memory = GBAMemory(self._core, self._native.memory.romSize) - def attach_sio(self, link, mode=lib.SIO_MULTI): + def attach_sio(self, link, mode=lib.GBA_SIO_MULTI): self._sio.add(mode) lib.GBASIOSetDriver(ffi.addressof(self._native.sio), link._native, mode) diff --git a/src/platform/qt/CoreController.cpp b/src/platform/qt/CoreController.cpp index 660de1f574f..02cd4db4c4b 100644 --- a/src/platform/qt/CoreController.cpp +++ b/src/platform/qt/CoreController.cpp @@ -424,7 +424,7 @@ bool CoreController::attachDolphin(const Address& address) { } if (GBASIODolphinConnect(&m_dolphin, &address, 0, 0)) { GBA* gba = static_cast(m_threadContext.core->board); - GBASIOSetDriver(&gba->sio, &m_dolphin.d, SIO_JOYBUS); + GBASIOSetDriver(&gba->sio, &m_dolphin.d, GBA_SIO_JOYBUS); return true; } return false; @@ -433,7 +433,7 @@ bool CoreController::attachDolphin(const Address& address) { void CoreController::detachDolphin() { if (platform() == mPLATFORM_GBA) { GBA* gba = static_cast(m_threadContext.core->board); - GBASIOSetDriver(&gba->sio, nullptr, SIO_JOYBUS); + GBASIOSetDriver(&gba->sio, nullptr, GBA_SIO_JOYBUS); } GBASIODolphinDestroy(&m_dolphin); } diff --git a/src/platform/qt/MultiplayerController.cpp b/src/platform/qt/MultiplayerController.cpp index 7ded956a4f4..149df238606 100644 --- a/src/platform/qt/MultiplayerController.cpp +++ b/src/platform/qt/MultiplayerController.cpp @@ -92,7 +92,7 @@ MultiplayerController::MultiplayerController() { if (!id) { for (int i = 1; i < controller->m_players.count(); ++i) { player = controller->player(i); - if (player->node.gba->d.p->mode > SIO_MULTI) { + if (player->node.gba->d.p->mode > GBA_SIO_MULTI) { player->controller->setSync(true); continue; } @@ -254,8 +254,8 @@ bool MultiplayerController::attachGame(CoreController* controller) { GBASIOLockstepAttachNode(&m_gbaLockstep, node); player.node.gba = node; - GBASIOSetDriver(&gba->sio, &node->d, SIO_MULTI); - GBASIOSetDriver(&gba->sio, &node->d, SIO_NORMAL_32); + GBASIOSetDriver(&gba->sio, &node->d, GBA_SIO_MULTI); + GBASIOSetDriver(&gba->sio, &node->d, GBA_SIO_NORMAL_32); break; } #endif @@ -342,8 +342,8 @@ void MultiplayerController::detachGame(CoreController* controller) { case mPLATFORM_GBA: { GBA* gba = static_cast(thread->core->board); GBASIOLockstepNode* node = reinterpret_cast(gba->sio.drivers.multiplayer); - GBASIOSetDriver(&gba->sio, nullptr, SIO_MULTI); - GBASIOSetDriver(&gba->sio, nullptr, SIO_NORMAL_32); + GBASIOSetDriver(&gba->sio, nullptr, GBA_SIO_MULTI); + GBASIOSetDriver(&gba->sio, nullptr, GBA_SIO_NORMAL_32); if (node) { GBASIOLockstepDetachNode(&m_gbaLockstep, node); delete node; From ff2dfeb5164a3bd93a6fd517e00ad0d35dcfa32a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 7 May 2024 22:02:49 -0700 Subject: [PATCH 117/338] Util: Clean up VFileOpen backing a bit more --- CMakeLists.txt | 4 +++- include/mgba-util/vfs.h | 12 +++++++----- src/core/flags.h.in | 8 ++++++++ src/platform/3ds/CMakeLists.txt | 1 + src/platform/switch/CMakeLists.txt | 2 +- src/platform/wii/CMakeLists.txt | 2 +- src/util/vfs.c | 4 +++- 7 files changed, 24 insertions(+), 9 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 3767bae8bc0..8b8262b8b5e 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -207,6 +207,7 @@ elseif(BUILD_PGO AND PGO_STAGE_2) endif() # Platform support +set(OS_DEFINES) if(WIN32) set(WIN32_VERSION "${LIB_VERSION_MAJOR},${LIB_VERSION_MINOR},${LIB_VERSION_PATCH}") set(CMAKE_WINDOWS_EXPORT_ALL_SYMBOLS TRUE) @@ -220,6 +221,7 @@ if(WIN32) endif() endif() list(APPEND OS_LIB ws2_32 shlwapi) + list(APPEND OS_DEFINES ENABLE_VFS_FD) list(APPEND VFS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/windows/vfs-w32.c) file(GLOB OS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/windows/*.c) source_group("Windows-specific code" FILES ${OS_SRC}) @@ -230,6 +232,7 @@ elseif(UNIX) add_definitions(-D_GNU_SOURCE) endif() + list(APPEND OS_DEFINES ENABLE_VFS_FD) list(APPEND VFS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${CMAKE_CURRENT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c) file(GLOB OS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/posix/*.c) source_group("POSIX-specific code" FILES ${OS_SRC}) @@ -858,7 +861,6 @@ source_group("Extra features" FILES ${FEATURE_SRC}) source_group("Third-party code" FILES ${THIRD_PARTY_SRC}) # Platform binaries -set(OS_DEFINES) if(DEFINED 3DS) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/src/platform/3ds ${CMAKE_CURRENT_BINARY_DIR}/3ds) endif() diff --git a/include/mgba-util/vfs.h b/include/mgba-util/vfs.h index 004dbd685ef..0279fb755b2 100644 --- a/include/mgba-util/vfs.h +++ b/include/mgba-util/vfs.h @@ -66,11 +66,18 @@ struct VDir { }; struct VFile* VFileOpen(const char* path, int flags); +#endif +#ifdef ENABLE_VFS_FD struct VFile* VFileOpenFD(const char* path, int flags); struct VFile* VFileFromFD(int fd); #endif +#ifdef ENABLE_VFS_FILE +struct VFile* VFileFOpen(const char* path, const char* mode); +struct VFile* VFileFromFILE(FILE* file); +#endif + struct VFile* VFileFromMemory(void* mem, size_t size); struct VFile* VFileFromConstMemory(const void* mem, size_t size); struct VFile* VFileMemChunk(const void* mem, size_t size); @@ -97,11 +104,6 @@ struct VDir* VDeviceList(void); bool VDirCreate(const char* path); struct VFile* VDirFindFirst(struct VDir* dir, bool (*filter)(struct VFile*)); struct VFile* VDirFindNextAvailable(struct VDir*, const char* basename, const char* infix, const char* suffix, int mode); - -#ifdef ENABLE_VFS_FILE -struct VFile* VFileFOpen(const char* path, const char* mode); -struct VFile* VFileFromFILE(FILE* file); -#endif #endif void separatePath(const char* path, char* dirname, char* basename, char* extension); diff --git a/src/core/flags.h.in b/src/core/flags.h.in index b91e1907ac3..3507df03223 100644 --- a/src/core/flags.h.in +++ b/src/core/flags.h.in @@ -65,6 +65,14 @@ #cmakedefine ENABLE_VFS #endif +#ifndef ENABLE_VFS_FD +#cmakedefine ENABLE_VFS_FD +#endif + +#ifndef ENABLE_VFS_FILE +#cmakedefine ENABLE_VFS_FILE +#endif + // USE flags #ifndef USE_DISCORD_RPC diff --git a/src/platform/3ds/CMakeLists.txt b/src/platform/3ds/CMakeLists.txt index 2073e13fedc..a52c5e81efe 100644 --- a/src/platform/3ds/CMakeLists.txt +++ b/src/platform/3ds/CMakeLists.txt @@ -31,6 +31,7 @@ source_group("3DS-specific code" FILES ${OS_SRC}) if(ENABLE_VFS_3DS) list(APPEND OS_DEFINES ENABLE_VFS_3DS) else() + list(APPEND OS_DEFINES ENABLE_VFS_FD) list(APPEND VFS_SRC ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c) endif() set(VFS_SRC ${VFS_SRC} PARENT_SCOPE) diff --git a/src/platform/switch/CMakeLists.txt b/src/platform/switch/CMakeLists.txt index 55db05d127b..66e5b6f4ac2 100644 --- a/src/platform/switch/CMakeLists.txt +++ b/src/platform/switch/CMakeLists.txt @@ -4,7 +4,7 @@ find_program(BUILD_ROMFS build_romfs) find_library(GLAPI_LIBRARY glapi REQUIRED) find_library(EGL_LIBRARY EGL REQUIRED) -set(OS_DEFINES _GNU_SOURCE IOAPI_NO_64) +set(OS_DEFINES _GNU_SOURCE IOAPI_NO_64 ENABLE_VFS_FD) list(APPEND VFS_SRC ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c) list(APPEND GUI_SRC ${CMAKE_CURRENT_SOURCE_DIR}/gui-font.c) diff --git a/src/platform/wii/CMakeLists.txt b/src/platform/wii/CMakeLists.txt index f8e6984f4eb..a5f77e84d63 100644 --- a/src/platform/wii/CMakeLists.txt +++ b/src/platform/wii/CMakeLists.txt @@ -8,7 +8,7 @@ if(WIIDRC_LIBRARY) add_definitions(-DWIIDRC) endif() -set(OS_DEFINES _GNU_SOURCE COLOR_16_BIT COLOR_5_6_5 IOAPI_NO_64 FIXED_ROM_BUFFER) +set(OS_DEFINES _GNU_SOURCE COLOR_16_BIT COLOR_5_6_5 IOAPI_NO_64 FIXED_ROM_BUFFER ENABLE_VFS_FD) list(APPEND VFS_SRC ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-fd.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-dirent.c ${PROJECT_SOURCE_DIR}/src/util/vfs/vfs-devlist.c) include_directories(${CMAKE_CURRENT_BINARY_DIR}) diff --git a/src/util/vfs.c b/src/util/vfs.c index 74a96b3697e..a14100bbf62 100644 --- a/src/util/vfs.c +++ b/src/util/vfs.c @@ -96,8 +96,10 @@ struct VFile* VFileOpen(const char* path, int flags) { vf->seek(vf, vf->size(vf), SEEK_SET); } return vf; -#else +#elif defined(ENABLE_VFS_FD) return VFileOpenFD(path, flags); +#else +#error "Can't build VFS subsystem without a VFile backend" #endif } From 8106fbf51c05878050747842722b6f544edb45d6 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 7 May 2024 22:05:27 -0700 Subject: [PATCH 118/338] Libretro: Fix build --- CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 8b8262b8b5e..1742cb8053b 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -981,7 +981,7 @@ endif() if(BUILD_LIBRETRO) file(GLOB RETRO_SRC ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/libretro/*.c) - add_library(${BINARY_NAME}_libretro SHARED ${CORE_SRC} ${RETRO_SRC}) + add_library(${BINARY_NAME}_libretro SHARED ${CORE_SRC} ${RETRO_SRC} ${VFS_SRC}) add_dependencies(${BINARY_NAME}_libretro ${BINARY_NAME}-version-info) set_target_properties(${BINARY_NAME}_libretro PROPERTIES PREFIX "" COMPILE_DEFINITIONS "__LIBRETRO__;COLOR_16_BIT;COLOR_5_6_5;DISABLE_THREADING;MGBA_STANDALONE;${OS_DEFINES};${FUNCTION_DEFINES};ENABLE_VFS;MINIMAL_CORE=2") target_link_libraries(${BINARY_NAME}_libretro ${OS_LIB}) From e5333f4e7c92d9a12c853cbcbedaa3f190342579 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 7 May 2024 22:32:33 -0700 Subject: [PATCH 119/338] GBA Audio: Call audioRateChanged on reset if applicable --- src/gba/audio.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/gba/audio.c b/src/gba/audio.c index c84d6ce27f7..e6b49538231 100644 --- a/src/gba/audio.c +++ b/src/gba/audio.c @@ -43,6 +43,7 @@ void GBAAudioInit(struct GBAAudio* audio, size_t samples) { audio->forceDisableChA = false; audio->forceDisableChB = false; audio->masterVolume = GBA_AUDIO_VOLUME_MAX; + audio->sampleInterval = GBA_ARM7TDMI_FREQUENCY / 0x8000; } void GBAAudioReset(struct GBAAudio* audio) { @@ -81,7 +82,12 @@ void GBAAudioReset(struct GBAAudio* audio) { audio->chBLeft = false; audio->chBTimer = false; audio->enable = false; - audio->sampleInterval = GBA_ARM7TDMI_FREQUENCY / 0x8000; + if (audio->sampleInterval != GBA_ARM7TDMI_FREQUENCY / 0x8000) { + audio->sampleInterval = GBA_ARM7TDMI_FREQUENCY / 0x8000; + if (audio->p->stream && audio->p->stream->audioRateChanged) { + audio->p->stream->audioRateChanged(audio->p->stream, GBA_ARM7TDMI_FREQUENCY / audio->sampleInterval); + } + } audio->psg.sampleInterval = audio->sampleInterval; } From 1ca75446c6f4f3c26c4593c03ff4a8f26330fa42 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 7 May 2024 22:32:58 -0700 Subject: [PATCH 120/338] Libretro: Fix audio resampling after GBA fix --- src/platform/libretro/libretro.c | 20 +++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index d2565a42b01..8191d48681c 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -53,6 +53,7 @@ static retro_set_sensor_state_t sensorStateCallback; static void GBARetroLog(struct mLogger* logger, int category, enum mLogLevel level, const char* format, va_list args); static void _postAudioBuffer(struct mAVStream*, struct mAudioBuffer*); +static void _audioRateChanged(struct mAVStream*, unsigned rate); static void _setRumble(struct mRumble* rumble, int enable); static uint8_t _readLux(struct GBALuminanceSource* lux); static void _updateLux(struct GBALuminanceSource* lux); @@ -498,10 +499,11 @@ void retro_init(void) { logger.log = GBARetroLog; mLogSetDefaultLogger(&logger); - stream.videoDimensionsChanged = 0; - stream.postAudioFrame = 0; - stream.postAudioBuffer = _postAudioBuffer; - stream.postVideoFrame = 0; + stream.videoDimensionsChanged = NULL; + stream.postAudioFrame = NULL; + stream.postAudioBuffer = NULL; + stream.postVideoFrame = NULL; + stream.audioRateChanged = _audioRateChanged; imageSource.startRequestImage = _startImage; imageSource.stopRequestImage = _stopImage; @@ -913,13 +915,14 @@ bool retro_load_game(const struct retro_game_info* game) { * using the regular stream-set _postAudioBuffer() * callback with a fixed buffer size, which seems * (historically) to produce adequate results */ - core->setAVStream(core, &stream); + stream.postAudioBuffer = _postAudioBuffer; audioSampleBufferSize = GB_SAMPLES * 2; audioSampleBuffer = malloc(audioSampleBufferSize * sizeof(int16_t)); audioSamplesPerFrameAvg = GB_SAMPLES; core->setAudioBufferSize(core, GB_SAMPLES); } + core->setAVStream(core, &stream); core->setPeripheral(core, mPERIPH_RUMBLE, &rumble); core->setPeripheral(core, mPERIPH_ROTATION, &rotation); @@ -1250,6 +1253,13 @@ static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buff } } +static void _audioRateChanged(struct mAVStream* stream, unsigned rate) { + UNUSED(stream); + struct retro_system_av_info info; + retro_get_system_av_info(&info); + environCallback(RETRO_ENVIRONMENT_SET_SYSTEM_AV_INFO, &info); +} + static void _setRumble(struct mRumble* rumble, int enable) { UNUSED(rumble); if (!rumbleInitDone) { From e73f302aee38323ee77a5242c84ae2f87298daf0 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 8 May 2024 17:06:53 -0700 Subject: [PATCH 121/338] Libretro: Attempt to fix #3202 --- src/platform/libretro/libretro.c | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index 8191d48681c..38fbcdbb9f5 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -744,7 +744,7 @@ static void _setupMaps(struct mCore* core) { #ifdef M_CORE_GB if (core->platform(core) == mPLATFORM_GB) { struct GB* gb = core->board; - struct retro_memory_descriptor descs[11]; + struct retro_memory_descriptor descs[12]; struct retro_memory_map mmaps; memset(descs, 0, sizeof(descs)); @@ -814,8 +814,16 @@ static void _setupMaps(struct mCore* core) { if (savedataSize) { descs[i].ptr = savedata; descs[i].start = GB_BASE_EXTERNAL_RAM; - descs[i].len = savedataSize; + descs[i].len = savedataSize < GB_SIZE_EXTERNAL_RAM ? savedataSize : GB_SIZE_EXTERNAL_RAM; i++; + + if ((savedataSize & ~0xFF) > GB_SIZE_EXTERNAL_RAM) { + descs[i].ptr = savedata; + descs[i].offset = GB_SIZE_EXTERNAL_RAM; + descs[i].start = GB_BASE_EXTERNAL_RAM; + descs[i].len = savedataSize - GB_SIZE_EXTERNAL_RAM; + i++; + } } if (gb->model >= GB_MODEL_CGB) { @@ -825,7 +833,6 @@ static void _setupMaps(struct mCore* core) { descs[i].ptr = gb->memory.wram + 0x2000; descs[i].start = 0x10000; descs[i].len = GB_SIZE_WORKING_RAM - 0x2000; - descs[i].select = 0xFFFFA000; i++; } From f6851eba95a94d7018f4744ae11ce63011a27e2b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 8 May 2024 17:26:54 -0700 Subject: [PATCH 122/338] Libretro: Fix mapped high SRAM start address --- src/platform/libretro/libretro.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index 38fbcdbb9f5..b7d7d82431b 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -820,7 +820,7 @@ static void _setupMaps(struct mCore* core) { if ((savedataSize & ~0xFF) > GB_SIZE_EXTERNAL_RAM) { descs[i].ptr = savedata; descs[i].offset = GB_SIZE_EXTERNAL_RAM; - descs[i].start = GB_BASE_EXTERNAL_RAM; + descs[i].start = 0x16000; descs[i].len = savedataSize - GB_SIZE_EXTERNAL_RAM; i++; } From 92b67f960c447296f8693e7e0485156e91a48b77 Mon Sep 17 00:00:00 2001 From: Evrins Hu Date: Sat, 11 May 2024 10:46:28 +0800 Subject: [PATCH 123/338] doc: update readme in zh_cn --- README_ZH_CN.md | 39 +++++++++++++++++++++++++++------------ 1 file changed, 27 insertions(+), 12 deletions(-) diff --git a/README_ZH_CN.md b/README_ZH_CN.md index ab725694c6e..1991e2d1d6a 100644 --- a/README_ZH_CN.md +++ b/README_ZH_CN.md @@ -5,7 +5,9 @@ mGBA 是一个è¿è¡Œ Game Boy Advance 游æˆçš„模拟器。mGBA 的目标是比 å¯åœ¨ä»¥ä¸‹ç½‘å€æ‰¾åˆ°æœ€æ–°æ–°é—»å’Œä¸‹è½½ï¼š[mgba.io](https://mgba.io/)。 -[![Build status](https://travis-ci.org/mgba-emu/mgba.svg?branch=master)](https://travis-ci.org/mgba-emu/mgba) +[![Build status](https://buildbot.mgba.io/badges/build-win32.svg)](https://buildbot.mgba.io) +[![Translation status](https://hosted.weblate.org/widgets/mgba/-/svg-badge.svg)](https://hosted.weblate.org/engage/mgba) + 功能 -------- @@ -13,7 +15,7 @@ mGBA 是一个è¿è¡Œ Game Boy Advance 游æˆçš„模拟器。mGBA 的目标是比 - 支æŒé«˜ç²¾ç¡®çš„ Game Boy Advance 硬件[[1]](#missing)。 - æ”¯æŒ Game Boy/Game Boy Color 硬件。 - 快速模拟:已知å³ä½¿åœ¨ä½Žç«¯ç¡¬ä»¶ï¼ˆä¾‹å¦‚上网本)上也能够全速è¿è¡Œã€‚ -- 用于é‡åž‹å’Œè½»åž‹å‰ç«¯çš„ Qt å’Œ SDL 端å£ã€‚ +- å¯ç”¨äºŽé‡åž‹å’Œè½»åž‹å‰ç«¯çš„ Qt å’Œ SDL 移æ¤ã€‚ - 支æŒæœ¬åœ°ï¼ˆåŒä¸€å°è®¡ç®—机)链接电缆。 - 存档类型检测,å³ä½¿æ˜¯é—ªå­˜å¤§å°ä¹Ÿå¯æ£€æµ‹[[2]](#flashdetect)。 - 支æŒé™„带有è¿åŠ¨ä¼ æ„Ÿå™¨å’ŒæŒ¯åŠ¨æœºåˆ¶çš„å¡å¸¦ï¼ˆä»…适用于游æˆæŽ§åˆ¶å™¨ï¼‰ã€‚ @@ -21,6 +23,7 @@ mGBA 是一个è¿è¡Œ Game Boy Advance 游æˆçš„模拟器。mGBA 的目标是比 - 支æŒã€Šæˆ‘们的太阳》系列游æˆçš„太阳能传感器。 - æ”¯æŒ Game Boy 相机和 Game Boy 打å°æœºã€‚ - 内置 BIOS 执行,并具有加载外部 BIOS 文件的功能。 +- 支æŒä½¿ç”¨ Lua 编写脚本 - æ”¯æŒ Turbo/å¿«è¿›åŠŸèƒ½ï¼ˆæŒ‰ä½ Tab 键)。 - 支æŒå€’带(按ä½å引å·é”®ï¼‰ã€‚ - 支æŒè·³å¸§ï¼Œæœ€å¤šå¯é…ç½® 10 级。 @@ -32,10 +35,11 @@ mGBA 是一个è¿è¡Œ Game Boy Advance 游æˆçš„模拟器。mGBA 的目标是比 - å¯é‡æ–°æ˜ å°„键盘和游æˆæ‰‹æŸ„的控制键。 - 支æŒä»Ž ZIP å’Œ 7z 文件中加载。 - æ”¯æŒ IPSã€UPS å’Œ BPS è¡¥ä¸ã€‚ -- 支æŒé€šè¿‡å‘½ä»¤è¡Œç•Œé¢å’Œ GDB 远程支æŒè¿›è¡Œæ¸¸æˆè°ƒè¯•ï¼Œå…¼å®¹ IDA Pro。 +- 支æŒé€šè¿‡å‘½ä»¤è¡Œç•Œé¢å’Œ GDB 远程支æŒè¿›è¡Œæ¸¸æˆè°ƒè¯•ï¼Œå…¼å®¹ Ghidra å’Œ IDA Pro。 - 支æŒå¯é…置的模拟倒带。 - 支æŒè½½å…¥å’Œå¯¼å‡º GameShark å’Œ Action Replay 快照。 - 适用于 RetroArch/Libretro å’Œ OpenEmu 的内核。 +- 社区支æŒçš„多ç§è¯­è¨€ç¿»è¯‘ [Weblate](https://hosted.weblate.org/engage/mgba). - 许许多多的å°çŽ©æ„。 #### Game Boy 映射器(mapper) @@ -51,9 +55,10 @@ mGBA 是一个è¿è¡Œ Game Boy Advance 游æˆçš„模拟器。mGBA 的目标是比 - MBC5+振动 - MBC7 - Wisdom Tree(未授æƒï¼‰ +- NT "old type" 1 and 2 (未授æƒå¤šåˆä¸€å¡å¸¦) +- NT "new type" (æœªæŽˆæƒ MBC5-like) - Pokémon Jade/Diamond(未授æƒï¼‰ -- BBD(未授æƒã€ç±» MBC5) -- Hitek(未授æƒã€ç±» MBC5) +- Sachen MMC1 (未授æƒ) 部分支æŒä»¥ä¸‹ mapper: @@ -63,6 +68,11 @@ mGBA 是一个è¿è¡Œ Game Boy Advance 游æˆçš„模拟器。mGBA 的目标是比 - TAMA5(缺少 RTC 支æŒï¼‰ - HuC-1(缺少 IR 支æŒï¼‰ - HuC-3(缺少 IR å’Œ RTC 支æŒï¼‰ +- Sachen MMC2 (缺少备用接线支æŒ) +- BBD (缺少图标切æ¢) +- Hitek (缺少图标切æ¢) +- GGB-81 (缺少图标切æ¢) +- Li Cheng (缺少图标切æ¢) ### 计划加入的功能 @@ -70,7 +80,6 @@ mGBA 是一个è¿è¡Œ Game Boy Advance 游æˆçš„模拟器。mGBA 的目标是比 - æ”¯æŒ Dolphin/JOY 总线链接电缆。 - MP2k 音频混åˆï¼ŒèŽ·å¾—比硬件更高质é‡çš„声音。 - 支æŒé’ˆå¯¹å·¥å…·è¾…助竞速(Tool-Assisted Speedrun)的é‡å½•åŠŸèƒ½ã€‚ -- æ”¯æŒ Lua 脚本。 - 全方ä½çš„调试套件。 - 支æŒæ— çº¿é€‚é…器。 @@ -112,17 +121,19 @@ mGBA 是一个è¿è¡Œ Game Boy Advance 游æˆçš„模拟器。mGBA 的目标是比 编译 --------- -编译需è¦ä½¿ç”¨ CMake 3.1 或更新版本。已知 GCC å’Œ Clang 都å¯ä»¥ç¼–译 mGBA,而 Visual Studio 2013 和更旧的版本则无法编译。我们å³å°†å®žçŽ°å¯¹ Visual Studio 2015 或更新版本的支æŒã€‚ +编译需è¦ä½¿ç”¨ CMake 3.1 或更新版本。已知 GCC , Clang å’Œ Visual Studio 2013 都å¯ä»¥ç¼–译 mGBA。 #### Docker 构建 对于大多数平å°æ¥è¯´ï¼Œå»ºè®®ä½¿ç”¨ Docker 进行构建。我们æ供了多个 Docker 映åƒï¼Œå…¶ä¸­åŒ…å«åœ¨å¤šä¸ªå¹³å°ä¸Šæž„建 mGBA 所需的工具链和ä¾èµ–项。 +注æ„: 如果你是用的是 Widnows 10 之å‰çš„旧版本 Windows 系统, ä½ å¯èƒ½éœ€è¦é…置你的 Docker 使用 VirtualBox å…±äº«æ–‡ä»¶å¤¹ä»¥æ­£ç¡®æ˜ å°„ä½ å½“å‰ mGBA 检出目录到 Docker é•œåƒä¸­çš„工作目录. 详细细节å‚è§ issue [#1985](https://mgba.io/i/1985) + è¦ä½¿ç”¨ Docker 映åƒæž„建 mGBA,åªéœ€åœ¨ mGBA 的签出(checkout)根目录中è¿è¡Œä»¥ä¸‹å‘½ä»¤ï¼š docker run --rm -t -v $PWD:/home/mgba/src mgba/windows:w32 -æ­¤å‘½ä»¤å°†ç”Ÿæˆ `build-win32` 目录。将 `mgba/windows:w32` 替æ¢ä¸ºå…¶ä»–å¹³å°ä¸Šçš„ Docker 映åƒï¼Œä¼šç”Ÿæˆç›¸åº”的其他目录。Docker Hub 上æ供了以下 Docker 映åƒï¼š +å¯åŠ¨ Docker 容器之åŽ, æ­¤å‘½ä»¤å°†ç”Ÿæˆ `build-win32` 目录, 此目录中包å«ç¼–译产物。将 `mgba/windows:w32` 替æ¢ä¸ºå…¶ä»–å¹³å°ä¸Šçš„ Docker 映åƒï¼Œä¼šç”Ÿæˆç›¸åº”的其他目录。Docker Hub 上æ供了以下 Docker 映åƒï¼š - mgba/3ds - mgba/switch @@ -135,6 +146,8 @@ mGBA 是一个è¿è¡Œ Game Boy Advance 游æˆçš„模拟器。mGBA 的目标是比 - mgba/windows:w32 - mgba/windows:w64 +如果你希望加速编译过程, å¯ä»¥è€ƒè™‘添加编译选项 `-e MAKEFLAGS=-jN`, 使用 `N` 个 CPU 核心æ¥å¹¶è¡Œæž„建 mGBA + #### *nix 构建 è¦åœ¨åŸºäºŽ Unix 的系统上使用 CMake 进行构建,推è执行以下命令: @@ -147,7 +160,7 @@ mGBA 是一个è¿è¡Œ Game Boy Advance 游æˆçš„模拟器。mGBA 的目标是比 这些命令将构建 mGBA 并将其安装到 `/usr/bin` å’Œ `/usr/lib` 中。系统会自动检测已安装的ä¾èµ–项,如果未找到ä¾èµ–项,则会在æ示找ä¸åˆ°ä¾èµ–项的情况下è¿è¡Œ `cmake` 命令,并显示已被ç¦ç”¨çš„功能。 -如果您使用的是 MacOS,则步骤略有ä¸åŒã€‚å‡è®¾æ‚¨ä½¿ç”¨çš„是自制软件包管ç†å™¨ï¼Œå»ºè®®ä½¿ç”¨ä»¥ä¸‹å‘½ä»¤æ¥èŽ·å–ä¾èµ–项并进行构建: +如果您使用的是 MacOS,则步骤略有ä¸åŒã€‚å‡è®¾æ‚¨ä½¿ç”¨çš„ homebrew 软件包管ç†å™¨ï¼Œå»ºè®®ä½¿ç”¨ä»¥ä¸‹å‘½ä»¤æ¥èŽ·å–ä¾èµ–项并进行构建: brew install cmake ffmpeg libzip qt5 sdl2 libedit pkg-config mkdir build @@ -220,10 +233,12 @@ mGBA 没有硬性的ä¾èµ–项,但是特定功能需è¦ä»¥ä¸‹å¯é€‰çš„ä¾èµ–项 - libzip 或 zlib:载入储存在 ZIP 文件中的 ROM 的所需ä¾èµ–项。 - SQLite3:游æˆæ•°æ®åº“的所需ä¾èµ–项 - libelf:ELF 载入的所需ä¾èµ–项 +- Lua: è„šæœ¬æ”¯æŒ +- json-c: 脚本 `storage` API æ”¯æŒ SQLite3ã€libpng ä»¥åŠ zlib 已包å«åœ¨æ¨¡æ‹Ÿå™¨ä¸­ï¼Œå› æ­¤ä¸éœ€è¦å…ˆå¯¹è¿™äº›ä¾èµ–项进行外部编译。 -Footnotes +脚注 --------- [1] ç›®å‰ç¼ºå¤±çš„功能有 @@ -232,7 +247,7 @@ Footnotes [2] 闪存大å°æ£€æµ‹åœ¨æŸäº›æƒ…况下ä¸èµ·ä½œç”¨ã€‚ 这些å¯ä»¥åœ¨è¿è¡Œæ—¶ä¸­è¿›è¡Œé…置,但如果é‡åˆ°æ­¤ç±»æƒ…况,建议æ交错误。 -[3] ä»… Qt 端å£éœ€è¦ 10.9。应该å¯ä»¥åœ¨ 10.7 或更早版本上构建或è¿è¡Œ Qt 端å£ï¼Œä½†è¿™ç±»æ“作ä¸å—官方支æŒã€‚已知 SDL 端å£å¯ä»¥åœ¨ 10.5 上è¿è¡Œï¼Œå¹¶ä¸”å¯èƒ½èƒ½å¤Ÿåœ¨æ—§ç‰ˆæœ¬ä¸Šè¿è¡Œã€‚ +[3] ä»… Qt 移æ¤éœ€è¦ 10.9。应该å¯ä»¥åœ¨ 10.7 或更早版本上构建或è¿è¡Œ Qt 移æ¤ï¼Œä½†è¿™ç±»æ“作ä¸å—官方支æŒã€‚已知 SDL 移æ¤å¯ä»¥åœ¨ 10.5 上è¿è¡Œï¼Œå¹¶ä¸”å¯èƒ½èƒ½å¤Ÿåœ¨æ—§ç‰ˆæœ¬ä¸Šè¿è¡Œã€‚ [downloads]: http://mgba.io/downloads.html [source]: https://github.com/mgba-emu/mgba/ @@ -240,7 +255,7 @@ Footnotes ç‰ˆæƒ --------- -mGBA ç‰ˆæƒ Â© 2013 – 2020 Jeffrey Pfau。基于 [Mozilla 公共许å¯è¯ç‰ˆæœ¬ 2.0](https://www.mozilla.org/MPL/2.0/) 许å¯è¯åˆ†å‘。分å‘çš„ LICENSE 文件中æ供了许å¯è¯çš„副本。 +mGBA ç‰ˆæƒ Â© 2013 – 2023 Jeffrey Pfau。基于 [Mozilla 公共许å¯è¯ç‰ˆæœ¬ 2.0](https://www.mozilla.org/MPL/2.0/) 许å¯è¯åˆ†å‘。分å‘çš„ LICENSE 文件中æ供了许å¯è¯çš„副本。 mGBA 包å«ä»¥ä¸‹ç¬¬ä¸‰æ–¹åº“: From 6e3a00e0814d4f3a6af080bfdbb9c0d073f95da9 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 11 May 2024 21:40:56 -0700 Subject: [PATCH 124/338] Qt: Fix crash when applying changes to GB I/O registers in I/O view --- CHANGES | 1 + src/platform/qt/IOViewer.cpp | 15 ++++++++++++++- 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/CHANGES b/CHANGES index 15f85e7f0e0..899b3391a0a 100644 --- a/CHANGES +++ b/CHANGES @@ -23,6 +23,7 @@ Other fixes: - GBA Memory: Let raw access read high MMIO addresses - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) - Qt: Fix potential crash when configuring shortcuts + - Qt: Fix crash when applying changes to GB I/O registers in I/O view - Updater: Fix updating appimage across filesystems Misc: - Core: Handle relative paths for saves, screenshots, etc consistently (fixes mgba.io/i/2826) diff --git a/src/platform/qt/IOViewer.cpp b/src/platform/qt/IOViewer.cpp index 531ba69556a..ef995921c6c 100644 --- a/src/platform/qt/IOViewer.cpp +++ b/src/platform/qt/IOViewer.cpp @@ -1687,7 +1687,20 @@ void IOViewer::bitFlipped() { void IOViewer::writeback() { { CoreController::Interrupter interrupter(m_controller); - GBAIOWrite(static_cast(m_controller->thread()->core->board), m_register, m_value); + switch (m_controller->platform()) { +#ifdef M_CORE_GB + case mPLATFORM_GB: + GBIOWrite(static_cast(m_controller->thread()->core->board), m_register, m_value); + break; +#endif +#ifdef M_CORE_GBA + case mPLATFORM_GBA: + GBAIOWrite(static_cast(m_controller->thread()->core->board), m_register, m_value); + break; +#endif + case mPLATFORM_NONE: + return; + } } updateRegister(); } From b723ed47645c0d87c3a95197de12bd17648570a5 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 12 May 2024 02:48:05 -0700 Subject: [PATCH 125/338] Qt: Better fix for I/O viewer --- src/platform/qt/IOViewer.cpp | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) diff --git a/src/platform/qt/IOViewer.cpp b/src/platform/qt/IOViewer.cpp index ef995921c6c..90a97fdbb28 100644 --- a/src/platform/qt/IOViewer.cpp +++ b/src/platform/qt/IOViewer.cpp @@ -1687,19 +1687,14 @@ void IOViewer::bitFlipped() { void IOViewer::writeback() { { CoreController::Interrupter interrupter(m_controller); - switch (m_controller->platform()) { -#ifdef M_CORE_GB - case mPLATFORM_GB: - GBIOWrite(static_cast(m_controller->thread()->core->board), m_register, m_value); + mCore* core = m_controller->thread()->core; + switch (m_width) { + case 0: + core->busWrite8(core, m_base + m_register, m_value); break; -#endif -#ifdef M_CORE_GBA - case mPLATFORM_GBA: - GBAIOWrite(static_cast(m_controller->thread()->core->board), m_register, m_value); + case 1: + core->busWrite16(core, m_base + m_register, m_value); break; -#endif - case mPLATFORM_NONE: - return; } } updateRegister(); From 8b1efec1161411c57d9643f4d437fd9bbdc4a5fb Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 12 May 2024 02:51:07 -0700 Subject: [PATCH 126/338] Qt: Fix LCDC background priority/enable bit being mis-mapped in I/O view --- CHANGES | 1 + src/platform/qt/IOViewer.cpp | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGES b/CHANGES index 899b3391a0a..60c1a61fb97 100644 --- a/CHANGES +++ b/CHANGES @@ -24,6 +24,7 @@ Other fixes: - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) - Qt: Fix potential crash when configuring shortcuts - Qt: Fix crash when applying changes to GB I/O registers in I/O view + - Qt: Fix LCDC background priority/enable bit being mis-mapped in I/O view - Updater: Fix updating appimage across filesystems Misc: - Core: Handle relative paths for saves, screenshots, etc consistently (fixes mgba.io/i/2826) diff --git a/src/platform/qt/IOViewer.cpp b/src/platform/qt/IOViewer.cpp index 90a97fdbb28..9b44af04f27 100644 --- a/src/platform/qt/IOViewer.cpp +++ b/src/platform/qt/IOViewer.cpp @@ -1323,7 +1323,7 @@ const QList& IOViewer::registerDescriptions(mPlat }); // 0xFF40: LCDC regGB.append({ - { tr("Background enable/priority"), 1 }, + { tr("Background enable/priority"), 0 }, { tr("Enable sprites"), 1 }, { tr("Double-height sprites"), 2 }, { tr("Background tile map"), 3, 1, { From 649be1b5056ad8c99e00c7d8d308cfc9fe8bcd5c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 21 May 2024 23:02:35 -0700 Subject: [PATCH 127/338] SDL: Properly disable SDL build if libsdl isn't found (fixes #3213) --- src/platform/sdl/CMakeLists.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/src/platform/sdl/CMakeLists.txt b/src/platform/sdl/CMakeLists.txt index 38e328d731c..d62c74694ab 100644 --- a/src/platform/sdl/CMakeLists.txt +++ b/src/platform/sdl/CMakeLists.txt @@ -40,6 +40,7 @@ endif() if (NOT SDL2_FOUND AND NOT SDL_FOUND) set(SDL_FOUND OFF PARENT_SCOPE) + set(BUILD_SDL OFF PARENT_SCOPE) return() endif() From 8c0a28477b23db01c0ce8ec916542097c1aa05f5 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 24 May 2024 01:31:25 -0700 Subject: [PATCH 128/338] GBA SIO: Improve MULTI timing --- src/gba/sio.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/gba/sio.c b/src/gba/sio.c index beb8efdfe74..4ffeb63880a 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -12,10 +12,10 @@ mLOG_DEFINE_CATEGORY(GBA_SIO, "GBA Serial I/O", "gba.sio"); const int GBASIOCyclesPerTransfer[4][MAX_GBAS] = { - { 38326, 73003, 107680, 142356 }, - { 9582, 18251, 26920, 35589 }, - { 6388, 12167, 17947, 23726 }, - { 3194, 6075, 8973, 11863 } + { 31976, 63427, 94884, 125829 }, + { 8378, 16241, 24104, 31457 }, + { 5750, 10998, 16241, 20972 }, + { 3140, 5755, 8376, 10486 } }; static struct GBASIODriver* _lookupDriver(struct GBASIO* sio, enum GBASIOMode mode) { From 2b394e1e26a38359c731a6db507fea6559723cce Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 24 May 2024 21:17:10 -0700 Subject: [PATCH 129/338] GBA SIO: Remove erroneous RCNT setting --- src/gba/sio/lockstep.c | 1 - 1 file changed, 1 deletion(-) diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 4f12610f191..ba620911e5d 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -105,7 +105,6 @@ bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver) { switch (node->mode) { case GBA_SIO_MULTI: node->d.writeRegister = GBASIOLockstepNodeMultiWriteRegister; - node->d.p->rcnt |= 3; ATOMIC_ADD(node->p->attachedMulti, 1); node->d.p->siocnt = GBASIOMultiplayerSetReady(node->d.p->siocnt, node->p->attachedMulti == node->p->d.attached); if (node->id) { From 3a3ebb5dc7a1dc6f8f893093d213a637acfc4024 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 25 May 2024 01:33:26 -0700 Subject: [PATCH 130/338] Third-Party: Cherry-pick rapidjson buildfix --- src/third-party/discord-rpc/include/rapidjson/document.h | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/third-party/discord-rpc/include/rapidjson/document.h b/src/third-party/discord-rpc/include/rapidjson/document.h index e3e20dfbdc9..b0f1f70beba 100644 --- a/src/third-party/discord-rpc/include/rapidjson/document.h +++ b/src/third-party/discord-rpc/include/rapidjson/document.h @@ -316,8 +316,6 @@ struct GenericStringRef { GenericStringRef(const GenericStringRef& rhs) : s(rhs.s), length(rhs.length) {} - GenericStringRef& operator=(const GenericStringRef& rhs) { s = rhs.s; length = rhs.length; } - //! implicit conversion to plain CharType pointer operator const Ch *() const { return s; } From c7b5d1054644b31d3fcd7b60d471948eb33648ed Mon Sep 17 00:00:00 2001 From: oltolm Date: Sat, 25 May 2024 14:11:53 +0200 Subject: [PATCH 131/338] fix Qt deprecation warnings --- src/platform/qt/ConfigController.cpp | 4 ++++ src/platform/qt/FrameView.cpp | 8 ++++++++ src/platform/qt/MapView.cpp | 5 +++++ src/platform/qt/MemoryModel.cpp | 10 ++++++++++ src/platform/qt/SaveConverter.cpp | 2 +- src/platform/qt/Swatch.cpp | 5 +++++ src/platform/qt/TilePainter.cpp | 5 +++++ src/platform/qt/Window.cpp | 8 ++++++++ src/platform/qt/main.cpp | 6 ++++++ 9 files changed, 52 insertions(+), 1 deletion(-) diff --git a/src/platform/qt/ConfigController.cpp b/src/platform/qt/ConfigController.cpp index 91ecf8e7a7b..ccec60432f2 100644 --- a/src/platform/qt/ConfigController.cpp +++ b/src/platform/qt/ConfigController.cpp @@ -318,7 +318,11 @@ void ConfigController::setOption(const char* key, const char* value) { } void ConfigController::setOption(const char* key, const QVariant& value) { +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (value.type() == QVariant::Bool) { +#else + if (value.typeId() == QMetaType::Type::Bool) { +#endif setOption(key, value.toBool()); return; } diff --git a/src/platform/qt/FrameView.cpp b/src/platform/qt/FrameView.cpp index 2fe37e64c28..ada077d742f 100644 --- a/src/platform/qt/FrameView.cpp +++ b/src/platform/qt/FrameView.cpp @@ -505,12 +505,20 @@ bool FrameView::eventFilter(QObject*, QEvent* event) { QPointF pos; switch (event->type()) { case QEvent::MouseButtonPress: +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) pos = static_cast(event)->localPos(); +#else + pos = static_cast(event)->position(); +#endif pos /= m_ui.magnification->value(); selectLayer(pos); return true; case QEvent::MouseButtonDblClick: +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) pos = static_cast(event)->localPos(); +#else + pos = static_cast(event)->position(); +#endif pos /= m_ui.magnification->value(); disableLayer(pos); return true; diff --git a/src/platform/qt/MapView.cpp b/src/platform/qt/MapView.cpp index a00c63c0e6e..aef8c58b783 100644 --- a/src/platform/qt/MapView.cpp +++ b/src/platform/qt/MapView.cpp @@ -161,8 +161,13 @@ bool MapView::eventFilter(QObject*, QEvent* event) { if (event->type() != QEvent::MouseButtonPress) { return false; } +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) int x = static_cast(event)->x(); int y = static_cast(event)->y(); +#else + int x = static_cast(event)->position().x(); + int y = static_cast(event)->position().y(); +#endif x /= 8 * m_ui.magnification->value(); y /= 8 * m_ui.magnification->value(); selectTile(x, y); diff --git a/src/platform/qt/MemoryModel.cpp b/src/platform/qt/MemoryModel.cpp index 538ce2c51c3..9bcf54223ca 100644 --- a/src/platform/qt/MemoryModel.cpp +++ b/src/platform/qt/MemoryModel.cpp @@ -511,8 +511,13 @@ void MemoryModel::wheelEvent(QWheelEvent* event) { } void MemoryModel::mousePressEvent(QMouseEvent* event) { +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (event->x() < m_margins.left() || event->y() < m_margins.top() || event->x() > size().width() - m_margins.right()) { +#else + if (event->position().x() < m_margins.left() || event->position().y() < m_margins.top() || + event->position().x() > size().width() - m_margins.right()) { +#endif m_selection = qMakePair(0, 0); return; } @@ -540,8 +545,13 @@ void MemoryModel::mousePressEvent(QMouseEvent* event) { } void MemoryModel::mouseMoveEvent(QMouseEvent* event) { +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (event->x() < m_margins.left() || event->y() < m_margins.top() || event->x() > size().width() - m_margins.right()) { +#else + if (event->position().x() < m_margins.left() || event->position().y() < m_margins.top() || + event->position().x() > size().width() - m_margins.right()) { +#endif return; } diff --git a/src/platform/qt/SaveConverter.cpp b/src/platform/qt/SaveConverter.cpp index d16eeeea4f5..974f31af0fd 100644 --- a/src/platform/qt/SaveConverter.cpp +++ b/src/platform/qt/SaveConverter.cpp @@ -281,7 +281,7 @@ void SaveConverter::detectFromHeaders(std::shared_ptr vf) { } free(data); } - } else if (buffer.left(gsv.count()) == gsv) { + } else if (buffer.left(gsv.size()) == gsv) { size_t size; void* data = GBASavedataGSVGetPayload(*vf, &size, nullptr, false); if (data) { diff --git a/src/platform/qt/Swatch.cpp b/src/platform/qt/Swatch.cpp index 3eb85d780fc..f4a9ad7c352 100644 --- a/src/platform/qt/Swatch.cpp +++ b/src/platform/qt/Swatch.cpp @@ -56,8 +56,13 @@ void Swatch::paintEvent(QPaintEvent*) { } void Swatch::mousePressEvent(QMouseEvent* event) { +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) int x = event->x() / (m_size + 1); int y = event->y() / (m_size + 1); +#else + int x = event->position().x() / (m_size + 1); + int y = event->position().y() / (m_size + 1); +#endif emit indexPressed(y * m_dims.width() + x); } diff --git a/src/platform/qt/TilePainter.cpp b/src/platform/qt/TilePainter.cpp index c27ade72e40..fcb62d42080 100644 --- a/src/platform/qt/TilePainter.cpp +++ b/src/platform/qt/TilePainter.cpp @@ -39,8 +39,13 @@ void TilePainter::resizeEvent(QResizeEvent*) { } void TilePainter::mousePressEvent(QMouseEvent* event) { +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) int x = event->x() / m_size; int y = event->y() / m_size; +#else + int x = event->position().x() / m_size; + int y = event->position().y() / m_size; +#endif int index = y * (width() / m_size) + x; if (index < m_tileCount) { emit indexPressed(index); diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index c75a163efbf..a5576c1c9d9 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -918,7 +918,11 @@ void Window::gameStarted() { #ifdef M_CORE_GBA if (m_controller->platform() == mPLATFORM_GBA) { QVariant eCardList = m_config->takeArgvOption(QString("ecard")); +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (eCardList.canConvert(QMetaType::QStringList)) { +#else + if (QMetaType::canConvert(eCardList.metaType(), QMetaType(QMetaType::QStringList))) { +#endif m_controller->scanCards(eCardList.toStringList()); } } @@ -2149,7 +2153,11 @@ void Window::setController(CoreController* controller, const QString& fname) { #ifdef M_CORE_GBA if (m_controller->platform() == mPLATFORM_GBA) { QVariant mb = m_config->takeArgvOption(QString("mb")); +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (mb.canConvert(QMetaType::QString)) { +#else + if (QMetaType::canConvert(mb.metaType(), QMetaType(QMetaType::QString))) { +#endif m_controller->replaceGame(mb.toString()); } } diff --git a/src/platform/qt/main.cpp b/src/platform/qt/main.cpp index 62967bf1a07..f98d2cd88b3 100644 --- a/src/platform/qt/main.cpp +++ b/src/platform/qt/main.cpp @@ -90,7 +90,9 @@ int main(int argc, char* argv[]) { QApplication::setApplicationName(projectName); QApplication::setApplicationVersion(projectVersion); +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) QApplication::setAttribute(Qt::AA_UseHighDpiPixmaps, true); +#endif #ifdef BUILD_GLES2 QSurfaceFormat format; @@ -109,7 +111,11 @@ int main(int argc, char* argv[]) { #endif QTranslator qtTranslator; +#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) if (qtTranslator.load(locale, "qt", "_", QLibraryInfo::location(QLibraryInfo::TranslationsPath))) { +#else + if (qtTranslator.load(locale, "qt", "_", QLibraryInfo::path(QLibraryInfo::TranslationsPath))) { +#endif application.installTranslator(&qtTranslator); } From b7729c9e80736e34a46ff9f38fcaf0d1ed97a7b2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 27 May 2024 02:57:11 -0700 Subject: [PATCH 132/338] GBA Video: Add special circlular window handling in OpenGL renderer --- CHANGES | 1 + include/mgba/internal/gba/renderers/gl.h | 2 + src/gba/renderers/gl.c | 138 ++++++++++++++++++++++- 3 files changed, 139 insertions(+), 2 deletions(-) diff --git a/CHANGES b/CHANGES index 60c1a61fb97..3d477b02204 100644 --- a/CHANGES +++ b/CHANGES @@ -32,6 +32,7 @@ Misc: - GB Serialize: Add missing savestate support for MBC6 and NT (newer) - GBA: Improve detection of valid ELF ROMs - GBA Audio: Remove broken XQ audio pending rewrite + - GBA Video: Add special circlular window handling in OpenGL renderer - Libretro: Add Super Game Boy Color support (closes mgba.io/i/3188) - mGUI: Enable auto-softpatching (closes mgba.io/i/2899) - mGUI: Persist fast forwarding after closing menu (fixes mgba.io/i/2414) diff --git a/include/mgba/internal/gba/renderers/gl.h b/include/mgba/internal/gba/renderers/gl.h index 14cf11678ad..74baec41ea8 100644 --- a/include/mgba/internal/gba/renderers/gl.h +++ b/include/mgba/internal/gba/renderers/gl.h @@ -118,6 +118,8 @@ enum { GBA_GL_WIN_FLAGS, GBA_GL_WIN_WIN0, GBA_GL_WIN_WIN1, + GBA_GL_WIN_CIRCLE0, + GBA_GL_WIN_CIRCLE1, GBA_GL_FINALIZE_SCALE = 2, GBA_GL_FINALIZE_LAYERS, diff --git a/src/gba/renderers/gl.c b/src/gba/renderers/gl.c index c80da2bcb97..afc9c54ace2 100644 --- a/src/gba/renderers/gl.c +++ b/src/gba/renderers/gl.c @@ -486,6 +486,8 @@ static const struct GBAVideoGLUniform _uniformsWindow[] = { { "flags", GBA_GL_WIN_FLAGS, }, { "win0", GBA_GL_WIN_WIN0, }, { "win1", GBA_GL_WIN_WIN1, }, + { "circle0", GBA_GL_WIN_CIRCLE0, }, + { "circle1", GBA_GL_WIN_CIRCLE1, }, { 0 } }; @@ -496,6 +498,8 @@ static const char* const _renderWindow = "uniform ivec3 flags;\n" "uniform ivec4 win0[160];\n" "uniform ivec4 win1[160];\n" + "uniform vec3 circle0;\n" + "uniform vec3 circle1;\n" "OUT(0) out ivec4 window;\n" "bool crop(vec4 windowParams) {\n" @@ -529,13 +533,20 @@ static const char* const _renderWindow = " return vec4(mix(bottom.xy, top.xy, fract(texCoord.y)), top.zw);\n" "}\n" + "bool test(vec3 circle, vec4 top, vec4 bottom) {\n" + " if (circle.z > 0) {\n" + " return distance(circle.xy, texCoord.xy) <= circle.z;\n" + " }\n" + " return crop(interpolate(top, bottom));\n" + "}\n" + "void main() {\n" " ivec4 windowFlags = ivec4(flags.z, blend, 0);\n" " int top = int(texCoord.y);\n" " int bottom = max(top - 1, 0);\n" - " if ((dispcnt & 0x20) != 0 && crop(interpolate(vec4(win0[top]), vec4(win0[bottom])))) { \n" + " if ((dispcnt & 0x20) != 0 && test(circle0, vec4(win0[top]), vec4(win0[bottom]))) {\n" " windowFlags.x = flags.x;\n" - " } else if ((dispcnt & 0x40) != 0 && crop(interpolate(vec4(win1[top]), vec4(win1[bottom])))) {\n" + " } else if ((dispcnt & 0x40) != 0 && test(circle1, vec4(win1[top]), vec4(win1[bottom]))) {\n" " windowFlags.x = flags.y;\n" " }\n" " window = windowFlags;\n" @@ -1924,6 +1935,127 @@ void GBAVideoGLRendererDrawBackgroundMode5(struct GBAVideoGLRenderer* renderer, glDrawBuffers(1, (GLenum[]) { GL_COLOR_ATTACHMENT0 }); } +static void _detectCircle(struct GBAVideoGLRenderer* renderer, int y, int window) { + int lastStart = 0; + int lastEnd = 0; + + int startX = 0; + int endX = 0; + + int firstY = -1; + float centerX; + float centerY = -1; + float radius = 0; + bool invalid = false; + + int i; + for (i = renderer->firstY; i <= y; ++i) { + lastStart = startX; + lastEnd = endX; + startX = renderer->winNHistory[window][i * 4]; + endX = renderer->winNHistory[window][i * 4 + 1]; + int startY = renderer->winNHistory[window][i * 4 + 2]; + int endY = renderer->winNHistory[window][i * 4 + 3]; + + if (startX == endX || i < startY || i >= endY) { + if (firstY >= 0) { + // The bottom edge of the circle + centerY = (firstY + i) / 2.f; + firstY = -1; + } + continue; + } + if (lastEnd - lastStart <= 0) { + continue; + } + + // The previous segment was non-zero + if (startX >= GBA_VIDEO_HORIZONTAL_PIXELS) { + invalid = true; + break; + } + + int startDiff = lastStart - startX; + int endDiff = endX - lastEnd; + // Make sure the slopes match, otherwise this isn't a circle + if (startDiff - endDiff < -1 || startDiff - endDiff > 1) { + invalid = true; + break; + } + + if (startX < lastStart) { + centerX = (startX + endX) / 2.f; + if (radius > 0) { + // We found two separate shapes, which the interpolation can't handle + invalid = true; + break; + } + } else if (startX > lastStart && radius <= 0) { + radius = (lastEnd - lastStart) / 2.f; + } + + if (firstY < 0 && i - 1 >= startY && i - 1 < endY) { + firstY = i - 1; + } + } + + if (radius <= 0) { + invalid = true; + } + if (centerY < 0) { + invalid = true; + } + + // Check validity + for (i = renderer->firstY; i <= y && !invalid; ++i) { + int startX = renderer->winNHistory[window][i * 4]; + int endX = renderer->winNHistory[window][i * 4 + 1]; + int startY = renderer->winNHistory[window][i * 4 + 2]; + int endY = renderer->winNHistory[window][i * 4 + 3]; + + bool xActive = startX < endX; + bool yActive = i >= startY && i < endY; + + if (xActive && yActive) { + // Real window would be active, make sure simulated window would too + if (centerY - i > radius) { + // y is above the radius + invalid = true; + break; + } + if (i - centerY > radius) { + // y is below the radius + invalid = true; + break; + } + + float cosine = fabsf(i - centerY); + float sine = sqrtf(radius * radius - cosine * cosine); + if (fabsf(centerX - sine - startX) <= 1 && fabsf(centerX + sine - endX) <= 1) { + continue; + } + + if (radius >= cosine + 1) { + sine = sqrtf(radius * radius - (cosine + 1) * (cosine + 1)); + if (fabsf(centerX - sine - startX) <= 1 && fabsf(centerX + sine - endX) <= 1) { + continue; + } + } + // y is active on the wrong parts of the scanline + invalid = true; + } else if (centerY - i < radius && i - centerY < radius) { + // Real window would be inactive, make sure simulated window would too + invalid = true; + } + } + + if (invalid) { + glUniform3f(renderer->windowShader.uniforms[GBA_GL_WIN_CIRCLE0 + window], 0, 0, 0); + } else { + glUniform3f(renderer->windowShader.uniforms[GBA_GL_WIN_CIRCLE0 + window], centerX, centerY, radius - 0.499); + } +} + void GBAVideoGLRendererDrawWindow(struct GBAVideoGLRenderer* renderer, int y) { const struct GBAVideoGLShader* shader = &renderer->windowShader; const GLuint* uniforms = shader->uniforms; @@ -1950,6 +2082,8 @@ void GBAVideoGLRendererDrawWindow(struct GBAVideoGLRenderer* renderer, int y) { glUniform3i(uniforms[GBA_GL_WIN_FLAGS], renderer->winN[0].control, renderer->winN[1].control, renderer->winout); glUniform4iv(uniforms[GBA_GL_WIN_WIN0], GBA_VIDEO_VERTICAL_PIXELS, renderer->winNHistory[0]); glUniform4iv(uniforms[GBA_GL_WIN_WIN1], GBA_VIDEO_VERTICAL_PIXELS, renderer->winNHistory[1]); + _detectCircle(renderer, y, 0); + _detectCircle(renderer, y, 1); glDrawArrays(GL_TRIANGLE_FAN, 0, 4); break; } From 56023cfd02a1a95c3c9f15b4463ff0c6479550c9 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 1 Jun 2024 00:07:19 -0700 Subject: [PATCH 133/338] Core: Fix warnings --- src/core/thread.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/core/thread.c b/src/core/thread.c index 0be5f81e21f..2462407cc1f 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -459,11 +459,11 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { } logger->filter = NULL; - return 0; + THREAD_EXIT(0); } bool mCoreThreadStart(struct mCoreThread* threadContext) { - threadContext->impl = calloc(sizeof(*threadContext->impl), 1); + threadContext->impl = calloc(1, sizeof(*threadContext->impl)); threadContext->impl->state = mTHREAD_INITIALIZED; threadContext->impl->requested = 0; threadContext->logger.p = threadContext; From 942167acdf44a3d99494179a63dfd942ecf725d5 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 2 Jun 2024 17:17:24 -0700 Subject: [PATCH 134/338] ARM: Backport some CPU table improvements from medusa --- include/mgba/internal/arm/emitter-arm.h | 521 ++++++++++++------------ 1 file changed, 261 insertions(+), 260 deletions(-) diff --git a/include/mgba/internal/arm/emitter-arm.h b/include/mgba/internal/arm/emitter-arm.h index e99a1b7eed9..bdea1db8a6f 100644 --- a/include/mgba/internal/arm/emitter-arm.h +++ b/include/mgba/internal/arm/emitter-arm.h @@ -1,4 +1,4 @@ -/* Copyright (c) 2013-2014 Jeffrey Pfau +/* Copyright (c) 2013-2024 Jeffrey Pfau * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this @@ -67,269 +67,270 @@ DO_8(DECLARE_INSTRUCTION_ARM(EMITTER, NAME)), \ DO_8(DECLARE_INSTRUCTION_ARM(EMITTER, NAME)) -#define DECLARE_ARM_COPROCESSOR_BLOCK(EMITTER, NAME1, NAME2) \ - DO_8(DO_8(DO_INTERLACE(DECLARE_INSTRUCTION_ARM(EMITTER, NAME1), DECLARE_INSTRUCTION_ARM(EMITTER, NAME2)))) +#define DECLARE_ARM_COPROCESSOR_BLOCK(EMITTER, NAME1, NAME2, NAME3) \ + DO_8(DO_INTERLACE( \ + DO_8(DO_INTERLACE(DECLARE_INSTRUCTION_ARM(EMITTER, NAME1), DECLARE_INSTRUCTION_ARM(EMITTER, NAME2))), \ + DO_8(DO_INTERLACE(DECLARE_INSTRUCTION_ARM(EMITTER, NAME1), DECLARE_INSTRUCTION_ARM(EMITTER, NAME3))))) #define DECLARE_ARM_SWI_BLOCK(EMITTER) \ DO_256(DECLARE_INSTRUCTION_ARM(EMITTER, SWI)) #define DECLARE_ARM_EMITTER_BLOCK(EMITTER) \ - DECLARE_ARM_ALU_BLOCK(EMITTER, AND, MUL, STRH, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, ANDS, MULS, LDRH, LDRSB, LDRSH), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, EOR, MLA, STRH, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, EORS, MLAS, LDRH, LDRSB, LDRSH), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, SUB, ILL, STRHI, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, SUBS, ILL, LDRHI, LDRSBI, LDRSHI), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, RSB, ILL, STRHI, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, RSBS, ILL, LDRHI, LDRSBI, LDRSHI), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, ADD, UMULL, STRHU, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, ADDS, UMULLS, LDRHU, LDRSBU, LDRSHU), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, ADC, UMLAL, STRHU, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, ADCS, UMLALS, LDRHU, LDRSBU, LDRSHU), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, SBC, SMULL, STRHIU, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, SBCS, SMULLS, LDRHIU, LDRSBIU, LDRSHIU), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, RSC, SMLAL, STRHIU, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, RSCS, SMLALS, LDRHIU, LDRSBIU, LDRSHIU), \ - DECLARE_INSTRUCTION_ARM(EMITTER, MRS), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, SWP), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, STRHP), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, TST, ILL, LDRHP, LDRSBP, LDRSHP), \ - DECLARE_INSTRUCTION_ARM(EMITTER, MSR), \ - DECLARE_INSTRUCTION_ARM(EMITTER, BX), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, BKPT), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, STRHPW), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, TEQ, ILL, LDRHPW, LDRSBPW, LDRSHPW), \ - DECLARE_INSTRUCTION_ARM(EMITTER, MRSR), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, SWPB), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, STRHIP), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, CMP, ILL, LDRHIP, LDRSBIP, LDRSHIP), \ - DECLARE_INSTRUCTION_ARM(EMITTER, MSRR), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, STRHIPW), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, CMN, ILL, LDRHIPW, LDRSBIPW, LDRSHIPW), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, ORR, SMLAL, STRHPU, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, ORRS, SMLALS, LDRHPU, LDRSBPU, LDRSHPU), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, MOV, SMLAL, STRHPUW, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, MOVS, SMLALS, LDRHPUW, LDRSBPUW, LDRSHPUW), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, BIC, SMLAL, STRHIPU, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, BICS, SMLALS, LDRHIPU, LDRSBIPU, LDRSHIPU), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, MVN, SMLAL, STRHIPUW, ILL, ILL), \ - DECLARE_ARM_ALU_BLOCK(EMITTER, MVNS, SMLALS, LDRHIPUW, LDRSBIPUW, LDRSHIPUW), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, AND), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ANDS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, EOR), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, EORS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, SUB), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, SUBS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, RSB), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, RSBS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ADD), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ADDS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ADC), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ADCS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, SBC), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, SBCS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, RSC), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, RSCS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, TST), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, TST), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MSR), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, TEQ), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, CMP), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, CMP), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MSRR), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, CMN), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ORR), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ORRS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MOV), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MOVS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, BIC), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, BICS), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MVN), \ - DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MVNS), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, , , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, , , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRT, , , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRT, , , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, , , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, , , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRBT, , , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRBT, , , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, , U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, , U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRT, , U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRT, , U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, , U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, , U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRBT, , U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRBT, , U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, P, , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, P, , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, P, , W), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, P, , W), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, P, , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, P, , ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, P, , W), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, P, , W), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, P, U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, P, U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, P, U, W), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, P, U, W), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, P, U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, P, U, ), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, P, U, W), \ - DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, P, U, W), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, , , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, , , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRT, , , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRT, , , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, , , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, , , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRBT, , , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRBT, , , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, , U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, , U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRT, , U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRT, , U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, , U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, , U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRBT, , U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRBT, , U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, P, , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, P, , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, P, , W), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, P, , W), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, P, , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, P, , ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, P, , W), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, P, , W), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, P, U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, P, U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, P, U, W), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, P, U, W), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, P, U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, P, U, ), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, P, U, W), \ - DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, P, U, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, DA, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, DA, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, DA, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, DA, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, DA, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, DA, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, DA, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, DA, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, IA, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, IA, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, IA, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, IA, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, IA, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, IA, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, IA, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, IA, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, DB, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, DB, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, DB, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, DB, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, DB, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, DB, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, DB, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, DB, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, IB, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, IB, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, IB, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, IB, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, IB, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, IB, ), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, IB, W), \ - DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, IB, W), \ - DECLARE_ARM_BRANCH_BLOCK(EMITTER, B), \ - DECLARE_ARM_BRANCH_BLOCK(EMITTER, BL), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , , , ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , , , ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , , , W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , , , W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , , N, ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , , N, ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , , N, W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , , N, W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , U, , ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , U, , ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , U, , W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , U, , W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , U, N, ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , U, N, ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , U, N, W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , U, N, W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, , , ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, , , ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, , , W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, , , W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, U, N, ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, U, N, ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, U, N, W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, U, N, W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, , N, ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, , N, ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, , N, W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, , N, W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, U, N, ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, U, N, ), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, U, N, W), \ - DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, U, N, W), \ - DECLARE_ARM_COPROCESSOR_BLOCK(EMITTER, CDP, MCR), \ - DECLARE_ARM_COPROCESSOR_BLOCK(EMITTER, CDP, MRC), \ - DECLARE_ARM_SWI_BLOCK(EMITTER) + /* -00---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, AND, MUL, STRH, ILL, ILL), \ + /* -01---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, ANDS, MULS, LDRH, LDRSB, LDRSH), \ + /* -02---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, EOR, MLA, STRH, ILL, ILL), \ + /* -03---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, EORS, MLAS, LDRH, LDRSB, LDRSH), \ + /* -04---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, SUB, ILL, STRHI, ILL, ILL), \ + /* -05---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, SUBS, ILL, LDRHI, LDRSBI, LDRSHI), \ + /* -06---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, RSB, ILL, STRHI, ILL, ILL), \ + /* -07---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, RSBS, ILL, LDRHI, LDRSBI, LDRSHI), \ + /* -08---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, ADD, UMULL, STRHU, ILL, ILL), \ + /* -09---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, ADDS, UMULLS, LDRHU, LDRSBU, LDRSHU), \ + /* -0A---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, ADC, UMLAL, STRHU, ILL, ILL), \ + /* -0B---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, ADCS, UMLALS, LDRHU, LDRSBU, LDRSHU), \ + /* -0C---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, SBC, SMULL, STRHIU, ILL, ILL), \ + /* -0D---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, SBCS, SMULLS, LDRHIU, LDRSBIU, LDRSHIU), \ + /* -0E---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, RSC, SMLAL, STRHIU, ILL, ILL), \ + /* -0F---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, RSCS, SMLALS, LDRHIU, LDRSBIU, LDRSHIU), \ + /* -10---0- */ DECLARE_INSTRUCTION_ARM(EMITTER, MRS), \ + /* -10---1- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---2- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---3- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---4- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---5- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---6- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---7- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---8- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---9- */ DECLARE_INSTRUCTION_ARM(EMITTER, SWP), \ + /* -10---A- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---B- */ DECLARE_INSTRUCTION_ARM(EMITTER, STRHP), \ + /* -10---C- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---D- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---E- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -10---F- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -11---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, TST, ILL, LDRHP, LDRSBP, LDRSHP), \ + /* -12---0- */ DECLARE_INSTRUCTION_ARM(EMITTER, MSR), \ + /* -12---1- */ DECLARE_INSTRUCTION_ARM(EMITTER, BX), \ + /* -12---2- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---3- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---4- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---5- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---6- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---7- */ DECLARE_INSTRUCTION_ARM(EMITTER, BKPT), \ + /* -12---8- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---9- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---A- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---B- */ DECLARE_INSTRUCTION_ARM(EMITTER, STRHPW), \ + /* -12---C- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---D- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---E- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -12---F- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -13---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, TEQ, ILL, LDRHPW, LDRSBPW, LDRSHPW), \ + /* -14---0- */ DECLARE_INSTRUCTION_ARM(EMITTER, MRSR), \ + /* -14---1- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---2- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---3- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---4- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---5- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---6- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---7- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---8- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---9- */ DECLARE_INSTRUCTION_ARM(EMITTER, SWPB), \ + /* -14---A- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---B- */ DECLARE_INSTRUCTION_ARM(EMITTER, STRHIP), \ + /* -14---C- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---D- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---E- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -14---F- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -15---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, CMP, ILL, LDRHIP, LDRSBIP, LDRSHIP), \ + /* -16---0- */ DECLARE_INSTRUCTION_ARM(EMITTER, MSRR), \ + /* -16---1- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---2- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---3- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---4- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---5- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---6- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---7- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---8- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---9- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---A- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---B- */ DECLARE_INSTRUCTION_ARM(EMITTER, STRHIPW), \ + /* -16---C- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---D- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---E- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -16---F- */ DECLARE_INSTRUCTION_ARM(EMITTER, ILL), \ + /* -17---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, CMN, ILL, LDRHIPW, LDRSBIPW, LDRSHIPW), \ + /* -18---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, ORR, SMLAL, STRHPU, ILL, ILL), \ + /* -19---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, ORRS, SMLALS, LDRHPU, LDRSBPU, LDRSHPU), \ + /* -1A---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, MOV, SMLAL, STRHPUW, ILL, ILL), \ + /* -1B---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, MOVS, SMLALS, LDRHPUW, LDRSBPUW, LDRSHPUW), \ + /* -1C---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, BIC, SMLAL, STRHIPU, ILL, ILL), \ + /* -1D---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, BICS, SMLALS, LDRHIPU, LDRSBIPU, LDRSHIPU), \ + /* -1E---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, MVN, SMLAL, STRHIPUW, ILL, ILL), \ + /* -1F---X- */ DECLARE_ARM_ALU_BLOCK(EMITTER, MVNS, SMLALS, LDRHIPUW, LDRSBIPUW, LDRSHIPUW), \ + /* -20---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, AND), \ + /* -21---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ANDS), \ + /* -22---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, EOR), \ + /* -23---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, EORS), \ + /* -24---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, SUB), \ + /* -25---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, SUBS), \ + /* -26---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, RSB), \ + /* -27---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, RSBS), \ + /* -28---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ADD), \ + /* -29---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ADDS), \ + /* -2A---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ADC), \ + /* -2B---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ADCS), \ + /* -2C---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, SBC), \ + /* -2D---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, SBCS), \ + /* -2E---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, RSC), \ + /* -2F---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, RSCS), \ + /* -30---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, TST), \ + /* -31---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, TST), \ + /* -32---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MSR), \ + /* -33---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, TEQ), \ + /* -34---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, CMP), \ + /* -35---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, CMP), \ + /* -36---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MSRR), \ + /* -37---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, CMN), \ + /* -38---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ORR), \ + /* -39---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, ORRS), \ + /* -3A---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MOV), \ + /* -3B---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MOVS), \ + /* -3C---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, BIC), \ + /* -3D---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, BICS), \ + /* -3E---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MVN), \ + /* -3F---X- */ DECLARE_ARM_ALU_IMMEDIATE_BLOCK(EMITTER, MVNS), \ + /* -40---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, , , ), \ + /* -41---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, , , ), \ + /* -42---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRT, , , ), \ + /* -43---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRT, , , ), \ + /* -44---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, , , ), \ + /* -45---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, , , ), \ + /* -46---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRBT, , , ), \ + /* -47---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRBT, , , ), \ + /* -48---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, , U, ), \ + /* -49---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, , U, ), \ + /* -4A---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRT, , U, ), \ + /* -4B---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRT, , U, ), \ + /* -4C---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, , U, ), \ + /* -4D---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, , U, ), \ + /* -4E---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRBT, , U, ), \ + /* -4F---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRBT, , U, ), \ + /* -50---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, P, , ), \ + /* -51---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, P, , ), \ + /* -52---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, P, , W), \ + /* -53---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, P, , W), \ + /* -54---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, P, , ), \ + /* -55---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, P, , ), \ + /* -56---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, P, , W), \ + /* -57---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, P, , W), \ + /* -58---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, P, U, ), \ + /* -59---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, P, U, ), \ + /* -5A---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STR, P, U, W), \ + /* -5B---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDR, P, U, W), \ + /* -5C---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, P, U, ), \ + /* -5D---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, P, U, ), \ + /* -5E---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, STRB, P, U, W), \ + /* -5F---X- */ DECLARE_ARM_LOAD_STORE_IMMEDIATE_BLOCK(EMITTER, LDRB, P, U, W), \ + /* -60---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, , , ), \ + /* -61---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, , , ), \ + /* -62---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRT, , , ), \ + /* -63---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRT, , , ), \ + /* -64---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, , , ), \ + /* -65---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, , , ), \ + /* -66---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRBT, , , ), \ + /* -67---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRBT, , , ), \ + /* -68---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, , U, ), \ + /* -69---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, , U, ), \ + /* -6A---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRT, , U, ), \ + /* -6B---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRT, , U, ), \ + /* -6C---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, , U, ), \ + /* -6D---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, , U, ), \ + /* -6E---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRBT, , U, ), \ + /* -6F---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRBT, , U, ), \ + /* -70---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, P, , ), \ + /* -71---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, P, , ), \ + /* -72---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, P, , W), \ + /* -73---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, P, , W), \ + /* -74---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, P, , ), \ + /* -75---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, P, , ), \ + /* -76---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, P, , W), \ + /* -77---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, P, , W), \ + /* -78---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, P, U, ), \ + /* -79---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, P, U, ), \ + /* -7A---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STR, P, U, W), \ + /* -7B---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDR, P, U, W), \ + /* -7C---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, P, U, ), \ + /* -7D---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, P, U, ), \ + /* -7E---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, STRB, P, U, W), \ + /* -7F---X- */ DECLARE_ARM_LOAD_STORE_BLOCK(EMITTER, LDRB, P, U, W), \ + /* -80---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, DA, ), \ + /* -81---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, DA, ), \ + /* -82---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, DA, W), \ + /* -83---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, DA, W), \ + /* -84---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, DA, ), \ + /* -85---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, DA, ), \ + /* -86---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, DA, W), \ + /* -87---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, DA, W), \ + /* -88---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, IA, ), \ + /* -89---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, IA, ), \ + /* -8A---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, IA, W), \ + /* -8B---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, IA, W), \ + /* -8C---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, IA, ), \ + /* -8D---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, IA, ), \ + /* -8E---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, IA, W), \ + /* -8F---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, IA, W), \ + /* -90---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, DB, ), \ + /* -91---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, DB, ), \ + /* -92---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, DB, W), \ + /* -93---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, DB, W), \ + /* -94---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, DB, ), \ + /* -95---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, DB, ), \ + /* -96---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, DB, W), \ + /* -97---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, DB, W), \ + /* -98---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, IB, ), \ + /* -99---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, IB, ), \ + /* -9A---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STM, IB, W), \ + /* -9B---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDM, IB, W), \ + /* -9C---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, IB, ), \ + /* -9D---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, IB, ), \ + /* -9E---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, STMS, IB, W), \ + /* -9F---X- */ DECLARE_ARM_LOAD_STORE_MULTIPLE_BLOCK(EMITTER, LDMS, IB, W), \ + /* -AX---X- */ DECLARE_ARM_BRANCH_BLOCK(EMITTER, B), \ + /* -BX---X- */ DECLARE_ARM_BRANCH_BLOCK(EMITTER, BL), \ + /* -C0---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , , , ), \ + /* -C1---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , , , ), \ + /* -C2---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , , , W), \ + /* -C3---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , , , W), \ + /* -C4---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , , N, ), \ + /* -C5---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , , N, ), \ + /* -C6---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , , N, W), \ + /* -C7---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , , N, W), \ + /* -C8---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , U, , ), \ + /* -C9---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , U, , ), \ + /* -CA---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , U, , W), \ + /* -CB---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , U, , W), \ + /* -CC---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , U, N, ), \ + /* -CD---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , U, N, ), \ + /* -CE---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, , U, N, W), \ + /* -CF---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, , U, N, W), \ + /* -D0---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, , , ), \ + /* -D1---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, , , ), \ + /* -D2---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, , , W), \ + /* -D3---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, , , W), \ + /* -D4---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, U, N, ), \ + /* -D5---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, U, N, ), \ + /* -D6---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, U, N, W), \ + /* -D7---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, U, N, W), \ + /* -D8---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, , N, ), \ + /* -D9---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, , N, ), \ + /* -DA---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, , N, W), \ + /* -DB---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, , N, W), \ + /* -DC---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, U, N, ), \ + /* -DD---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, U, N, ), \ + /* -DE---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, STC, P, U, N, W), \ + /* -DF---X- */ DECLARE_ARM_LOAD_STORE_COPROCESSOR_BLOCK(EMITTER, LDC, P, U, N, W), \ + /* -EX---X- */ DECLARE_ARM_COPROCESSOR_BLOCK(EMITTER, CDP, MCR, MRC), \ + /* -FX---X- */ DECLARE_ARM_SWI_BLOCK(EMITTER) #endif From e4e455dd5ed09ac38d65d099aba2d2e0e082fad8 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 2 Jun 2024 17:30:17 -0700 Subject: [PATCH 135/338] ARM: Add framework for coprocessor support --- CHANGES | 1 + include/mgba/internal/arm/arm.h | 7 ++++++ src/arm/arm.c | 1 + src/arm/isa-arm.c | 39 ++++++++++++++++++++++++++++++--- 4 files changed, 45 insertions(+), 3 deletions(-) diff --git a/CHANGES b/CHANGES index 3d477b02204..7c48e3ab157 100644 --- a/CHANGES +++ b/CHANGES @@ -7,6 +7,7 @@ Features: - New unlicensed GB mappers: NT (older types 1 and 2), Li Cheng, GGB-81 - Debugger: Add range watchpoints Emulation fixes: + - ARM: Add framework for coprocessor support - GB Audio: Fix audio envelope timing resetting too often (fixes mgba.io/i/3164) - GB I/O: Fix STAT writing IRQ trigger conditions (fixes mgba.io/i/2501) - GB Serialize: Add missing Pocket Cam state to savestates diff --git a/include/mgba/internal/arm/arm.h b/include/mgba/internal/arm/arm.h index f9eeafdb6db..5f25acf9035 100644 --- a/include/mgba/internal/arm/arm.h +++ b/include/mgba/internal/arm/arm.h @@ -134,6 +134,12 @@ struct ARMMemory { void (*setActiveRegion)(struct ARMCore*, uint32_t address); }; +struct ARMCoprocessor { + int32_t (*mrc)(struct ARMCore*, int crn, int crm, int opcode1, int opcode2); + void (*mcr)(struct ARMCore*, int crn, int crm, int opcode1, int opcode2, int32_t value); + void (*cdp)(struct ARMCore*, int crn, int crm, int crd, int opcode1, int opcode2); +}; + struct ARMInterruptHandler { void (*reset)(struct ARMCore* cpu); void (*processEvents)(struct ARMCore* cpu); @@ -179,6 +185,7 @@ struct ARMCore { struct ARMMemory memory; struct ARMInterruptHandler irqh; + struct ARMCoprocessor cp[16]; struct mCPUComponent* master; diff --git a/src/arm/arm.c b/src/arm/arm.c index cb93136aa46..0b92d7f55f1 100644 --- a/src/arm/arm.c +++ b/src/arm/arm.c @@ -45,6 +45,7 @@ void ARMSetPrivilegeMode(struct ARMCore* cpu, enum PrivilegeMode mode) { } void ARMInit(struct ARMCore* cpu) { + memset(cpu->cp, 0, sizeof(cpu->cp)); cpu->master->init(cpu, cpu->master); size_t i; for (i = 0; i < cpu->numComponents; ++i) { diff --git a/src/arm/isa-arm.c b/src/arm/isa-arm.c index 7f158dc6e67..aaecf25171f 100644 --- a/src/arm/isa-arm.c +++ b/src/arm/isa-arm.c @@ -655,11 +655,44 @@ DEFINE_INSTRUCTION_ARM(BX, // Begin coprocessor definitions -DEFINE_INSTRUCTION_ARM(CDP, ARM_STUB) +#define DEFINE_COPROCESSOR_INSTRUCTION(NAME, BODY) \ + DEFINE_INSTRUCTION_ARM(NAME, \ + int op1 = (opcode >> 21) & 7; \ + int op2 = (opcode >> 5) & 7; \ + int rd = (opcode >> 12) & 0xF; \ + int cp = (opcode >> 8) & 0xF; \ + int crn = (opcode >> 16) & 0xF; \ + int crm = opcode & 0xF; \ + UNUSED(op1); \ + UNUSED(op2); \ + UNUSED(rd); \ + UNUSED(crn); \ + UNUSED(crm); \ + BODY;) + +DEFINE_COPROCESSOR_INSTRUCTION(MRC, + if (cpu->cp[cp].mrc) { + cpu->gprs[rd] = cpu->cp[cp].mrc(cpu, crn, crm, op1, op2); + } else { + ARM_ILL; + }) + +DEFINE_COPROCESSOR_INSTRUCTION(MCR, + if (cpu->cp[cp].mcr) { + cpu->cp[cp].mcr(cpu, crn, crm, op1, op2, cpu->gprs[rd]); + } else { + ARM_ILL; + }) + +DEFINE_COPROCESSOR_INSTRUCTION(CDP, + if (cpu->cp[cp].cdp) { + cpu->cp[cp].cdp(cpu, crn, crm, rd, op1, op2); + } else { + ARM_ILL; + }) + DEFINE_INSTRUCTION_ARM(LDC, ARM_STUB) DEFINE_INSTRUCTION_ARM(STC, ARM_STUB) -DEFINE_INSTRUCTION_ARM(MCR, ARM_STUB) -DEFINE_INSTRUCTION_ARM(MRC, ARM_STUB) // Begin miscellaneous definitions From 455060ec08548905a16428a0aeebb34a3e1faafd Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 2 Jun 2024 17:33:25 -0700 Subject: [PATCH 136/338] GBA: Add baseline CP0 (Wii U VC) and CP1 (DCC) implementations --- CHANGES | 1 + src/gba/gba.c | 18 ++++++++++++++++++ 2 files changed, 19 insertions(+) diff --git a/CHANGES b/CHANGES index 7c48e3ab157..2ff272fb6a8 100644 --- a/CHANGES +++ b/CHANGES @@ -13,6 +13,7 @@ Emulation fixes: - GB Serialize: Add missing Pocket Cam state to savestates - GB Video: Implement DMG-style sprite ordering - GBA: Unhandled bkpt should be treated as an undefined exception + - GBA: Add baseline CP0 (Wii U VC) and CP1 (DCC) implementations - GBA GPIO: Fix gyro read-out start (fixes mgba.io/i/3141) - GBA I/O: Fix HALTCNT access behavior (fixes mgba.io/i/2309) - GBA SIO: Fix MULTI mode SIOCNT bit 7 writes on secondary GBAs (fixes mgba.io/i/3110) diff --git a/src/gba/gba.c b/src/gba/gba.c index 94ed7562a65..3783a0c4456 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -40,6 +40,8 @@ static const uint8_t GBA_ROM_MAGIC2[] = { 0x96 }; static const size_t GBA_MB_MAGIC_OFFSET = 0xC0; static void GBAInit(void* cpu, struct mCPUComponent* component); +static void GBACP0Process(struct ARMCore* cpu, int crn, int crm, int crd, int opcode1, int opcode2); +static int32_t GBACP14Read(struct ARMCore* cpu, int crn, int crm, int opcode1, int opcode2); static void GBAInterruptHandlerInit(struct ARMInterruptHandler* irqh); static void GBAProcessEvents(struct ARMCore* cpu); static void GBAHitStub(struct ARMCore* cpu, uint32_t opcode); @@ -72,6 +74,8 @@ static void GBAInit(void* cpu, struct mCPUComponent* component) { gba->sync = 0; GBAInterruptHandlerInit(&gba->cpu->irqh); + gba->cpu->cp[0].cdp = GBACP0Process; + gba->cpu->cp[14].mrc = GBACP14Read; GBAMemoryInit(gba); gba->memory.savedata.timing = &gba->timing; @@ -186,6 +190,20 @@ void GBADestroy(struct GBA* gba) { mCoreCallbacksListDeinit(&gba->coreCallbacks); } +static void GBACP0Process(struct ARMCore* cpu, int crn, int crm, int crd, int opcode1, int opcode2) { + UNUSED(cpu); + mLOG(GBA, INFO, "Hit Wii U VC opcode: cdp p0, %i, c%i, c%i, c%i, %i", opcode1, crd, crn, crm, opcode2); +} + +static int32_t GBACP14Read(struct ARMCore* cpu, int crn, int crm, int opcode1, int opcode2) { + UNUSED(cpu); + UNUSED(crn); + UNUSED(crm); + UNUSED(opcode1); + UNUSED(opcode2); + return 0xF000B570; +} + void GBAInterruptHandlerInit(struct ARMInterruptHandler* irqh) { irqh->reset = GBAReset; irqh->processEvents = GBAProcessEvents; From cf959fe20e13744690c5830a3fd9a81f182317d6 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 2 Jun 2024 17:37:18 -0700 Subject: [PATCH 137/338] GBA: Actually it reads open bus --- src/gba/gba.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/gba/gba.c b/src/gba/gba.c index 3783a0c4456..2f0ae76d65e 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -196,12 +196,12 @@ static void GBACP0Process(struct ARMCore* cpu, int crn, int crm, int crd, int op } static int32_t GBACP14Read(struct ARMCore* cpu, int crn, int crm, int opcode1, int opcode2) { - UNUSED(cpu); UNUSED(crn); UNUSED(crm); UNUSED(opcode1); UNUSED(opcode2); - return 0xF000B570; + mLOG(GBA, GAME_ERROR, "Read from missing CP14"); + return GBALoadBad(cpu); } void GBAInterruptHandlerInit(struct ARMInterruptHandler* irqh) { From 8b041e9a2315ebed008d92bbf7b2aa3fce19a582 Mon Sep 17 00:00:00 2001 From: yeah-its-gloria <32610623+yeah-its-gloria@users.noreply.github.com> Date: Mon, 3 Jun 2024 19:49:23 -0400 Subject: [PATCH 138/338] Qt: Ignore rewind while loading/saving states --- src/platform/qt/Window.cpp | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index a5576c1c9d9..010dde78289 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -1464,6 +1464,11 @@ void Window::setupMenu(QMenuBar* menubar) { }, "emu"); auto rewindHeld = m_actions.addHeldAction(tr("Rewind (held)"), "holdRewind", [this](bool held) { + // Prevent rewinding while the load/save state window is active + if (held && this->m_stateWindow != nullptr) { + return; + } + if (m_controller) { m_controller->setRewinding(held); } From 7451decdacc7f0abcdac36ad9f6951e8ae7090b3 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 3 Jun 2024 18:44:01 -0700 Subject: [PATCH 139/338] Windows: Inno Setup fixes Update minimum Windows version to 7, add DisableDirPage=no --- src/platform/windows/setup/setup.iss.in | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/platform/windows/setup/setup.iss.in b/src/platform/windows/setup/setup.iss.in index 3aad9ef1be6..7fdda053ee7 100644 --- a/src/platform/windows/setup/setup.iss.in +++ b/src/platform/windows/setup/setup.iss.in @@ -32,10 +32,11 @@ DefaultDirName={pf}\{#AppName} DefaultGroupName={#AppName} AllowNoIcons=yes DirExistsWarning=no +DisableDirPage=no ChangesAssociations=True AppendDefaultDirName=False UninstallDisplayIcon={app}\{#AppName}.exe -MinVersion=0,6.0 +MinVersion=6.1 AlwaysShowDirOnReadyPage=True UsePreviousSetupType=True UsePreviousTasks=True @@ -52,7 +53,7 @@ OutputBaseFilename={#AppName}-setup-{#CleanVersionString}-win{#WinBits} UsePreviousLanguage=False DisableWelcomePage=False VersionInfoDescription={#AppName} is an open-source Game Boy Advance emulator -VersionInfoCopyright=© 2013–2022 Jeffrey Pfau +VersionInfoCopyright=© 2013–2024 Jeffrey Pfau VersionInfoProductName={#AppName} VersionInfoVersion={#AppVer} Compression=lzma2/ultra From 59f4fb71326205d890b75ade9e523fe7b59d2b2f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 9 Jun 2024 00:55:07 -0700 Subject: [PATCH 140/338] Test: Read config file in rom-test --- src/platform/test/rom-test-main.c | 1 + 1 file changed, 1 insertion(+) diff --git a/src/platform/test/rom-test-main.c b/src/platform/test/rom-test-main.c index 8524a852f4b..be9f36e8eb1 100644 --- a/src/platform/test/rom-test-main.c +++ b/src/platform/test/rom-test-main.c @@ -93,6 +93,7 @@ int main(int argc, char * argv[]) { mCoreConfigSetDefaultValue(&core->config, "idleOptimization", "remove"); mCoreConfigSetDefaultIntValue(&core->config, "logToStdout", true); + mCoreLoadConfig(core); mStandardLoggerInit(&_logger); mStandardLoggerConfig(&_logger, &core->config); From 6f261f6f1b164451f903a541949577d70ac56f45 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 9 Jun 2024 01:12:14 -0700 Subject: [PATCH 141/338] Scripting: Split console implementation out from Core scripting --- include/mgba/core/scripting.h | 27 ---- include/mgba/script.h | 1 + src/core/scripting.c | 133 ----------------- .../qt/scripting/ScriptingTextBuffer.h | 1 + src/script/CMakeLists.txt | 1 + src/script/console.c | 141 ++++++++++++++++++ 6 files changed, 144 insertions(+), 160 deletions(-) create mode 100644 src/script/console.c diff --git a/include/mgba/core/scripting.h b/include/mgba/core/scripting.h index c0fdcb413f6..bab2009cfe6 100644 --- a/include/mgba/core/scripting.h +++ b/include/mgba/core/scripting.h @@ -20,8 +20,6 @@ struct mCore; struct mScriptTextBuffer; mSCRIPT_DECLARE_STRUCT(mCore); mSCRIPT_DECLARE_STRUCT(mLogger); -mSCRIPT_DECLARE_STRUCT(mScriptConsole); -mSCRIPT_DECLARE_STRUCT(mScriptTextBuffer); struct mScriptBridge; struct VFile; @@ -40,24 +38,6 @@ struct mScriptEngine { #endif }; -struct mScriptTextBuffer { - void (*init)(struct mScriptTextBuffer*, const char* name); - void (*deinit)(struct mScriptTextBuffer*); - - void (*setName)(struct mScriptTextBuffer*, const char* text); - - uint32_t (*getX)(const struct mScriptTextBuffer*); - uint32_t (*getY)(const struct mScriptTextBuffer*); - uint32_t (*cols)(const struct mScriptTextBuffer*); - uint32_t (*rows)(const struct mScriptTextBuffer*); - - void (*print)(struct mScriptTextBuffer*, const char* text); - void (*clear)(struct mScriptTextBuffer*); - void (*setSize)(struct mScriptTextBuffer*, uint32_t cols, uint32_t rows); - void (*moveCursor)(struct mScriptTextBuffer*, uint32_t x, uint32_t y); - void (*advance)(struct mScriptTextBuffer*, int32_t); -}; - struct mScriptBridge* mScriptBridgeCreate(void); void mScriptBridgeDestroy(struct mScriptBridge*); @@ -80,13 +60,6 @@ struct mScriptContext; void mScriptContextAttachCore(struct mScriptContext*, struct mCore*); void mScriptContextDetachCore(struct mScriptContext*); -struct mLogger; -void mScriptContextAttachLogger(struct mScriptContext*, struct mLogger*); -void mScriptContextDetachLogger(struct mScriptContext*); - -typedef struct mScriptTextBuffer* (*mScriptContextBufferFactory)(void*); -void mScriptContextSetTextBufferFactory(struct mScriptContext*, mScriptContextBufferFactory factory, void* cbContext); - CXX_GUARD_END #endif diff --git a/include/mgba/script.h b/include/mgba/script.h index 747dfedc1ed..44ec86b3ca9 100644 --- a/include/mgba/script.h +++ b/include/mgba/script.h @@ -8,6 +8,7 @@ #include #include +#include #include #include #include diff --git a/src/core/scripting.c b/src/core/scripting.c index 57d0eed2bf8..13cc403c851 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -207,12 +207,6 @@ struct mScriptCoreAdapter { #endif }; -struct mScriptConsole { - struct mLogger* logger; - mScriptContextBufferFactory textBufferFactory; - void* textBufferContext; -}; - #define CALCULATE_SEGMENT_INFO \ uint32_t segmentSize = adapter->block.end - adapter->block.start; \ uint32_t segmentStart = adapter->block.segmentStart - adapter->block.start; \ @@ -1354,130 +1348,3 @@ void mScriptContextDetachCore(struct mScriptContext* context) { mScriptContextRemoveGlobal(context, "emu"); } - -static struct mScriptTextBuffer* _mScriptConsoleCreateBuffer(struct mScriptConsole* lib, const char* name) { - struct mScriptTextBuffer* buffer = lib->textBufferFactory(lib->textBufferContext); - buffer->init(buffer, name); - return buffer; -} - -static void mScriptConsoleLog(struct mScriptConsole* console, const char* msg) { - if (console->logger) { - mLogExplicit(console->logger, _mLOG_CAT_SCRIPT, mLOG_INFO, "%s", msg); - } else { - mLog(_mLOG_CAT_SCRIPT, mLOG_INFO, "%s", msg); - } -} - -static void mScriptConsoleWarn(struct mScriptConsole* console, const char* msg) { - if (console->logger) { - mLogExplicit(console->logger, _mLOG_CAT_SCRIPT, mLOG_WARN, "%s", msg); - } else { - mLog(_mLOG_CAT_SCRIPT, mLOG_WARN, "%s", msg); - } -} - -static void mScriptConsoleError(struct mScriptConsole* console, const char* msg) { - if (console->logger) { - mLogExplicit(console->logger, _mLOG_CAT_SCRIPT, mLOG_ERROR, "%s", msg); - } else { - mLog(_mLOG_CAT_SCRIPT, mLOG_ERROR, "%s", msg); - } -} - -mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptConsole, log, mScriptConsoleLog, 1, CHARP, msg); -mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptConsole, warn, mScriptConsoleWarn, 1, CHARP, msg); -mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptConsole, error, mScriptConsoleError, 1, CHARP, msg); -mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptConsole, S(mScriptTextBuffer), createBuffer, _mScriptConsoleCreateBuffer, 1, CHARP, name); - -mSCRIPT_DEFINE_STRUCT(mScriptConsole) - mSCRIPT_DEFINE_CLASS_DOCSTRING( - "A global singleton object `console` that can be used for presenting textual information to the user via a console." - ) - mSCRIPT_DEFINE_DOCSTRING("Print a log to the console") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptConsole, log) - mSCRIPT_DEFINE_DOCSTRING("Print a warning to the console") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptConsole, warn) - mSCRIPT_DEFINE_DOCSTRING("Print an error to the console") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptConsole, error) - mSCRIPT_DEFINE_DOCSTRING("Create a text buffer that can be used to display custom information") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptConsole, createBuffer) -mSCRIPT_DEFINE_END; - -mSCRIPT_DEFINE_STRUCT_BINDING_DEFAULTS(mScriptConsole, createBuffer) - mSCRIPT_CHARP(NULL) -mSCRIPT_DEFINE_DEFAULTS_END; - -static struct mScriptConsole* _ensureConsole(struct mScriptContext* context) { - struct mScriptValue* value = mScriptContextGetGlobal(context, "console"); - if (value) { - return value->value.opaque; - } - struct mScriptConsole* console = calloc(1, sizeof(*console)); - value = mScriptValueAlloc(mSCRIPT_TYPE_MS_S(mScriptConsole)); - value->value.opaque = console; - value->flags = mSCRIPT_VALUE_FLAG_FREE_BUFFER; - mScriptContextSetGlobal(context, "console", value); - mScriptContextSetDocstring(context, "console", "Singleton instance of struct::mScriptConsole"); - return console; -} - -void mScriptContextAttachLogger(struct mScriptContext* context, struct mLogger* logger) { - struct mScriptConsole* console = _ensureConsole(context); - console->logger = logger; -} - -void mScriptContextDetachLogger(struct mScriptContext* context) { - struct mScriptValue* value = mScriptContextGetGlobal(context, "console"); - if (!value) { - return; - } - struct mScriptConsole* console = value->value.opaque; - console->logger = mLogGetContext(); -} - -mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, deinit, 0); -mSCRIPT_DECLARE_STRUCT_CD_METHOD(mScriptTextBuffer, U32, getX, 0); -mSCRIPT_DECLARE_STRUCT_CD_METHOD(mScriptTextBuffer, U32, getY, 0); -mSCRIPT_DECLARE_STRUCT_CD_METHOD(mScriptTextBuffer, U32, cols, 0); -mSCRIPT_DECLARE_STRUCT_CD_METHOD(mScriptTextBuffer, U32, rows, 0); -mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, print, 1, CHARP, text); -mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, clear, 0); -mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, setSize, 2, U32, cols, U32, rows); -mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, moveCursor, 2, U32, x, U32, y); -mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, advance, 1, S32, adv); -mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, setName, 1, CHARP, name); - -mSCRIPT_DEFINE_STRUCT(mScriptTextBuffer) - mSCRIPT_DEFINE_CLASS_DOCSTRING( - "An object that can be used to present texual data to the user. It is displayed monospaced, " - "and text can be edited after sending by moving the cursor or clearing the buffer." - ) - mSCRIPT_DEFINE_STRUCT_DEINIT_NAMED(mScriptTextBuffer, deinit) - mSCRIPT_DEFINE_DOCSTRING("Get the current x position of the cursor") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, getX) - mSCRIPT_DEFINE_DOCSTRING("Get the current y position of the cursor") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, getY) - mSCRIPT_DEFINE_DOCSTRING("Get number of columns in the buffer") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, cols) - mSCRIPT_DEFINE_DOCSTRING("Get number of rows in the buffer") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, rows) - mSCRIPT_DEFINE_DOCSTRING("Print a string to the buffer") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, print) - mSCRIPT_DEFINE_DOCSTRING("Clear the buffer") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, clear) - mSCRIPT_DEFINE_DOCSTRING("Set the number of rows and columns") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, setSize) - mSCRIPT_DEFINE_DOCSTRING("Set the position of the cursor") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, moveCursor) - mSCRIPT_DEFINE_DOCSTRING("Advance the cursor a number of columns") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, advance) - mSCRIPT_DEFINE_DOCSTRING("Set the user-visible name of this buffer") - mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, setName) -mSCRIPT_DEFINE_END; - -void mScriptContextSetTextBufferFactory(struct mScriptContext* context, mScriptContextBufferFactory factory, void* cbContext) { - struct mScriptConsole* console = _ensureConsole(context); - console->textBufferFactory = factory; - console->textBufferContext = cbContext; -} diff --git a/src/platform/qt/scripting/ScriptingTextBuffer.h b/src/platform/qt/scripting/ScriptingTextBuffer.h index b70e9f82ada..b4a9c5b8312 100644 --- a/src/platform/qt/scripting/ScriptingTextBuffer.h +++ b/src/platform/qt/scripting/ScriptingTextBuffer.h @@ -10,6 +10,7 @@ #include #include +#include #include namespace QGBA { diff --git a/src/script/CMakeLists.txt b/src/script/CMakeLists.txt index a72f48d2221..19802c27893 100644 --- a/src/script/CMakeLists.txt +++ b/src/script/CMakeLists.txt @@ -1,6 +1,7 @@ include(ExportDirectory) set(SOURCE_FILES canvas.c + console.c context.c input.c image.c diff --git a/src/script/console.c b/src/script/console.c new file mode 100644 index 00000000000..d908534f66c --- /dev/null +++ b/src/script/console.c @@ -0,0 +1,141 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#include + +#include + +struct mScriptConsole { + struct mLogger* logger; + mScriptContextBufferFactory textBufferFactory; + void* textBufferContext; +}; + +static struct mScriptTextBuffer* _mScriptConsoleCreateBuffer(struct mScriptConsole* lib, const char* name) { + struct mScriptTextBuffer* buffer = lib->textBufferFactory(lib->textBufferContext); + buffer->init(buffer, name); + return buffer; +} + +static void mScriptConsoleLog(struct mScriptConsole* console, const char* msg) { + if (console->logger) { + mLogExplicit(console->logger, _mLOG_CAT_SCRIPT, mLOG_INFO, "%s", msg); + } else { + mLog(_mLOG_CAT_SCRIPT, mLOG_INFO, "%s", msg); + } +} + +static void mScriptConsoleWarn(struct mScriptConsole* console, const char* msg) { + if (console->logger) { + mLogExplicit(console->logger, _mLOG_CAT_SCRIPT, mLOG_WARN, "%s", msg); + } else { + mLog(_mLOG_CAT_SCRIPT, mLOG_WARN, "%s", msg); + } +} + +static void mScriptConsoleError(struct mScriptConsole* console, const char* msg) { + if (console->logger) { + mLogExplicit(console->logger, _mLOG_CAT_SCRIPT, mLOG_ERROR, "%s", msg); + } else { + mLog(_mLOG_CAT_SCRIPT, mLOG_ERROR, "%s", msg); + } +} + +mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptConsole, log, mScriptConsoleLog, 1, CHARP, msg); +mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptConsole, warn, mScriptConsoleWarn, 1, CHARP, msg); +mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptConsole, error, mScriptConsoleError, 1, CHARP, msg); +mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptConsole, S(mScriptTextBuffer), createBuffer, _mScriptConsoleCreateBuffer, 1, CHARP, name); + +mSCRIPT_DEFINE_STRUCT(mScriptConsole) + mSCRIPT_DEFINE_CLASS_DOCSTRING( + "A global singleton object `console` that can be used for presenting textual information to the user via a console." + ) + mSCRIPT_DEFINE_DOCSTRING("Print a log to the console") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptConsole, log) + mSCRIPT_DEFINE_DOCSTRING("Print a warning to the console") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptConsole, warn) + mSCRIPT_DEFINE_DOCSTRING("Print an error to the console") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptConsole, error) + mSCRIPT_DEFINE_DOCSTRING("Create a text buffer that can be used to display custom information") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptConsole, createBuffer) +mSCRIPT_DEFINE_END; + +mSCRIPT_DEFINE_STRUCT_BINDING_DEFAULTS(mScriptConsole, createBuffer) + mSCRIPT_CHARP(NULL) +mSCRIPT_DEFINE_DEFAULTS_END; + +static struct mScriptConsole* _ensureConsole(struct mScriptContext* context) { + struct mScriptValue* value = mScriptContextGetGlobal(context, "console"); + if (value) { + return value->value.opaque; + } + struct mScriptConsole* console = calloc(1, sizeof(*console)); + value = mScriptValueAlloc(mSCRIPT_TYPE_MS_S(mScriptConsole)); + value->value.opaque = console; + value->flags = mSCRIPT_VALUE_FLAG_FREE_BUFFER; + mScriptContextSetGlobal(context, "console", value); + mScriptContextSetDocstring(context, "console", "Singleton instance of struct::mScriptConsole"); + return console; +} + +void mScriptContextAttachLogger(struct mScriptContext* context, struct mLogger* logger) { + struct mScriptConsole* console = _ensureConsole(context); + console->logger = logger; +} + +void mScriptContextDetachLogger(struct mScriptContext* context) { + struct mScriptValue* value = mScriptContextGetGlobal(context, "console"); + if (!value) { + return; + } + struct mScriptConsole* console = value->value.opaque; + console->logger = mLogGetContext(); +} + +mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, deinit, 0); +mSCRIPT_DECLARE_STRUCT_CD_METHOD(mScriptTextBuffer, U32, getX, 0); +mSCRIPT_DECLARE_STRUCT_CD_METHOD(mScriptTextBuffer, U32, getY, 0); +mSCRIPT_DECLARE_STRUCT_CD_METHOD(mScriptTextBuffer, U32, cols, 0); +mSCRIPT_DECLARE_STRUCT_CD_METHOD(mScriptTextBuffer, U32, rows, 0); +mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, print, 1, CHARP, text); +mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, clear, 0); +mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, setSize, 2, U32, cols, U32, rows); +mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, moveCursor, 2, U32, x, U32, y); +mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, advance, 1, S32, adv); +mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mScriptTextBuffer, setName, 1, CHARP, name); + +mSCRIPT_DEFINE_STRUCT(mScriptTextBuffer) + mSCRIPT_DEFINE_CLASS_DOCSTRING( + "An object that can be used to present texual data to the user. It is displayed monospaced, " + "and text can be edited after sending by moving the cursor or clearing the buffer." + ) + mSCRIPT_DEFINE_STRUCT_DEINIT_NAMED(mScriptTextBuffer, deinit) + mSCRIPT_DEFINE_DOCSTRING("Get the current x position of the cursor") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, getX) + mSCRIPT_DEFINE_DOCSTRING("Get the current y position of the cursor") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, getY) + mSCRIPT_DEFINE_DOCSTRING("Get number of columns in the buffer") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, cols) + mSCRIPT_DEFINE_DOCSTRING("Get number of rows in the buffer") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, rows) + mSCRIPT_DEFINE_DOCSTRING("Print a string to the buffer") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, print) + mSCRIPT_DEFINE_DOCSTRING("Clear the buffer") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, clear) + mSCRIPT_DEFINE_DOCSTRING("Set the number of rows and columns") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, setSize) + mSCRIPT_DEFINE_DOCSTRING("Set the position of the cursor") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, moveCursor) + mSCRIPT_DEFINE_DOCSTRING("Advance the cursor a number of columns") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, advance) + mSCRIPT_DEFINE_DOCSTRING("Set the user-visible name of this buffer") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptTextBuffer, setName) +mSCRIPT_DEFINE_END; + +void mScriptContextSetTextBufferFactory(struct mScriptContext* context, mScriptContextBufferFactory factory, void* cbContext) { + struct mScriptConsole* console = _ensureConsole(context); + console->textBufferFactory = factory; + console->textBufferContext = cbContext; +} From 2c975157427090c93dfda6cf296b6a216a64f5d4 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 9 Jun 2024 01:15:25 -0700 Subject: [PATCH 142/338] Script: Add missing include --- include/mgba/script/console.h | 51 +++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 include/mgba/script/console.h diff --git a/include/mgba/script/console.h b/include/mgba/script/console.h new file mode 100644 index 00000000000..8e7a64345e4 --- /dev/null +++ b/include/mgba/script/console.h @@ -0,0 +1,51 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#ifndef M_SCRIPT_CONSOLE_H +#define M_SCRIPT_CONSOLE_H + +#include + +CXX_GUARD_START + +#include +#include +#include + +struct mCore; +struct mScriptTextBuffer; +mSCRIPT_DECLARE_STRUCT(mCore); +mSCRIPT_DECLARE_STRUCT(mLogger); +mSCRIPT_DECLARE_STRUCT(mScriptConsole); +mSCRIPT_DECLARE_STRUCT(mScriptTextBuffer); + +struct mScriptTextBuffer { + void (*init)(struct mScriptTextBuffer*, const char* name); + void (*deinit)(struct mScriptTextBuffer*); + + void (*setName)(struct mScriptTextBuffer*, const char* text); + + uint32_t (*getX)(const struct mScriptTextBuffer*); + uint32_t (*getY)(const struct mScriptTextBuffer*); + uint32_t (*cols)(const struct mScriptTextBuffer*); + uint32_t (*rows)(const struct mScriptTextBuffer*); + + void (*print)(struct mScriptTextBuffer*, const char* text); + void (*clear)(struct mScriptTextBuffer*); + void (*setSize)(struct mScriptTextBuffer*, uint32_t cols, uint32_t rows); + void (*moveCursor)(struct mScriptTextBuffer*, uint32_t x, uint32_t y); + void (*advance)(struct mScriptTextBuffer*, int32_t); +}; + +struct mLogger; +void mScriptContextAttachLogger(struct mScriptContext*, struct mLogger*); +void mScriptContextDetachLogger(struct mScriptContext*); + +typedef struct mScriptTextBuffer* (*mScriptContextBufferFactory)(void*); +void mScriptContextSetTextBufferFactory(struct mScriptContext*, mScriptContextBufferFactory factory, void* cbContext); + +CXX_GUARD_END + +#endif From e16dfc264a7b0949cbfad2ce347adc1686849206 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 9 Jun 2024 02:20:27 -0700 Subject: [PATCH 143/338] GBA: CP14 mcr also is a no-op --- src/gba/gba.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/gba/gba.c b/src/gba/gba.c index 2f0ae76d65e..6e1fb89238d 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -42,6 +42,7 @@ static const size_t GBA_MB_MAGIC_OFFSET = 0xC0; static void GBAInit(void* cpu, struct mCPUComponent* component); static void GBACP0Process(struct ARMCore* cpu, int crn, int crm, int crd, int opcode1, int opcode2); static int32_t GBACP14Read(struct ARMCore* cpu, int crn, int crm, int opcode1, int opcode2); +static void GBACP14Write(struct ARMCore* cpu, int crn, int crm, int opcode1, int opcode2, int32_t value); static void GBAInterruptHandlerInit(struct ARMInterruptHandler* irqh); static void GBAProcessEvents(struct ARMCore* cpu); static void GBAHitStub(struct ARMCore* cpu, uint32_t opcode); @@ -76,6 +77,7 @@ static void GBAInit(void* cpu, struct mCPUComponent* component) { GBAInterruptHandlerInit(&gba->cpu->irqh); gba->cpu->cp[0].cdp = GBACP0Process; gba->cpu->cp[14].mrc = GBACP14Read; + gba->cpu->cp[14].mcr = GBACP14Write; GBAMemoryInit(gba); gba->memory.savedata.timing = &gba->timing; @@ -204,6 +206,16 @@ static int32_t GBACP14Read(struct ARMCore* cpu, int crn, int crm, int opcode1, i return GBALoadBad(cpu); } +static void GBACP14Write(struct ARMCore* cpu, int crn, int crm, int opcode1, int opcode2, int32_t value) { + UNUSED(cpu); + UNUSED(crn); + UNUSED(crm); + UNUSED(opcode1); + UNUSED(opcode2); + UNUSED(value); + mLOG(GBA, GAME_ERROR, "Write to missing CP14"); +} + void GBAInterruptHandlerInit(struct ARMInterruptHandler* irqh) { irqh->reset = GBAReset; irqh->processEvents = GBAProcessEvents; From 20fc7b6ef30cc9a51499b374762f46e54704b1af Mon Sep 17 00:00:00 2001 From: Rib <1957489+RibShark@users.noreply.github.com> Date: Sun, 9 Jun 2024 22:28:51 +0100 Subject: [PATCH 144/338] GBA Memory: Support the Chinese version of Digimon Sapphire by Vast Fame --- include/mgba/internal/gba/cart/vfame.h | 3 ++- src/gba/cart/vfame.c | 24 ++++++++++++++++++++++-- 2 files changed, 24 insertions(+), 3 deletions(-) diff --git a/include/mgba/internal/gba/cart/vfame.h b/include/mgba/internal/gba/cart/vfame.h index eff24a039d1..cda1d145c7b 100644 --- a/include/mgba/internal/gba/cart/vfame.h +++ b/include/mgba/internal/gba/cart/vfame.h @@ -16,7 +16,8 @@ CXX_GUARD_START enum GBAVFameCartType { VFAME_NO = 0, VFAME_STANDARD = 1, - VFAME_GEORGE = 2 + VFAME_ALTERNATE = 2, + VFAME_GEORGE = 3 }; struct GBAVFameCart { diff --git a/src/gba/cart/vfame.c b/src/gba/cart/vfame.c index aedcf5d3e06..0daabcc8cca 100644 --- a/src/gba/cart/vfame.c +++ b/src/gba/cart/vfame.c @@ -7,12 +7,18 @@ #include #include +#include static const uint8_t ADDRESS_REORDERING[4][16] = { { 15, 14, 9, 1, 8, 10, 7, 3, 5, 11, 4, 0, 13, 12, 2, 6 }, { 15, 7, 13, 5, 11, 6, 0, 9, 12, 2, 10, 14, 3, 1, 8, 4 }, { 15, 0, 3, 12, 2, 4, 14, 13, 1, 8, 6, 7, 9, 5, 11, 10 } }; +static const uint8_t ADDRESS_REORDERING_ALTERNATE[4][16] = { + { 15, 0, 13, 5, 8, 4, 7, 3, 1, 2, 10, 14, 9, 12, 11, 6 }, + { 15, 7, 9, 1, 2, 6, 14, 13, 12, 11, 4, 0, 3, 5, 8, 10 }, + { 15, 14, 3, 12, 11, 10, 0, 9, 5, 8, 6, 7, 13, 1, 2, 4 } +}; static const uint8_t ADDRESS_REORDERING_GEORGE[4][16] = { { 15, 7, 13, 1, 11, 10, 14, 9, 12, 2, 4, 0, 3, 5, 8, 6 }, { 15, 14, 3, 12, 8, 4, 0, 13, 5, 11, 6, 7, 9, 1, 2, 10 }, @@ -23,6 +29,11 @@ static const uint8_t VALUE_REORDERING[4][16] = { { 3, 2, 1, 0, 7, 6, 5, 4 }, { 1, 0, 7, 6, 5, 4, 3, 2 } }; +static const uint8_t VALUE_REORDERING_ALTERNATE[4][16] = { + { 5, 4, 7, 2, 1, 0, 3, 6 }, + { 1, 2, 3, 0, 5, 6, 7, 4 }, + { 3, 0, 1, 6, 7, 4, 5, 2 } +}; static const uint8_t VALUE_REORDERING_GEORGE[4][16] = { { 3, 0, 7, 2, 1, 4, 5, 6 }, { 1, 4, 3, 0, 5, 6, 7, 2 }, @@ -65,13 +76,18 @@ void GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize) { mLOG(GBA_MEM, INFO, "Vast Fame game detected"); } - // This game additionally operates with a different set of SRAM modes - // Its initialisation seems to be identical so the difference must be in the cart HW itself + // These games additionally operates with a different set of SRAM modes + // Their initialisation seems to be identical so the difference must be in the cart HW itself // Other undumped games may have similar differences if (memcmp("George Sango", &((struct GBACartridge*) rom)->title, 12) == 0) { cart->cartType = VFAME_GEORGE; mLOG(GBA_MEM, INFO, "George mode"); } + // Chinese version of Digimon Sapphire; header is identical to the English version which uses the normal reordering + // so we have to use some other way to detect it + else if (doCrc32(rom, romSize) == 0x793A328F) { + cart->cartType = VFAME_STANDARD; + } } // This is not currently being used but would be called on ROM reads @@ -256,6 +272,8 @@ static uint32_t _modifySramAddress(enum GBAVFameCartType type, uint32_t address, return address; } else if (type == VFAME_GEORGE) { return _reorderBits(address, ADDRESS_REORDERING_GEORGE[mode - 1], 16); + } else if (type == VFAME_ALTERNATE) { + return _reorderBits(address, ADDRESS_REORDERING_ALTERNATE[mode - 1], 16); } else { return _reorderBits(address, ADDRESS_REORDERING[mode - 1], 16); } @@ -266,6 +284,8 @@ static int8_t _modifySramValue(enum GBAVFameCartType type, uint8_t value, int mo if (reorderType != 0) { if (type == VFAME_GEORGE) { value = _reorderBits(value, VALUE_REORDERING_GEORGE[reorderType - 1], 8); + } else if (type == VFAME_ALTERNATE) { + value = _reorderBits(value, VALUE_REORDERING_ALTERNATE[reorderType - 1], 8); } else { value = _reorderBits(value, VALUE_REORDERING[reorderType - 1], 8); } From 58651f205451054d4869238031b3bf56bd3e5133 Mon Sep 17 00:00:00 2001 From: Rib <1957489+RibShark@users.noreply.github.com> Date: Sun, 9 Jun 2024 22:28:51 +0100 Subject: [PATCH 145/338] GBA Memory: Clean up Vast Fame code somewhat --- include/mgba/internal/gba/cart/vfame.h | 8 ++++--- src/gba/cart/vfame.c | 32 ++++++++++++-------------- src/gba/gba.c | 2 +- 3 files changed, 21 insertions(+), 21 deletions(-) diff --git a/include/mgba/internal/gba/cart/vfame.h b/include/mgba/internal/gba/cart/vfame.h index cda1d145c7b..5bee2884846 100644 --- a/include/mgba/internal/gba/cart/vfame.h +++ b/include/mgba/internal/gba/cart/vfame.h @@ -13,11 +13,13 @@ CXX_GUARD_START +#define DIGIMON_SAPPHIRE_CHINESE_CRC32 0x793A328F + enum GBAVFameCartType { VFAME_NO = 0, VFAME_STANDARD = 1, - VFAME_ALTERNATE = 2, - VFAME_GEORGE = 3 + VFAME_GEORGE = 2, + VFAME_ALTERNATE = 3, }; struct GBAVFameCart { @@ -29,7 +31,7 @@ struct GBAVFameCart { }; void GBAVFameInit(struct GBAVFameCart* cart); -void GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize); +void GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize, uint32_t crc32); void GBAVFameSramWrite(struct GBAVFameCart* cart, uint32_t address, uint8_t value, uint8_t* sramData); uint32_t GBAVFameModifyRomAddress(struct GBAVFameCart* cart, uint32_t address, size_t romSize); uint32_t GBAVFameGetPatternValue(uint32_t address, int bits); diff --git a/src/gba/cart/vfame.c b/src/gba/cart/vfame.c index 0daabcc8cca..260db35b843 100644 --- a/src/gba/cart/vfame.c +++ b/src/gba/cart/vfame.c @@ -7,38 +7,37 @@ #include #include -#include static const uint8_t ADDRESS_REORDERING[4][16] = { { 15, 14, 9, 1, 8, 10, 7, 3, 5, 11, 4, 0, 13, 12, 2, 6 }, { 15, 7, 13, 5, 11, 6, 0, 9, 12, 2, 10, 14, 3, 1, 8, 4 }, { 15, 0, 3, 12, 2, 4, 14, 13, 1, 8, 6, 7, 9, 5, 11, 10 } }; -static const uint8_t ADDRESS_REORDERING_ALTERNATE[4][16] = { - { 15, 0, 13, 5, 8, 4, 7, 3, 1, 2, 10, 14, 9, 12, 11, 6 }, - { 15, 7, 9, 1, 2, 6, 14, 13, 12, 11, 4, 0, 3, 5, 8, 10 }, - { 15, 14, 3, 12, 11, 10, 0, 9, 5, 8, 6, 7, 13, 1, 2, 4 } -}; static const uint8_t ADDRESS_REORDERING_GEORGE[4][16] = { { 15, 7, 13, 1, 11, 10, 14, 9, 12, 2, 4, 0, 3, 5, 8, 6 }, { 15, 14, 3, 12, 8, 4, 0, 13, 5, 11, 6, 7, 9, 1, 2, 10 }, { 15, 0, 9, 5, 2, 6, 7, 3, 1, 8, 10, 14, 13, 12, 11, 4 } }; +static const uint8_t ADDRESS_REORDERING_ALTERNATE[4][16] = { + { 15, 0, 13, 5, 8, 4, 7, 3, 1, 2, 10, 14, 9, 12, 11, 6 }, + { 15, 7, 9, 1, 2, 6, 14, 13, 12, 11, 4, 0, 3, 5, 8, 10 }, + { 15, 14, 3, 12, 11, 10, 0, 9, 5, 8, 6, 7, 13, 1, 2, 4 } +}; static const uint8_t VALUE_REORDERING[4][16] = { { 5, 4, 3, 2, 1, 0, 7, 6 }, { 3, 2, 1, 0, 7, 6, 5, 4 }, { 1, 0, 7, 6, 5, 4, 3, 2 } }; -static const uint8_t VALUE_REORDERING_ALTERNATE[4][16] = { - { 5, 4, 7, 2, 1, 0, 3, 6 }, - { 1, 2, 3, 0, 5, 6, 7, 4 }, - { 3, 0, 1, 6, 7, 4, 5, 2 } -}; static const uint8_t VALUE_REORDERING_GEORGE[4][16] = { { 3, 0, 7, 2, 1, 4, 5, 6 }, { 1, 4, 3, 0, 5, 6, 7, 2 }, { 5, 2, 1, 6, 7, 0, 3, 4 } }; +static const uint8_t VALUE_REORDERING_ALTERNATE[4][16] = { + { 5, 4, 7, 2, 1, 0, 3, 6 }, + { 1, 2, 3, 0, 5, 6, 7, 4 }, + { 3, 0, 1, 6, 7, 4, 5, 2 } +}; static const int8_t MODE_CHANGE_START_SEQUENCE[5] = { 0x99, 0x02, 0x05, 0x02, 0x03 }; static const int8_t MODE_CHANGE_END_SEQUENCE[5] = { 0x99, 0x03, 0x62, 0x02, 0x56 }; @@ -60,7 +59,7 @@ void GBAVFameInit(struct GBAVFameCart* cart) { cart->acceptingModeChange = false; } -void GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize) { +void GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize, uint32_t crc32) { cart->cartType = VFAME_NO; // The initialisation code is also present & run in the dumps of Digimon Ruby & Sapphire from hacked/deprotected reprint carts, @@ -82,11 +81,10 @@ void GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize) { if (memcmp("George Sango", &((struct GBACartridge*) rom)->title, 12) == 0) { cart->cartType = VFAME_GEORGE; mLOG(GBA_MEM, INFO, "George mode"); - } - // Chinese version of Digimon Sapphire; header is identical to the English version which uses the normal reordering - // so we have to use some other way to detect it - else if (doCrc32(rom, romSize) == 0x793A328F) { - cart->cartType = VFAME_STANDARD; + } else if (crc32 == DIGIMON_SAPPHIRE_CHINESE_CRC32) { + // Chinese version of Digimon Sapphire; header is identical to the English version which uses the normal reordering + // so we have to use some other way to detect it + cart->cartType = VFAME_ALTERNATE; } } diff --git a/src/gba/gba.c b/src/gba/gba.c index 6e1fb89238d..0ceb8209abc 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -493,7 +493,7 @@ bool GBALoadROM(struct GBA* gba, struct VFile* vf) { gba->cpu->memory.setActiveRegion(gba->cpu, gba->cpu->gprs[ARM_PC]); } GBAHardwareInit(&gba->memory.hw, &((uint16_t*) gba->memory.rom)[GPIO_REG_DATA >> 1]); - GBAVFameDetect(&gba->memory.vfame, gba->memory.rom, gba->memory.romSize); + GBAVFameDetect(&gba->memory.vfame, gba->memory.rom, gba->memory.romSize, gba->romCrc32); // TODO: error check return true; } From ab0194fb49b24a45181acbc7c538a3499d0e17ab Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 10 Jun 2024 03:08:21 -0700 Subject: [PATCH 146/338] GB MBC: Switch Pocket Cam to using standard color conversion methods --- src/gb/mbc/pocket-cam.c | 17 +++++------------ 1 file changed, 5 insertions(+), 12 deletions(-) diff --git a/src/gb/mbc/pocket-cam.c b/src/gb/mbc/pocket-cam.c index c587dfa6a26..0eab34abaf8 100644 --- a/src/gb/mbc/pocket-cam.c +++ b/src/gb/mbc/pocket-cam.c @@ -95,39 +95,32 @@ void _GBPocketCamCapture(struct GBMemory* memory) { case mCOLOR_XRGB8: case mCOLOR_ARGB8: case mCOLOR_ABGR8: - color = ((const uint32_t*) image)[y * stride + x]; - gray = (color & 0xFF) + ((color >> 8) & 0xFF) + ((color >> 16) & 0xFF); - break; case mCOLOR_BGRX8: case mCOLOR_RGBX8: case mCOLOR_RGBA8: case mCOLOR_BGRA8: color = ((const uint32_t*) image)[y * stride + x]; - gray = ((color >> 8) & 0xFF) + ((color >> 16) & 0xFF) + ((color >> 24) & 0xFF); break; case mCOLOR_BGR5: case mCOLOR_RGB5: case mCOLOR_ARGB5: case mCOLOR_ABGR5: - color = ((const uint16_t*) image)[y * stride + x]; - gray = ((color << 3) & 0xF8) + ((color >> 2) & 0xF8) + ((color >> 7) & 0xF8); - break; case mCOLOR_BGR565: case mCOLOR_RGB565: - color = ((const uint16_t*) image)[y * stride + x]; - gray = ((color << 3) & 0xF8) + ((color >> 3) & 0xFC) + ((color >> 8) & 0xF8); - break; case mCOLOR_BGRA5: case mCOLOR_RGBA5: color = ((const uint16_t*) image)[y * stride + x]; - gray = ((color << 2) & 0xF8) + ((color >> 3) & 0xF8) + ((color >> 8) & 0xF8); + break; + case mCOLOR_L8: + color = ((const uint8_t*) image)[y * stride + x]; break; default: mLOG(GB_MBC, WARN, "Unsupported pixel format: %X", format); return; } uint16_t exposure = (pocketCam->registers[2] << 8) | (pocketCam->registers[3]); - gray = (gray + 1) * exposure / 0x300; + gray = mColorConvert(color, format, mCOLOR_L8); + gray = (gray + 1) * exposure / 0x100; // TODO: Additional processing int matrixEntry = 3 * ((x & 3) + 4 * (y & 3)); if (gray < pocketCam->registers[matrixEntry + 6]) { From 3837ea8444d84a90720a54eb81e9484dfb4c10c1 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 10 Jun 2024 23:20:52 -0700 Subject: [PATCH 147/338] GB Debugger: Fix file formatting --- src/gb/debugger/debugger.c | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/gb/debugger/debugger.c b/src/gb/debugger/debugger.c index cc05bb7a560..1a3743e421d 100644 --- a/src/gb/debugger/debugger.c +++ b/src/gb/debugger/debugger.c @@ -3,14 +3,14 @@ * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ - #include +#include - #include - #include - #include - #include - #include - #include +#include +#include +#include +#include +#include +#include static const struct SM83Segment _GBSegments[] = { { .name = "ROM", .start = GB_BASE_CART_BANK1, .end = GB_BASE_VRAM }, From 745e36e6bcc6b0c2758193fe18f2b9a70a38573f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 10 Jun 2024 23:23:13 -0700 Subject: [PATCH 148/338] GB Video: Remove leftover #include --- src/gb/video.c | 1 - 1 file changed, 1 deletion(-) diff --git a/src/gb/video.c b/src/gb/video.c index 37c1e36502e..38be72a5ab7 100644 --- a/src/gb/video.c +++ b/src/gb/video.c @@ -6,7 +6,6 @@ #include #include -#include #include #include #include From 458300b02ec9934948d7c1e9255bde1e0c987456 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 16 Jun 2024 23:28:04 -0700 Subject: [PATCH 149/338] Core: Improve rumble emulation by averaging state over entire frame (fixes #3232) --- CHANGES | 1 + include/mgba/core/interface.h | 15 +++++++- include/mgba/internal/gb/memory.h | 1 + include/mgba/internal/gba/gba.h | 1 + src/core/interface.c | 41 ++++++++++++++++++++++ src/core/scripting.c | 15 ++++++-- src/gb/gb.c | 6 ++++ src/gb/mbc.c | 1 + src/gb/mbc/mbc.c | 4 ++- src/gb/mbc/unlicensed.c | 4 ++- src/gba/cart/gpio.c | 4 ++- src/gba/gba.c | 7 ++++ src/gba/sio/gbp.c | 5 +-- src/platform/libretro/libretro.c | 34 +++++------------- src/platform/psp2/psp2-context.c | 27 ++++----------- src/platform/qt/input/SDLInputDriver.cpp | 2 +- src/platform/sdl/main.c | 2 +- src/platform/sdl/sdl-events.c | 44 +++++++----------------- src/platform/sdl/sdl-events.h | 5 +-- src/platform/switch/main.c | 40 +++++++-------------- src/platform/wii/main.c | 5 +-- 21 files changed, 142 insertions(+), 122 deletions(-) diff --git a/CHANGES b/CHANGES index 2ff272fb6a8..626e9aa413f 100644 --- a/CHANGES +++ b/CHANGES @@ -30,6 +30,7 @@ Other fixes: - Updater: Fix updating appimage across filesystems Misc: - Core: Handle relative paths for saves, screenshots, etc consistently (fixes mgba.io/i/2826) + - Core: Improve rumble emulation by averaging state over entire frame (fixes mgba.io/i/3232) - GB: Prevent incompatible BIOSes from being used on differing models - GB Serialize: Add missing savestate support for MBC6 and NT (newer) - GBA: Improve detection of valid ELF ROMs diff --git a/include/mgba/core/interface.h b/include/mgba/core/interface.h index b07f300f3f5..3e6261e9c5b 100644 --- a/include/mgba/core/interface.h +++ b/include/mgba/core/interface.h @@ -110,9 +110,22 @@ struct mRTCGenericState { void mRTCGenericSourceInit(struct mRTCGenericSource* rtc, struct mCore* core); struct mRumble { - void (*setRumble)(struct mRumble*, int enable); + void (*reset)(struct mRumble*, bool enable); + void (*setRumble)(struct mRumble*, bool enable, uint32_t sinceLast); + void (*integrate)(struct mRumble*, uint32_t period); }; +struct mRumbleIntegrator { + struct mRumble d; + bool state; + uint32_t timeOn; + uint32_t totalTime; + + void (*setRumble)(struct mRumbleIntegrator*, float value); +}; + +void mRumbleIntegratorInit(struct mRumbleIntegrator*); + struct mCoreChannelInfo { size_t id; const char* internalName; diff --git a/include/mgba/internal/gb/memory.h b/include/mgba/internal/gb/memory.h index 052a9f77e08..e4b34088bda 100644 --- a/include/mgba/internal/gb/memory.h +++ b/include/mgba/internal/gb/memory.h @@ -339,6 +339,7 @@ struct GBMemory { struct mRTCSource* rtc; struct mRotationSource* rotation; struct mRumble* rumble; + int32_t lastRumble; struct mImageSource* cam; }; diff --git a/include/mgba/internal/gba/gba.h b/include/mgba/internal/gba/gba.h index e66ac47f337..83246ff981e 100644 --- a/include/mgba/internal/gba/gba.h +++ b/include/mgba/internal/gba/gba.h @@ -91,6 +91,7 @@ struct GBA { struct GBALuminanceSource* luminanceSource; struct mRTCSource* rtcSource; struct mRumble* rumble; + int32_t lastRumble; bool isPristine; size_t pristineRomSize; diff --git a/src/core/interface.c b/src/core/interface.c index d63754895a8..e5b7f83783a 100644 --- a/src/core/interface.c +++ b/src/core/interface.c @@ -109,3 +109,44 @@ void mRTCGenericSourceInit(struct mRTCGenericSource* rtc, struct mCore* core) { rtc->d.serialize = _rtcGenericSerialize; rtc->d.deserialize = _rtcGenericDeserialize; } + +static void mRumbleIntegratorReset(struct mRumble* rumble, bool enable) { + struct mRumbleIntegrator* integrator = (struct mRumbleIntegrator*) rumble; + integrator->state = enable; + integrator->timeOn = 0; + integrator->totalTime = 0; +} + +static void mRumbleIntegratorSetRumble(struct mRumble* rumble, bool enable, uint32_t sinceLast) { + struct mRumbleIntegrator* integrator = (struct mRumbleIntegrator*) rumble; + + if (integrator->state) { + integrator->timeOn += sinceLast; + } + integrator->totalTime += sinceLast; + integrator->state = enable; +} + +static void mRumbleIntegratorIntegrate(struct mRumble* rumble, uint32_t period) { + if (!period) { + return; + } + + struct mRumbleIntegrator* integrator = (struct mRumbleIntegrator*) rumble; + if (integrator->state) { + integrator->timeOn += period - integrator->totalTime; + } + integrator->setRumble(integrator, fminf(integrator->timeOn / (float) period, 1.0f)); + + integrator->totalTime = 0; + integrator->timeOn = 0; +} + +void mRumbleIntegratorInit(struct mRumbleIntegrator* integrator) { + integrator->d.reset = mRumbleIntegratorReset; + integrator->d.setRumble = mRumbleIntegratorSetRumble; + integrator->d.integrate = mRumbleIntegratorIntegrate; + + integrator->state = false; + integrator->timeOn = 0; +} diff --git a/src/core/scripting.c b/src/core/scripting.c index 13cc403c851..ea0af459dfc 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -196,6 +196,7 @@ struct mScriptCoreAdapter { struct mScriptDebugger debugger; #endif struct mRumble rumble; + struct mRumbleIntegrator rumbleIntegrator; struct mRumble* oldRumble; struct mRotationSource rotation; struct mScriptValue* rotationCbTable; @@ -1165,16 +1166,22 @@ mSCRIPT_DEFINE_STRUCT(mScriptCoreAdapter) mSCRIPT_DEFINE_STRUCT_CAST_TO_MEMBER(mScriptCoreAdapter, CS(mCore), _core) mSCRIPT_DEFINE_END; -static void _setRumble(struct mRumble* rumble, int enable) { +static void _setRumble(struct mRumble* rumble, bool enable, uint32_t timeSince) { struct mScriptCoreAdapter* adapter = containerof(rumble, struct mScriptCoreAdapter, rumble); if (adapter->oldRumble) { - adapter->oldRumble->setRumble(adapter->oldRumble, enable); + adapter->oldRumble->setRumble(adapter->oldRumble, enable, timeSince); } + adapter->rumbleIntegrator.d.setRumble(&adapter->rumbleIntegrator.d, enable, timeSince); +} + +static void _setRumbleFloat(struct mRumbleIntegrator* integrator, float level) { + struct mScriptCoreAdapter* adapter = containerof(integrator, struct mScriptCoreAdapter, rumbleIntegrator); + struct mScriptList args; mScriptListInit(&args, 1); - *mScriptListAppend(&args) = mSCRIPT_MAKE_BOOL(!!enable); + *mScriptListAppend(&args) = mSCRIPT_MAKE_F32(level); mScriptContextTriggerCallback(adapter->context, "rumble", &args); mScriptListDeinit(&args); } @@ -1293,6 +1300,8 @@ void mScriptContextAttachCore(struct mScriptContext* context, struct mCore* core adapter->memory.type = mSCRIPT_TYPE_MS_TABLE; adapter->memory.type->alloc(&adapter->memory); + mRumbleIntegratorInit(&adapter->rumbleIntegrator); + adapter->rumbleIntegrator.setRumble = _setRumbleFloat; adapter->rumble.setRumble = _setRumble; adapter->rotation.sample = _rotationSample; adapter->rotation.readTiltX = _rotationReadTiltX; diff --git a/src/gb/gb.c b/src/gb/gb.c index c0e966c27ca..c6198ed58e5 100644 --- a/src/gb/gb.c +++ b/src/gb/gb.c @@ -1174,6 +1174,12 @@ void GBFrameEnded(struct GB* gb) { } } + struct mRumble* rumble = gb->memory.rumble; + if (rumble && rumble->integrate) { + gb->memory.lastRumble = mTimingCurrentTime(&gb->timing); + rumble->integrate(rumble, GB_VIDEO_TOTAL_LENGTH); + } + // TODO: Move to common code if (gb->stream && gb->stream->postVideoFrame) { const color_t* pixels; diff --git a/src/gb/mbc.c b/src/gb/mbc.c index 76c005f96d2..c9ebed54638 100644 --- a/src/gb/mbc.c +++ b/src/gb/mbc.c @@ -540,6 +540,7 @@ void GBMBCReset(struct GB* gb) { gb->memory.cartBus = 0xFF; gb->memory.cartBusPc = 0; gb->memory.cartBusDecay = 1; + gb->memory.lastRumble = 0; memset(&gb->memory.mbcState, 0, sizeof(gb->memory.mbcState)); GBMBCInit(gb); diff --git a/src/gb/mbc/mbc.c b/src/gb/mbc/mbc.c index 864b6e9f8a6..699bdb209ab 100644 --- a/src/gb/mbc/mbc.c +++ b/src/gb/mbc/mbc.c @@ -253,7 +253,9 @@ void _GBMBC5(struct GB* gb, uint16_t address, uint8_t value) { case 0x4: case 0x5: if (memory->mbcType == GB_MBC5_RUMBLE && memory->rumble) { - memory->rumble->setRumble(memory->rumble, (value >> 3) & 1); + int32_t currentTime = mTimingCurrentTime(&gb->timing); + memory->rumble->setRumble(memory->rumble, (value >> 3) & 1, currentTime - memory->lastRumble); + memory->lastRumble = currentTime; value &= ~8; } GBMBCSwitchSramBank(gb, value & 0xF); diff --git a/src/gb/mbc/unlicensed.c b/src/gb/mbc/unlicensed.c index 1577a15fa41..950ddf074dd 100644 --- a/src/gb/mbc/unlicensed.c +++ b/src/gb/mbc/unlicensed.c @@ -228,7 +228,9 @@ void _GBNTOld2(struct GB* gb, uint16_t address, uint8_t value) { } if (mbcState->rumble && memory->rumble) { - memory->rumble->setRumble(memory->rumble, !!(mbcState->swapped ? value & 0x08 : value & 0x02)); + int32_t currentTime = mTimingCurrentTime(&gb->timing); + memory->rumble->setRumble(memory->rumble, !!(mbcState->swapped ? value & 0x08 : value & 0x02), currentTime - memory->lastRumble); + memory->lastRumble = currentTime; } break; } diff --git a/src/gba/cart/gpio.c b/src/gba/cart/gpio.c index 0a396f74620..fde4e3714b0 100644 --- a/src/gba/cart/gpio.c +++ b/src/gba/cart/gpio.c @@ -354,7 +354,9 @@ void _rumbleReadPins(struct GBACartridgeHardware* hw) { return; } - rumble->setRumble(rumble, !!(hw->pinState & 8)); + int32_t currentTime = mTimingCurrentTime(&hw->p->timing); + rumble->setRumble(rumble, !!(hw->pinState & 8), currentTime - hw->p->lastRumble); + hw->p->lastRumble = currentTime; } // == Light sensor diff --git a/src/gba/gba.c b/src/gba/gba.c index 0ceb8209abc..013dcad4efe 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -250,6 +250,7 @@ void GBAReset(struct ARMCore* cpu) { gba->memory.romMask = toPow2(gba->memory.romSize) - 1; gba->yankedRomSize = 0; } + gba->lastRumble = 0; mTimingClear(&gba->timing); GBAMemoryReset(gba); GBAVideoReset(&gba->video); @@ -993,6 +994,12 @@ void GBAFrameEnded(struct GBA* gba) { GBASIOPlayerUpdate(gba); } + struct mRumble* rumble = gba->rumble; + if (rumble && rumble->integrate) { + gba->lastRumble = mTimingCurrentTime(&gba->timing); + rumble->integrate(rumble, VIDEO_TOTAL_LENGTH); + } + size_t c; for (c = 0; c < mCoreCallbacksListSize(&gba->coreCallbacks); ++c) { struct mCoreCallbacks* callbacks = mCoreCallbacksListGetPointer(&gba->coreCallbacks, c); diff --git a/src/gba/sio/gbp.c b/src/gba/sio/gbp.c index b5f98735213..d992ebe2efd 100644 --- a/src/gba/sio/gbp.c +++ b/src/gba/sio/gbp.c @@ -108,12 +108,13 @@ uint16_t _gbpSioWriteRegister(struct GBASIODriver* driver, uint32_t address, uin if (gbp->txPosition < 12 && gbp->txPosition > 0) { // TODO: Check expected } else if (gbp->txPosition >= 12) { - uint32_t mask = 0x33; // 0x00 = Stop // 0x11 = Hard Stop // 0x22 = Start if (gbp->p->rumble) { - gbp->p->rumble->setRumble(gbp->p->rumble, (rx & mask) == 0x22); + int32_t currentTime = mTimingCurrentTime(&gbp->p->timing); + gbp->p->rumble->setRumble(gbp->p->rumble, (rx & 0x33) == 0x22, currentTime - gbp->p->lastRumble); + gbp->p->lastRumble = currentTime; } } mTimingDeschedule(&gbp->p->timing, &gbp->event); diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index b7d7d82431b..88743b63edc 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -33,7 +33,6 @@ * to calculating the average for the last 180 * frames, or 3 seconds of runtime... */ #define SAMPLES_PER_FRAME_MOVING_AVG_ALPHA (1.0f / 180.0f) -#define RUMBLE_PWM 35 #define EVENT_RATE 60 #define VIDEO_WIDTH_MAX 256 @@ -54,7 +53,7 @@ static void GBARetroLog(struct mLogger* logger, int category, enum mLogLevel lev static void _postAudioBuffer(struct mAVStream*, struct mAudioBuffer*); static void _audioRateChanged(struct mAVStream*, unsigned rate); -static void _setRumble(struct mRumble* rumble, int enable); +static void _setRumble(struct mRumbleIntegrator*, float level); static uint8_t _readLux(struct GBALuminanceSource* lux); static void _updateLux(struct GBALuminanceSource* lux); static void _updateCamera(const uint32_t* buffer, unsigned width, unsigned height, size_t pitch); @@ -77,9 +76,7 @@ static void* savedata; static struct mAVStream stream; static bool sensorsInitDone; static bool rumbleInitDone; -static int rumbleUp; -static int rumbleDown; -static struct mRumble rumble; +static struct mRumbleIntegrator rumble; static struct GBALuminanceSource lux; static struct mRotationSource rotation; static bool tiltEnabled; @@ -467,6 +464,7 @@ void retro_init(void) { // TODO: RETRO_ENVIRONMENT_SET_SUPPORT_NO_GAME when BIOS booting is supported rumbleInitDone = false; + mRumbleIntegratorInit(&rumble); rumble.setRumble = _setRumble; rumbleCallback = 0; @@ -645,18 +643,6 @@ void retro_run(void) { } } #endif - - if (rumbleCallback) { - if (rumbleUp) { - rumbleCallback(0, RETRO_RUMBLE_STRONG, rumbleUp * 0xFFFF / (rumbleUp + rumbleDown)); - rumbleCallback(0, RETRO_RUMBLE_WEAK, rumbleUp * 0xFFFF / (rumbleUp + rumbleDown)); - } else { - rumbleCallback(0, RETRO_RUMBLE_STRONG, 0); - rumbleCallback(0, RETRO_RUMBLE_WEAK, 0); - } - rumbleUp = 0; - rumbleDown = 0; - } } static void _setupMaps(struct mCore* core) { @@ -848,10 +834,8 @@ static void _setupMaps(struct mCore* core) { void retro_reset(void) { core->reset(core); + mRumbleIntegratorInit(&rumble); _setupMaps(core); - - rumbleUp = 0; - rumbleDown = 0; } bool retro_load_game(const struct retro_game_info* game) { @@ -1267,7 +1251,7 @@ static void _audioRateChanged(struct mAVStream* stream, unsigned rate) { environCallback(RETRO_ENVIRONMENT_SET_SYSTEM_AV_INFO, &info); } -static void _setRumble(struct mRumble* rumble, int enable) { +static void _setRumble(struct mRumbleIntegrator* rumble, float level) { UNUSED(rumble); if (!rumbleInitDone) { _initRumble(); @@ -1275,11 +1259,9 @@ static void _setRumble(struct mRumble* rumble, int enable) { if (!rumbleCallback) { return; } - if (enable) { - ++rumbleUp; - } else { - ++rumbleDown; - } + + rumbleCallback(0, RETRO_RUMBLE_STRONG, level * 0xFFFF); + rumbleCallback(0, RETRO_RUMBLE_WEAK, level * 0xFFFF); } static void _updateLux(struct GBALuminanceSource* lux) { diff --git a/src/platform/psp2/psp2-context.c b/src/platform/psp2/psp2-context.c index 0f456fa7ec2..be9ff449581 100644 --- a/src/platform/psp2/psp2-context.c +++ b/src/platform/psp2/psp2-context.c @@ -36,7 +36,6 @@ #include -#define RUMBLE_PWM 8 #define CDRAM_ALIGN 0x40000 mLOG_DECLARE_CATEGORY(GUI_PSP2); @@ -64,11 +63,7 @@ static struct mSceRotationSource { struct SceMotionSensorState state; } rotation; -static struct mSceRumble { - struct mRumble d; - struct mCircleBuffer history; - int current; -} rumble; +static struct mRumbleIntegrator rumble; static struct mSceImageSource { struct mImageSource d; @@ -157,17 +152,10 @@ static int32_t _readGyroZ(struct mRotationSource* source) { return rotation->state.gyro.z * -0x8000000; } -static void _setRumble(struct mRumble* source, int enable) { - struct mSceRumble* rumble = (struct mSceRumble*) source; - rumble->current += enable; - if (mCircleBufferSize(&rumble->history) == RUMBLE_PWM) { - int8_t oldLevel; - mCircleBufferRead8(&rumble->history, &oldLevel); - rumble->current -= oldLevel; - } - mCircleBufferWrite8(&rumble->history, enable); - int small = (rumble->current << 21) / 65793; - int big = ((rumble->current * rumble->current) << 18) / 65793; +static void _setRumble(struct mRumbleIntegrator* source, float level) { + UNUSED(source); + int small = level * 255; + int big = (level * level) * 255; struct SceCtrlActuator state = { small, big @@ -363,8 +351,8 @@ void mPSP2Setup(struct mGUIRunner* runner) { rotation.d.readGyroZ = _readGyroZ; runner->core->setPeripheral(runner->core, mPERIPH_ROTATION, &rotation.d); - rumble.d.setRumble = _setRumble; - mCircleBufferInit(&rumble.history, RUMBLE_PWM); + mRumbleIntegratorInit(&rumble); + rumble.setRumble = _setRumble; runner->core->setPeripheral(runner->core, mPERIPH_RUMBLE, &rumble.d); camera.d.startRequestImage = _startRequestImage; @@ -509,7 +497,6 @@ void mPSP2Unpaused(struct mGUIRunner* runner) { void mPSP2Teardown(struct mGUIRunner* runner) { UNUSED(runner); - mCircleBufferDeinit(&rumble.history); mAudioResamplerDeinit(&audioContext.resampler); mAudioBufferDeinit(&audioContext.buffer); vita2d_free_texture(tex[0]); diff --git a/src/platform/qt/input/SDLInputDriver.cpp b/src/platform/qt/input/SDLInputDriver.cpp index 72d148057a1..402b92a1239 100644 --- a/src/platform/qt/input/SDLInputDriver.cpp +++ b/src/platform/qt/input/SDLInputDriver.cpp @@ -112,7 +112,7 @@ void SDLInputDriver::bindDefaults(InputController* controller) { mRumble* SDLInputDriver::rumble() { #if SDL_VERSION_ATLEAST(2, 0, 0) if (m_playerAttached) { - return &m_sdlPlayer.rumble.d; + return &m_sdlPlayer.rumble.d.d; } #endif return nullptr; diff --git a/src/platform/sdl/main.c b/src/platform/sdl/main.c index b1b850e21fb..4debea3ee74 100644 --- a/src/platform/sdl/main.c +++ b/src/platform/sdl/main.c @@ -157,7 +157,7 @@ int main(int argc, char** argv) { mSDLPlayerLoadConfig(&renderer.player, mCoreConfigGetInput(&renderer.core->config)); #if SDL_VERSION_ATLEAST(2, 0, 0) - renderer.core->setPeripheral(renderer.core, mPERIPH_RUMBLE, &renderer.player.rumble.d); + renderer.core->setPeripheral(renderer.core, mPERIPH_RUMBLE, &renderer.player.rumble.d.d); #endif int ret; diff --git a/src/platform/sdl/sdl-events.c b/src/platform/sdl/sdl-events.c index afeedba68dc..ca8345d221b 100644 --- a/src/platform/sdl/sdl-events.c +++ b/src/platform/sdl/sdl-events.c @@ -22,15 +22,14 @@ #endif #define GYRO_STEPS 100 -#define RUMBLE_PWM 16 -#define RUMBLE_STEPS 2 +#define RUMBLE_THRESHOLD 1.f / 128.f mLOG_DEFINE_CATEGORY(SDL_EVENTS, "SDL Events", "platform.sdl.events"); DEFINE_VECTOR(SDL_JoystickList, struct SDL_JoystickCombo); #if SDL_VERSION_ATLEAST(2, 0, 0) -static void _mSDLSetRumble(struct mRumble* rumble, int enable); +static void _mSDLSetRumble(struct mRumbleIntegrator* rumble, float level); #endif static int32_t _mSDLReadTiltX(struct mRotationSource* rumble); static int32_t _mSDLReadTiltY(struct mRotationSource* rumble); @@ -188,9 +187,8 @@ bool mSDLAttachPlayer(struct mSDLEvents* events, struct mSDLPlayer* player) { } #if SDL_VERSION_ATLEAST(2, 0, 0) + mRumbleIntegratorInit(&player->rumble.d); player->rumble.d.setRumble = _mSDLSetRumble; - mCircleBufferInit(&player->rumble.history, RUMBLE_PWM); - player->rumble.level = 0; player->rumble.activeLevel = 0; player->rumble.p = player; #endif @@ -281,9 +279,6 @@ void mSDLDetachPlayer(struct mSDLEvents* events, struct mSDLPlayer* player) { } --events->playersAttached; mCircleBufferDeinit(&player->rotation.zHistory); -#if SDL_VERSION_ATLEAST(2, 0, 0) - mCircleBufferDeinit(&player->rumble.history); -#endif } void mSDLPlayerLoadConfig(struct mSDLPlayer* context, const struct Configuration* config) { @@ -701,7 +696,7 @@ void mSDLHandleEvent(struct mCoreThread* context, struct mSDLPlayer* sdlContext, } #if SDL_VERSION_ATLEAST(2, 0, 0) -static void _mSDLSetRumble(struct mRumble* rumble, int enable) { +static void _mSDLSetRumble(struct mRumbleIntegrator* rumble, float level) { struct mSDLRumble* sdlRumble = (struct mSDLRumble*) rumble; if (!sdlRumble->p->joystick) { return; @@ -719,36 +714,23 @@ static void _mSDLSetRumble(struct mRumble* rumble, int enable) { } #endif - int8_t originalLevel = sdlRumble->level; - sdlRumble->level += enable; - if (mCircleBufferSize(&sdlRumble->history) == RUMBLE_PWM) { - int8_t oldLevel; - mCircleBufferRead8(&sdlRumble->history, &oldLevel); - sdlRumble->level -= oldLevel; - } - mCircleBufferWrite8(&sdlRumble->history, enable); - if (sdlRumble->level == originalLevel) { - return; - } - float activeLevel = ceil(RUMBLE_STEPS * sdlRumble->level / (float) RUMBLE_PWM) / RUMBLE_STEPS; - if (fabsf(sdlRumble->activeLevel - activeLevel) < 0.75 / RUMBLE_STEPS) { - return; - } - sdlRumble->activeLevel = activeLevel; #if SDL_VERSION_ATLEAST(2, 0, 9) - if (sdlRumble->p->joystick->controller) { - SDL_GameControllerRumble(sdlRumble->p->joystick->controller, activeLevel * 0xFFFF, activeLevel * 0xFFFF, 500); - } else { - SDL_JoystickRumble(sdlRumble->p->joystick->joystick, activeLevel * 0xFFFF, activeLevel * 0xFFFF, 500); + if (sdlRumble->activeLevel > RUMBLE_THRESHOLD || level > RUMBLE_THRESHOLD) { + if (sdlRumble->p->joystick->controller) { + SDL_GameControllerRumble(sdlRumble->p->joystick->controller, level * 0xFFFF, level * 0xFFFF, 67); + } else { + SDL_JoystickRumble(sdlRumble->p->joystick->joystick, level * 0xFFFF, level * 0xFFFF, 67); + } } #else - if (sdlRumble->activeLevel > 0.5 / RUMBLE_STEPS) { + if (sdlRumble->activeLevel > RUMBLE_THRESHOLD || level > RUMBLE_THRESHOLD) { SDL_HapticRumbleStop(sdlRumble->p->joystick->haptic); - SDL_HapticRumblePlay(sdlRumble->p->joystick->haptic, activeLevel, 500); + SDL_HapticRumblePlay(sdlRumble->p->joystick->haptic, level, 500); } else { SDL_HapticRumbleStop(sdlRumble->p->joystick->haptic); } #endif + sdlRumble->activeLevel = level; } #endif diff --git a/src/platform/sdl/sdl-events.h b/src/platform/sdl/sdl-events.h index 877818a01a4..59b7c7e9267 100644 --- a/src/platform/sdl/sdl-events.h +++ b/src/platform/sdl/sdl-events.h @@ -71,12 +71,9 @@ struct mSDLPlayer { SDL_Window* window; struct mSDLRumble { - struct mRumble d; + struct mRumbleIntegrator d; struct mSDLPlayer* p; - - int level; float activeLevel; - struct mCircleBuffer history; } rumble; #else int newWidth; diff --git a/src/platform/switch/main.c b/src/platform/switch/main.c index 9a3441b9ba5..c829ab9b088 100644 --- a/src/platform/switch/main.c +++ b/src/platform/switch/main.c @@ -82,9 +82,7 @@ static struct GUIFont* font; static color_t* frameBuffer; static struct mAVStream stream; static struct mSwitchRumble { - struct mRumble d; - int up; - int down; + struct mRumbleIntegrator d; HidVibrationValue value; } rumble; static struct mRotationSource rotation = {0}; @@ -298,7 +296,8 @@ static void _setup(struct mGUIRunner* runner) { } _updateRenderer(runner, fakeBool); - runner->core->setPeripheral(runner->core, mPERIPH_RUMBLE, &rumble.d); + mRumbleIntegratorInit(&rumble.d); + runner->core->setPeripheral(runner->core, mPERIPH_RUMBLE, &rumble.d.d); runner->core->setPeripheral(runner->core, mPERIPH_ROTATION, &rotation); runner->core->setAVStream(runner->core, &stream); @@ -365,12 +364,12 @@ static void _gameLoaded(struct mGUIRunner* runner) { } } - rumble.up = 0; - rumble.down = 0; + mRumbleIntegratorInit(&rumble.d); } static void _gameUnloaded(struct mGUIRunner* runner) { UNUSED(runner); + mRumbleIntegratorInit(&rumble.d); HidVibrationValue values[4]; memcpy(&values[0], &vibrationStop, sizeof(rumble.value)); memcpy(&values[1], &vibrationStop, sizeof(rumble.value)); @@ -510,24 +509,12 @@ static void _drawFrame(struct mGUIRunner* runner, bool faded) { _drawTex(runner, width, height, faded, false); } - HidVibrationValue values[4]; - if (rumble.up) { - rumble.value.amp_low = rumble.up / (float) (rumble.up + rumble.down); - rumble.value.amp_high = rumble.up / (float) (rumble.up + rumble.down); - memcpy(&values[0], &rumble.value, sizeof(rumble.value)); - memcpy(&values[1], &rumble.value, sizeof(rumble.value)); - memcpy(&values[2], &rumble.value, sizeof(rumble.value)); - memcpy(&values[3], &rumble.value, sizeof(rumble.value)); - } else { - memcpy(&values[0], &vibrationStop, sizeof(rumble.value)); - memcpy(&values[1], &vibrationStop, sizeof(rumble.value)); - memcpy(&values[2], &vibrationStop, sizeof(rumble.value)); - memcpy(&values[3], &vibrationStop, sizeof(rumble.value)); - } + memcpy(&values[0], &rumble.value, sizeof(rumble.value)); + memcpy(&values[1], &rumble.value, sizeof(rumble.value)); + memcpy(&values[2], &rumble.value, sizeof(rumble.value)); + memcpy(&values[3], &rumble.value, sizeof(rumble.value)); hidSendVibrationValues(vibrationDeviceHandles, values, 4); - rumble.up = 0; - rumble.down = 0; } static void _drawScreenshot(struct mGUIRunner* runner, const color_t* pixels, unsigned width, unsigned height, bool faded) { @@ -615,13 +602,10 @@ static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer* buff audrvUpdate(&audrenDriver); } -void _setRumble(struct mRumble* rumble, int enable) { +void _setRumble(struct mRumbleIntegrator* rumble, float level) { struct mSwitchRumble* sr = (struct mSwitchRumble*) rumble; - if (enable) { - ++sr->up; - } else { - ++sr->down; - } + sr->value.amp_low = level; + sr->value.amp_high = level; } void _sampleRotation(struct mRotationSource* source) { diff --git a/src/platform/wii/main.c b/src/platform/wii/main.c index 55bae973897..f05e0089745 100644 --- a/src/platform/wii/main.c +++ b/src/platform/wii/main.c @@ -79,7 +79,7 @@ static void _retraceCallback(u32 count); static void _postAudioBuffer(struct mAVStream* stream, struct mAudioBuffer*); static void _audioRateChanged(struct mAVStream* stream, unsigned); static void _audioDMA(void); -static void _setRumble(struct mRumble* rumble, int enable); +static void _setRumble(struct mRumble* rumble, bool enable, uint32_t sinceLast); static void _sampleRotation(struct mRotationSource* source); static int32_t _readTiltX(struct mRotationSource* source); static int32_t _readTiltY(struct mRotationSource* source); @@ -1722,8 +1722,9 @@ void _incrementScreenMode(struct mGUIRunner* runner) { } } -void _setRumble(struct mRumble* rumble, int enable) { +void _setRumble(struct mRumble* rumble, bool enable, uint32_t sinceLast) { UNUSED(rumble); + UNUSED(sinceLast); WPAD_Rumble(0, enable); if (enable) { PAD_ControlMotor(0, PAD_MOTOR_RUMBLE); From 2ea11feda65c7b632c78a8f0ecca565aaf4ad9ac Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 17 Jun 2024 02:27:31 -0700 Subject: [PATCH 150/338] GBA Memory: Improve VRAM access stall cycle estimation --- CHANGES | 1 + include/mgba/internal/gba/video.h | 8 ++- src/gba/memory.c | 80 +++++++++++++++++++++------- src/gba/video.c | 86 +++++++++++++++++++++++++++++-- 4 files changed, 151 insertions(+), 24 deletions(-) diff --git a/CHANGES b/CHANGES index 626e9aa413f..6119069f38e 100644 --- a/CHANGES +++ b/CHANGES @@ -35,6 +35,7 @@ Misc: - GB Serialize: Add missing savestate support for MBC6 and NT (newer) - GBA: Improve detection of valid ELF ROMs - GBA Audio: Remove broken XQ audio pending rewrite + - GBA Memory: Improve VRAM access stall cycle estimation - GBA Video: Add special circlular window handling in OpenGL renderer - Libretro: Add Super Game Boy Color support (closes mgba.io/i/3188) - mGUI: Enable auto-softpatching (closes mgba.io/i/2899) diff --git a/include/mgba/internal/gba/video.h b/include/mgba/internal/gba/video.h index 5b12d1541a8..b29b3d60742 100644 --- a/include/mgba/internal/gba/video.h +++ b/include/mgba/internal/gba/video.h @@ -16,6 +16,12 @@ CXX_GUARD_START mLOG_DECLARE_CATEGORY(GBA_VIDEO); +#define GBA_VSTALL_T4(X) (0x011 << (X)) +#define GBA_VSTALL_T8(X) (0x010 << (X)) +#define GBA_VSTALL_A2 0x100 +#define GBA_VSTALL_A3 0x200 +#define GBA_VSTALL_B 0x400 + enum { VIDEO_HBLANK_PIXELS = 68, VIDEO_HDRAW_LENGTH = 1008, @@ -208,7 +214,7 @@ struct GBAVideo { struct mTimingEvent event; int vcount; - int shouldStall; + unsigned stallMask; uint16_t palette[512]; uint16_t* vram; diff --git a/src/gba/memory.c b/src/gba/memory.c index 4c72ca80e8d..62b26b1e34b 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -401,7 +401,7 @@ static void GBASetActiveRegion(struct ARMCore* cpu, uint32_t address) { LOAD_32(value, address & 0x0001FFFC, gba->video.vram); \ } \ ++wait; \ - if (gba->video.shouldStall && (address & 0x0001FFFF) < ((GBARegisterDISPCNTGetMode(gba->memory.io[GBA_REG(DISPCNT)]) >= 3) ? 0x00014000 : 0x00010000)) { \ + if (gba->video.stallMask && (address & 0x0001FFFF) < ((GBARegisterDISPCNTGetMode(gba->memory.io[GBA_REG(DISPCNT)]) >= 3) ? 0x00014000 : 0x00010000)) { \ wait += GBAMemoryStallVRAM(gba, wait, 1); \ } @@ -561,7 +561,7 @@ uint32_t GBALoad16(struct ARMCore* cpu, uint32_t address, int* cycleCounter) { } else { LOAD_16(value, address & 0x0001FFFE, gba->video.vram); } - if (gba->video.shouldStall && (address & 0x0001FFFF) < ((GBARegisterDISPCNTGetMode(gba->memory.io[GBA_REG(DISPCNT)]) >= 3) ? 0x00014000 : 0x00010000)) { + if (gba->video.stallMask && (address & 0x0001FFFF) < ((GBARegisterDISPCNTGetMode(gba->memory.io[GBA_REG(DISPCNT)]) >= 3) ? 0x00014000 : 0x00010000)) { wait += GBAMemoryStallVRAM(gba, wait, 0); } break; @@ -676,7 +676,7 @@ uint32_t GBALoad8(struct ARMCore* cpu, uint32_t address, int* cycleCounter) { } else { value = ((uint8_t*) gba->video.vram)[address & 0x0001FFFF]; } - if (gba->video.shouldStall) { + if (gba->video.stallMask) { wait += GBAMemoryStallVRAM(gba, wait, 0); } break; @@ -781,7 +781,7 @@ uint32_t GBALoad8(struct ARMCore* cpu, uint32_t address, int* cycleCounter) { } \ } \ ++wait; \ - if (gba->video.shouldStall && (address & 0x0001FFFF) < ((GBARegisterDISPCNTGetMode(gba->memory.io[GBA_REG(DISPCNT)]) >= 3) ? 0x00014000 : 0x00010000)) { \ + if (gba->video.stallMask && (address & 0x0001FFFF) < ((GBARegisterDISPCNTGetMode(gba->memory.io[GBA_REG(DISPCNT)]) >= 3) ? 0x00014000 : 0x00010000)) { \ wait += GBAMemoryStallVRAM(gba, wait, 1); \ } @@ -908,7 +908,7 @@ void GBAStore16(struct ARMCore* cpu, uint32_t address, int16_t value, int* cycle gba->video.renderer->writeVRAM(gba->video.renderer, address & 0x0001FFFE); } } - if (gba->video.shouldStall && (address & 0x0001FFFF) < ((GBARegisterDISPCNTGetMode(gba->memory.io[GBA_REG(DISPCNT)]) >= 3) ? 0x00014000 : 0x00010000)) { + if (gba->video.stallMask && (address & 0x0001FFFF) < ((GBARegisterDISPCNTGetMode(gba->memory.io[GBA_REG(DISPCNT)]) >= 3) ? 0x00014000 : 0x00010000)) { wait += GBAMemoryStallVRAM(gba, wait, 0); } break; @@ -1038,7 +1038,7 @@ void GBAStore8(struct ARMCore* cpu, uint32_t address, int8_t value, int* cycleCo gba->video.renderer->vram[(address & 0x1FFFE) >> 1] = ((uint8_t) value) | (value << 8); gba->video.renderer->writeVRAM(gba->video.renderer, address & 0x0001FFFE); } - if (gba->video.shouldStall) { + if (gba->video.stallMask) { wait += GBAMemoryStallVRAM(gba, wait, 0); } break; @@ -1778,20 +1778,64 @@ int32_t GBAMemoryStall(struct ARMCore* cpu, int32_t wait) { } int32_t GBAMemoryStallVRAM(struct GBA* gba, int32_t wait, int extra) { - UNUSED(extra); - // TODO - uint16_t dispcnt = gba->memory.io[GBA_REG(DISPCNT)]; - int32_t stall = 0; - switch (GBARegisterDISPCNTGetMode(dispcnt)) { - case 2: - if (GBARegisterDISPCNTIsBg2Enable(dispcnt) && GBARegisterDISPCNTIsBg3Enable(dispcnt)) { - // If both backgrounds are enabled, VRAM access is entirely blocked during hdraw - stall = mTimingUntil(&gba->timing, &gba->video.event); + static const uint16_t stallLUT[32] = { + GBA_VSTALL_T4(0) | GBA_VSTALL_A3, + GBA_VSTALL_T4(1) | GBA_VSTALL_A3, + GBA_VSTALL_T4(2) | GBA_VSTALL_A2, + GBA_VSTALL_T4(3) | GBA_VSTALL_A3 | GBA_VSTALL_B, + + GBA_VSTALL_T4(0) | GBA_VSTALL_A3, + GBA_VSTALL_T4(1) | GBA_VSTALL_A3, + GBA_VSTALL_T4(2) | GBA_VSTALL_A2, + GBA_VSTALL_T4(3) | GBA_VSTALL_A3 | GBA_VSTALL_B, + + GBA_VSTALL_A3, + GBA_VSTALL_A3, + GBA_VSTALL_A2, + GBA_VSTALL_A3 | GBA_VSTALL_B, + + GBA_VSTALL_T8(0) | GBA_VSTALL_A3, + GBA_VSTALL_T8(1) | GBA_VSTALL_A3, + GBA_VSTALL_T8(2) | GBA_VSTALL_A2, + GBA_VSTALL_T8(3) | GBA_VSTALL_A3 | GBA_VSTALL_B, + + GBA_VSTALL_A3, + GBA_VSTALL_A3, + GBA_VSTALL_A2, + GBA_VSTALL_A3 | GBA_VSTALL_B, + + GBA_VSTALL_T4(0) | GBA_VSTALL_A3, + GBA_VSTALL_T4(1) | GBA_VSTALL_A3, + GBA_VSTALL_T4(2) | GBA_VSTALL_A2, + GBA_VSTALL_T4(3) | GBA_VSTALL_A3 | GBA_VSTALL_B, + + GBA_VSTALL_A3, + GBA_VSTALL_A3, + GBA_VSTALL_A2, + GBA_VSTALL_A3 | GBA_VSTALL_B, + + GBA_VSTALL_T8(0) | GBA_VSTALL_A3, + GBA_VSTALL_T8(1) | GBA_VSTALL_A3, + GBA_VSTALL_T8(2) | GBA_VSTALL_A2, + GBA_VSTALL_T8(3) | GBA_VSTALL_A3 | GBA_VSTALL_B, + }; + + int32_t until = mTimingUntil(&gba->timing, &gba->video.event); + int period = -until & 0x1F; + + int32_t stall = until; + + int i; + for (i = 0; i < 16; ++i) { + if (!(stallLUT[(period + i) & 0x1F] & gba->video.stallMask)) { + if (!extra) { + stall = i; + break; + } + --extra; } - break; - default: - return 0; } + stall -= wait; if (stall < 0) { return 0; diff --git a/src/gba/video.c b/src/gba/video.c index bfe556943e4..5a4d2c8c021 100644 --- a/src/gba/video.c +++ b/src/gba/video.c @@ -32,6 +32,7 @@ static void GBAVideoDummyRendererPutPixels(struct GBAVideoRenderer* renderer, si static void _startHblank(struct mTiming*, void* context, uint32_t cyclesLate); static void _startHdraw(struct mTiming*, void* context, uint32_t cyclesLate); +static unsigned _calculateStallMask(struct GBA* gba); MGBA_EXPORT const int GBAVideoObjSizes[16][2] = { { 8, 8 }, @@ -78,7 +79,7 @@ void GBAVideoReset(struct GBAVideo* video) { video->frameCounter = 0; video->frameskipCounter = 0; - video->shouldStall = 0; + video->stallMask = 0; memset(video->palette, 0, sizeof(video->palette)); memset(video->oam.raw, 0, sizeof(video->oam.raw)); @@ -149,7 +150,7 @@ void _startHdraw(struct mTiming* timing, void* context, uint32_t cyclesLate) { video->p->memory.io[GBA_REG(VCOUNT)] = video->vcount; if (video->vcount < GBA_VIDEO_VERTICAL_PIXELS) { - video->shouldStall = 1; + video->stallMask = _calculateStallMask(video->p); } GBARegisterDISPSTAT dispstat = video->p->memory.io[GBA_REG(DISPSTAT)]; @@ -214,7 +215,7 @@ void _startHblank(struct mTiming* timing, void* context, uint32_t cyclesLate) { if (GBARegisterDISPSTATIsHblankIRQ(dispstat)) { GBARaiseIRQ(video->p, GBA_IRQ_HBLANK, cyclesLate - 6); // TODO: Where does this fudge factor come from? } - video->shouldStall = 0; + video->stallMask = 0; video->p->memory.io[GBA_REG(DISPSTAT)] = dispstat; } @@ -224,6 +225,81 @@ void GBAVideoWriteDISPSTAT(struct GBAVideo* video, uint16_t value) { // TODO: Does a VCounter IRQ trigger on write? } +static unsigned _calculateStallMask(struct GBA* gba) { + unsigned mask = 0; + + unsigned dispcnt = gba->memory.io[GBA_REG(DISPCNT)]; + switch (GBARegisterDISPCNTGetMode(dispcnt)) { + case 0: + if (GBARegisterDISPCNTIsBg0Enable(dispcnt)) { + if (GBARegisterBGCNTIs256Color(gba->memory.io[GBA_REG(BG0CNT)])) { + mask |= GBA_VSTALL_T8(0); + } else { + mask |= GBA_VSTALL_T4(0); + } + } + if (GBARegisterDISPCNTIsBg1Enable(dispcnt)) { + if (GBARegisterBGCNTIs256Color(gba->memory.io[GBA_REG(BG1CNT)])) { + mask |= GBA_VSTALL_T8(1); + } else { + mask |= GBA_VSTALL_T4(1); + } + } + if (GBARegisterDISPCNTIsBg2Enable(dispcnt)) { + if (GBARegisterBGCNTIs256Color(gba->memory.io[GBA_REG(BG2CNT)])) { + mask |= GBA_VSTALL_T8(2); + } else { + mask |= GBA_VSTALL_T4(2); + } + } + if (GBARegisterDISPCNTIsBg3Enable(dispcnt)) { + if (GBARegisterBGCNTIs256Color(gba->memory.io[GBA_REG(BG3CNT)])) { + mask |= GBA_VSTALL_T8(3); + } else { + mask |= GBA_VSTALL_T4(3); + } + } + break; + case 1: + if (GBARegisterDISPCNTIsBg0Enable(dispcnt)) { + if (GBARegisterBGCNTIs256Color(gba->memory.io[GBA_REG(BG0CNT)])) { + mask |= GBA_VSTALL_T8(0); + } else { + mask |= GBA_VSTALL_T4(0); + } + } + if (GBARegisterDISPCNTIsBg1Enable(dispcnt)) { + if (GBARegisterBGCNTIs256Color(gba->memory.io[GBA_REG(BG1CNT)])) { + mask |= GBA_VSTALL_T8(1); + } else { + mask |= GBA_VSTALL_T4(1); + } + } + if (GBARegisterDISPCNTIsBg2Enable(dispcnt)) { + mask |= GBA_VSTALL_A2; + } + break; + case 2: + if (GBARegisterDISPCNTIsBg2Enable(dispcnt)) { + mask |= GBA_VSTALL_A2; + } + if (GBARegisterDISPCNTIsBg3Enable(dispcnt)) { + mask |= GBA_VSTALL_A3; + } + break; + case 3: + case 4: + case 5: + if (GBARegisterDISPCNTIsBg2Enable(dispcnt)) { + mask |= GBA_VSTALL_B; + } + break; + default: + break; + } + return mask; +} + static void GBAVideoDummyRendererInit(struct GBAVideoRenderer* renderer) { UNUSED(renderer); // Nothing to do @@ -353,7 +429,7 @@ void GBAVideoDeserialize(struct GBAVideo* video, const struct GBASerializedState } LOAD_32(video->frameCounter, 0, &state->video.frameCounter); - video->shouldStall = 0; + video->stallMask = 0; int32_t flags; LOAD_32(flags, 0, &state->video.flags); GBARegisterDISPSTAT dispstat = state->io[GBA_REG(DISPSTAT)]; @@ -370,7 +446,7 @@ void GBAVideoDeserialize(struct GBAVideo* video, const struct GBASerializedState break; case 2: video->event.callback = _startHblank; - video->shouldStall = 1; + video->stallMask = _calculateStallMask(video->p); break; case 3: video->event.callback = _startHdraw; From 9318e9b2cb1c019e8862755c0aad5675405648de Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 20 Jun 2024 02:20:36 -0700 Subject: [PATCH 151/338] All: Clean up how assertions are done --- include/mgba-util/common.h | 20 ++++++++++++++++ src/core/tile-cache.c | 10 ++------ src/gba/gba.c | 13 +++-------- src/script/canvas.c | 6 ++--- src/script/context.c | 4 +--- src/script/types.c | 13 ++++------- src/util/audio-resampler.c | 4 +--- src/util/circle-buffer.c | 48 +++++++------------------------------- src/util/sfo.c | 4 +--- src/util/vfs/vfs-zip.c | 4 +--- 10 files changed, 43 insertions(+), 83 deletions(-) diff --git a/include/mgba-util/common.h b/include/mgba-util/common.h index d91a6557c4f..c5008e01fab 100644 --- a/include/mgba-util/common.h +++ b/include/mgba-util/common.h @@ -314,6 +314,26 @@ typedef intptr_t ssize_t; #define ROR(I, ROTATE) ((((uint32_t) (I)) >> ROTATE) | ((uint32_t) (I) << ((-ROTATE) & 31))) +#define mASSERT(COND) \ + if (!(COND)) { \ + abort(); \ + } +#define mASSERT_DEBUG(COND) assert((COND)) + +#define mASSERT_LOG(CAT, COND, ...) \ + if (!(COND)) { \ + mLOG(CAT, FATAL, __VA_ARGS__); \ + } + +#ifdef NDEBUG +#define mASSERT_DEBUG_LOG(...) +#else +#define mASSERT_DEBUG_LOG(CAT, COND, ...) \ + if (!(COND)) { \ + mLOG(CAT, FATAL, __VA_ARGS__); \ + } +#endif + CXX_GUARD_END #endif diff --git a/src/core/tile-cache.c b/src/core/tile-cache.c index 249cd0116d2..d9f68066cb4 100644 --- a/src/core/tile-cache.c +++ b/src/core/tile-cache.c @@ -197,14 +197,8 @@ static void _regenerateTile256(struct mTileCache* cache, color_t* tile, unsigned static inline color_t* _tileLookup(struct mTileCache* cache, unsigned tileId, unsigned paletteId) { if (mTileCacheConfigurationIsShouldStore(cache->config)) { unsigned tiles = mTileCacheSystemInfoGetMaxTiles(cache->sysConfig); -#ifndef NDEBUG - if (tileId >= tiles) { - abort(); - } - if (paletteId >= 1U << mTileCacheSystemInfoGetPaletteCount(cache->sysConfig)) { - abort(); - } -#endif + mASSERT(tileId < tiles); + mASSERT_DEBUG(paletteId < 1U << mTileCacheSystemInfoGetPaletteCount(cache->sysConfig)); return &cache->cache[(tileId + paletteId * tiles) << 6]; } else { return cache->temporaryTile; diff --git a/src/gba/gba.c b/src/gba/gba.c index 013dcad4efe..2d10f5cc91d 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -339,11 +339,7 @@ static void GBAProcessEvents(struct ARMCore* cpu) { #ifdef ENABLE_DEBUGGERS gba->timing.globalCycles += cycles < nextEvent ? nextEvent : cycles; #endif -#ifndef NDEBUG - if (cycles < 0) { - mLOG(GBA, FATAL, "Negative cycles passed: %i", cycles); - } -#endif + mASSERT_DEBUG_LOG(GBA, cycles >= 0, "Negative cycles passed: %i", cycles); nextEvent = mTimingTick(&gba->timing, cycles < nextEvent ? nextEvent : cycles); } while (gba->cpuBlocked && !gba->earlyExit); @@ -353,12 +349,9 @@ static void GBAProcessEvents(struct ARMCore* cpu) { if (!gba->memory.io[GBA_REG(IME)] || !gba->memory.io[GBA_REG(IE)]) { break; } + } else { + mASSERT_DEBUG_LOG(GBA, nextEvent >= 0, "Negative cycles will pass: %i", nextEvent); } -#ifndef NDEBUG - else if (nextEvent < 0) { - mLOG(GBA, FATAL, "Negative cycles will pass: %i", nextEvent); - } -#endif if (gba->earlyExit) { break; } diff --git a/src/script/canvas.c b/src/script/canvas.c index 5e931943d6f..0a0ce5b8028 100644 --- a/src/script/canvas.c +++ b/src/script/canvas.c @@ -157,10 +157,8 @@ static struct mScriptValue* mScriptCanvasLayerCreate(struct mScriptCanvasContext } struct mScriptCanvasLayer* layer = &context->overlays[next]; - if (layer->image) { - // This shouldn't exist yet - abort(); - } + // This shouldn't exist yet + mASSERT(!layer->image); layer->image = mImageCreate(w, h, mCOLOR_ABGR8); layer->dirty = true; diff --git a/src/script/context.c b/src/script/context.c index ab0937500ea..d9afd55a1be 100644 --- a/src/script/context.c +++ b/src/script/context.c @@ -458,9 +458,7 @@ bool mScriptContextActivate(struct mScriptContext* context) { void mScriptContextDeactivate(struct mScriptContext* context) { #ifndef NDEBUG struct mScriptContext* threadContext = ThreadLocalGetValue(_threadContext); - if (threadContext != context) { - abort(); - } + mASSERT(threadContext == context); #endif --context->threadDepth; diff --git a/src/script/types.c b/src/script/types.c index d860d40c0c3..be58a43bff9 100644 --- a/src/script/types.c +++ b/src/script/types.c @@ -895,9 +895,8 @@ struct mScriptValue* mScriptValueAlloc(const struct mScriptType* type) { } void mScriptValueRef(struct mScriptValue* val) { - if (val->refs == INT_MAX) { - abort(); - } else if (val->refs == mSCRIPT_VALUE_UNREF) { + mASSERT(val->refs != INT_MAX); + if (val->refs == mSCRIPT_VALUE_UNREF) { return; } ++val->refs; @@ -1238,12 +1237,8 @@ static void _mScriptClassInit(struct mScriptTypeClass* cls, const struct mScript member->docstring = docstring; docstring = NULL; } - if (detail->info.member.type->base != mSCRIPT_TYPE_FUNCTION) { - abort(); - } - if (detail->info.member.type->details.function.parameters.count != 3) { - abort(); - } + mASSERT(detail->info.member.type->base == mSCRIPT_TYPE_FUNCTION); + mASSERT(detail->info.member.type->details.function.parameters.count == 3); HashTableInsert(&cls->setters, detail->info.member.type->details.function.parameters.entries[2]->name, member); break; case mSCRIPT_CLASS_INIT_INTERNAL: diff --git a/src/util/audio-resampler.c b/src/util/audio-resampler.c index 5b7a069e436..3b1848190ae 100644 --- a/src/util/audio-resampler.c +++ b/src/util/audio-resampler.c @@ -77,9 +77,7 @@ size_t mAudioResamplerProcess(struct mAudioResampler* resampler) { }; size_t read = 0; - if (resampler->source->channels > MAX_CHANNELS) { - abort(); - } + mASSERT(resampler->source->channels <= MAX_CHANNELS); while (true) { if (timestamp + resampler->highWaterMark >= mAudioBufferAvailable(resampler->source)) { diff --git a/src/util/circle-buffer.c b/src/util/circle-buffer.c index ec14bfc4f88..cd13c082f1a 100644 --- a/src/util/circle-buffer.c +++ b/src/util/circle-buffer.c @@ -59,11 +59,7 @@ int mCircleBufferWrite8(struct mCircleBuffer* buffer, int8_t value) { buffer->writePtr = buffer->data; } buffer->size += sizeof(int8_t); -#ifndef NDEBUG - if (!_checkIntegrity(buffer)) { - abort(); - } -#endif + mASSERT_DEBUG(_checkIntegrity(buffer)); return 1; } @@ -89,11 +85,7 @@ int mCircleBufferWrite32(struct mCircleBuffer* buffer, int32_t value) { buffer->writePtr = buffer->data; } buffer->size += sizeof(int32_t); -#ifndef NDEBUG - if (!_checkIntegrity(buffer)) { - abort(); - } -#endif + mASSERT_DEBUG(_checkIntegrity(buffer)); return 4; } @@ -117,11 +109,7 @@ int mCircleBufferWrite16(struct mCircleBuffer* buffer, int16_t value) { buffer->writePtr = buffer->data; } buffer->size += sizeof(int16_t); -#ifndef NDEBUG - if (!_checkIntegrity(buffer)) { - abort(); - } -#endif + mASSERT_DEBUG(_checkIntegrity(buffer)); return 2; } @@ -145,11 +133,7 @@ size_t mCircleBufferWrite(struct mCircleBuffer* buffer, const void* input, size_ } buffer->size += length; -#ifndef NDEBUG - if (!_checkIntegrity(buffer)) { - abort(); - } -#endif + mASSERT_DEBUG(_checkIntegrity(buffer)); return length; } @@ -174,11 +158,7 @@ int mCircleBufferRead8(struct mCircleBuffer* buffer, int8_t* value) { buffer->readPtr = buffer->data; } buffer->size -= sizeof(int8_t); -#ifndef NDEBUG - if (!_checkIntegrity(buffer)) { - abort(); - } -#endif + mASSERT_DEBUG(_checkIntegrity(buffer)); return 1; } @@ -202,11 +182,7 @@ int mCircleBufferRead16(struct mCircleBuffer* buffer, int16_t* value) { buffer->readPtr = buffer->data; } buffer->size -= sizeof(int16_t); -#ifndef NDEBUG - if (!_checkIntegrity(buffer)) { - abort(); - } -#endif + mASSERT_DEBUG(_checkIntegrity(buffer)); return 2; } @@ -232,11 +208,7 @@ int mCircleBufferRead32(struct mCircleBuffer* buffer, int32_t* value) { buffer->readPtr = buffer->data; } buffer->size -= sizeof(int32_t); -#ifndef NDEBUG - if (!_checkIntegrity(buffer)) { - abort(); - } -#endif + mASSERT_DEBUG(_checkIntegrity(buffer)); return 4; } @@ -267,11 +239,7 @@ size_t mCircleBufferRead(struct mCircleBuffer* buffer, void* output, size_t leng } buffer->size -= length; -#ifndef NDEBUG - if (!_checkIntegrity(buffer)) { - abort(); - } -#endif + mASSERT_DEBUG(_checkIntegrity(buffer)); return length; } diff --git a/src/util/sfo.c b/src/util/sfo.c index 339da1d8e1e..97c4e385346 100644 --- a/src/util/sfo.c +++ b/src/util/sfo.c @@ -209,9 +209,7 @@ bool SfoWrite(struct Table* sfo, struct VFile* vf) { } } - if (keysSize != ALIGN4(keysOffset) || dataSize != dataOffset) { - abort(); - } + mASSERT(keysSize == ALIGN4(keysOffset) && dataSize == dataOffset); free(sortedEntries); diff --git a/src/util/vfs/vfs-zip.c b/src/util/vfs/vfs-zip.c index 65e1c1e320c..bd803d7bb09 100644 --- a/src/util/vfs/vfs-zip.c +++ b/src/util/vfs/vfs-zip.c @@ -309,9 +309,7 @@ ssize_t _vfzRead(struct VFile* vf, void* buffer, size_t size) { if (!vfz->buffer) { vfz->bufferSize = BLOCK_SIZE; vfz->buffer = malloc(BLOCK_SIZE); - if (vfz->readSize) { - abort(); - } + mASSERT(!vfz->readSize); } while (bytesRead < size) { From d8375a5896e9ebf2d742f884d3229c0e8e3b61d2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 20 Jun 2024 22:30:16 -0700 Subject: [PATCH 152/338] GBA Memory: Fix affine background timing errors --- src/gba/memory.c | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/gba/memory.c b/src/gba/memory.c index 62b26b1e34b..1ddd2eb993b 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -1782,42 +1782,42 @@ int32_t GBAMemoryStallVRAM(struct GBA* gba, int32_t wait, int extra) { GBA_VSTALL_T4(0) | GBA_VSTALL_A3, GBA_VSTALL_T4(1) | GBA_VSTALL_A3, GBA_VSTALL_T4(2) | GBA_VSTALL_A2, - GBA_VSTALL_T4(3) | GBA_VSTALL_A3 | GBA_VSTALL_B, + GBA_VSTALL_T4(3) | GBA_VSTALL_A2 | GBA_VSTALL_B, GBA_VSTALL_T4(0) | GBA_VSTALL_A3, GBA_VSTALL_T4(1) | GBA_VSTALL_A3, GBA_VSTALL_T4(2) | GBA_VSTALL_A2, - GBA_VSTALL_T4(3) | GBA_VSTALL_A3 | GBA_VSTALL_B, + GBA_VSTALL_T4(3) | GBA_VSTALL_A2 | GBA_VSTALL_B, GBA_VSTALL_A3, GBA_VSTALL_A3, GBA_VSTALL_A2, - GBA_VSTALL_A3 | GBA_VSTALL_B, + GBA_VSTALL_A2 | GBA_VSTALL_B, GBA_VSTALL_T8(0) | GBA_VSTALL_A3, GBA_VSTALL_T8(1) | GBA_VSTALL_A3, GBA_VSTALL_T8(2) | GBA_VSTALL_A2, - GBA_VSTALL_T8(3) | GBA_VSTALL_A3 | GBA_VSTALL_B, + GBA_VSTALL_T8(3) | GBA_VSTALL_A2 | GBA_VSTALL_B, GBA_VSTALL_A3, GBA_VSTALL_A3, GBA_VSTALL_A2, - GBA_VSTALL_A3 | GBA_VSTALL_B, + GBA_VSTALL_A2 | GBA_VSTALL_B, GBA_VSTALL_T4(0) | GBA_VSTALL_A3, GBA_VSTALL_T4(1) | GBA_VSTALL_A3, GBA_VSTALL_T4(2) | GBA_VSTALL_A2, - GBA_VSTALL_T4(3) | GBA_VSTALL_A3 | GBA_VSTALL_B, + GBA_VSTALL_T4(3) | GBA_VSTALL_A2 | GBA_VSTALL_B, GBA_VSTALL_A3, GBA_VSTALL_A3, GBA_VSTALL_A2, - GBA_VSTALL_A3 | GBA_VSTALL_B, + GBA_VSTALL_A2 | GBA_VSTALL_B, GBA_VSTALL_T8(0) | GBA_VSTALL_A3, GBA_VSTALL_T8(1) | GBA_VSTALL_A3, GBA_VSTALL_T8(2) | GBA_VSTALL_A2, - GBA_VSTALL_T8(3) | GBA_VSTALL_A3 | GBA_VSTALL_B, + GBA_VSTALL_T8(3) | GBA_VSTALL_A2 | GBA_VSTALL_B, }; int32_t until = mTimingUntil(&gba->timing, &gba->video.event); From e8bfaa210a2fc3112d72596989c4153dcef50d34 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 24 Jun 2024 01:16:12 -0700 Subject: [PATCH 153/338] GBA Video: Fix VRAM access stalling even during force blanking --- src/gba/video.c | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/src/gba/video.c b/src/gba/video.c index 5a4d2c8c021..63e7115c159 100644 --- a/src/gba/video.c +++ b/src/gba/video.c @@ -32,7 +32,7 @@ static void GBAVideoDummyRendererPutPixels(struct GBAVideoRenderer* renderer, si static void _startHblank(struct mTiming*, void* context, uint32_t cyclesLate); static void _startHdraw(struct mTiming*, void* context, uint32_t cyclesLate); -static unsigned _calculateStallMask(struct GBA* gba); +static unsigned _calculateStallMask(struct GBA* gba, unsigned dispcnt); MGBA_EXPORT const int GBAVideoObjSizes[16][2] = { { 8, 8 }, @@ -150,7 +150,8 @@ void _startHdraw(struct mTiming* timing, void* context, uint32_t cyclesLate) { video->p->memory.io[GBA_REG(VCOUNT)] = video->vcount; if (video->vcount < GBA_VIDEO_VERTICAL_PIXELS) { - video->stallMask = _calculateStallMask(video->p); + unsigned dispcnt = video->p->memory.io[GBA_REG(DISPCNT)]; + video->stallMask = _calculateStallMask(video->p, dispcnt); } GBARegisterDISPSTAT dispstat = video->p->memory.io[GBA_REG(DISPSTAT)]; @@ -225,10 +226,13 @@ void GBAVideoWriteDISPSTAT(struct GBAVideo* video, uint16_t value) { // TODO: Does a VCounter IRQ trigger on write? } -static unsigned _calculateStallMask(struct GBA* gba) { +static unsigned _calculateStallMask(struct GBA* gba, unsigned dispcnt) { unsigned mask = 0; - unsigned dispcnt = gba->memory.io[GBA_REG(DISPCNT)]; + if (GBARegisterDISPCNTIsForcedBlank(dispcnt)) { + return 0; + } + switch (GBARegisterDISPCNTGetMode(dispcnt)) { case 0: if (GBARegisterDISPCNTIsBg0Enable(dispcnt)) { @@ -446,7 +450,7 @@ void GBAVideoDeserialize(struct GBAVideo* video, const struct GBASerializedState break; case 2: video->event.callback = _startHblank; - video->stallMask = _calculateStallMask(video->p); + video->stallMask = _calculateStallMask(video->p, state->io[GBA_REG(DISPCNT)]); break; case 3: video->event.callback = _startHdraw; From 1a3873da671958901e1ea26cbef7e501f7761af9 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 25 Jun 2024 03:13:33 -0700 Subject: [PATCH 154/338] GBA Serialize: Fix some minor save state edge cases There are two edge cases fixed in this commit. The first one involves audio FIFO DMA state not being properly updated if the game reconfigured it between save and load. This doesn't happen often, but it could conceivably affect custom sound engines. The second case is the extremely rare case of a save state being taken directly after a DMA ending but before an open bus read. The chances of this happening are negligible, but it's still a bug regargless. --- CHANGES | 1 + include/mgba/internal/gba/serialize.h | 14 +++++++++++--- src/gba/audio.c | 12 ++++++++++++ src/gba/io.c | 2 ++ 4 files changed, 26 insertions(+), 3 deletions(-) diff --git a/CHANGES b/CHANGES index 6119069f38e..132d5ae4462 100644 --- a/CHANGES +++ b/CHANGES @@ -16,6 +16,7 @@ Emulation fixes: - GBA: Add baseline CP0 (Wii U VC) and CP1 (DCC) implementations - GBA GPIO: Fix gyro read-out start (fixes mgba.io/i/3141) - GBA I/O: Fix HALTCNT access behavior (fixes mgba.io/i/2309) + - GBA Serialize: Fix some minor save state edge cases - GBA SIO: Fix MULTI mode SIOCNT bit 7 writes on secondary GBAs (fixes mgba.io/i/3110) - GBA Video: Disable BG target 1 blending when OBJ blending (fixes mgba.io/i/2722) Other fixes: diff --git a/include/mgba/internal/gba/serialize.h b/include/mgba/internal/gba/serialize.h index 25bd170d63a..b31fd0f5a6c 100644 --- a/include/mgba/internal/gba/serialize.h +++ b/include/mgba/internal/gba/serialize.h @@ -20,7 +20,7 @@ extern MGBA_EXPORT const uint32_t GBASavestateVersion; mLOG_DECLARE_CATEGORY(GBA_STATE); /* Savestate format: - * 0x00000 - 0x00003: Version Magic (0x01000006) + * 0x00000 - 0x00003: Version Magic (0x01000007) * 0x00004 - 0x00007: BIOS checksum (e.g. 0xBAAE187F for official BIOS) * 0x00008 - 0x0000B: ROM CRC32 * 0x0000C - 0x0000F: Master cycles @@ -107,6 +107,9 @@ mLOG_DECLARE_CATEGORY(GBA_STATE); * | 0x001E0 - 0x001E3: Last sample * | 0x001E4 - 0x001E7: Additional audio flags * | bits 0 - 3: Current sample index + * | bits 4 - 5: Channel A DMA source + * | bits 6 - 7: Channel B DMA source + * | bits 8 - 31: Reserved * | 0x001E8 - 0x001EF: Reserved * 0x001F0 - 0x001FF: Video miscellaneous state * | 0x001F0 - 0x001F3: Reserved @@ -232,7 +235,8 @@ mLOG_DECLARE_CATEGORY(GBA_STATE); * 0x00370 - 0x0037F: Audio FIFO A samples * 0x00380 - 0x0038F: Audio FIFO B samples * 0x00390 - 0x003CF: Audio rendered samples - * 0x003D0 - 0x003FF: Reserved (leave zero) + * 0x003D0 - 0x003D3: Memory bus value + * 0x003D4 - 0x003FF: Reserved (leave zero) * 0x00400 - 0x007FF: I/O memory * 0x00800 - 0x00BFF: Palette * 0x00C00 - 0x00FFF: OAM @@ -250,6 +254,8 @@ DECL_BITS(GBASerializedAudioFlags, FIFOSamplesA, 7, 3); DECL_BITFIELD(GBASerializedAudioFlags2, uint32_t); DECL_BITS(GBASerializedAudioFlags2, SampleIndex, 0, 4); +DECL_BITS(GBASerializedAudioFlags2, ChASource, 4, 2); +DECL_BITS(GBASerializedAudioFlags2, ChBSource, 6, 2); DECL_BITFIELD(GBASerializedVideoFlags, uint32_t); DECL_BITS(GBASerializedVideoFlags, Mode, 0, 2); @@ -405,7 +411,9 @@ struct GBASerializedState { struct mStereoSample currentSamples[GBA_MAX_SAMPLES]; - uint32_t reserved[12]; + uint32_t bus; + + uint32_t reserved[11]; uint16_t io[GBA_SIZE_IO >> 1]; uint16_t pram[GBA_SIZE_PALETTE_RAM >> 1]; diff --git a/src/gba/audio.c b/src/gba/audio.c index e6b49538231..aca2f276561 100644 --- a/src/gba/audio.c +++ b/src/gba/audio.c @@ -475,6 +475,10 @@ void GBAAudioSerialize(const struct GBAAudio* audio, struct GBASerializedState* GBASerializedAudioFlags2 flags2 = 0; flags2 = GBASerializedAudioFlags2SetSampleIndex(flags2, audio->sampleIndex); + // This flag was introduced in 0.11 and will only ever be 0, 1 or 2, so we + // add 1 and use a non-zero value to mark its presence in the state file + flags2 = GBASerializedAudioFlags2SetChASource(flags2, audio->chA.dmaSource + 1); + flags2 = GBASerializedAudioFlags2SetChBSource(flags2, audio->chB.dmaSource + 1); STORE_32(flags2, 0, &state->audio.gbaFlags2); STORE_32(audio->sampleEvent.when - mTimingCurrentTime(&audio->p->timing), 0, &state->audio.nextSample); @@ -526,6 +530,14 @@ void GBAAudioDeserialize(struct GBAAudio* audio, const struct GBASerializedState GBASerializedAudioFlags2 flags2; LOAD_32(flags2, 0, &state->audio.gbaFlags2); audio->sampleIndex = GBASerializedAudioFlags2GetSampleIndex(flags2); + // This flag was introduced in 0.11 and will only ever be 0, 1 or 2, so we + // add 1 and use a non-zero value to mark its presence in the state file + if (GBASerializedAudioFlags2GetChASource(flags2) > 0) { + audio->chA.dmaSource = GBASerializedAudioFlags2GetChASource(flags2) - 1; + } + if (GBASerializedAudioFlags2GetChBSource(flags2) > 0) { + audio->chB.dmaSource = GBASerializedAudioFlags2GetChBSource(flags2) - 1; + } uint32_t when; LOAD_32(when, 0, &state->audio.nextSample); diff --git a/src/gba/io.c b/src/gba/io.c index 184146511f7..397eb925366 100644 --- a/src/gba/io.c +++ b/src/gba/io.c @@ -941,6 +941,7 @@ void GBAIOSerialize(struct GBA* gba, struct GBASerializedState* state) { STORE_32(gba->memory.dmaTransferRegister, 0, &state->dmaTransferRegister); STORE_32(gba->dmaPC, 0, &state->dmaBlockPC); + STORE_32(gba->bus, 0, &state->bus); GBAHardwareSerialize(&gba->memory.hw, state); } @@ -987,6 +988,7 @@ void GBAIODeserialize(struct GBA* gba, const struct GBASerializedState* state) { LOAD_32(gba->memory.dmaTransferRegister, 0, &state->dmaTransferRegister); LOAD_32(gba->dmaPC, 0, &state->dmaBlockPC); + LOAD_32(gba->bus, 0, &state->bus); GBADMAUpdate(gba); GBAHardwareDeserialize(&gba->memory.hw, state); From a4c2571d981a9aa9e71bbfd420e350ad3f65a044 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 25 Jun 2024 03:43:22 -0700 Subject: [PATCH 155/338] GBA Audio: Fix crash if audio FIFOs and timers get out of sync --- CHANGES | 1 + src/gba/audio.c | 3 +++ 2 files changed, 4 insertions(+) diff --git a/CHANGES b/CHANGES index 132d5ae4462..c73b2528b85 100644 --- a/CHANGES +++ b/CHANGES @@ -23,6 +23,7 @@ Other fixes: - Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963) - Debugger: Fix writing to specific segment in command-line debugger - GB: Fix uninitialized save data when loading undersized temporary saves + - GBA Audio: Fix crash if audio FIFOs and timers get out of sync - GBA Memory: Let raw access read high MMIO addresses - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) - Qt: Fix potential crash when configuring shortcuts diff --git a/src/gba/audio.c b/src/gba/audio.c index aca2f276561..25e400b199d 100644 --- a/src/gba/audio.c +++ b/src/gba/audio.c @@ -321,6 +321,9 @@ void GBAAudioSampleFIFO(struct GBAAudio* audio, int fifoId, int32_t cycles) { int bits = 2 << GBARegisterSOUNDBIASGetResolution(audio->soundbias); until += 1 << (9 - GBARegisterSOUNDBIASGetResolution(audio->soundbias)); until >>= 9 - GBARegisterSOUNDBIASGetResolution(audio->soundbias); + if (UNLIKELY(bits < until)) { + until = bits; + } int i; for (i = bits - until; i < bits; ++i) { channel->samples[i] = channel->internalSample; From 79193b914bdd2221b7d5222ab64750d54fccb339 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 25 Jun 2024 04:08:47 -0700 Subject: [PATCH 156/338] GBA Audio: Fix crash in audio subsampling if timing lockstep breaks --- CHANGES | 1 + include/mgba/internal/gba/audio.h | 2 +- src/gba/audio.c | 3 +++ 3 files changed, 5 insertions(+), 1 deletion(-) diff --git a/CHANGES b/CHANGES index c73b2528b85..a0b87e214e1 100644 --- a/CHANGES +++ b/CHANGES @@ -24,6 +24,7 @@ Other fixes: - Debugger: Fix writing to specific segment in command-line debugger - GB: Fix uninitialized save data when loading undersized temporary saves - GBA Audio: Fix crash if audio FIFOs and timers get out of sync + - GBA Audio: Fix crash in audio subsampling if timing lockstep breaks - GBA Memory: Let raw access read high MMIO addresses - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) - Qt: Fix potential crash when configuring shortcuts diff --git a/include/mgba/internal/gba/audio.h b/include/mgba/internal/gba/audio.h index 5b5db3a621b..fba5090bf62 100644 --- a/include/mgba/internal/gba/audio.h +++ b/include/mgba/internal/gba/audio.h @@ -80,7 +80,7 @@ struct GBAAudio { int32_t sampleInterval; int32_t lastSample; - int sampleIndex; + unsigned sampleIndex; struct mStereoSample currentSamples[GBA_MAX_SAMPLES]; bool forceDisableChA; diff --git a/src/gba/audio.c b/src/gba/audio.c index 25e400b199d..a6ebafbae6b 100644 --- a/src/gba/audio.c +++ b/src/gba/audio.c @@ -232,6 +232,9 @@ void GBAAudioWriteSOUNDBIAS(struct GBAAudio* audio, uint16_t value) { if (oldSampleInterval != audio->sampleInterval) { timestamp -= audio->lastSample; audio->sampleIndex = timestamp >> (9 - GBARegisterSOUNDBIASGetResolution(value)); + if (audio->sampleIndex >= GBA_MAX_SAMPLES) { + audio->sampleIndex = 0; + } if (audio->p->stream && audio->p->stream->audioRateChanged) { audio->p->stream->audioRateChanged(audio->p->stream, GBA_ARM7TDMI_FREQUENCY / audio->sampleInterval); } From a824989e5a1ecf32775d7d33a0ae47a86b28c7f4 Mon Sep 17 00:00:00 2001 From: oltolm Date: Tue, 30 Apr 2024 19:01:52 +0200 Subject: [PATCH 157/338] fix shortcuts --- src/platform/qt/KeyEditor.cpp | 49 +++++------------------------------ src/platform/qt/KeyEditor.h | 2 +- 2 files changed, 7 insertions(+), 44 deletions(-) diff --git a/src/platform/qt/KeyEditor.cpp b/src/platform/qt/KeyEditor.cpp index 50702da731c..818b6c703d4 100644 --- a/src/platform/qt/KeyEditor.cpp +++ b/src/platform/qt/KeyEditor.cpp @@ -41,7 +41,7 @@ void KeyEditor::setValue(int key) { if (m_button) { updateButtonText(); } else { - if (key < 0) { + if (key == Qt::Key_unknown) { setText(tr("---")); } else { setText(keyName(key)); @@ -78,7 +78,7 @@ void KeyEditor::setValueHat(int hat, GamepadHatEvent::Direction direction) { void KeyEditor::clearButton() { m_button = true; - setValue(-1); + setValue(Qt::Key_unknown); } void KeyEditor::clearAxis() { @@ -106,48 +106,11 @@ QSize KeyEditor::sizeHint() const { void KeyEditor::keyPressEvent(QKeyEvent* event) { if (!m_button) { - if (m_key < 0 || !m_lastKey.isActive()) { - m_key = 0; + if (!m_lastKey.isActive()) { + m_key = Qt::Key_unknown; } m_lastKey.start(KEY_TIME); - if (m_key) { - if (ShortcutController::isModifierKey(m_key)) { - switch (event->key()) { - case Qt::Key_Shift: - setValue(Qt::ShiftModifier); - break; - case Qt::Key_Control: - setValue(Qt::ControlModifier); - break; - case Qt::Key_Alt: - setValue(Qt::AltModifier); - break; - case Qt::Key_Meta: - setValue(Qt::MetaModifier); - break; - } - } - if (ShortcutController::isModifierKey(event->key())) { - switch (event->key()) { - case Qt::Key_Shift: - setValue(m_key | Qt::ShiftModifier); - break; - case Qt::Key_Control: - setValue(m_key | Qt::ControlModifier); - break; - case Qt::Key_Alt: - setValue(m_key | Qt::AltModifier); - break; - case Qt::Key_Meta: - setValue(m_key | Qt::MetaModifier); - break; - } - } else { - setValue(event->key() | (m_key & (Qt::ShiftModifier | Qt::ControlModifier | Qt::AltModifier | Qt::MetaModifier))); - } - } else { - setValue(event->key()); - } + setValue(ShortcutController::isModifierKey(event->key()) ? event->modifiers() : event->key() | event->modifiers()); } event->accept(); } @@ -213,7 +176,7 @@ void KeyEditor::updateButtonText() { break; } } - if (m_key >= 0) { + if (m_key != Qt::Key_unknown) { std::shared_ptr gamepad; if (m_controller && m_controller->gamepadDriver()) { gamepad = m_controller->gamepadDriver()->activeGamepad(); diff --git a/src/platform/qt/KeyEditor.h b/src/platform/qt/KeyEditor.h index 93af927ac98..66599ad60c6 100644 --- a/src/platform/qt/KeyEditor.h +++ b/src/platform/qt/KeyEditor.h @@ -57,7 +57,7 @@ public slots: void updateButtonText(); - int m_key = -1; + int m_key = Qt::Key_unknown; int m_axis = -1; int m_hat = -1; bool m_button = false; From 916fa1dba0a0452a0db9c870f6fe7ce2133b868a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 1 Jul 2024 00:51:15 -0700 Subject: [PATCH 158/338] CMake: Fix compile flags for docgen --- CMakeLists.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/CMakeLists.txt b/CMakeLists.txt index 1742cb8053b..78fddfce4ac 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1014,6 +1014,7 @@ endif() if(ENABLE_SCRIPTING AND BUILD_DOCGEN) add_executable(docgen ${CMAKE_CURRENT_SOURCE_DIR}/src/tools/docgen.c) target_link_libraries(docgen ${OS_LIB} ${PLATFORM_LIBRARY} ${BINARY_NAME}) + set_target_properties(docgen PROPERTIES COMPILE_DEFINITIONS "${OS_DEFINES};${FUNCTION_DEFINES};${FEATURE_DEFINES}") endif() if(BUILD_MAINTAINER_TOOLS) From 0a57aca1a5c6c75eb68abba79d0e487968655d4a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 1 Jul 2024 20:45:26 -0700 Subject: [PATCH 159/338] Qt: Fix closure argument types --- src/platform/qt/input/SDLInputDriver.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/platform/qt/input/SDLInputDriver.cpp b/src/platform/qt/input/SDLInputDriver.cpp index 402b92a1239..620602f034d 100644 --- a/src/platform/qt/input/SDLInputDriver.cpp +++ b/src/platform/qt/input/SDLInputDriver.cpp @@ -159,7 +159,7 @@ void SDLInputDriver::updateGamepads() { m_gamepads.removeAt(i); --i; } - std::sort(m_gamepads.begin(), m_gamepads.end(), [](const auto& a, const auto b) { + std::sort(m_gamepads.begin(), m_gamepads.end(), [](const auto& a, const auto& b) { return a->m_index < b->m_index; }); @@ -173,7 +173,7 @@ void SDLInputDriver::updateGamepads() { } m_gamepads.append(std::make_shared(this, i)); } - std::sort(m_gamepads.begin(), m_gamepads.end(), [](const auto& a, const auto b) { + std::sort(m_gamepads.begin(), m_gamepads.end(), [](const auto& a, const auto& b) { return a->m_index < b->m_index; }); } From f394c51a750b550cbfd536ef5df12d4e168b3f59 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 1 Jul 2024 20:52:04 -0700 Subject: [PATCH 160/338] Qt: Fix some controllers with multiple players (e.g. Mayflash GC adapter) getting duplicated --- src/platform/qt/input/SDLInputDriver.cpp | 6 +++--- src/platform/qt/input/SDLInputDriver.h | 1 + 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/src/platform/qt/input/SDLInputDriver.cpp b/src/platform/qt/input/SDLInputDriver.cpp index 620602f034d..792c84834cf 100644 --- a/src/platform/qt/input/SDLInputDriver.cpp +++ b/src/platform/qt/input/SDLInputDriver.cpp @@ -249,6 +249,7 @@ SDLGamepad::SDLGamepad(SDLInputDriver* driver, int index, QObject* parent) #if SDL_VERSION_ATLEAST(2, 0, 0) SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, m_index)->joystick; SDL_JoystickGetGUIDString(SDL_JoystickGetGUID(joystick), m_guid, sizeof(m_guid)); + m_id = SDL_JoystickInstanceID(joystick); #endif } @@ -395,11 +396,10 @@ QString SDLGamepad::visibleName() const { #if SDL_VERSION_ATLEAST(2, 0, 0) bool SDLGamepad::updateIndex() { - char guid[34]; for (size_t i = 0; i < SDL_JoystickListSize(&s_sdlEvents.joysticks); ++i) { SDL_Joystick* joystick = SDL_JoystickListGetPointer(&s_sdlEvents.joysticks, i)->joystick; - SDL_JoystickGetGUIDString(SDL_JoystickGetGUID(joystick), guid, sizeof(guid)); - if (memcmp(guid, m_guid, 33) == 0) { + SDL_JoystickID id = SDL_JoystickInstanceID(joystick); + if (id == m_id) { m_index = i; return true; } diff --git a/src/platform/qt/input/SDLInputDriver.h b/src/platform/qt/input/SDLInputDriver.h index 217dc40a7e5..70c7eed177f 100644 --- a/src/platform/qt/input/SDLInputDriver.h +++ b/src/platform/qt/input/SDLInputDriver.h @@ -109,6 +109,7 @@ Q_OBJECT size_t m_index; #if SDL_VERSION_ATLEAST(2, 0, 0) char m_guid[34]{}; + SDL_JoystickID m_id; #endif bool verify() const; From bdffa83e6b57e879cdbe113771124f7a088e5e30 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 7 Jul 2024 11:03:06 -0700 Subject: [PATCH 161/338] GB, GBA Core: Fix memory leak if reloading debug symbols Also fix loading an ELF if the current seek is not 0 --- CHANGES | 1 + src/gb/core.c | 4 +++- src/gba/core.c | 11 ++++++++++- 3 files changed, 14 insertions(+), 2 deletions(-) diff --git a/CHANGES b/CHANGES index a0b87e214e1..5f82de6434d 100644 --- a/CHANGES +++ b/CHANGES @@ -23,6 +23,7 @@ Other fixes: - Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963) - Debugger: Fix writing to specific segment in command-line debugger - GB: Fix uninitialized save data when loading undersized temporary saves + - GB, GBA Core: Fix memory leak if reloading debug symbols - GBA Audio: Fix crash if audio FIFOs and timers get out of sync - GBA Audio: Fix crash in audio subsampling if timing lockstep breaks - GBA Memory: Let raw access read high MMIO addresses diff --git a/src/gb/core.c b/src/gb/core.c index 9dbf36bc1e6..4e8351fc6e9 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -1107,7 +1107,9 @@ static void _GBCoreDetachDebugger(struct mCore* core) { } static void _GBCoreLoadSymbols(struct mCore* core, struct VFile* vf) { - core->symbolTable = mDebuggerSymbolTableCreate(); + if (!core->symbolTable) { + core->symbolTable = mDebuggerSymbolTableCreate(); + } #ifdef ENABLE_VFS if (!vf && core->dirs.base) { vf = mDirectorySetOpenSuffix(&core->dirs, core->dirs.base, ".sym", O_RDONLY); diff --git a/src/gba/core.c b/src/gba/core.c index 256aebdabc9..8e44990b5cd 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -1243,7 +1243,14 @@ static void _GBACoreDetachDebugger(struct mCore* core) { static void _GBACoreLoadSymbols(struct mCore* core, struct VFile* vf) { bool closeAfter = false; - core->symbolTable = mDebuggerSymbolTableCreate(); + if (!core->symbolTable) { + core->symbolTable = mDebuggerSymbolTableCreate(); + } + off_t seek; + if (vf) { + seek = vf->seek(vf, 0, SEEK_CUR); + vf->seek(vf, 0, SEEK_SET); + } #ifdef ENABLE_VFS #ifdef USE_ELF if (!vf && core->dirs.base) { @@ -1273,6 +1280,8 @@ static void _GBACoreLoadSymbols(struct mCore* core, struct VFile* vf) { } if (closeAfter) { vf->close(vf); + } else { + vf->seek(vf, seek, SEEK_SET); } } From 5ebf3822cc22998c18acca507207f5cdeba69247 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 7 Jul 2024 11:08:29 -0700 Subject: [PATCH 162/338] Debugger: Remove redundant ifdef --- src/debugger/cli-debugger.c | 2 -- 1 file changed, 2 deletions(-) diff --git a/src/debugger/cli-debugger.c b/src/debugger/cli-debugger.c index b5a6595d354..c21d17a7203 100644 --- a/src/debugger/cli-debugger.c +++ b/src/debugger/cli-debugger.c @@ -1427,9 +1427,7 @@ static void _loadSymbols(struct CLIDebugger* debugger, struct CLIDebugVector* dv #ifdef USE_ELF struct ELF* elf = ELFOpen(vf); if (elf) { -#ifdef ENABLE_DEBUGGERS mCoreLoadELFSymbols(symbolTable, elf); -#endif ELFClose(elf); } else #endif From 4c161ff4df002e5810eb46d9af030434ca66f53e Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 7 Jul 2024 11:13:32 -0700 Subject: [PATCH 163/338] GBA Core: Fix loading symbols from ELF files if the file doesn't end with .elf --- CHANGES | 1 + src/gba/core.c | 11 +++++++++++ 2 files changed, 12 insertions(+) diff --git a/CHANGES b/CHANGES index 5f82de6434d..ff9c74489c4 100644 --- a/CHANGES +++ b/CHANGES @@ -26,6 +26,7 @@ Other fixes: - GB, GBA Core: Fix memory leak if reloading debug symbols - GBA Audio: Fix crash if audio FIFOs and timers get out of sync - GBA Audio: Fix crash in audio subsampling if timing lockstep breaks + - GBA Core: Fix loading symbols from ELF files if the file doesn't end with .elf - GBA Memory: Let raw access read high MMIO addresses - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) - Qt: Fix potential crash when configuring shortcuts diff --git a/src/gba/core.c b/src/gba/core.c index 8e44990b5cd..6b8d15f1dcb 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -1242,6 +1242,7 @@ static void _GBACoreDetachDebugger(struct mCore* core) { } static void _GBACoreLoadSymbols(struct mCore* core, struct VFile* vf) { + struct GBA* gba = core->board; bool closeAfter = false; if (!core->symbolTable) { core->symbolTable = mDebuggerSymbolTableCreate(); @@ -1263,6 +1264,16 @@ static void _GBACoreLoadSymbols(struct mCore* core, struct VFile* vf) { vf = mDirectorySetOpenSuffix(&core->dirs, core->dirs.base, ".sym", O_RDONLY); } #endif + if (!vf && gba->mbVf) { + vf = gba->mbVf; + seek = vf->seek(vf, 0, SEEK_CUR); + vf->seek(vf, 0, SEEK_SET); + } + if (!vf && gba->romVf) { + vf = gba->romVf; + seek = vf->seek(vf, 0, SEEK_CUR); + vf->seek(vf, 0, SEEK_SET); + } if (!vf) { return; } From 0484cd5d3162fc252720a998910ce92d0a0f2640 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 7 Jul 2024 12:24:24 -0700 Subject: [PATCH 164/338] GBA: Remove unused field --- include/mgba/internal/gba/gba.h | 1 - 1 file changed, 1 deletion(-) diff --git a/include/mgba/internal/gba/gba.h b/include/mgba/internal/gba/gba.h index 83246ff981e..cc340d76024 100644 --- a/include/mgba/internal/gba/gba.h +++ b/include/mgba/internal/gba/gba.h @@ -81,7 +81,6 @@ struct GBA { struct GBATimer timers[4]; - int springIRQ; struct mTimingEvent irqEvent; uint32_t biosChecksum; From 9b598d2fe4c5ae49180fd381c742e5cb8a0973f0 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 11 Jul 2024 14:09:35 -0700 Subject: [PATCH 165/338] GBA Core: Fix crash after loading debug symbols (fixes #3254) --- src/gba/core.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/gba/core.c b/src/gba/core.c index 6b8d15f1dcb..11b1ccfc4ed 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -1265,11 +1265,13 @@ static void _GBACoreLoadSymbols(struct mCore* core, struct VFile* vf) { } #endif if (!vf && gba->mbVf) { + closeAfter = false; vf = gba->mbVf; seek = vf->seek(vf, 0, SEEK_CUR); vf->seek(vf, 0, SEEK_SET); } if (!vf && gba->romVf) { + closeAfter = false; vf = gba->romVf; seek = vf->seek(vf, 0, SEEK_CUR); vf->seek(vf, 0, SEEK_SET); From d1ab52112ae82392f5afbfcd4bcf5f34f35603e8 Mon Sep 17 00:00:00 2001 From: Adam Higerd Date: Fri, 12 Jul 2024 19:15:45 -0500 Subject: [PATCH 166/338] Don't try to load non-.sym files as ARMIPS symbols --- src/gba/core.c | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/gba/core.c b/src/gba/core.c index 11b1ccfc4ed..e05767dd654 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -1260,8 +1260,12 @@ static void _GBACoreLoadSymbols(struct mCore* core, struct VFile* vf) { } #endif if (!vf && core->dirs.base) { - closeAfter = true; vf = mDirectorySetOpenSuffix(&core->dirs, core->dirs.base, ".sym", O_RDONLY); + if (vf) { + mDebuggerLoadARMIPSSymbols(core->symbolTable, vf); + vf->close(vf); + } + return; } #endif if (!vf && gba->mbVf) { @@ -1286,11 +1290,8 @@ static void _GBACoreLoadSymbols(struct mCore* core, struct VFile* vf) { mCoreLoadELFSymbols(core->symbolTable, elf); #endif ELFClose(elf); - } else -#endif - { - mDebuggerLoadARMIPSSymbols(core->symbolTable, vf); } +#endif if (closeAfter) { vf->close(vf); } else { From eb1b5718c3d69cc3778865a0b6b59e55a0807766 Mon Sep 17 00:00:00 2001 From: Adam Higerd Date: Fri, 12 Jul 2024 19:26:42 -0500 Subject: [PATCH 167/338] Fix misplaced return in previous PR --- src/gba/core.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gba/core.c b/src/gba/core.c index e05767dd654..1f39afea692 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -1264,8 +1264,8 @@ static void _GBACoreLoadSymbols(struct mCore* core, struct VFile* vf) { if (vf) { mDebuggerLoadARMIPSSymbols(core->symbolTable, vf); vf->close(vf); + return; } - return; } #endif if (!vf && gba->mbVf) { From 09f456484cb401856d5dda1af5b80a659b7c2097 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 19 Jul 2024 19:42:38 -0700 Subject: [PATCH 168/338] GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1 --- CHANGES | 1 + src/gb/serialize.c | 7 +++++++ 2 files changed, 8 insertions(+) diff --git a/CHANGES b/CHANGES index ff9c74489c4..9af2528d96a 100644 --- a/CHANGES +++ b/CHANGES @@ -24,6 +24,7 @@ Other fixes: - Debugger: Fix writing to specific segment in command-line debugger - GB: Fix uninitialized save data when loading undersized temporary saves - GB, GBA Core: Fix memory leak if reloading debug symbols + - GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1 - GBA Audio: Fix crash if audio FIFOs and timers get out of sync - GBA Audio: Fix crash in audio subsampling if timing lockstep breaks - GBA Core: Fix loading symbols from ELF files if the file doesn't end with .elf diff --git a/src/gb/serialize.c b/src/gb/serialize.c index 0abdc1958f0..8f874d8eb82 100644 --- a/src/gb/serialize.c +++ b/src/gb/serialize.c @@ -122,6 +122,13 @@ bool GBDeserialize(struct GB* gb, const struct GBSerializedState* state) { mLOG(GB_STATE, WARN, "Savestate is corrupted: video y is out of range"); error = true; } + + GBSerializedVideoFlags videoFlags = state->video.flags; + if (check16 >= GB_VIDEO_VERTICAL_PIXELS && GBSerializedVideoFlagsGetMode(videoFlags) != 1) { + mLOG(GB_STATE, WARN, "Savestate is corrupted: video y is in vblank but mode is not vblank"); + error = true; + } + LOAD_16LE(ucheck16, 0, &state->memory.dmaDest); if (ucheck16 + state->memory.dmaRemaining > GB_SIZE_OAM) { mLOG(GB_STATE, WARN, "Savestate is corrupted: DMA destination is out of range"); From fde15b6e7d4fcd858ab4d59fc9e83752abe2b982 Mon Sep 17 00:00:00 2001 From: jmjoy Date: Fri, 9 Aug 2024 10:52:47 +0800 Subject: [PATCH 169/338] Remove SDL_WINDOW_OPENGL flag in mSDLSWInit --- src/platform/sdl/sw-sdl2.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/platform/sdl/sw-sdl2.c b/src/platform/sdl/sw-sdl2.c index 75ad1c2ead5..734ee903c2c 100644 --- a/src/platform/sdl/sw-sdl2.c +++ b/src/platform/sdl/sw-sdl2.c @@ -22,7 +22,7 @@ void mSDLSWCreate(struct mSDLRenderer* renderer) { bool mSDLSWInit(struct mSDLRenderer* renderer) { unsigned width, height; renderer->core->baseVideoSize(renderer->core, &width, &height); - renderer->window = SDL_CreateWindow(projectName, SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, renderer->viewportWidth, renderer->viewportHeight, SDL_WINDOW_OPENGL | (SDL_WINDOW_FULLSCREEN_DESKTOP * renderer->player.fullscreen)); + renderer->window = SDL_CreateWindow(projectName, SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, renderer->viewportWidth, renderer->viewportHeight, SDL_WINDOW_FULLSCREEN_DESKTOP * renderer->player.fullscreen); SDL_GetWindowSize(renderer->window, &renderer->viewportWidth, &renderer->viewportHeight); renderer->player.window = renderer->window; renderer->sdlRenderer = SDL_CreateRenderer(renderer->window, -1, SDL_RENDERER_ACCELERATED | SDL_RENDERER_PRESENTVSYNC); From ff216ad83babf27476783b14ec3131517a7aa745 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 10 Aug 2024 21:20:08 -0700 Subject: [PATCH 170/338] Res: Update nointro.dat --- res/nointro.dat | 25671 +++++++++++++++++++++++++--------------------- 1 file changed, 14162 insertions(+), 11509 deletions(-) diff --git a/res/nointro.dat b/res/nointro.dat index d63e3f818d7..48047026f68 100644 --- a/res/nointro.dat +++ b/res/nointro.dat @@ -1,7 +1,7 @@ clrmamepro ( name "Nintendo - Game Boy Advance" description "Nintendo - Game Boy Advance" - version 20240104-012251 + version 20240807-214821 author "aci68, Arctic Circle System, Aringon, Bent, BigFred, bikerspade, C. V. Reynolds, chillerecke, DeadSkullzJr, Densetsu, DeriLoko3, einstein95, ElBarto, Enker, FakeShemp, Flashfire42, fuzzball, Gefflon, Hiccup, hking0036, hydr0x, InternalLoss, Jack, jimmsu, Just001Kim, kazumi213, Larsenv, Lesserkuma, Madeline, MeguCocoa, Money_114, NESBrew12, niemand, nnssxx, norkmetnoil577, NovaAurora, omonim2007, Powerpuff, PPLToast, Prominos, Psychofox11, psykopat, rarenight, relax, RetroGamer, Rifu, sCZther, SonGoku, Tauwasser, Tescu, togemet2, ufocrossing, Vallaine01, Whovian9369, xprism, xuom2, zg" homepage No-Intro url "https://www.no-intro.org" @@ -597,7 +597,7 @@ game ( game ( name "2 in 1 Game Pack - Spider-Man + Spider-Man 2 (USA) (En,Fr,De+En,Fr,De,Es)" description "2 in 1 Game Pack - Spider-Man + Spider-Man 2 (USA) (En,Fr,De+En,Fr,De,Es)" - rom ( name "2 in 1 Game Pack - Spider-Man + Spider-Man 2 (USA) (En,Fr,De+En,Fr,De,Es).gba" size 33554432 crc 0ae3637f sha1 8bc2b600a043b776bc61fe8c0f4007b4360545f9 ) + rom ( name "2 in 1 Game Pack - Spider-Man + Spider-Man 2 (USA) (En,Fr,De+En,Fr,De,Es).gba" size 33554432 crc 3abc30bd sha1 1438db8336bd6204ad81011a7ed2b2e04850326a ) ) game ( @@ -648,12 +648,6 @@ game ( rom ( name "2006 FIFA World Cup - Germany 2006 (USA, Europe) (En,Fr,De,Es,It).gba" size 8388608 crc 50ab4544 sha1 295580745787ba9593799213564484aaaa7fd463 flags verified ) ) -game ( - name "2048 Pool (World) (Aftermarket) (Unl)" - description "2048 Pool (World) (Aftermarket) (Unl)" - rom ( name "2048 Pool (World) (Aftermarket) (Unl).gba" size 203440 crc 9df6ae4f sha1 c93a9cf3502237b474e70de8dee274901ee7ecb2 ) -) - game ( name "2K Sports - Major League Baseball 2K7 (USA) (Beta)" description "2K Sports - Major League Baseball 2K7 (USA) (Beta)" @@ -711,7 +705,7 @@ game ( game ( name "3 Games in One! - Breakout + Centipede + Warlords (USA)" description "3 Games in One! - Breakout + Centipede + Warlords (USA)" - rom ( name "3 Games in One! - Breakout + Centipede + Warlords (USA).gba" size 4194304 crc 02e0cca4 sha1 e91e58c62363fb10dd4ffcaeb09c98ca6b9b5a77 ) + rom ( name "3 Games in One! - Breakout + Centipede + Warlords (USA).gba" size 4194304 crc 02e0cca4 sha1 e91e58c62363fb10dd4ffcaeb09c98ca6b9b5a77 flags verified ) ) game ( @@ -993,13 +987,13 @@ game ( game ( name "Adventures of Jimmy Neutron Boy Genius, The - Attack of the Twonkies (USA, Europe)" description "Adventures of Jimmy Neutron Boy Genius, The - Attack of the Twonkies (USA, Europe)" - rom ( name "Adventures of Jimmy Neutron Boy Genius, The - Attack of the Twonkies (USA, Europe).gba" size 4194304 crc d59d753b sha1 16ba112f07d02484febd554f902bb18776144186 ) + rom ( name "Adventures of Jimmy Neutron Boy Genius, The - Attack of the Twonkies (USA, Europe).gba" size 4194304 crc d59d753b sha1 16ba112f07d02484febd554f902bb18776144186 flags verified ) ) game ( name "Adventures of Jimmy Neutron Boy Genius, The - Jet Fusion (USA, Europe)" description "Adventures of Jimmy Neutron Boy Genius, The - Jet Fusion (USA, Europe)" - rom ( name "Adventures of Jimmy Neutron Boy Genius, The - Jet Fusion (USA, Europe).gba" size 4194304 crc 67756000 sha1 68778c93fc16d06b97462174d91035cb0d0d8bd5 ) + rom ( name "Adventures of Jimmy Neutron Boy Genius, The - Jet Fusion (USA, Europe).gba" size 4194304 crc 67756000 sha1 68778c93fc16d06b97462174d91035cb0d0d8bd5 flags verified ) ) game ( @@ -1075,9 +1069,9 @@ game ( ) game ( - name "Agoria - Ode to Fate (World) (Aftermarket) (Unl)" - description "Agoria - Ode to Fate (World) (Aftermarket) (Unl)" - rom ( name "Agoria - Ode to Fate (World) (Aftermarket) (Unl).gba" size 2725504 crc 67d3361f sha1 cb0b83b85a290c223cd3249b37ae7207d3efde06 ) + name "Agoria - Ode to Fate (World) (Unl)" + description "Agoria - Ode to Fate (World) (Unl)" + rom ( name "Agoria - Ode to Fate (World) (Unl).gba" size 2725504 crc 67d3361f sha1 cb0b83b85a290c223cd3249b37ae7207d3efde06 ) ) game ( @@ -1110,6 +1104,12 @@ game ( rom ( name "Aigle de Guerre, L' (France).gba" size 8388608 crc 36a0e152 sha1 567809bf35d62418a69e469d0cfa9993a889c030 ) ) +game ( + name "Airball (World) (v1.3) (Unl)" + description "Airball (World) (v1.3) (Unl)" + rom ( name "Airball (World) (v1.3) (Unl).gba" size 1365740 crc 52dac8c6 sha1 50c772f91fa431b8b3d01133762015e127d4f816 ) +) + game ( name "AirForce Delta II (Japan) (En,Ja,Fr,De)" description "AirForce Delta II (Japan) (En,Ja,Fr,De)" @@ -1185,7 +1185,7 @@ game ( game ( name "Alex Rider - Stormbreaker (USA)" description "Alex Rider - Stormbreaker (USA)" - rom ( name "Alex Rider - Stormbreaker (USA).gba" size 4194304 crc cca55dfd sha1 e9ba9d340701173ccd3a4d279630e1541ed96a73 ) + rom ( name "Alex Rider - Stormbreaker (USA).gba" size 4194304 crc cca55dfd sha1 e9ba9d340701173ccd3a4d279630e1541ed96a73 flags verified ) ) game ( @@ -1269,7 +1269,7 @@ game ( game ( name "American Idol (USA)" description "American Idol (USA)" - rom ( name "American Idol (USA).gba" size 16777216 crc f053ffbf sha1 13236689db1e2236673ae59c2a8ff84340a8a8c2 ) + rom ( name "American Idol (USA).gba" size 16777216 crc f053ffbf sha1 13236689db1e2236673ae59c2a8ff84340a8a8c2 flags verified ) ) game ( @@ -1302,72 +1302,6 @@ game ( rom ( name "Angelique (Japan).gba" size 4194304 crc c9d41f35 sha1 cf01dfc9f25c805b9a72524903f742f11570a8eb ) ) -game ( - name "Anguna - Warriors of Virtue (World) (v0.95) (Aftermarket) (Unl)" - description "Anguna - Warriors of Virtue (World) (v0.95) (Aftermarket) (Unl)" - rom ( name "Anguna - Warriors of Virtue (World) (v0.95) (Aftermarket) (Unl).gba" size 1710888 crc 3346891f sha1 270c426705df767a4ad2dc69d039842442f779b2 flags verified ) -) - -game ( - name "Anguna - Warriors of Virtue (World) (2021-02-28) (Patreon) (Aftermarket) (Unl)" - description "Anguna - Warriors of Virtue (World) (2021-02-28) (Patreon) (Aftermarket) (Unl)" - rom ( name "Anguna - Warriors of Virtue (World) (2021-02-28) (Patreon) (Aftermarket) (Unl).gba" size 1729120 crc a354d555 sha1 d7cd0ab9d622187d4ce55bf0c7f14a24ee781710 ) -) - -game ( - name "Anguna - Warriors of Virtue (World) (v0.95) (Itch.io) (Aftermarket) (Unl)" - description "Anguna - Warriors of Virtue (World) (v0.95) (Itch.io) (Aftermarket) (Unl)" - rom ( name "Anguna - Warriors of Virtue (World) (v0.95) (Itch.io) (Aftermarket) (Unl).gba" size 1775856 crc 41ea5b0b sha1 e351bc6a9046ec002fc2dfdee061047908bd4350 ) -) - -game ( - name "Anguna - Warriors of Virtue (World) (Retro-Bit Generations) (Aftermarket) (Unl)" - description "Anguna - Warriors of Virtue (World) (Retro-Bit Generations) (Aftermarket) (Unl)" - rom ( name "Anguna - Warriors of Virtue (World) (Retro-Bit Generations) (Aftermarket) (Unl).gba" size 1775660 crc a234813c sha1 ad904624bf198a164ba580eea326cd30fffebac8 ) -) - -game ( - name "Anguna - Warriors of Virtue (World) (Demo) (Aftermarket) (Unl)" - description "Anguna - Warriors of Virtue (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Anguna - Warriors of Virtue (World) (Demo) (Aftermarket) (Unl).gba" size 597104 crc 0a9098b4 sha1 0992fb6f38e49426adc834fb3831748a1caa1bc0 ) -) - -game ( - name "Anguna - Warriors of Virtue (World) (v2.0) (Demo) (Aftermarket) (Unl)" - description "Anguna - Warriors of Virtue (World) (v2.0) (Demo) (Aftermarket) (Unl)" - rom ( name "Anguna - Warriors of Virtue (World) (v2.0) (Demo) (Aftermarket) (Unl).gba" size 811840 crc 63c1cc2c sha1 faca8225ee20b8e5edb14e005af77b63c6f51446 ) -) - -game ( - name "Anguna - Warriors of Virtue (World) (v0.91) (Aftermarket) (Unl)" - description "Anguna - Warriors of Virtue (World) (v0.91) (Aftermarket) (Unl)" - rom ( name "Anguna - Warriors of Virtue (World) (v0.91) (Aftermarket) (Unl).gba" size 1714000 crc eebb016f sha1 008a9d06f78bccc540ca4ece4d1982de76f95901 ) -) - -game ( - name "Anguna - Warriors of Virtue (World) (v0.92) (Aftermarket) (Unl)" - description "Anguna - Warriors of Virtue (World) (v0.92) (Aftermarket) (Unl)" - rom ( name "Anguna - Warriors of Virtue (World) (v0.92) (Aftermarket) (Unl).gba" size 1710624 crc ba271987 sha1 04f1e79e79e894d8f45ed1ea2ff5aa67053f0ab3 ) -) - -game ( - name "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl)" - description "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl)" - rom ( name "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl).gba" size 1710624 crc df7108e3 sha1 bd267fd7e762acb8cd595e54bfd51a139864759e ) -) - -game ( - name "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl) (Alt)" - description "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl) (Alt)" - rom ( name "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl) (Alt).gba" size 1714000 crc 54ff2e56 sha1 0386315fc140db2a43a6f927c04de658bd800da9 ) -) - -game ( - name "Anguna - Warriors of Virtue (World) (v0.94) (Aftermarket) (Unl)" - description "Anguna - Warriors of Virtue (World) (v0.94) (Aftermarket) (Unl)" - rom ( name "Anguna - Warriors of Virtue (World) (v0.94) (Aftermarket) (Unl).gba" size 1710952 crc cb4e2768 sha1 a7297cf4ecffc1f93f86edde68e1ff42e8099f3b ) -) - game ( name "Animal Mania - Dokidoki Aishou Check (Japan)" description "Animal Mania - Dokidoki Aishou Check (Japan)" @@ -1405,15 +1339,15 @@ game ( ) game ( - name "Another World (Europe) (En,Fr) (v2.1) (Unl)" - description "Another World (Europe) (En,Fr) (v2.1) (Unl)" - rom ( name "Another World (Europe) (En,Fr) (v2.1) (Unl).gba" size 2010358 crc 86c4f772 sha1 41d39a0c34f72469dd3fbcc90190605b8ada93e6 ) + name "Another World (World) (En,Fr) (v2.1) (Unl)" + description "Another World (World) (En,Fr) (v2.1) (Unl)" + rom ( name "Another World (World) (En,Fr) (v2.1) (Unl).gba" size 2010358 crc 86c4f772 sha1 41d39a0c34f72469dd3fbcc90190605b8ada93e6 ) ) game ( - name "Another World (Europe) (Fr) (v1.2) (Unl)" - description "Another World (Europe) (Fr) (v1.2) (Unl)" - rom ( name "Another World (Europe) (Fr) (v1.2) (Unl).gba" size 1823864 crc 1a1397de sha1 5bcc5c9a633e2226411dd41f1a191b9fcc793d92 ) + name "Another World (World) (Fr) (v1.2) (Unl)" + description "Another World (World) (Fr) (v1.2) (Unl)" + rom ( name "Another World (World) (Fr) (v1.2) (Unl).gba" size 1823864 crc 1a1397de sha1 5bcc5c9a633e2226411dd41f1a191b9fcc793d92 ) ) game ( @@ -1446,22 +1380,16 @@ game ( rom ( name "Ao-Zora to Nakama-tachi - Yume no Bouken (Japan).gba" size 4194304 crc ad9af125 sha1 0e6c92477793ce495caa400899effb4f87384f3c ) ) -game ( - name "Apotris (World) (v3.4.5) (Aftermarket) (Unl)" - description "Apotris (World) (v3.4.5) (Aftermarket) (Unl)" - rom ( name "Apotris (World) (v3.4.5) (Aftermarket) (Unl).gba" size 4194304 crc 55ae4312 sha1 fb7142bcc30f71f187cc51b7fcbc5a3958374c6c ) -) - game ( name "Archer Maclean's 3D Pool (USA)" description "Archer Maclean's 3D Pool (USA)" - rom ( name "Archer Maclean's 3D Pool (USA).gba" size 4194304 crc 4202a9cd sha1 5b1dcab6984d454e3ed3f3fe107f43a645283c0f ) + rom ( name "Archer Maclean's 3D Pool (USA).gba" size 4194304 crc 4202a9cd sha1 5b1dcab6984d454e3ed3f3fe107f43a645283c0f flags verified ) ) game ( name "Arctic Tale (USA)" description "Arctic Tale (USA)" - rom ( name "Arctic Tale (USA).gba" size 4194304 crc 81397ac0 sha1 9654a5c6a40b946c35cc9e09aae48bdd47ea7692 ) + rom ( name "Arctic Tale (USA).gba" size 4194304 crc 81397ac0 sha1 9654a5c6a40b946c35cc9e09aae48bdd47ea7692 flags verified ) ) game ( @@ -1578,6 +1506,12 @@ game ( rom ( name "Atlantis - The Lost Empire (Europe) (En,Fr,De,Es,It,Nl).gba" size 4194304 crc b3948dbc sha1 93624eaa9a80cdb791bd14955b55dd7c58c4abbd ) ) +game ( + name "Atomic Betty (USA, Europe) (Beta)" + description "Atomic Betty (USA, Europe) (Beta)" + rom ( name "Atomic Betty (USA, Europe) (Beta).gba" size 8388608 crc b79472b8 sha1 1dfa6ad1bdc0ee52b4e53c78f29d92ec208db1b1 ) +) + game ( name "Atomic Betty (USA, Europe)" description "Atomic Betty (USA, Europe)" @@ -1585,9 +1519,9 @@ game ( ) game ( - name "Atomic Betty (USA, Europe) (Beta)" - description "Atomic Betty (USA, Europe) (Beta)" - rom ( name "Atomic Betty (USA, Europe) (Beta).gba" size 8388608 crc b79472b8 sha1 1dfa6ad1bdc0ee52b4e53c78f29d92ec208db1b1 ) + name "Atomix (World) (Unl)" + description "Atomix (World) (Unl)" + rom ( name "Atomix (World) (Unl).gba" size 934600 crc fc610889 sha1 ecf3848324a25fa57988f67167f0b58e648989ce ) ) game ( @@ -1647,7 +1581,7 @@ game ( game ( name "Azumanga Daiou Advance (Japan)" description "Azumanga Daiou Advance (Japan)" - rom ( name "Azumanga Daiou Advance (Japan).gba" size 8388608 crc 216704f6 sha1 95b266e8ecdae1938cd180f597e5f21cb86d8b96 ) + rom ( name "Azumanga Daiou Advance (Japan).gba" size 8388608 crc 216704f6 sha1 95b266e8ecdae1938cd180f597e5f21cb86d8b96 flags verified ) ) game ( @@ -1737,7 +1671,7 @@ game ( game ( name "Backyard Football 2006 (USA)" description "Backyard Football 2006 (USA)" - rom ( name "Backyard Football 2006 (USA).gba" size 4194304 crc db0723e3 sha1 53d134268d2fc973388861687e50f77cc4682941 ) + rom ( name "Backyard Football 2006 (USA).gba" size 4194304 crc db0723e3 sha1 53d134268d2fc973388861687e50f77cc4682941 flags verified ) ) game ( @@ -1827,7 +1761,7 @@ game ( game ( name "Banjo-Kazooie - Grunty's Revenge (Europe) (En,Fr,De)" description "Banjo-Kazooie - Grunty's Revenge (Europe) (En,Fr,De)" - rom ( name "Banjo-Kazooie - Grunty's Revenge (Europe) (En,Fr,De).gba" size 8388608 crc fb4f38e2 sha1 f335fede72cd0273fcce925a20ca272ede08c15b ) + rom ( name "Banjo-Kazooie - Grunty's Revenge (Europe) (En,Fr,De).gba" size 8388608 crc fb4f38e2 sha1 f335fede72cd0273fcce925a20ca272ede08c15b flags verified ) ) game ( @@ -1890,6 +1824,30 @@ game ( rom ( name "Barbie - The Princess and the Pauper (Europe) (En,Fr,De,Es,It,Nl).gba" size 4194304 crc 116194f2 sha1 779f2050efcd15cac8b70fedce5bd0ccb773f179 ) ) +game ( + name "Barbie and the Magic of Pegasus (USA) (Beta) (2005-01-21)" + description "Barbie and the Magic of Pegasus (USA) (Beta) (2005-01-21)" + rom ( name "Barbie and the Magic of Pegasus (USA) (Beta) (2005-01-21).gba" size 136680 crc ae6cf631 sha1 fb0548d72eff99b7dabdd34112e55f8bea6326ec ) +) + +game ( + name "Barbie and the Magic of Pegasus (USA) (Beta) (2005-02-18)" + description "Barbie and the Magic of Pegasus (USA) (Beta) (2005-02-18)" + rom ( name "Barbie and the Magic of Pegasus (USA) (Beta) (2005-02-18).gba" size 360672 crc bd807770 sha1 84a5686f5c5dee770e6b1bbbc1a60648387cf255 ) +) + +game ( + name "Barbie and the Magic of Pegasus (USA) (Beta) (2005-03-18)" + description "Barbie and the Magic of Pegasus (USA) (Beta) (2005-03-18)" + rom ( name "Barbie and the Magic of Pegasus (USA) (Beta) (2005-03-18).gba" size 1502628 crc 4b58b5d6 sha1 e822173e315138443e9fec509621dc88afcbcc0b ) +) + +game ( + name "Barbie and the Magic of Pegasus (USA) (Beta) (2005-04-15)" + description "Barbie and the Magic of Pegasus (USA) (Beta) (2005-04-15)" + rom ( name "Barbie and the Magic of Pegasus (USA) (Beta) (2005-04-15).gba" size 2837392 crc 46f21e41 sha1 74e261c56123806b8cbd31ed907fe25a5ad99b62 ) +) + game ( name "Barbie and the Magic of Pegasus (USA)" description "Barbie and the Magic of Pegasus (USA)" @@ -2046,6 +2004,18 @@ game ( rom ( name "Battle Network - Rockman EXE 2 (Japan).gba" size 8388608 crc 98e4f096 sha1 6ed31ea56328673ba9d87186a7d506c701508e28 ) ) +game ( + name "Battle Network - Rockman EXE 2 (Japan) (Rev 1) (Virtual Console)" + description "Battle Network - Rockman EXE 2 (Japan) (Rev 1) (Virtual Console)" + rom ( name "Battle Network - Rockman EXE 2 (Japan) (Rev 1) (Virtual Console).gba" size 8388608 crc 44d44721 sha1 1c2416dfb86936752c5f68861f6339feac21458f ) +) + +game ( + name "Battle Network - Rockman EXE 2 (World) (Ja) (Mega Man Battle Network Legacy Collection)" + description "Battle Network - Rockman EXE 2 (World) (Ja) (Mega Man Battle Network Legacy Collection)" + rom ( name "Battle Network - Rockman EXE 2 (World) (Ja) (Mega Man Battle Network Legacy Collection).gba" size 8388608 crc 046eed8d sha1 7f6e770282718813f1115b29ec502f77422ac300 ) +) + game ( name "Battle Network - Rockman EXE 2 (Japan) (Rev 1)" description "Battle Network - Rockman EXE 2 (Japan) (Rev 1)" @@ -2053,9 +2023,9 @@ game ( ) game ( - name "Battle Network - Rockman EXE 2 (Japan) (Rev 1) (Virtual Console)" - description "Battle Network - Rockman EXE 2 (Japan) (Rev 1) (Virtual Console)" - rom ( name "Battle Network - Rockman EXE 2 (Japan) (Rev 1) (Virtual Console).gba" size 8388608 crc 44d44721 sha1 1c2416dfb86936752c5f68861f6339feac21458f ) + name "Battle Network - Rockman EXE 3 (Japan) (Rev 1)" + description "Battle Network - Rockman EXE 3 (Japan) (Rev 1)" + rom ( name "Battle Network - Rockman EXE 3 (Japan) (Rev 1).gba" size 8388608 crc e48e6bc9 sha1 87e0ab10541eaaa5e9c01f7fad822a3e1bf52278 ) ) game ( @@ -2071,15 +2041,9 @@ game ( ) game ( - name "Battle Network - Rockman EXE 3 (Japan) (Rev 1)" - description "Battle Network - Rockman EXE 3 (Japan) (Rev 1)" - rom ( name "Battle Network - Rockman EXE 3 (Japan) (Rev 1).gba" size 8388608 crc e48e6bc9 sha1 87e0ab10541eaaa5e9c01f7fad822a3e1bf52278 ) -) - -game ( - name "Battle Network - Rockman EXE 3 - Black (Japan) (Promo)" - description "Battle Network - Rockman EXE 3 - Black (Japan) (Promo)" - rom ( name "Battle Network - Rockman EXE 3 - Black (Japan) (Promo).gba" size 8388608 crc 1f13c41f sha1 ff65af8fea15ecf5a556595efe414d1211a9ab4e ) + name "Battle Network - Rockman EXE 3 - Black (Japan) (Rev 1)" + description "Battle Network - Rockman EXE 3 - Black (Japan) (Rev 1)" + rom ( name "Battle Network - Rockman EXE 3 - Black (Japan) (Rev 1).gba" size 8388608 crc fd57493b sha1 e089a2254496a4791666c8122585cb785e3012fc ) ) game ( @@ -2089,9 +2053,9 @@ game ( ) game ( - name "Battle Network - Rockman EXE 3 - Black (Japan) (Rev 1)" - description "Battle Network - Rockman EXE 3 - Black (Japan) (Rev 1)" - rom ( name "Battle Network - Rockman EXE 3 - Black (Japan) (Rev 1).gba" size 8388608 crc fd57493b sha1 e089a2254496a4791666c8122585cb785e3012fc ) + name "Battle Network - Rockman EXE 3 - Black (Japan) (Promo)" + description "Battle Network - Rockman EXE 3 - Black (Japan) (Promo)" + rom ( name "Battle Network - Rockman EXE 3 - Black (Japan) (Promo).gba" size 8388608 crc 1f13c41f sha1 ff65af8fea15ecf5a556595efe414d1211a9ab4e ) ) game ( @@ -2121,7 +2085,7 @@ game ( game ( name "BattleBots - Design & Destroy (USA)" description "BattleBots - Design & Destroy (USA)" - rom ( name "BattleBots - Design & Destroy (USA).gba" size 4194304 crc 8d5ffbca sha1 635986e584ebdc347c77eb45b1370a1206fbd7d7 ) + rom ( name "BattleBots - Design & Destroy (USA).gba" size 4194304 crc 8d5ffbca sha1 635986e584ebdc347c77eb45b1370a1206fbd7d7 flags verified ) ) game ( @@ -2193,7 +2157,7 @@ game ( game ( name "Beyblade V-Force - Ultimate Blader Jam (USA)" description "Beyblade V-Force - Ultimate Blader Jam (USA)" - rom ( name "Beyblade V-Force - Ultimate Blader Jam (USA).gba" size 8388608 crc 4a49272b sha1 cd527c8c24e20e33913fc45199e64b3e6138a6e5 ) + rom ( name "Beyblade V-Force - Ultimate Blader Jam (USA).gba" size 8388608 crc 4a49272b sha1 cd527c8c24e20e33913fc45199e64b3e6138a6e5 flags verified ) ) game ( @@ -2262,6 +2226,12 @@ game ( rom ( name "Bionicle - Matoran Adventures (USA, Europe) (En,Fr,De,Es,It,Nl,Sv,Da).gba" size 4194304 crc daec2264 sha1 a478f5880c484a70a5fdefc42f73aae2eb948168 flags verified ) ) +game ( + name "Bionicle - Maze of Shadows (Europe) (En,De)" + description "Bionicle - Maze of Shadows (Europe) (En,De)" + rom ( name "Bionicle - Maze of Shadows (Europe) (En,De).gba" size 8388608 crc bce2d68e sha1 7ff9811e2bd40b24da02be194213d41a0885aa34 ) +) + game ( name "Bionicle - Maze of Shadows (USA)" description "Bionicle - Maze of Shadows (USA)" @@ -2274,12 +2244,6 @@ game ( rom ( name "Bionicle - Maze of Shadows (Europe) (En,De) (Rev 1).gba" size 8388608 crc 9d66ec5e sha1 430c7dac6f7dd989294a8ac1cfdabd9e74b3e682 ) ) -game ( - name "Bionicle - Maze of Shadows (Europe) (En,De)" - description "Bionicle - Maze of Shadows (Europe) (En,De)" - rom ( name "Bionicle - Maze of Shadows (Europe) (En,De).gba" size 8388608 crc bce2d68e sha1 7ff9811e2bd40b24da02be194213d41a0885aa34 ) -) - game ( name "Bionicle Heroes (USA) (En,Fr,De,Es,It,Da)" description "Bionicle Heroes (USA) (En,Fr,De,Es,It,Da)" @@ -2352,6 +2316,12 @@ game ( rom ( name "Black Matrix Zero (Japan).gba" size 8388608 crc 2b2afa2e sha1 697f85513ab5704b8b1d554e087a45bfdb92ec33 ) ) +game ( + name "Black Sigil - Blade of the Exiled (USA) (Proto) (2007-02-10)" + description "Black Sigil - Blade of the Exiled (USA) (Proto) (2007-02-10)" + rom ( name "Black Sigil - Blade of the Exiled (USA) (Proto) (2007-02-10).gba" size 12478504 crc 010035a8 sha1 567e4efa496eabbf1db285e0ec02a8da8a8c07a3 ) +) + game ( name "Blackthorne (USA)" description "Blackthorne (USA)" @@ -2376,12 +2346,6 @@ game ( rom ( name "Bleach Advance - Kurenai ni Somaru Soul Society (Japan).gba" size 33554432 crc 9de5cd08 sha1 29d24c38d3ec8bbe9d81df2f5ff61c4a2dadcee4 ) ) -game ( - name "Blender Bros. (World) (Aftermarket) (Unl)" - description "Blender Bros. (World) (Aftermarket) (Unl)" - rom ( name "Blender Bros. (World) (Aftermarket) (Unl).gba" size 8388608 crc 440f2f06 sha1 8f9ca62306b7ab56d8da45673d7b7d0eb4c349c5 ) -) - game ( name "Blender Bros. (USA)" description "Blender Bros. (USA)" @@ -2415,7 +2379,7 @@ game ( game ( name "Board Game Classics - Backgammon & Chess & Draughts (Europe) (En,Fr,De,Es,It)" description "Board Game Classics - Backgammon & Chess & Draughts (Europe) (En,Fr,De,Es,It)" - rom ( name "Board Game Classics - Backgammon & Chess & Draughts (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc e5c745d8 sha1 f9a3058e55d72efdebc5e2b4d2b5d6e00e71e5ff ) + rom ( name "Board Game Classics - Backgammon & Chess & Draughts (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc e5c745d8 sha1 f9a3058e55d72efdebc5e2b4d2b5d6e00e71e5ff flags verified ) ) game ( @@ -2442,6 +2406,12 @@ game ( rom ( name "Boboboubo Boubobo - Ougi 87.5 Bakuretsu Hanage Shinken (Japan).gba" size 8388608 crc 58105f89 sha1 c93fd22bb10e26cb986161ce1cdc4c2acb38add9 ) ) +game ( + name "Boktai - The Sun Is in Your Hand (USA) (Sample)" + description "Possibly a version given out to press at E3 or an E3 demo" + rom ( name "Boktai - The Sun Is in Your Hand (USA) (Sample).gba" size 16777216 crc cf692572 sha1 f91126cd3a1bf7bf5f770d3a70229171d0d5a6ee ) +) + game ( name "Boktai - The Sun Is in Your Hand (USA)" description "Boktai - The Sun Is in Your Hand (USA)" @@ -2454,12 +2424,6 @@ game ( rom ( name "Boktai - The Sun Is in Your Hand (Europe) (En,Fr,De,Es,It).gba" size 16777216 crc 9686c36b sha1 64f7bf0f0560f6e94da33b549d3206678b29f557 flags verified ) ) -game ( - name "Boktai - The Sun Is in Your Hand (USA) (Sample)" - description "Possibly a version given out to press at E3 or an E3 demo" - rom ( name "Boktai - The Sun Is in Your Hand (USA) (Sample).gba" size 16777216 crc cf692572 sha1 f91126cd3a1bf7bf5f770d3a70229171d0d5a6ee ) -) - game ( name "Boktai 2 - Solar Boy Django (USA)" description "Boktai 2 - Solar Boy Django (USA)" @@ -2541,7 +2505,7 @@ game ( game ( name "Bomberman Max 2 - Red Advance (Europe) (En,Fr,De)" description "Bomberman Max 2 - Red Advance (Europe) (En,Fr,De)" - rom ( name "Bomberman Max 2 - Red Advance (Europe) (En,Fr,De).gba" size 16777216 crc 67d2e5b8 sha1 4d514fe19b59d42be9a118c99e2008efee2aedcb ) + rom ( name "Bomberman Max 2 - Red Advance (Europe) (En,Fr,De).gba" size 16777216 crc 67d2e5b8 sha1 4d514fe19b59d42be9a118c99e2008efee2aedcb flags verified ) ) game ( @@ -2553,7 +2517,7 @@ game ( game ( name "Bomberman Tournament (USA, Europe)" description "Bomberman Tournament (USA, Europe)" - rom ( name "Bomberman Tournament (USA, Europe).gba" size 4194304 crc 240282e6 sha1 da44a5d65f1a00d75a57e5b46e30f9e4e2d18f6c ) + rom ( name "Bomberman Tournament (USA, Europe).gba" size 4194304 crc 240282e6 sha1 da44a5d65f1a00d75a57e5b46e30f9e4e2d18f6c flags verified ) ) game ( @@ -2691,7 +2655,7 @@ game ( game ( name "Bratz - The Movie (USA)" description "Bratz - The Movie (USA)" - rom ( name "Bratz - The Movie (USA).gba" size 4194304 crc 2ef801c0 sha1 bfab6a139275b6968531a43ab34d4710e9efc7ef ) + rom ( name "Bratz - The Movie (USA).gba" size 4194304 crc 2ef801c0 sha1 bfab6a139275b6968531a43ab34d4710e9efc7ef flags verified ) ) game ( @@ -2784,12 +2748,6 @@ game ( rom ( name "Broken Circle (Europe) (En,It) (Proto).gba" size 8409344 crc e78bc690 sha1 d015a5039ff5d08eeba3ddb16470eaab259631d0 ) ) -game ( - name "Broken Circle (World) (En,It) (Aftermarket) (Unl)" - description "Broken Circle (World) (En,It) (Aftermarket) (Unl)" - rom ( name "Broken Circle (World) (En,It) (Aftermarket) (Unl).gba" size 16777216 crc 3212c09b sha1 e04a71dbe7b640cc53e81f447856e60666e64aa3 ) -) - game ( name "Broken Sword - The Shadow of the Templars (Europe) (En,Fr,De,Es,It)" description "Broken Sword - The Shadow of the Templars (Europe) (En,Fr,De,Es,It)" @@ -2805,13 +2763,13 @@ game ( game ( name "Brother Bear (USA)" description "Brother Bear (USA)" - rom ( name "Brother Bear (USA).gba" size 8388608 crc 342de1d6 sha1 89e6903500f62e11483402b76c1454af788646c0 ) + rom ( name "Brother Bear (USA).gba" size 8388608 crc 342de1d6 sha1 89e6903500f62e11483402b76c1454af788646c0 flags verified ) ) game ( name "Brother Bear (Europe) (Fr,De,Es,It,Nl,Sv,Da)" description "Brother Bear (Europe) (Fr,De,Es,It,Nl,Sv,Da)" - rom ( name "Brother Bear (Europe) (Fr,De,Es,It,Nl,Sv,Da).gba" size 8388608 crc fd814097 sha1 7e217e5f644b0333c51f3827df5fd64023ac7c0e ) + rom ( name "Brother Bear (Europe) (Fr,De,Es,It,Nl,Sv,Da).gba" size 8388608 crc fd814097 sha1 7e217e5f644b0333c51f3827df5fd64023ac7c0e flags verified ) ) game ( @@ -2877,7 +2835,7 @@ game ( game ( name "Butt-Ugly Martians - B.K.M. Battles (USA)" description "Butt-Ugly Martians - B.K.M. Battles (USA)" - rom ( name "Butt-Ugly Martians - B.K.M. Battles (USA).gba" size 4194304 crc 74be9148 sha1 24962220f242b49231969f6d313e325148886106 ) + rom ( name "Butt-Ugly Martians - B.K.M. Battles (USA).gba" size 4194304 crc 74be9148 sha1 24962220f242b49231969f6d313e325148886106 flags verified ) ) game ( @@ -2901,7 +2859,7 @@ game ( game ( name "Cabela's Big Game Hunter (USA)" description "Cabela's Big Game Hunter (USA)" - rom ( name "Cabela's Big Game Hunter (USA).gba" size 8388608 crc 70a8a141 sha1 f6590b9f069856c1a9e43d19b4b05e3175a97e02 ) + rom ( name "Cabela's Big Game Hunter (USA).gba" size 8388608 crc 70a8a141 sha1 f6590b9f069856c1a9e43d19b4b05e3175a97e02 flags verified ) ) game ( @@ -3078,12 +3036,6 @@ game ( rom ( name "Cartoon Network Speedway (USA).gba" size 4194304 crc 066a2705 sha1 26afa157c527dcaa5a4fa0eccc772426156320d8 ) ) -game ( - name "Casper (Europe) (En,Fr,De,Es,It,Nl,Pt)" - description "Casper (Europe) (En,Fr,De,Es,It,Nl,Pt)" - rom ( name "Casper (Europe) (En,Fr,De,Es,It,Nl,Pt).gba" size 4194304 crc ddaf8bac sha1 2321b90c04690e8e4973a4495d25c9197ab5bfcc ) -) - game ( name "Casper (USA) (En,Fr,Es)" description "Casper (USA) (En,Fr,Es)" @@ -3091,9 +3043,15 @@ game ( ) game ( - name "Castlevania (Europe) (Virtual Console)" - description "Castlevania (Europe) (Virtual Console)" - rom ( name "Castlevania (Europe) (Virtual Console).gba" size 8388608 crc dba05255 sha1 b5fa3402a8fb86786f97d08f88b3cbc790bb5d6e ) + name "Casper (Europe) (En,Fr,De,Es,It,Nl,Pt)" + description "Casper (Europe) (En,Fr,De,Es,It,Nl,Pt)" + rom ( name "Casper (Europe) (En,Fr,De,Es,It,Nl,Pt).gba" size 4194304 crc ddaf8bac sha1 2321b90c04690e8e4973a4495d25c9197ab5bfcc ) +) + +game ( + name "Castle Master (World) (Unl)" + description "Castle Master (World) (Unl)" + rom ( name "Castle Master (World) (Unl).gba" size 259192 crc 307f7d77 sha1 bf78a4efde3b5c3bab65bd7156c69907fb86b512 ) ) game ( @@ -3102,6 +3060,12 @@ game ( rom ( name "Castlevania (Europe) (Castlevania Advance Collection).gba" size 8388608 crc 050e2164 sha1 30a2fd3fe95a8a84b02da7ddbc8b2a90e0553d9b ) ) +game ( + name "Castlevania (Europe) (Virtual Console)" + description "Castlevania (Europe) (Virtual Console)" + rom ( name "Castlevania (Europe) (Virtual Console).gba" size 8388608 crc dba05255 sha1 b5fa3402a8fb86786f97d08f88b3cbc790bb5d6e ) +) + game ( name "Castlevania (Europe)" description "Castlevania (Europe)" @@ -3138,18 +3102,6 @@ game ( rom ( name "Castlevania - Aria of Sorrow (USA) (Castlevania Advance Collection).gba" size 8388608 crc ca9b82dd sha1 f2869a861f1be637a1d1b57009cb42cc06b82e09 ) ) -game ( - name "Castlevania - Aria of Sorrow (USA) (Virtual Console)" - description "Castlevania - Aria of Sorrow (USA) (Virtual Console)" - rom ( name "Castlevania - Aria of Sorrow (USA) (Virtual Console).gba" size 8388608 crc 28baa30e sha1 b69a77970878b453e2b308fe124641f66925ae6a ) -) - -game ( - name "Castlevania - Aria of Sorrow (Europe) (En,Fr,De) (Virtual Console)" - description "Castlevania - Aria of Sorrow (Europe) (En,Fr,De) (Virtual Console)" - rom ( name "Castlevania - Aria of Sorrow (Europe) (En,Fr,De) (Virtual Console).gba" size 8388608 crc d97dbfec sha1 458c42a6b8fd6cf18579b0f7eef9dcd12b43c12b ) -) - game ( name "Castlevania - Aria of Sorrow (Europe) (En,Fr,De)" description "Castlevania - Aria of Sorrow (Europe) (En,Fr,De)" @@ -3163,9 +3115,15 @@ game ( ) game ( - name "Castlevania - Byakuya no Concerto (Japan)" - description "Castlevania - Byakuya no Concerto (Japan)" - rom ( name "Castlevania - Byakuya no Concerto (Japan).gba" size 8388608 crc 379b3248 sha1 3aeb81ee60fa3e56a56ee069b0ce0d8bc34d9c4c ) + name "Castlevania - Aria of Sorrow (USA) (Virtual Console)" + description "Castlevania - Aria of Sorrow (USA) (Virtual Console)" + rom ( name "Castlevania - Aria of Sorrow (USA) (Virtual Console).gba" size 8388608 crc 28baa30e sha1 b69a77970878b453e2b308fe124641f66925ae6a ) +) + +game ( + name "Castlevania - Aria of Sorrow (Europe) (En,Fr,De) (Virtual Console)" + description "Castlevania - Aria of Sorrow (Europe) (En,Fr,De) (Virtual Console)" + rom ( name "Castlevania - Aria of Sorrow (Europe) (En,Fr,De) (Virtual Console).gba" size 8388608 crc d97dbfec sha1 458c42a6b8fd6cf18579b0f7eef9dcd12b43c12b ) ) game ( @@ -3175,9 +3133,9 @@ game ( ) game ( - name "Castlevania - Circle of the Moon (USA) (Castlevania Advance Collection)" - description "Castlevania - Circle of the Moon (USA) (Castlevania Advance Collection)" - rom ( name "Castlevania - Circle of the Moon (USA) (Castlevania Advance Collection).gba" size 8388608 crc 14c1ab7c sha1 9483aa48b384ff3142c47fe81c13ca874a608eb0 ) + name "Castlevania - Byakuya no Concerto (Japan)" + description "Castlevania - Byakuya no Concerto (Japan)" + rom ( name "Castlevania - Byakuya no Concerto (Japan).gba" size 8388608 crc 379b3248 sha1 3aeb81ee60fa3e56a56ee069b0ce0d8bc34d9c4c ) ) game ( @@ -3192,6 +3150,12 @@ game ( rom ( name "Castlevania - Circle of the Moon (USA) (Virtual Console).gba" size 8388608 crc d5412e91 sha1 e055b4ab00e16ec39c9036ef85463c770d809c6c ) ) +game ( + name "Castlevania - Circle of the Moon (USA) (Castlevania Advance Collection)" + description "Castlevania - Circle of the Moon (USA) (Castlevania Advance Collection)" + rom ( name "Castlevania - Circle of the Moon (USA) (Castlevania Advance Collection).gba" size 8388608 crc 14c1ab7c sha1 9483aa48b384ff3142c47fe81c13ca874a608eb0 ) +) + game ( name "Castlevania - Harmony of Dissonance (Europe) (Castlevania Advance Collection)" description "Castlevania - Harmony of Dissonance (Europe) (Castlevania Advance Collection)" @@ -3246,12 +3210,6 @@ game ( rom ( name "Cat in the Hat, The (USA).gba" size 4194304 crc 13c2249e sha1 9340482db02bf5263429a15798d06c509017aa93 ) ) -game ( - name "Cat's Curse (World) (Aftermarket) (Unl)" - description "Cat's Curse (World) (Aftermarket) (Unl)" - rom ( name "Cat's Curse (World) (Aftermarket) (Unl).gba" size 353052 crc a35d87de sha1 4a149baad17840948c2d4ffdf068bfaf1116a024 ) -) - game ( name "Catwoman (USA, Europe) (En,Fr,De,Es,It,Nl)" description "Catwoman (USA, Europe) (En,Fr,De,Es,It,Nl)" @@ -3270,24 +3228,6 @@ game ( rom ( name "Catz (Europe) (En,Fr,De,It).gba" size 8388608 crc c3aa382d sha1 0dab5140ebc541e03dd00a8ce87cce4f0326b0e6 ) ) -game ( - name "Celeste Classic (World) (v1.0) (Aftermarket) (Unl)" - description "Celeste Classic (World) (v1.0) (Aftermarket) (Unl)" - rom ( name "Celeste Classic (World) (v1.0) (Aftermarket) (Unl).gba" size 5416932 crc f79b0d53 sha1 756f02396a150698e695ad4afd24445e2af70576 ) -) - -game ( - name "Celeste Classic (World) (v1.1) (Aftermarket) (Unl)" - description "Celeste Classic (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Celeste Classic (World) (v1.1) (Aftermarket) (Unl).gba" size 5418248 crc f5d36ad2 sha1 95a86dff641b11b4c2ed0d0fe8152c33b462d927 ) -) - -game ( - name "Celeste Classic (World) (v1.2) (Aftermarket) (Unl)" - description "Celeste Classic (World) (v1.2) (Aftermarket) (Unl)" - rom ( name "Celeste Classic (World) (v1.2) (Aftermarket) (Unl).gba" size 5418424 crc ff0e8ada sha1 08512605e5c02e81a72e24c2c8d4959d8e84e1f4 ) -) - game ( name "Chaoji Maliou 2 (China)" description "Chaoji Maliou 2 (China)" @@ -3333,19 +3273,7 @@ game ( game ( name "Cheetah Girls, The (USA)" description "Cheetah Girls, The (USA)" - rom ( name "Cheetah Girls, The (USA).gba" size 8388608 crc e2efc2aa sha1 f46296d4ab97d539dbcfa551e05ed6d58715c5b6 ) -) - -game ( - name "Chessmaster (USA)" - description "Chessmaster (USA)" - rom ( name "Chessmaster (USA).gba" size 4194304 crc 25b0e933 sha1 5e3ac500d119a2bbe67d480edc1c1dd09061e385 ) -) - -game ( - name "Chessmaster (Germany)" - description "Chessmaster (Germany)" - rom ( name "Chessmaster (Germany).gba" size 4194304 crc 06abacc5 sha1 76a69da6183239f4ab0c45ef43c3ef7e2bd96d03 ) + rom ( name "Cheetah Girls, The (USA).gba" size 8388608 crc e2efc2aa sha1 f46296d4ab97d539dbcfa551e05ed6d58715c5b6 flags verified ) ) game ( @@ -3360,6 +3288,18 @@ game ( rom ( name "Chessmaster (France).gba" size 4194304 crc 55ef8392 sha1 eb5630d7b56ebdf4609665d50bf188e3f9eac668 ) ) +game ( + name "Chessmaster (USA)" + description "Chessmaster (USA)" + rom ( name "Chessmaster (USA).gba" size 4194304 crc 25b0e933 sha1 5e3ac500d119a2bbe67d480edc1c1dd09061e385 ) +) + +game ( + name "Chessmaster (Germany)" + description "Chessmaster (Germany)" + rom ( name "Chessmaster (Germany).gba" size 4194304 crc 06abacc5 sha1 76a69da6183239f4ab0c45ef43c3ef7e2bd96d03 ) +) + game ( name "Chi Vuol Essere Milionario (Italy)" description "Chi Vuol Essere Milionario (Italy)" @@ -3414,6 +3354,12 @@ game ( rom ( name "Chinmoku no Iseki - Estpolis Gaiden (Japan) (Virtual Console).gba" size 8388608 crc 36cc41bf sha1 882cc3c71ce7025abbe0a65a2f007428887d7113 ) ) +game ( + name "Chip Advance (World) (En,Fr) (v2.1) (Unl)" + description "Chip Advance (World) (En,Fr) (v2.1) (Unl)" + rom ( name "Chip Advance (World) (En,Fr) (v2.1) (Unl).gba" size 10498128 crc 586c4345 sha1 29c889b3c25b851f590685dea03400110e98fabd ) +) + game ( name "Chobits for Game Boy Advance - Atashi Dake no Hito (Japan)" description "Chobits for Game Boy Advance - Atashi Dake no Hito (Japan)" @@ -3528,6 +3474,12 @@ game ( rom ( name "Cinnamoroll - Koko ni Iru yo (Japan).gba" size 4194304 crc 8376d53b sha1 f13533eb284f7321d8709df058ff28d61a031802 ) ) +game ( + name "City Connection (World) (Fr) (v1.7) (Unl)" + description "City Connection (World) (Fr) (v1.7) (Unl)" + rom ( name "City Connection (World) (Fr) (v1.7) (Unl).gba" size 1924768 crc 234a42a5 sha1 e1c6d46521310d96fedf46a39982ad1372cdc42c ) +) + game ( name "Classic NES Series - Bomberman (USA, Europe)" description "Classic NES Series - Bomberman (USA, Europe)" @@ -3573,7 +3525,7 @@ game ( game ( name "Classic NES Series - Pac-Man (USA, Europe)" description "Classic NES Series - Pac-Man (USA, Europe)" - rom ( name "Classic NES Series - Pac-Man (USA, Europe).gba" size 1048576 crc c28df82f sha1 843d853ed28a116c85a5357f9a94e9179f36a6d0 ) + rom ( name "Classic NES Series - Pac-Man (USA, Europe).gba" size 1048576 crc c28df82f sha1 843d853ed28a116c85a5357f9a94e9179f36a6d0 flags verified ) ) game ( @@ -3591,7 +3543,7 @@ game ( game ( name "Classic NES Series - Xevious (USA, Europe)" description "Classic NES Series - Xevious (USA, Europe)" - rom ( name "Classic NES Series - Xevious (USA, Europe).gba" size 1048576 crc 9cd2d5dd sha1 b2088582808480e0d70c63a777b046409d4e15c4 ) + rom ( name "Classic NES Series - Xevious (USA, Europe).gba" size 1048576 crc 9cd2d5dd sha1 b2088582808480e0d70c63a777b046409d4e15c4 flags verified ) ) game ( @@ -3624,6 +3576,12 @@ game ( rom ( name "Codename - Kids Next Door - Operation S.O.D.A. (USA).gba" size 8388608 crc 420a81b7 sha1 bbd176cc9a5331fdfdb332ad037d869610e4b3fb ) ) +game ( + name "Coin Adventure (World) (Unl)" + description "Coin Adventure (World) (Unl)" + rom ( name "Coin Adventure (World) (Unl).gba" size 677920 crc bb3a4566 sha1 088aeb8d40927969c690a66321d7006751a73e20 ) +) + game ( name "Colin McRae Rally 2.0 (Europe) (En,Fr,De)" description "Colin McRae Rally 2.0 (Europe) (En,Fr,De)" @@ -3759,7 +3717,7 @@ game ( game ( name "Crash & Spyro Superpack - Spyro Orange - The Cortex Conspiracy + Crash Bandicoot Purple - Ripto's Rampage (USA)" description "Crash & Spyro Superpack - Spyro Orange - The Cortex Conspiracy + Crash Bandicoot Purple - Ripto's Rampage (USA)" - rom ( name "Crash & Spyro Superpack - Spyro Orange - The Cortex Conspiracy + Crash Bandicoot Purple - Ripto's Rampage (USA).gba" size 33554432 crc 5940906e sha1 95b5a68962ce552a71d8212850e85d90d2844b40 ) + rom ( name "Crash & Spyro Superpack - Spyro Orange - The Cortex Conspiracy + Crash Bandicoot Purple - Ripto's Rampage (USA).gba" size 33554432 crc 9b76b90b sha1 a14854c2189516501a51d9e3fce7f10f3593fc9a ) ) game ( @@ -3777,7 +3735,7 @@ game ( game ( name "Crash Bandicoot 2 - N-Tranced (USA)" description "Crash Bandicoot 2 - N-Tranced (USA)" - rom ( name "Crash Bandicoot 2 - N-Tranced (USA).gba" size 8388608 crc 2e16184a sha1 972158859ea08aa5746ab2e0d4c81ac43728adff ) + rom ( name "Crash Bandicoot 2 - N-Tranced (USA).gba" size 8388608 crc 2e16184a sha1 972158859ea08aa5746ab2e0d4c81ac43728adff flags verified ) ) game ( @@ -3873,7 +3831,7 @@ game ( game ( name "Crayon Shin-chan - Densetsu o Yobu Omake no Miyako Shockgaan! (Japan)" description "Crayon Shin-chan - Densetsu o Yobu Omake no Miyako Shockgaan! (Japan)" - rom ( name "Crayon Shin-chan - Densetsu o Yobu Omake no Miyako Shockgaan! (Japan).gba" size 33554432 crc 45c84466 sha1 e17baa57d339f7d85f562441111696e88088fcdd ) + rom ( name "Crayon Shin-chan - Densetsu o Yobu Omake no Miyako Shockgaan! (Japan).gba" size 33554432 crc 52f463fe sha1 10aa9bd3b72ed918e7c59fdbc0cc05e5b48dcc70 ) ) game ( @@ -3966,6 +3924,18 @@ game ( rom ( name "Croket! Great - Toki no Boukensha (Japan).gba" size 16777216 crc f0e81971 sha1 410fb8fe2fe07be146c8454122d874287f92fbac ) ) +game ( + name "Cross Town Heroes (USA)" + description "Cross Town Heroes (USA)" + rom ( name "Cross Town Heroes (USA).gba" size 4194304 crc 0fffb458 sha1 6baa6bfe76b077f365bedffa52346b94689b61d7 ) +) + +game ( + name "Cross Town Heroes (Europe)" + description "Cross Town Heroes (Europe)" + rom ( name "Cross Town Heroes (Europe).gba" size 4194304 crc c9ea02f5 sha1 13310b7f25a0332a8e09e722587ec79aee11c373 ) +) + game ( name "Crouching Tiger, Hidden Dragon (USA) (En,Fr,Es)" description "Crouching Tiger, Hidden Dragon (USA) (En,Fr,Es)" @@ -3979,15 +3949,15 @@ game ( ) game ( - name "Crouching Tiger, Hidden Dragon (USA) (Beta)" - description "Crouching Tiger, Hidden Dragon (USA) (Beta)" - rom ( name "Crouching Tiger, Hidden Dragon (USA) (Beta).gba" size 8388608 crc 204ff8d5 sha1 af24d128b28758a8a1bda45b5a24a299e1e14b90 ) + name "Crouching Tiger, Hidden Dragon (USA) (Beta 2)" + description "Crouching Tiger, Hidden Dragon (USA) (Beta 2)" + rom ( name "Crouching Tiger, Hidden Dragon (USA) (Beta 2).gba" size 8388608 crc 204ff8d5 sha1 af24d128b28758a8a1bda45b5a24a299e1e14b90 ) ) game ( - name "Cruis'n Velocity (USA, Europe) (Beta)" - description "Cruis'n Velocity (USA, Europe) (Beta)" - rom ( name "Cruis'n Velocity (USA, Europe) (Beta).gba" size 8388608 crc 5436d5da sha1 d1716d4603dd8db7ae8715d5142a60230d17e1d2 ) + name "Crouching Tiger, Hidden Dragon (USA) (Beta 1)" + description "Crouching Tiger, Hidden Dragon (USA) (Beta 1)" + rom ( name "Crouching Tiger, Hidden Dragon (USA) (Beta 1).gba" size 3353604 crc a1d2d006 sha1 3d554e4e33563211865b9c5481444b0b8b4e6127 ) ) game ( @@ -3996,6 +3966,12 @@ game ( rom ( name "Cruis'n Velocity (USA, Europe).gba" size 4194304 crc adf14db5 sha1 762aabc26501dee4aa566e8327600433c8edbf7a ) ) +game ( + name "Cruis'n Velocity (USA, Europe) (Beta)" + description "Cruis'n Velocity (USA, Europe) (Beta)" + rom ( name "Cruis'n Velocity (USA, Europe) (Beta).gba" size 8388608 crc 5436d5da sha1 d1716d4603dd8db7ae8715d5142a60230d17e1d2 ) +) + game ( name "Crushed Baseball (USA)" description "Crushed Baseball (USA)" @@ -4008,18 +3984,18 @@ game ( rom ( name "CT Special Forces (USA) (En,Fr,De,Es,It,Nl).gba" size 4194304 crc aea22ae0 sha1 ab151206c142dbcdb4f2ea9877d6bcd2c89b8b55 ) ) -game ( - name "CT Special Forces (Europe) (En,Fr,De,Es,It,Nl)" - description "CT Special Forces (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "CT Special Forces (Europe) (En,Fr,De,Es,It,Nl).gba" size 4194304 crc a20d9adb sha1 e178192ba2c78759245541bd54d96d83a8d5d9c6 flags verified ) -) - game ( name "CT Special Forces (Europe) (En,Fr,De,Es,It,Nl) (Beta)" description "CT Special Forces (Europe) (En,Fr,De,Es,It,Nl) (Beta)" rom ( name "CT Special Forces (Europe) (En,Fr,De,Es,It,Nl) (Beta).gba" size 4194304 crc 40a0e1c9 sha1 fab8b62a141865f12c69334f4db14c837d9d94af ) ) +game ( + name "CT Special Forces (Europe) (En,Fr,De,Es,It,Nl)" + description "CT Special Forces (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "CT Special Forces (Europe) (En,Fr,De,Es,It,Nl).gba" size 4194304 crc a20d9adb sha1 e178192ba2c78759245541bd54d96d83a8d5d9c6 flags verified ) +) + game ( name "CT Special Forces - Back to Hell (Europe) (En,Fr,De,Es,It,Nl)" description "CT Special Forces - Back to Hell (Europe) (En,Fr,De,Es,It,Nl)" @@ -4107,7 +4083,7 @@ game ( game ( name "Dancing Sword - Senkou (Japan)" description "Dancing Sword - Senkou (Japan)" - rom ( name "Dancing Sword - Senkou (Japan).gba" size 8388608 crc e2316d47 sha1 5c5f33e0453cba1a60039160564daa53a82db8aa ) + rom ( name "Dancing Sword - Senkou (Japan).gba" size 8388608 crc e2316d47 sha1 5c5f33e0453cba1a60039160564daa53a82db8aa flags verified ) ) game ( @@ -4248,6 +4224,12 @@ game ( rom ( name "Deal or No Deal (USA).gba" size 4194304 crc b6c00edb sha1 3691000350db3b36311439c5d9c9879ee756fea6 ) ) +game ( + name "Decoder Cart (Japan) (En) (Pirate)" + description "Decoder Cart (Japan) (En) (Pirate)" + rom ( name "Decoder Cart (Japan) (En) (Pirate).gba" size 8388608 crc 80aa9cc5 sha1 20c6f5aaf8299dfcdeb76bd633f12da209625b97 ) +) + game ( name "Defender (USA)" description "Defender (USA)" @@ -4272,6 +4254,12 @@ game ( rom ( name "Defender of the Crown (Europe).gba" size 4194304 crc 6968959a sha1 4e37071533e946efd4166efc409562cc21af83d2 ) ) +game ( + name "Deflektor (World) (v1.1) (Unl)" + description "Deflektor (World) (v1.1) (Unl)" + rom ( name "Deflektor (World) (v1.1) (Unl).gba" size 386508 crc 5ec91001 sha1 92682b2404be3b2fd48f96cad0c51f51d07c8159 ) +) + game ( name "DemiKids - Dark Version (USA)" description "DemiKids - Dark Version (USA)" @@ -4338,18 +4326,18 @@ game ( rom ( name "Densetsu no Stafy 3 (Japan) (Rev 1) (Virtual Console).gba" size 16777216 crc 59ca95c6 sha1 5506cbcfa1a275441f365099822a583c80397fde ) ) -game ( - name "Densetsu no Stafy 3 (Japan)" - description "Densetsu no Stafy 3 (Japan)" - rom ( name "Densetsu no Stafy 3 (Japan).gba" size 16777216 crc fcaf1aa8 sha1 a7a742e779d314f6909f1350db2da8a63445c433 flags verified ) -) - game ( name "Densetsu no Stafy 3 (Japan) (Rev 1)" description "Densetsu no Stafy 3 (Japan) (Rev 1)" rom ( name "Densetsu no Stafy 3 (Japan) (Rev 1).gba" size 16777216 crc 2d6e4c3b sha1 dae5354bfe4ccafc92d22b1389265dbf1f79b636 ) ) +game ( + name "Densetsu no Stafy 3 (Japan)" + description "Densetsu no Stafy 3 (Japan)" + rom ( name "Densetsu no Stafy 3 (Japan).gba" size 16777216 crc fcaf1aa8 sha1 a7a742e779d314f6909f1350db2da8a63445c433 flags verified ) +) + game ( name "Derby Stallion Advance (Japan)" description "Derby Stallion Advance (Japan)" @@ -4368,12 +4356,6 @@ game ( rom ( name "Deutschland Sucht den Superstar (Germany).gba" size 16777216 crc 51f50f7d sha1 ce5253e82671569500af3d5df9d3131916fbe23d ) ) -game ( - name "Dexter's Laboratory - Chess Challenge (Europe) (En,Fr,De,Es)" - description "Dexter's Laboratory - Chess Challenge (Europe) (En,Fr,De,Es)" - rom ( name "Dexter's Laboratory - Chess Challenge (Europe) (En,Fr,De,Es).gba" size 8388608 crc f5436f5d sha1 e04dbb5e0534cf241e8fee85d17b1cc8a0032f14 ) -) - game ( name "Dexter's Laboratory - Chess Challenge (USA)" description "Dexter's Laboratory - Chess Challenge (USA)" @@ -4381,9 +4363,15 @@ game ( ) game ( - name "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It)" - description "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It)" - rom ( name "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It).gba" size 4194304 crc e948d412 sha1 f230375ba4b0346d749e50117fe701d8c1cbfffa ) + name "Dexter's Laboratory - Chess Challenge (Europe) (En,Fr,De,Es)" + description "Dexter's Laboratory - Chess Challenge (Europe) (En,Fr,De,Es)" + rom ( name "Dexter's Laboratory - Chess Challenge (Europe) (En,Fr,De,Es).gba" size 8388608 crc f5436f5d sha1 e04dbb5e0534cf241e8fee85d17b1cc8a0032f14 ) +) + +game ( + name "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It) (Rev 1)" + description "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It) (Rev 1)" + rom ( name "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It) (Rev 1).gba" size 4194304 crc 6bf168e6 sha1 b838b5bb37bfeb3315a68b6d372f29a5de635444 flags verified ) ) game ( @@ -4393,9 +4381,9 @@ game ( ) game ( - name "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It) (Rev 1)" - description "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It) (Rev 1)" - rom ( name "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It) (Rev 1).gba" size 4194304 crc 6bf168e6 sha1 b838b5bb37bfeb3315a68b6d372f29a5de635444 flags verified ) + name "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It)" + description "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It)" + rom ( name "Dexter's Laboratory - Deesaster Strikes! (USA) (En,Fr,De,Es,It).gba" size 4194304 crc e948d412 sha1 f230375ba4b0346d749e50117fe701d8c1cbfffa ) ) game ( @@ -4419,7 +4407,7 @@ game ( game ( name "Diddy Kong Pilot (Unknown) (Proto) (2001)" description "Diddy Kong Pilot (Unknown) (Proto) (2001)" - rom ( name "Diddy Kong Pilot (Unknown) (Proto) (2001).gba" size 7509167 crc 8903cc5f sha1 e14bfb4d63c6bd35c3a1a4aad4eb91e94d0402b3 ) + rom ( name "Diddy Kong Pilot (Unknown) (Proto) (2001).gba" size 5080644 crc 5c206101 sha1 6a76def610829ac1502afb58740e38b5e6926b3d ) ) game ( @@ -4695,7 +4683,7 @@ game ( game ( name "Dogz (USA)" description "Dogz (USA)" - rom ( name "Dogz (USA).gba" size 8388608 crc 124f27c0 sha1 462f05c18534cb22fffc65d47351a29f10a3f254 ) + rom ( name "Dogz (USA).gba" size 8388608 crc 124f27c0 sha1 462f05c18534cb22fffc65d47351a29f10a3f254 flags verified ) ) game ( @@ -4872,12 +4860,6 @@ game ( rom ( name "Donkey Kong Country 3 (USA).gba" size 16777216 crc fe03e5af sha1 c50982b4c26e25ba3538be97b585d95737d7ade7 flags verified ) ) -game ( - name "Donsol (World) (Aftermarket) (Unl)" - description "Donsol (World) (Aftermarket) (Unl)" - rom ( name "Donsol (World) (Aftermarket) (Unl).gba" size 52520 crc aec144b3 sha1 751675b0d77c341f2265b0edd38858b0dbdb7b50 ) -) - game ( name "Doom (USA, Europe)" description "Doom (USA, Europe)" @@ -4905,7 +4887,7 @@ game ( game ( name "Dora the Explorer - Super Spies (USA)" description "Dora the Explorer - Super Spies (USA)" - rom ( name "Dora the Explorer - Super Spies (USA).gba" size 4194304 crc 650fdfdb sha1 fa51e2102ce0a0e70c5db2f8776d2237c8d7db7d ) + rom ( name "Dora the Explorer - Super Spies (USA).gba" size 4194304 crc 650fdfdb sha1 fa51e2102ce0a0e70c5db2f8776d2237c8d7db7d flags verified ) ) game ( @@ -4923,7 +4905,7 @@ game ( game ( name "Dora the Explorer - The Search for the Pirate Pig's Treasure (USA)" description "Dora the Explorer - The Search for the Pirate Pig's Treasure (USA)" - rom ( name "Dora the Explorer - The Search for the Pirate Pig's Treasure (USA).gba" size 4194304 crc 9439541c sha1 10d1df1cb3fd94a14fff239083968b5182772a4d ) + rom ( name "Dora the Explorer - The Search for the Pirate Pig's Treasure (USA).gba" size 4194304 crc 9439541c sha1 10d1df1cb3fd94a14fff239083968b5182772a4d flags verified ) ) game ( @@ -5082,6 +5064,12 @@ game ( rom ( name "Dragon Ball - Advanced Adventure (Europe) (En,Fr,De,Es,It) (Beta) (2005-02-25).gba" size 16777216 crc 2b136906 sha1 fe190755f05994f1c796286ad767d7da49c36385 ) ) +game ( + name "Dragon Ball GT - Transformation (USA) (Beta) (2005-04-27)" + description "Dragon Ball GT - Transformation (USA) (Beta) (2005-04-27)" + rom ( name "Dragon Ball GT - Transformation (USA) (Beta) (2005-04-27).gba" size 8388608 crc 431bc807 sha1 58875496c9ab89ba3b769dc47d89ac2839b7cb7f ) +) + game ( name "Dragon Ball GT - Transformation (USA)" description "Dragon Ball GT - Transformation (USA)" @@ -5178,6 +5166,18 @@ game ( rom ( name "Dragon Ball Z - The Legacy of Goku II (USA).gba" size 8388608 crc 204142e1 sha1 18e0715dec419f3501c301511530d2edcd590f8b flags verified ) ) +game ( + name "Dragon Ball Z - The Legacy of Goku II (USA) (Beta) (2003-01-23)" + description "Dragon Ball Z - The Legacy of Goku II (USA) (Beta) (2003-01-23)" + rom ( name "Dragon Ball Z - The Legacy of Goku II (USA) (Beta) (2003-01-23).gba" size 7282372 crc 3c30f5b3 sha1 16f4c593a0ab0e243fbeca7cc1033ac88501e387 ) +) + +game ( + name "Dragon Ball Z - The Legacy of Goku II (USA) (Beta) (2003-01-31)" + description "Dragon Ball Z - The Legacy of Goku II (USA) (Beta) (2003-01-31)" + rom ( name "Dragon Ball Z - The Legacy of Goku II (USA) (Beta) (2003-01-31).gba" size 7279012 crc 25f34dbc sha1 fc76f3477f19af7415a42a6f38bd5bda43c640d2 ) +) + game ( name "Dragon Ball Z - The Legacy of Goku II International (Japan)" description "Dragon Ball Z - The Legacy of Goku II International (Japan)" @@ -5418,6 +5418,12 @@ game ( rom ( name "Duel Masters 3 (Japan) (Rev 1).gba" size 8388608 crc d2b9cfb6 sha1 05ad843564c663a050e137ae0ec07d09f585c714 ) ) +game ( + name "Duke Nukem Advance (World) (En,Fr,De,It) (Evercade) (Unl)" + description "Duke Nukem Advance (World) (En,Fr,De,It) (Evercade) (Unl)" + rom ( name "Duke Nukem Advance (World) (En,Fr,De,It) (Evercade) (Unl).gba" size 8388608 crc 2b077058 sha1 926b6c74d408cb3ff37a5276ddc3be8e2512c0b3 ) +) + game ( name "Duke Nukem Advance (USA)" description "Duke Nukem Advance (USA)" @@ -5568,6 +5574,12 @@ game ( rom ( name "Eggo Mania (Europe) (En,Fr,De,Es,It,Nl).gba" size 4194304 crc 0b2961ce sha1 5514d090d08643a07457e4698d848657ae5cd179 ) ) +game ( + name "Elements of Darkness (World) (Demo) (Unl)" + description "Elements of Darkness (World) (Demo) (Unl)" + rom ( name "Elements of Darkness (World) (Demo) (Unl).gba" size 3039348 crc 5f3b0637 sha1 f425b0a88c46bca220bf47c2067020b57e96f736 ) +) + game ( name "Elemix! (Japan)" description "Elemix! (Japan)" @@ -5599,9 +5611,9 @@ game ( ) game ( - name "Elland - The Crystal Wars (World) (Digital Release) (Aftermarket) (Unl)" - description "Elland - The Crystal Wars (World) (Digital Release) (Aftermarket) (Unl)" - rom ( name "Elland - The Crystal Wars (World) (Digital Release) (Aftermarket) (Unl).gba" size 4016344 crc e3128bcb sha1 67617136f205fa071d9fc239df09471e603c675c ) + name "Elite - The New Kind (World) (v1.7.1) (Unl)" + description "Elite - The New Kind (World) (v1.7.1) (Unl)" + rom ( name "Elite - The New Kind (World) (v1.7.1) (Unl).gba" size 546392 crc 5f9b4211 sha1 d3e6c12e6475ffb21617e3be7158d60ac535e74b ) ) game ( @@ -5637,7 +5649,7 @@ game ( game ( name "ESPN Final Round Golf 2002 (USA)" description "ESPN Final Round Golf 2002 (USA)" - rom ( name "ESPN Final Round Golf 2002 (USA).gba" size 8388608 crc c9bc75a5 sha1 ecee20b629a38bab7edbc972c70b2c968f50c23c ) + rom ( name "ESPN Final Round Golf 2002 (USA).gba" size 8388608 crc c9bc75a5 sha1 ecee20b629a38bab7edbc972c70b2c968f50c23c flags verified ) ) game ( @@ -5985,7 +5997,7 @@ game ( game ( name "F24 Stealth Fighter (USA)" description "F24 Stealth Fighter (USA)" - rom ( name "F24 Stealth Fighter (USA).gba" size 4194304 crc 9387ea7c sha1 ac9188c7836dd388b488d02e8774dc61b1d30b4a ) + rom ( name "F24 Stealth Fighter (USA).gba" size 4194304 crc 9387ea7c sha1 ac9188c7836dd388b488d02e8774dc61b1d30b4a flags verified ) ) game ( @@ -6165,7 +6177,7 @@ game ( game ( name "Famicom Mini 22 - Nazo no Murasame Jou (Japan)" description "Famicom Mini 22 - Nazo no Murasame Jou (Japan)" - rom ( name "Famicom Mini 22 - Nazo no Murasame Jou (Japan).gba" size 4194304 crc 8233349c sha1 0100d4e94c30adf73cd6082b89911dedf723ecd5 ) + rom ( name "Famicom Mini 22 - Nazo no Murasame Jou (Japan).gba" size 4194304 crc 8233349c sha1 0100d4e94c30adf73cd6082b89911dedf723ecd5 flags verified ) ) game ( @@ -6321,7 +6333,7 @@ game ( game ( name "Fear Factor - Unleashed (USA)" description "Fear Factor - Unleashed (USA)" - rom ( name "Fear Factor - Unleashed (USA).gba" size 8388608 crc 1289639c sha1 bf933c51bdcb52ae54d518e80129c687b751f836 ) + rom ( name "Fear Factor - Unleashed (USA).gba" size 8388608 crc bf91c27d sha1 d6f60f7d1707dca21c61f50db2b6324b7d680012 ) ) game ( @@ -6367,15 +6379,15 @@ game ( ) game ( - name "FILA Decathlon (Europe) (Beta)" - description "FILA Decathlon (Europe) (Beta)" - rom ( name "FILA Decathlon (Europe) (Beta).gba" size 4194304 crc 07434e3a sha1 1dc940dda8da59ade503c1e8901a0e44285f4e9b ) + name "FILA Decathlon (Europe) (En,Fr,De,Es,It,Sv)" + description "FILA Decathlon (Europe) (En,Fr,De,Es,It,Sv)" + rom ( name "FILA Decathlon (Europe) (En,Fr,De,Es,It,Sv).gba" size 4194304 crc 628355b5 sha1 41efd4b2fc8be52a12aadd1e4bf696fcc98230ca flags verified ) ) game ( - name "FILA Decathlon (Europe) (En,Fr,De,Es,It,Sv)" - description "FILA Decathlon (Europe) (En,Fr,De,Es,It,Sv)" - rom ( name "FILA Decathlon (Europe) (En,Fr,De,Es,It,Sv).gba" size 4194304 crc 628355b5 sha1 41efd4b2fc8be52a12aadd1e4bf696fcc98230ca ) + name "FILA Decathlon (Europe) (Beta)" + description "FILA Decathlon (Europe) (Beta)" + rom ( name "FILA Decathlon (Europe) (Beta).gba" size 4194304 crc 07434e3a sha1 1dc940dda8da59ade503c1e8901a0e44285f4e9b ) ) game ( @@ -6439,15 +6451,15 @@ game ( ) game ( - name "Final Fantasy Tactics Advance (USA)" - description "Final Fantasy Tactics Advance (USA)" - rom ( name "Final Fantasy Tactics Advance (USA).gba" size 16777216 crc 5645e56c sha1 4ac05441f4de70a4ec3dd932116346c61b8783d9 flags verified ) + name "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It) (Virtual Console)" + description "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It) (Virtual Console)" + rom ( name "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It) (Virtual Console).gba" size 16777216 crc 4a8d2c39 sha1 c184b9da365f6361b7dcda35fe1a970fa9857ae0 ) ) game ( - name "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It)" - description "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It)" - rom ( name "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It).gba" size 16777216 crc ba5de047 sha1 9efaf328cbbcbc830be14940e42e4b92d90dfb58 flags verified ) + name "Final Fantasy Tactics Advance (Japan) (Virtual Console)" + description "Final Fantasy Tactics Advance (Japan) (Virtual Console)" + rom ( name "Final Fantasy Tactics Advance (Japan) (Virtual Console).gba" size 16777216 crc ee31422a sha1 8e90027e0831b27fa174e446e6a773f2a421aed1 ) ) game ( @@ -6457,15 +6469,15 @@ game ( ) game ( - name "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It) (Virtual Console)" - description "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It) (Virtual Console)" - rom ( name "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It) (Virtual Console).gba" size 16777216 crc 4a8d2c39 sha1 c184b9da365f6361b7dcda35fe1a970fa9857ae0 ) + name "Final Fantasy Tactics Advance (USA)" + description "Final Fantasy Tactics Advance (USA)" + rom ( name "Final Fantasy Tactics Advance (USA).gba" size 16777216 crc 5645e56c sha1 4ac05441f4de70a4ec3dd932116346c61b8783d9 flags verified ) ) game ( - name "Final Fantasy Tactics Advance (Japan) (Virtual Console)" - description "Final Fantasy Tactics Advance (Japan) (Virtual Console)" - rom ( name "Final Fantasy Tactics Advance (Japan) (Virtual Console).gba" size 16777216 crc ee31422a sha1 8e90027e0831b27fa174e446e6a773f2a421aed1 ) + name "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It)" + description "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It)" + rom ( name "Final Fantasy Tactics Advance (Europe) (En,Fr,De,Es,It).gba" size 16777216 crc ba5de047 sha1 9efaf328cbbcbc830be14940e42e4b92d90dfb58 flags verified ) ) game ( @@ -6573,7 +6585,7 @@ game ( game ( name "Findet Nemo (Germany)" description "Findet Nemo (Germany)" - rom ( name "Findet Nemo (Germany).gba" size 8388608 crc 6b6b0908 sha1 5c5ee51c4bc8196bea226b3bf4750c8de1ee7f38 ) + rom ( name "Findet Nemo (Germany).gba" size 8388608 crc 6b6b0908 sha1 5c5ee51c4bc8196bea226b3bf4750c8de1ee7f38 flags verified ) ) game ( @@ -6780,6 +6792,12 @@ game ( rom ( name "Flintstones, The - Big Trouble in Bedrock (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc 39782c26 sha1 3eb5a53a395acfaae672d8b8e3c79fc4442a00ab ) ) +game ( + name "Flood (World) (v0.9) (Proto) (Unl)" + description "Flood (World) (v0.9) (Proto) (Unl)" + rom ( name "Flood (World) (v0.9) (Proto) (Unl).gba" size 485108 crc 46ad658a sha1 c3e6dfaca1570fb7d2af45a25fd93e94e11beb1e ) +) + game ( name "Flushed Away (USA)" description "Flushed Away (USA)" @@ -6873,7 +6891,7 @@ game ( game ( name "Freekstyle (USA)" description "Freekstyle (USA)" - rom ( name "Freekstyle (USA).gba" size 8388608 crc 72434345 sha1 dcecce5ebc93cfc421094ecb00a50dfe371bad24 ) + rom ( name "Freekstyle (USA).gba" size 8388608 crc 72434345 sha1 dcecce5ebc93cfc421094ecb00a50dfe371bad24 flags verified ) ) game ( @@ -7008,6 +7026,12 @@ game ( rom ( name "Futari wa Pretty Cure Max Heart - Maji Maji! Fight de IN Janai (Japan).gba" size 8388608 crc 541c18f9 sha1 fb6b864b13f41af2521c7e9c7bec0b490962452f ) ) +game ( + name "Fuzz & Rocket (USA) (Proto) (2005-01-18)" + description "Fuzz & Rocket (USA) (Proto) (2005-01-18)" + rom ( name "Fuzz & Rocket (USA) (Proto) (2005-01-18).gba" size 4124984 crc fd239437 sha1 e6dab28aa3e9a5b1417bbf3929c45ff7260803b0 ) +) + game ( name "Gachasute! Dino Device - Blue (Japan)" description "Gachasute! Dino Device - Blue (Japan)" @@ -7170,6 +7194,12 @@ game ( rom ( name "Gang del Bosco, La (Italy).gba" size 8388608 crc 52a5b59d sha1 75e7060b7dce72d01fbd6a6d1d8e1d752bfc92d0 ) ) +game ( + name "Gap-Man (World) (Unl)" + description "Gap-Man (World) (Unl)" + rom ( name "Gap-Man (World) (Unl).gba" size 122052 crc 05e327d1 sha1 839b1115f11192864e90637c964e79872c6b4b88 ) +) + game ( name "Garfield - The Search for Pooky (USA) (En,Fr,De,Es,It)" description "Garfield - The Search for Pooky (USA) (En,Fr,De,Es,It)" @@ -7237,9 +7267,15 @@ game ( ) game ( - name "GBA Movie Player 2 CF (Spain) (Unl)" - description "GBA Movie Player 2 CF (Spain) (Unl)" - rom ( name "GBA Movie Player 2 CF (Spain) (Unl).gba" size 1048576 crc c879b340 sha1 55cf23d0b941b68fb89e35d5ee57a78d30b54827 ) + name "GBA Movie Player - 2nd Version (World) (V2.00) (Unl)" + description "GBA Movie Player - 2nd Version (World) (V2.00) (Unl)" + rom ( name "GBA Movie Player - 2nd Version (World) (V2.00) (Unl).gba" size 524288 crc 3fc91d4f sha1 36739e9467204c6b2a64211dcda7370af23972ed ) +) + +game ( + name "GBA Movie Player - 2nd Version (World) (Unl) [b]" + description "GBA Movie Player - 2nd Version (World) (Unl) [b]" + rom ( name "GBA Movie Player - 2nd Version (World) (Unl) [b].gba" size 1048576 crc c879b340 sha1 55cf23d0b941b68fb89e35d5ee57a78d30b54827 flags baddump ) ) game ( @@ -7350,12 +7386,6 @@ game ( rom ( name "Ghost Trap (Japan).gba" size 8388608 crc 81ea54e2 sha1 00efb5ed50127f91e2a2827926cf2d4491e4b1b3 ) ) -game ( - name "Glacia Dungeon (World) (En,Es,Ru,Ro) (v1.5.2) (Aftermarket) (Unl)" - description "Glacia Dungeon (World) (En,Es,Ru,Ro) (v1.5.2) (Aftermarket) (Unl)" - rom ( name "Glacia Dungeon (World) (En,Es,Ru,Ro) (v1.5.2) (Aftermarket) (Unl).gba" size 1210608 crc ab5ae65b sha1 e35037ff9cc24f8a7043d9a9d378e86d2ef80f9b ) -) - game ( name "Global Star - Sudoku Fever (USA)" description "Global Star - Sudoku Fever (USA)" @@ -7407,7 +7437,7 @@ game ( game ( name "Golden Nugget Casino (USA, Europe)" description "Golden Nugget Casino (USA, Europe)" - rom ( name "Golden Nugget Casino (USA, Europe).gba" size 4194304 crc 56b9e9e1 sha1 5ecf4ead4b22a5916086a34bbf2abf299aaf3401 ) + rom ( name "Golden Nugget Casino (USA, Europe).gba" size 4194304 crc 56b9e9e1 sha1 5ecf4ead4b22a5916086a34bbf2abf299aaf3401 flags verified ) ) game ( @@ -7476,96 +7506,6 @@ game ( rom ( name "Golden Sun - The Lost Age (USA, Europe) (Virtual Console).gba" size 16777216 crc 726bb764 sha1 3c15317369ecafcd3c018d13c297d9107790f14f flags verified ) ) -game ( - name "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.6) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.6) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13224124 crc 19ba7d80 sha1 1bf95f8730ecdfa6665b85bea8764f42a88e8e3d ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.6) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.6) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13219728 crc d4621e3e sha1 5bd59fac58c5f9a375216e9d1cf85fa5262f21f7 ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.6) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.6) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13225068 crc 21512022 sha1 8832d38f787f3e1da620fcae7514d7387445ccf2 ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.6) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.6) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13223944 crc c1811c9b sha1 9d413bce82708df137215a2968306a5196b1638b ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.6) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.6) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13269108 crc 3360e114 sha1 50186922ff77714b9ac638948b464cdbf80ab5fb ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.6) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.6) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13223696 crc 3477ef15 sha1 4b447de09a23fbfdaa6d640824f8ceb5bbe56fab ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.6) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.6) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13250016 crc a4054c2b sha1 c3cd833b9bdf87a8481c9b05251bba782bc3527e ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.7) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.7) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13220676 crc ab179d6e sha1 2ad1c4840f2f6c2138ed44b1a7aa36071c227a0a ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.7) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.7) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13221620 crc 3aa591f1 sha1 2548615eeaecd7498e32d02b5c758b713ada27f4 ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (De) (v1.0.7) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (De) (v1.0.7) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (De) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13221368 crc d02cdb6a sha1 1e579e15bdc8dc1def99bcb3c30acfc185e0476b ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.7) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.7) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13220496 crc 906717a5 sha1 31857a9ab4daa537322f80faa77482a4b8120483 ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.7) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.7) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13220252 crc d12372bd sha1 89ea5ea41133419c317fd28e7c7f172f5bb53ec3 ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.7) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.7) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13216280 crc d3c8dffd sha1 c41c0596a4c52b0e26bb9ffe5c9f7f1c064e0be6 ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.7) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.7) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13265660 crc 119f9ddc sha1 d6c23ff47b21a7bf2f8238ac916aeea3866042b5 ) -) - -game ( - name "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.7) (Demo) (Aftermarket) (Unl)" - description "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.7) (Demo) (Aftermarket) (Unl)" - rom ( name "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13246576 crc b14cd1b4 sha1 0d15bd0584148b1658f7d47a2dda604a936ea166 ) -) - game ( name "GP-1 Racing (USA) (Proto)" description "GP-1 Racing (USA) (Proto)" @@ -7614,18 +7554,6 @@ game ( rom ( name "Green Eggs and Ham by Dr. Seuss (USA).gba" size 4194304 crc e4ae2cd1 sha1 be062fa28db26ec37ec96e5a7e6dc77cf4ad6907 ) ) -game ( - name "Green Memories (World) (v1.2.0) (Aftermarket) (Unl)" - description "Green Memories (World) (v1.2.0) (Aftermarket) (Unl)" - rom ( name "Green Memories (World) (v1.2.0) (Aftermarket) (Unl).gba" size 6639328 crc 78b81bbc sha1 fb090890bd767a22afe07b3323dd0992d698c906 ) -) - -game ( - name "Green Memories (World) (v1.4.2) (Aftermarket) (Unl)" - description "Green Memories (World) (v1.4.2) (Aftermarket) (Unl)" - rom ( name "Green Memories (World) (v1.4.2) (Aftermarket) (Unl).gba" size 6937384 crc 9fa9f00f sha1 005f4dc0d615d36d32bbe36e9cc9007b22be2ecd ) -) - game ( name "Greg Hastings' Tournament Paintball Max'd (USA)" description "Greg Hastings' Tournament Paintball Max'd (USA)" @@ -7638,18 +7566,18 @@ game ( rom ( name "Gremlins - Stripe vs Gizmo (Europe) (En,Fr,De,Es,It,Pt) (Beta).gba" size 4194304 crc 68ae6bbb sha1 6aa43d0624af03214473f329fda6334dc9c63009 ) ) -game ( - name "Gremlins - Stripe vs Gizmo (Europe) (En,Fr,De,Es,It,Pt)" - description "Gremlins - Stripe vs Gizmo (Europe) (En,Fr,De,Es,It,Pt)" - rom ( name "Gremlins - Stripe vs Gizmo (Europe) (En,Fr,De,Es,It,Pt).gba" size 4194304 crc b6225186 sha1 a2c4bf97785e717ef45e4b73a6c66a2d4ae18192 ) -) - game ( name "Gremlins - Stripe vs Gizmo (USA)" description "Gremlins - Stripe vs Gizmo (USA)" rom ( name "Gremlins - Stripe vs Gizmo (USA).gba" size 4194304 crc 5e72899a sha1 ee32e704598d2b6a21b3db271f9cf94578b94744 ) ) +game ( + name "Gremlins - Stripe vs Gizmo (Europe) (En,Fr,De,Es,It,Pt)" + description "Gremlins - Stripe vs Gizmo (Europe) (En,Fr,De,Es,It,Pt)" + rom ( name "Gremlins - Stripe vs Gizmo (Europe) (En,Fr,De,Es,It,Pt).gba" size 4194304 crc b6225186 sha1 a2c4bf97785e717ef45e4b73a6c66a2d4ae18192 ) +) + game ( name "Grim Adventures of Billy & Mandy, The (USA)" description "Grim Adventures of Billy & Mandy, The (USA)" @@ -7695,7 +7623,7 @@ game ( game ( name "GT Advance 3 - Pro Concept Racing (Europe)" description "GT Advance 3 - Pro Concept Racing (Europe)" - rom ( name "GT Advance 3 - Pro Concept Racing (Europe).gba" size 8388608 crc 03898e7f sha1 1e81d7ad7a9d8c179ef9f1a2e334a155799fe788 ) + rom ( name "GT Advance 3 - Pro Concept Racing (Europe).gba" size 8388608 crc 03898e7f sha1 1e81d7ad7a9d8c179ef9f1a2e334a155799fe788 flags verified ) ) game ( @@ -7728,18 +7656,6 @@ game ( rom ( name "Gu Huo Lang 4 (Taiwan) (Unl).gba" size 33554432 crc 1608f6db sha1 8c40ce7a06f741fb11aa717b7ce2f151279fa2e2 ) ) -game ( - name "Guilty Gear X - Advance Edition (Japan) (Beta)" - description "Guilty Gear X - Advance Edition (Japan) (Beta)" - rom ( name "Guilty Gear X - Advance Edition (Japan) (Beta).gba" size 8388608 crc 4506ada8 sha1 85915ecf10ce73afe9fffbbc8cd7a449dfe802c4 ) -) - -game ( - name "Guilty Gear X - Advance Edition (USA)" - description "Guilty Gear X - Advance Edition (USA)" - rom ( name "Guilty Gear X - Advance Edition (USA).gba" size 8388608 crc 70db3f96 sha1 bb064410c57324b25de96d297338cc5e73262fe6 ) -) - game ( name "Guilty Gear X - Advance Edition (Japan)" description "Guilty Gear X - Advance Edition (Japan)" @@ -7752,6 +7668,18 @@ game ( rom ( name "Guilty Gear X - Advance Edition (Europe).gba" size 8388608 crc ba95861d sha1 8236a650a18dfedc22da7c00b5affd3e752ec5de ) ) +game ( + name "Guilty Gear X - Advance Edition (USA)" + description "Guilty Gear X - Advance Edition (USA)" + rom ( name "Guilty Gear X - Advance Edition (USA).gba" size 8388608 crc 70db3f96 sha1 bb064410c57324b25de96d297338cc5e73262fe6 ) +) + +game ( + name "Guilty Gear X - Advance Edition (Japan) (Beta)" + description "Guilty Gear X - Advance Edition (Japan) (Beta)" + rom ( name "Guilty Gear X - Advance Edition (Japan) (Beta).gba" size 8388608 crc 4506ada8 sha1 85915ecf10ce73afe9fffbbc8cd7a449dfe802c4 ) +) + game ( name "Gumby vs. the Astrobots (USA)" description "Gumby vs. the Astrobots (USA)" @@ -7789,9 +7717,9 @@ game ( ) game ( - name "Guru Logic Champ (Japan)" - description "Guru Logic Champ (Japan)" - rom ( name "Guru Logic Champ (Japan).gba" size 4194304 crc 30d04ad9 sha1 77588b6e802de57d1d826c4d43e4c3b0e3aebdae ) + name "Guru Logichamp (Japan)" + description "Guru Logichamp (Japan)" + rom ( name "Guru Logichamp (Japan).gba" size 4194304 crc 30d04ad9 sha1 77588b6e802de57d1d826c4d43e4c3b0e3aebdae ) ) game ( @@ -7959,7 +7887,7 @@ game ( game ( name "Hamtaro - Rainbow Rescue (USA) (Proto) (2003-07-29)" description "Hamtaro - Rainbow Rescue (USA) (Proto) (2003-07-29)" - rom ( name "Hamtaro - Rainbow Rescue (USA) (Proto) (2003-07-29).gba" size 16777216 crc fd630f6c sha1 14cf38e86f019572393f0109680ff2db345f9f50 ) + rom ( name "Hamtaro - Rainbow Rescue (USA) (Proto) (2003-07-29).gba" size 8388608 crc 5c5b934d sha1 b081395415fae9cd59963a5b85bc7cc0d5623cb9 ) ) game ( @@ -7977,13 +7905,13 @@ game ( game ( name "Happy Feet (Europe) (En,Fr,De,Es,It)" description "Happy Feet (Europe) (En,Fr,De,Es,It)" - rom ( name "Happy Feet (Europe) (En,Fr,De,Es,It).gba" size 33554432 crc 7a53173c sha1 cbccce77bb727efa7ab4805509773121239faf13 ) + rom ( name "Happy Feet (Europe) (En,Fr,De,Es,It).gba" size 33554432 crc b8653e59 sha1 1eabcfe84bd7558f64197e890a0eda8e76cdbc2c ) ) game ( name "Happy Feet (USA) (En,Fr)" description "Happy Feet (USA) (En,Fr)" - rom ( name "Happy Feet (USA) (En,Fr).gba" size 33554432 crc 682617cf sha1 e7c95cbc076e97ed2a414abc9f8d419e47174505 ) + rom ( name "Happy Feet (USA) (En,Fr).gba" size 33554432 crc 98235433 sha1 be8373ca6b9969af85303b1ec910ceb28b4f59f6 flags verified ) ) game ( @@ -8067,7 +7995,7 @@ game ( game ( name "Harry Potter Collection (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" description "Harry Potter Collection (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - rom ( name "Harry Potter Collection (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gba" size 33554432 crc ffa9f4fb sha1 a0e1a8f0c31ffd6e82ef99c95f903347a6eae623 ) + rom ( name "Harry Potter Collection (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gba" size 33554432 crc 4f39c174 sha1 1af909d2e9604501b094da95dd3e4d96e72778e8 ) ) game ( @@ -8220,6 +8148,12 @@ game ( rom ( name "Hi Hi Puffy AmiYumi - Kaznapped! (Europe) (En,De).gba" size 8388608 crc e5531d04 sha1 4060be81c5a0bc741d759f75cd83823106e5b6b9 ) ) +game ( + name "Hi Hi Puffy AmiYumi - Puffy Ami Yumi and the Manga Madman! (USA) (Proto)" + description "Hi Hi Puffy AmiYumi - Puffy Ami Yumi and the Manga Madman! (USA) (Proto)" + rom ( name "Hi Hi Puffy AmiYumi - Puffy Ami Yumi and the Manga Madman! (USA) (Proto).gba" size 8388608 crc d048ec49 sha1 f0a5e83593a3dd2c32166e6a6e48d550d7de9ecb ) +) + game ( name "Higanbana (Japan) (Rev 1)" description "Higanbana (Japan) (Rev 1)" @@ -8337,7 +8271,7 @@ game ( game ( name "Home on the Range (USA) (En,Fr)" description "Home on the Range (USA) (En,Fr)" - rom ( name "Home on the Range (USA) (En,Fr).gba" size 8388608 crc dbd4a6cb sha1 321bce711714f718ac3882acdc3c0f659db5191d ) + rom ( name "Home on the Range (USA) (En,Fr).gba" size 8388608 crc dbd4a6cb sha1 321bce711714f718ac3882acdc3c0f659db5191d flags verified ) ) game ( @@ -8520,18 +8454,18 @@ game ( rom ( name "Hugo 2 in 1 (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi,Pl).gba" size 8388608 crc 8eae8860 sha1 ba780a01415ac4b814e5376c077fda21d493f396 ) ) -game ( - name "Hunter X Hunter - Minna Tomodachi Daisakusen!! (Japan)" - description "Hunter X Hunter - Minna Tomodachi Daisakusen!! (Japan)" - rom ( name "Hunter X Hunter - Minna Tomodachi Daisakusen!! (Japan).gba" size 16777216 crc af22a5ea sha1 e752cad1fa3ffec56c9f6ca5886f37da0dc74240 ) -) - game ( name "Hunter X Hunter - Minna Tomodachi Daisakusen!! (Japan) (Rev 1)" description "Hunter X Hunter - Minna Tomodachi Daisakusen!! (Japan) (Rev 1)" rom ( name "Hunter X Hunter - Minna Tomodachi Daisakusen!! (Japan) (Rev 1).gba" size 16777216 crc 86c21aeb sha1 5a327073c67ee6a29bdd595f0c4031f055804e32 ) ) +game ( + name "Hunter X Hunter - Minna Tomodachi Daisakusen!! (Japan)" + description "Hunter X Hunter - Minna Tomodachi Daisakusen!! (Japan)" + rom ( name "Hunter X Hunter - Minna Tomodachi Daisakusen!! (Japan).gba" size 16777216 crc af22a5ea sha1 e752cad1fa3ffec56c9f6ca5886f37da0dc74240 ) +) + game ( name "Huo-Wen Zhanji - Fengyin Zhi Jian (China) (Proto)" description "Huo-Wen Zhanji - Fengyin Zhi Jian (China) (Proto)" @@ -8550,6 +8484,12 @@ game ( rom ( name "I Spy Challenger! (USA).gba" size 8388608 crc 946d2cbb sha1 532934239ea1151927fd45298d918e0646a6bea4 ) ) +game ( + name "I-Ninja (USA) (Proto)" + description "I-Ninja (USA) (Proto)" + rom ( name "I-Ninja (USA) (Proto).gba" size 8388608 crc 8f31e9c6 sha1 c5ca0f7d1d836285202fbd674ef914a7da87b024 ) +) + game ( name "Ice Age (USA) (En,Fr,Es)" description "Ice Age (USA) (En,Fr,Es)" @@ -8652,30 +8592,12 @@ game ( rom ( name "Increibles, Los (Spain).gba" size 8388608 crc fc6ccadb sha1 c87047934ae328f52ef6b01083a57c65cbbab514 ) ) -game ( - name "Inheritors of the Oubliette (World) (v1.2) (Aftermarket) (Unl)" - description "Inheritors of the Oubliette (World) (v1.2) (Aftermarket) (Unl)" - rom ( name "Inheritors of the Oubliette (World) (v1.2) (Aftermarket) (Unl).gba" size 10592124 crc a9014760 sha1 2430c6c0784912ad2f0b51e633bf577f087f189f ) -) - -game ( - name "Inheritors of the Oubliette (World) (GBA Jam) (Aftermarket) (Unl)" - description "Inheritors of the Oubliette (World) (GBA Jam) (Aftermarket) (Unl)" - rom ( name "Inheritors of the Oubliette (World) (GBA Jam) (Aftermarket) (Unl).gba" size 25516708 crc 965a1a75 sha1 ae23cfba1f53a9bbde025490f3d7bdf52c3970e4 ) -) - game ( name "Initial D - Another Stage (Japan)" description "Initial D - Another Stage (Japan)" rom ( name "Initial D - Another Stage (Japan).gba" size 8388608 crc 23110a94 sha1 abc8a136e00e38132bf07d38cf28e52a2719fab9 ) ) -game ( - name "Inky and the Alien Aquarium (World) (Demo) (Aftermarket) (Unl)" - description "Inky and the Alien Aquarium (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Inky and the Alien Aquarium (World) (Demo) (Aftermarket) (Unl).gba" size 3145728 crc 7ee7ae7f sha1 73d870fad3caa86b6f659e13b57eddac80db2f37 ) -) - game ( name "Inspector Gadget - Advance Mission (Europe) (En,Fr,De,Es,It,Nl)" description "Inspector Gadget - Advance Mission (Europe) (En,Fr,De,Es,It,Nl)" @@ -8748,12 +8670,6 @@ game ( rom ( name "iQue Video & Audio (China).gba" size 16777216 crc 92852a72 sha1 79c7494c116e276f85a5f62d59f3a4588bd88391 ) ) -game ( - name "Iridion 3D (USA) (Aftermarket) (Unl)" - description "Iridion 3D (USA) (Aftermarket) (Unl)" - rom ( name "Iridion 3D (USA) (Aftermarket) (Unl).gba" size 4194304 crc 4c7ebe42 sha1 6f1c77ab88351d2d50da412e4788fc7ca8a6714d ) -) - game ( name "Iridion 3D (USA, Europe)" description "Iridion 3D (USA, Europe)" @@ -8778,12 +8694,6 @@ game ( rom ( name "Iridion II (USA) (Beta).gba" size 8388608 crc 9c63d17c sha1 3e951fd97bacd4f258bf30785af22934f7697a91 ) ) -game ( - name "Iridion II (USA) (Aftermarket) (Unl)" - description "Iridion II (USA) (Aftermarket) (Unl)" - rom ( name "Iridion II (USA) (Aftermarket) (Unl).gba" size 8388608 crc b371f070 sha1 cc788b38a047ff5ec8c445ce11efcd1852ad7c4d ) -) - game ( name "Iron Kid (Korea)" description "Iron Kid (Korea)" @@ -8793,7 +8703,7 @@ game ( game ( name "Island Xtreme Stunts (USA, Europe) (En,Fr,De,Es,It,Nl,Sv,Da)" description "Island Xtreme Stunts (USA, Europe) (En,Fr,De,Es,It,Nl,Sv,Da)" - rom ( name "Island Xtreme Stunts (USA, Europe) (En,Fr,De,Es,It,Nl,Sv,Da).gba" size 4194304 crc 3beb5446 sha1 4eec876994bdea873188fe10033c48c924d129ec ) + rom ( name "Island Xtreme Stunts (USA, Europe) (En,Fr,De,Es,It,Nl,Sv,Da).gba" size 4194304 crc 3beb5446 sha1 4eec876994bdea873188fe10033c48c924d129ec flags verified ) ) game ( @@ -8907,7 +8817,7 @@ game ( game ( name "Jimmy Neutron - Boy Genius (USA)" description "Jimmy Neutron - Boy Genius (USA)" - rom ( name "Jimmy Neutron - Boy Genius (USA).gba" size 4194304 crc d3ee0c51 sha1 31ed7659e2e072d1c00baf95c0ee9c770e949900 ) + rom ( name "Jimmy Neutron - Boy Genius (USA).gba" size 4194304 crc d3ee0c51 sha1 31ed7659e2e072d1c00baf95c0ee9c770e949900 flags verified ) ) game ( @@ -9300,6 +9210,12 @@ game ( rom ( name "Kien (USA) (Proto).gba" size 8388608 crc 185c2eca sha1 da1673ec5ec35f8ececa3f04cb6a92d61237ce72 ) ) +game ( + name "Kien (World) (Proto) (Incub8 Games)" + description "Kien (World) (Proto) (Incub8 Games)" + rom ( name "Kien (World) (Proto) (Incub8 Games).gba" size 8350032 crc 5a64b473 sha1 3cf07cd95e5a83b65c773111051a50d9bef367eb flags verified ) +) + game ( name "Kikaika Guntai - Mech Platoon (Japan)" description "Kikaika Guntai - Mech Platoon (Japan)" @@ -9396,6 +9312,12 @@ game ( rom ( name "King of Fighters EX 2, The - Howling Blood (USA) (Beta) (2003-04-03).gba" size 8388608 crc 7704ff39 sha1 b859122c1813a5ec9fb565dcca815a9f0a52bf18 ) ) +game ( + name "King of Fighters EX 2, The - Howling Blood (Japan) (Rev 1)" + description "King of Fighters EX 2, The - Howling Blood (Japan) (Rev 1)" + rom ( name "King of Fighters EX 2, The - Howling Blood (Japan) (Rev 1).gba" size 8388608 crc dc5beacd sha1 2b7ec55de56d7f7f0932a53a0d3fcc3f36a0af8e ) +) + game ( name "King of Fighters EX 2, The - Howling Blood (Europe)" description "King of Fighters EX 2, The - Howling Blood (Europe)" @@ -9409,9 +9331,15 @@ game ( ) game ( - name "King of Fighters EX 2, The - Howling Blood (Japan) (Rev 1)" - description "King of Fighters EX 2, The - Howling Blood (Japan) (Rev 1)" - rom ( name "King of Fighters EX 2, The - Howling Blood (Japan) (Rev 1).gba" size 8388608 crc dc5beacd sha1 2b7ec55de56d7f7f0932a53a0d3fcc3f36a0af8e ) + name "King of Fighters EX, The - NeoBlood (USA) (Rev 1)" + description "King of Fighters EX, The - NeoBlood (USA) (Rev 1)" + rom ( name "King of Fighters EX, The - NeoBlood (USA) (Rev 1).gba" size 8388608 crc 0f960e70 sha1 3031264c4b27cac55c2df38ab5f2bfcafa7c301d ) +) + +game ( + name "King of Fighters EX, The - NeoBlood (Japan) (Beta)" + description "King of Fighters EX, The - NeoBlood (Japan) (Beta)" + rom ( name "King of Fighters EX, The - NeoBlood (Japan) (Beta).gba" size 8388608 crc 811ffcfa sha1 cde8454951d3509f0b2bf9de98221eef248f5f8d ) ) game ( @@ -9432,18 +9360,6 @@ game ( rom ( name "King of Fighters EX, The - NeoBlood (Europe).gba" size 8388608 crc 17e66b52 sha1 48c85734164d4d83a232b5aca6bb9a2c5b7f5317 ) ) -game ( - name "King of Fighters EX, The - NeoBlood (USA) (Rev 1)" - description "King of Fighters EX, The - NeoBlood (USA) (Rev 1)" - rom ( name "King of Fighters EX, The - NeoBlood (USA) (Rev 1).gba" size 8388608 crc 0f960e70 sha1 3031264c4b27cac55c2df38ab5f2bfcafa7c301d ) -) - -game ( - name "King of Fighters EX, The - NeoBlood (Japan) (Beta)" - description "King of Fighters EX, The - NeoBlood (Japan) (Beta)" - rom ( name "King of Fighters EX, The - NeoBlood (Japan) (Beta).gba" size 8388608 crc 811ffcfa sha1 cde8454951d3509f0b2bf9de98221eef248f5f8d ) -) - game ( name "Kingdom Hearts - Chain of Memories (Japan)" description "Kingdom Hearts - Chain of Memories (Japan)" @@ -9487,9 +9403,9 @@ game ( ) game ( - name "Kirby - Nightmare in Dream Land (USA) (Virtual Console)" - description "Kirby - Nightmare in Dream Land (USA) (Virtual Console)" - rom ( name "Kirby - Nightmare in Dream Land (USA) (Virtual Console).gba" size 8388608 crc 1af07ac8 sha1 3d142008d50a64c315fd2d7cbd86ba94dffa2e12 ) + name "Kirby - Nightmare in Dream Land (Europe) (En,Fr,De,Es,It)" + description "Kirby - Nightmare in Dream Land (Europe) (En,Fr,De,Es,It)" + rom ( name "Kirby - Nightmare in Dream Land (Europe) (En,Fr,De,Es,It).gba" size 16777216 crc 3b7a7477 sha1 39b00beee4558e6738859cfa250e4e0fcaae626e flags verified ) ) game ( @@ -9499,9 +9415,15 @@ game ( ) game ( - name "Kirby - Nightmare in Dream Land (Europe) (En,Fr,De,Es,It)" - description "Kirby - Nightmare in Dream Land (Europe) (En,Fr,De,Es,It)" - rom ( name "Kirby - Nightmare in Dream Land (Europe) (En,Fr,De,Es,It).gba" size 16777216 crc 3b7a7477 sha1 39b00beee4558e6738859cfa250e4e0fcaae626e flags verified ) + name "Kirby - Nightmare in Dream Land (USA) (Virtual Console)" + description "Kirby - Nightmare in Dream Land (USA) (Virtual Console)" + rom ( name "Kirby - Nightmare in Dream Land (USA) (Virtual Console).gba" size 8388608 crc 1af07ac8 sha1 3d142008d50a64c315fd2d7cbd86ba94dffa2e12 ) +) + +game ( + name "Kirby & The Amazing Mirror (USA) (Virtual Console)" + description "Kirby & The Amazing Mirror (USA) (Virtual Console)" + rom ( name "Kirby & The Amazing Mirror (USA) (Virtual Console).gba" size 16777216 crc f70ebb99 sha1 a7b758c2abf4f0ef722922eab4d394a1579b52e8 ) ) game ( @@ -9516,12 +9438,6 @@ game ( rom ( name "Kirby & The Amazing Mirror (USA).gba" size 16777216 crc 9f2a3048 sha1 274b102b6d940f46861a92b4e65f89a51815c12c flags verified ) ) -game ( - name "Kirby & The Amazing Mirror (USA) (Virtual Console)" - description "Kirby & The Amazing Mirror (USA) (Virtual Console)" - rom ( name "Kirby & The Amazing Mirror (USA) (Virtual Console).gba" size 16777216 crc f70ebb99 sha1 a7b758c2abf4f0ef722922eab4d394a1579b52e8 ) -) - game ( name "Kirby & The Amazing Mirror (Europe) (En,Fr,De,Es,It) (Virtual Console)" description "Kirby & The Amazing Mirror (Europe) (En,Fr,De,Es,It) (Virtual Console)" @@ -9555,13 +9471,7 @@ game ( game ( name "Klonoa - Empire of Dreams (Europe)" description "Klonoa - Empire of Dreams (Europe)" - rom ( name "Klonoa - Empire of Dreams (Europe).gba" size 4194304 crc 69492530 sha1 e4a81713b134e0b7409708843dad2a4948b903ef ) -) - -game ( - name "Klonoa 2 - Dream Champ Tournament (USA)" - description "Klonoa 2 - Dream Champ Tournament (USA)" - rom ( name "Klonoa 2 - Dream Champ Tournament (USA).gba" size 4194304 crc 8bd23a7f sha1 35c05676e65fd4c92220861662cd3709342f36e2 ) + rom ( name "Klonoa - Empire of Dreams (Europe).gba" size 4194304 crc 69492530 sha1 e4a81713b134e0b7409708843dad2a4948b903ef flags verified ) ) game ( @@ -9570,6 +9480,12 @@ game ( rom ( name "Klonoa 2 - Dream Champ Tournament (USA) (Virtual Console).gba" size 4194304 crc 766c7f9a sha1 455c6f19a703b2bd54a9a3a9588964239965e6db ) ) +game ( + name "Klonoa 2 - Dream Champ Tournament (USA)" + description "Klonoa 2 - Dream Champ Tournament (USA)" + rom ( name "Klonoa 2 - Dream Champ Tournament (USA).gba" size 4194304 crc 8bd23a7f sha1 35c05676e65fd4c92220861662cd3709342f36e2 ) +) + game ( name "Klonoa Heroes - Densetsu no Star Medal (Japan)" description "Klonoa Heroes - Densetsu no Star Medal (Japan)" @@ -9648,12 +9564,6 @@ game ( rom ( name "Konami Krazy Racers (Europe).gba" size 4194304 crc cfec0650 sha1 90a0035818ba0ab2a0c6ea45dc7eff2eb7296970 flags verified ) ) -game ( - name "Konami Krazy Racers (USA) (Beta)" - description "Konami Krazy Racers (USA) (Beta)" - rom ( name "Konami Krazy Racers (USA) (Beta).gba" size 4194304 crc 5f2ae8fe sha1 329b82282d633d1162f9afb3334c035b10b91e72 ) -) - game ( name "Konami Krazy Racers (USA) (Virtual Console)" description "Konami Krazy Racers (USA) (Virtual Console)" @@ -9667,9 +9577,9 @@ game ( ) game ( - name "Konami Wai Wai Racing Advance (Japan) (Virtual Console)" - description "Konami Wai Wai Racing Advance (Japan) (Virtual Console)" - rom ( name "Konami Wai Wai Racing Advance (Japan) (Virtual Console).gba" size 4194304 crc f424858f sha1 29f850ea1a9900446a0e1ce8ef1c2fd85341f242 ) + name "Konami Krazy Racers (USA) (Beta)" + description "Konami Krazy Racers (USA) (Beta)" + rom ( name "Konami Krazy Racers (USA) (Beta).gba" size 4194304 crc 5f2ae8fe sha1 329b82282d633d1162f9afb3334c035b10b91e72 ) ) game ( @@ -9678,6 +9588,12 @@ game ( rom ( name "Konami Wai Wai Racing Advance (Japan).gba" size 4194304 crc aa039a8a sha1 e3549b9b7d7208b88e368e7b7a59e31eec8b1da6 ) ) +game ( + name "Konami Wai Wai Racing Advance (Japan) (Virtual Console)" + description "Konami Wai Wai Racing Advance (Japan) (Virtual Console)" + rom ( name "Konami Wai Wai Racing Advance (Japan) (Virtual Console).gba" size 4194304 crc f424858f sha1 29f850ea1a9900446a0e1ce8ef1c2fd85341f242 ) +) + game ( name "Konchuu Monster - Battle Master (Japan)" description "Konchuu Monster - Battle Master (Japan)" @@ -9765,7 +9681,7 @@ game ( game ( name "Korokoro Puzzle - Happy Panecchu! (Japan)" description "Korokoro Puzzle - Happy Panecchu! (Japan)" - rom ( name "Korokoro Puzzle - Happy Panecchu! (Japan).gba" size 4194304 crc 0bfe46e9 sha1 40cb751d119a49be0cd44cf0491c93ebc8795ef0 ) + rom ( name "Korokoro Puzzle - Happy Panecchu! (Japan).gba" size 4194304 crc 0bfe46e9 sha1 40cb751d119a49be0cd44cf0491c93ebc8795ef0 flags verified ) ) game ( @@ -9951,13 +9867,13 @@ game ( game ( name "Legend of Spyro, The - The Eternal Night (USA) (En,Fr)" description "Legend of Spyro, The - The Eternal Night (USA) (En,Fr)" - rom ( name "Legend of Spyro, The - The Eternal Night (USA) (En,Fr).gba" size 33554432 crc bd2751e6 sha1 4bc88f2c7325937bbe0f16dfebda10f279d5ed20 ) + rom ( name "Legend of Spyro, The - The Eternal Night (USA) (En,Fr).gba" size 33554432 crc 8d780224 sha1 6cfa38d08b735e8b6b1c3763aee8a8ed5da52977 ) ) game ( name "Legend of Spyro, The - The Eternal Night (Europe) (En,Fr,De,Es,It,Nl)" description "Legend of Spyro, The - The Eternal Night (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Legend of Spyro, The - The Eternal Night (Europe) (En,Fr,De,Es,It,Nl).gba" size 33554432 crc 93b18353 sha1 4bce80310b43882f57c7bb5b202e09ce23687473 ) + rom ( name "Legend of Spyro, The - The Eternal Night (Europe) (En,Fr,De,Es,It,Nl).gba" size 33554432 crc a3eed091 sha1 0fced99190bce676e83bed31134e2f165ef997b8 ) ) game ( @@ -10176,10 +10092,16 @@ game ( rom ( name "Lilo & Stitch 2 - Haemsterviel Havoc (USA).gba" size 8388608 crc 021a5755 sha1 70e0dc5a8dcdf876b5dd87a4c1bbca03b6e30148 ) ) +game ( + name "Lindsi Luna Blast (World) (v1.01) (Unl)" + description "Lindsi Luna Blast (World) (v1.01) (Unl)" + rom ( name "Lindsi Luna Blast (World) (v1.01) (Unl).gba" size 4981720 crc e6fadd1a sha1 6786c08957251b3a5ab2534b15f5b2def2ee9d86 ) +) + game ( name "Lion King 1 1-2, The (USA)" description "Lion King 1 1-2, The (USA)" - rom ( name "Lion King 1 1-2, The (USA).gba" size 8388608 crc ea5ed4c0 sha1 382de6da61c5dc5c2844f5ffa28a1827d15319b1 ) + rom ( name "Lion King 1 1-2, The (USA).gba" size 8388608 crc ea5ed4c0 sha1 382de6da61c5dc5c2844f5ffa28a1827d15319b1 flags verified ) ) game ( @@ -10233,7 +10155,7 @@ game ( game ( name "Lizzie McGuire 2 - Lizzie Diaries (USA) (En,Fr)" description "Lizzie McGuire 2 - Lizzie Diaries (USA) (En,Fr)" - rom ( name "Lizzie McGuire 2 - Lizzie Diaries (USA) (En,Fr).gba" size 4194304 crc f11009f9 sha1 7ace37aec21c058aa98e3de12140cb691c070e00 ) + rom ( name "Lizzie McGuire 2 - Lizzie Diaries (USA) (En,Fr).gba" size 4194304 crc f11009f9 sha1 7ace37aec21c058aa98e3de12140cb691c070e00 flags verified ) ) game ( @@ -10368,12 +10290,6 @@ game ( rom ( name "Lufia - The Ruins of Lore (USA).gba" size 8388608 crc de5ffcbc sha1 a2b7e80a6c7d586ebeec77c8a2c2545fe27e0592 ) ) -game ( - name "Luggage Retrieval Officer (World) (Aftermarket) (Unl)" - description "Luggage Retrieval Officer (World) (Aftermarket) (Unl)" - rom ( name "Luggage Retrieval Officer (World) (Aftermarket) (Unl).gba" size 3336260 crc 5aa30d90 sha1 84c9b2d50c8af74b8b04f88af367d9fac1a24ef6 ) -) - game ( name "Lunar Legend (Japan)" description "Lunar Legend (Japan)" @@ -10657,9 +10573,9 @@ game ( ) game ( - name "Mandrake the Magician (Italy) (It) (Proto)" - description "Mandrake the Magician (Italy) (It) (Proto)" - rom ( name "Mandrake the Magician (Italy) (It) (Proto).gba" size 8388608 crc 7cfe1889 sha1 ddb5f0cdd5db80c22a448650c1b05d02feb0b831 ) + name "Mandrake the Magician (Italy) (Proto)" + description "Mandrake the Magician (Italy) (Proto)" + rom ( name "Mandrake the Magician (Italy) (Proto).gba" size 8388608 crc 7cfe1889 sha1 ddb5f0cdd5db80c22a448650c1b05d02feb0b831 ) ) game ( @@ -11013,13 +10929,13 @@ game ( game ( name "Mary-Kate and Ashley - Girls Night Out (USA, Europe)" description "Mary-Kate and Ashley - Girls Night Out (USA, Europe)" - rom ( name "Mary-Kate and Ashley - Girls Night Out (USA, Europe).gba" size 4194304 crc 8af3f3ad sha1 4b46751b6deb8064d58a0786d62b37206c9529ac ) + rom ( name "Mary-Kate and Ashley - Girls Night Out (USA, Europe).gba" size 4194304 crc 8af3f3ad sha1 4b46751b6deb8064d58a0786d62b37206c9529ac flags verified ) ) game ( name "Mary-Kate and Ashley - Sweet 16 - Licensed to Drive (USA, Europe)" description "Mary-Kate and Ashley - Sweet 16 - Licensed to Drive (USA, Europe)" - rom ( name "Mary-Kate and Ashley - Sweet 16 - Licensed to Drive (USA, Europe).gba" size 4194304 crc 5fe092c6 sha1 284059f03f0dda9ce511d3c57bf0607706b9fca3 ) + rom ( name "Mary-Kate and Ashley - Sweet 16 - Licensed to Drive (USA, Europe).gba" size 4194304 crc 5fe092c6 sha1 284059f03f0dda9ce511d3c57bf0607706b9fca3 flags verified ) ) game ( @@ -11058,18 +10974,6 @@ game ( rom ( name "Matantei Loki Ragnarok - Gensou no Labyrinth (Japan) (Rev 1).gba" size 8388608 crc d647ab18 sha1 3489569fa8a3c6a750c5cb0048915da78c5f40ab ) ) -game ( - name "Matchbox Cross Town Heroes (USA)" - description "Matchbox Cross Town Heroes (USA)" - rom ( name "Matchbox Cross Town Heroes (USA).gba" size 4194304 crc 0fffb458 sha1 6baa6bfe76b077f365bedffa52346b94689b61d7 ) -) - -game ( - name "Matchbox Cross Town Heroes (Europe)" - description "Matchbox Cross Town Heroes (Europe)" - rom ( name "Matchbox Cross Town Heroes (Europe).gba" size 4194304 crc c9ea02f5 sha1 13310b7f25a0332a8e09e722587ec79aee11c373 ) -) - game ( name "Math Patrol - The Kleptoid Threat (USA)" description "Math Patrol - The Kleptoid Threat (USA)" @@ -11142,6 +11046,12 @@ game ( rom ( name "Medabots - Metabee (Europe).gba" size 8388608 crc 50927f3e sha1 cd3d674e88f40a0707b150c4293588a659001d29 ) ) +game ( + name "Medabots - Metabee (USA)" + description "Medabots - Metabee (USA)" + rom ( name "Medabots - Metabee (USA).gba" size 8388608 crc 59f208fc sha1 ca185b65ab50ef89a10c8db00d9cd76626b81610 ) +) + game ( name "Medabots - Metabee (Spain)" description "Medabots - Metabee (Spain)" @@ -11155,15 +11065,9 @@ game ( ) game ( - name "Medabots - Metabee (USA)" - description "Medabots - Metabee (USA)" - rom ( name "Medabots - Metabee (USA).gba" size 8388608 crc 59f208fc sha1 ca185b65ab50ef89a10c8db00d9cd76626b81610 ) -) - -game ( - name "Medabots - Rokusho (USA)" - description "Medabots - Rokusho (USA)" - rom ( name "Medabots - Rokusho (USA).gba" size 8388608 crc e144ded2 sha1 c4572428ea97b302f699a3b4eba2a1f0e87c1c9c ) + name "Medabots - Rokusho (Spain)" + description "Medabots - Rokusho (Spain)" + rom ( name "Medabots - Rokusho (Spain).gba" size 8388608 crc 046d86c4 sha1 90fe7f2927c592aabc9b33d0df00d92046c5cb92 ) ) game ( @@ -11185,15 +11089,9 @@ game ( ) game ( - name "Medabots - Rokusho (Spain)" - description "Medabots - Rokusho (Spain)" - rom ( name "Medabots - Rokusho (Spain).gba" size 8388608 crc 046d86c4 sha1 90fe7f2927c592aabc9b33d0df00d92046c5cb92 ) -) - -game ( - name "Medabots AX - Metabee Ver. (USA)" - description "Medabots AX - Metabee Ver. (USA)" - rom ( name "Medabots AX - Metabee Ver. (USA).gba" size 8388608 crc 03294511 sha1 80c024df6d40e499776665d7f0c494a252973048 ) + name "Medabots - Rokusho (USA)" + description "Medabots - Rokusho (USA)" + rom ( name "Medabots - Rokusho (USA).gba" size 8388608 crc e144ded2 sha1 c4572428ea97b302f699a3b4eba2a1f0e87c1c9c ) ) game ( @@ -11202,6 +11100,12 @@ game ( rom ( name "Medabots AX - Metabee Ver. (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc 5f1e5a48 sha1 130c908d24ba3e422fd8db84e683bacc87235e78 flags verified ) ) +game ( + name "Medabots AX - Metabee Ver. (USA)" + description "Medabots AX - Metabee Ver. (USA)" + rom ( name "Medabots AX - Metabee Ver. (USA).gba" size 8388608 crc 03294511 sha1 80c024df6d40e499776665d7f0c494a252973048 ) +) + game ( name "Medabots AX - Metabee Ver. (USA) (Virtual Console)" description "Medabots AX - Metabee Ver. (USA) (Virtual Console)" @@ -11244,12 +11148,6 @@ game ( rom ( name "Medal of Honor - Infiltrator (USA, Europe) (En,Fr,De).gba" size 16777216 crc f23150a4 sha1 47761911475e9548c81fed78e3d3336ddae89a58 flags verified ) ) -game ( - name "Medal of Honor - Underground (Europe) (En,Fr,Es,It) (Zoo Digital)" - description "Medal of Honor - Underground (Europe) (En,Fr,Es,It) (Zoo Digital)" - rom ( name "Medal of Honor - Underground (Europe) (En,Fr,Es,It) (Zoo Digital).gba" size 8388608 crc 72b4cf20 sha1 abb26d759ef729d21e41a913fc6c1ce4ab77149f ) -) - game ( name "Medal of Honor - Underground (USA)" description "Medal of Honor - Underground (USA)" @@ -11262,6 +11160,12 @@ game ( rom ( name "Medal of Honor - Underground (Europe) (En,Fr,Es,It) (Ubi Soft).gba" size 8388608 crc 9db145b8 sha1 e43aaba3f925443cfccf9294b870024a9c71a9a9 ) ) +game ( + name "Medal of Honor - Underground (Europe) (En,Fr,Es,It) (Zoo Digital)" + description "Medal of Honor - Underground (Europe) (En,Fr,Es,It) (Zoo Digital)" + rom ( name "Medal of Honor - Underground (Europe) (En,Fr,Es,It) (Zoo Digital).gba" size 8388608 crc 72b4cf20 sha1 abb26d759ef729d21e41a913fc6c1ce4ab77149f ) +) + game ( name "Medal of Honor Advance (Japan)" description "Medal of Honor Advance (Japan)" @@ -11550,18 +11454,6 @@ game ( rom ( name "Megaman - Battle Network 5 - Team Colonel (Europe) (Virtual Console).gba" size 8388608 crc 5247772c sha1 061c291b29629d5ce44011d2d83931f2e35044ed ) ) -game ( - name "Megaman - Battle Network 5 - Team Protoman (Europe)" - description "Megaman - Battle Network 5 - Team Protoman (Europe)" - rom ( name "Megaman - Battle Network 5 - Team Protoman (Europe).gba" size 8388608 crc 79f45ed8 sha1 3d017ed23535e42174299ff89fff44678eb553c3 ) -) - -game ( - name "Megaman - Battle Network 5 - Team Protoman (USA)" - description "Megaman - Battle Network 5 - Team Protoman (USA)" - rom ( name "Megaman - Battle Network 5 - Team Protoman (USA).gba" size 8388608 crc a73e83a4 sha1 b3774e96b1f107bb8b1db79b216be41b9bc5bac0 ) -) - game ( name "Megaman - Battle Network 5 - Team Protoman (USA) (Virtual Console)" description "Megaman - Battle Network 5 - Team Protoman (USA) (Virtual Console)" @@ -11574,6 +11466,18 @@ game ( rom ( name "Megaman - Battle Network 5 - Team Protoman (Europe) (Virtual Console).gba" size 8388608 crc 7e5bc83d sha1 b68b310e3106e7fa6a47d4155239be2e43959da4 ) ) +game ( + name "Megaman - Battle Network 5 - Team Protoman (Europe)" + description "Megaman - Battle Network 5 - Team Protoman (Europe)" + rom ( name "Megaman - Battle Network 5 - Team Protoman (Europe).gba" size 8388608 crc 79f45ed8 sha1 3d017ed23535e42174299ff89fff44678eb553c3 ) +) + +game ( + name "Megaman - Battle Network 5 - Team Protoman (USA)" + description "Megaman - Battle Network 5 - Team Protoman (USA)" + rom ( name "Megaman - Battle Network 5 - Team Protoman (USA).gba" size 8388608 crc a73e83a4 sha1 b3774e96b1f107bb8b1db79b216be41b9bc5bac0 ) +) + game ( name "Megaman - Battle Network 6 - Cybeast Falzar (Europe)" description "Megaman - Battle Network 6 - Cybeast Falzar (Europe)" @@ -11628,12 +11532,6 @@ game ( rom ( name "Megaman & Bass (USA) (Virtual Console).gba" size 8388608 crc b61f99d4 sha1 37db963a52aecec8018057cef3811860c3e889ed ) ) -game ( - name "Megaman & Bass (Europe)" - description "Megaman & Bass (Europe)" - rom ( name "Megaman & Bass (Europe).gba" size 8388608 crc 01b4d95e sha1 5d6f8fb1f52803a54e9857e53d0b88173cf8f48a flags verified ) -) - game ( name "Megaman & Bass (Europe) (Virtual Console)" description "Megaman & Bass (Europe) (Virtual Console)" @@ -11647,9 +11545,9 @@ game ( ) game ( - name "Megaman Zero (USA, Europe)" - description "Megaman Zero (USA, Europe)" - rom ( name "Megaman Zero (USA, Europe).gba" size 8388608 crc 9707d2a1 sha1 193b14120119162518a73c70876f0b8bffdbd96e flags verified ) + name "Megaman & Bass (Europe)" + description "Megaman & Bass (Europe)" + rom ( name "Megaman & Bass (Europe).gba" size 8388608 crc 01b4d95e sha1 5d6f8fb1f52803a54e9857e53d0b88173cf8f48a flags verified ) ) game ( @@ -11659,9 +11557,9 @@ game ( ) game ( - name "Megaman Zero 2 (USA) (Virtual Console)" - description "Megaman Zero 2 (USA) (Virtual Console)" - rom ( name "Megaman Zero 2 (USA) (Virtual Console).gba" size 8388608 crc 30d051fe sha1 d7a1edd912f8e01bc442809b922bceaf5a1f0176 ) + name "Megaman Zero (USA, Europe)" + description "Megaman Zero (USA, Europe)" + rom ( name "Megaman Zero (USA, Europe).gba" size 8388608 crc 9707d2a1 sha1 193b14120119162518a73c70876f0b8bffdbd96e flags verified ) ) game ( @@ -11683,9 +11581,9 @@ game ( ) game ( - name "Megaman Zero 3 (Europe) (Virtual Console)" - description "Megaman Zero 3 (Europe) (Virtual Console)" - rom ( name "Megaman Zero 3 (Europe) (Virtual Console).gba" size 8388608 crc 87e8656e sha1 8245ecb895caf0e0a2914f46bb79e4c9c5ba8c4a ) + name "Megaman Zero 2 (USA) (Virtual Console)" + description "Megaman Zero 2 (USA) (Virtual Console)" + rom ( name "Megaman Zero 2 (USA) (Virtual Console).gba" size 8388608 crc 30d051fe sha1 d7a1edd912f8e01bc442809b922bceaf5a1f0176 ) ) game ( @@ -11706,6 +11604,12 @@ game ( rom ( name "Megaman Zero 3 (USA).gba" size 8388608 crc 2784f3f2 sha1 403a78f2cad93d41e4b0f2e520ce08026531664b ) ) +game ( + name "Megaman Zero 3 (Europe) (Virtual Console)" + description "Megaman Zero 3 (Europe) (Virtual Console)" + rom ( name "Megaman Zero 3 (Europe) (Virtual Console).gba" size 8388608 crc 87e8656e sha1 8245ecb895caf0e0a2914f46bb79e4c9c5ba8c4a ) +) + game ( name "Megaman Zero 4 (Europe) (Virtual Console)" description "Megaman Zero 4 (Europe) (Virtual Console)" @@ -11784,6 +11688,12 @@ game ( rom ( name "Mermaid Melody - Pichi Pichi Pitch - Pichi Pichitto Live Start! (Japan).gba" size 33554432 crc 7a4fdec3 sha1 d6bd3140b83fb9b1c2d84b6faf21c7286e29d129 ) ) +game ( + name "Metal Gear Solid 2D - Sensible (World) (v0.31) (Demo) (Unl)" + description "Metal Gear Solid 2D - Sensible (World) (v0.31) (Demo) (Unl)" + rom ( name "Metal Gear Solid 2D - Sensible (World) (v0.31) (Demo) (Unl).gba" size 149668 crc c797641c sha1 e8a32fbd80f644e9828369603c1a926392a4c105 ) +) + game ( name "Metal Max 2 Kai (Japan)" description "Metal Max 2 Kai (Japan)" @@ -11826,12 +11736,6 @@ game ( rom ( name "Metal Slug Advance (Europe).gba" size 8388608 crc 3806f4ae sha1 0719aee29b0da365e7ad52bb0ae9545bcd377152 flags verified ) ) -game ( - name "Metal Warrior 4 (World) (v1.3) (Aftermarket) (Unl)" - description "Metal Warrior 4 (World) (v1.3) (Aftermarket) (Unl)" - rom ( name "Metal Warrior 4 (World) (v1.3) (Aftermarket) (Unl).gba" size 524288 crc 7ec3485e sha1 729592141bc160ead0af51d4322c7f9f17da0b82 ) -) - game ( name "Metalgun Slinger (Japan)" description "Metalgun Slinger (Japan)" @@ -11844,6 +11748,24 @@ game ( rom ( name "Metroid - Zero Mission (Japan) (Virtual Console).gba" size 8388608 crc 220b68f5 sha1 24d99f32875464dbcef5ca8ec231ec42073ff1e8 ) ) +game ( + name "Metroid - Zero Mission (USA)" + description "Metroid - Zero Mission (USA)" + rom ( name "Metroid - Zero Mission (USA).gba" size 8388608 crc 5c61a844 sha1 5de8536afe1f0078ee6fe1089f890e8c7aa0a6e8 flags verified ) +) + +game ( + name "Metroid - Zero Mission (Europe) (En,Fr,De,Es,It)" + description "Metroid - Zero Mission (Europe) (En,Fr,De,Es,It)" + rom ( name "Metroid - Zero Mission (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc f1d92e63 sha1 0fd107445a42e6f3a3e5ce8c865f412583179903 flags verified ) +) + +game ( + name "Metroid - Zero Mission (Japan)" + description "Metroid - Zero Mission (Japan)" + rom ( name "Metroid - Zero Mission (Japan).gba" size 8388608 crc 44b79e2b sha1 096f07685a3dc9286e71aa0b761f233b5efa2fcd ) +) + game ( name "Metroid - Zero Mission (Europe) (En,Fr,De,Es,It) (Beta)" description "Metroid - Zero Mission (Europe) (En,Fr,De,Es,It) (Beta)" @@ -11869,21 +11791,27 @@ game ( ) game ( - name "Metroid - Zero Mission (USA)" - description "Metroid - Zero Mission (USA)" - rom ( name "Metroid - Zero Mission (USA).gba" size 8388608 crc 5c61a844 sha1 5de8536afe1f0078ee6fe1089f890e8c7aa0a6e8 flags verified ) + name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-11)" + description "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-11)" + rom ( name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-11).gba" size 16777216 crc 3acbd239 sha1 a45b539becbf10f3913255d6d624ee954dcc5593 ) ) game ( - name "Metroid - Zero Mission (Europe) (En,Fr,De,Es,It)" - description "Metroid - Zero Mission (Europe) (En,Fr,De,Es,It)" - rom ( name "Metroid - Zero Mission (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc f1d92e63 sha1 0fd107445a42e6f3a3e5ce8c865f412583179903 flags verified ) + name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-16)" + description "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-16)" + rom ( name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-16).gba" size 8388608 crc 1605e4f7 sha1 f688f2d3186a0a90040abb214efd1e8e93a424cd ) ) game ( - name "Metroid - Zero Mission (Japan)" - description "Metroid - Zero Mission (Japan)" - rom ( name "Metroid - Zero Mission (Japan).gba" size 8388608 crc 44b79e2b sha1 096f07685a3dc9286e71aa0b761f233b5efa2fcd ) + name "Metroid Fusion (USA) (Virtual Console)" + description "Metroid Fusion (USA) (Virtual Console)" + rom ( name "Metroid Fusion (USA) (Virtual Console).gba" size 8388608 crc 162a46b8 sha1 c63419a4ee7c2a5e412fa16645ee04cb24027724 ) +) + +game ( + name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Virtual Console)" + description "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Virtual Console)" + rom ( name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Virtual Console).gba" size 8388608 crc eee01b78 sha1 82e507863f647dc566bbf45227e8cd284052ecba ) ) game ( @@ -11910,30 +11838,6 @@ game ( rom ( name "Metroid Fusion (Japan).gba" size 8388608 crc 817a7e9e sha1 5d21c668baa84da4a5b745be56809bb277f947a3 flags verified ) ) -game ( - name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-11)" - description "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-11)" - rom ( name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-11).gba" size 16777216 crc 3acbd239 sha1 a45b539becbf10f3913255d6d624ee954dcc5593 ) -) - -game ( - name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-16)" - description "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-16)" - rom ( name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Beta) (2002-09-16).gba" size 8388608 crc 1605e4f7 sha1 f688f2d3186a0a90040abb214efd1e8e93a424cd ) -) - -game ( - name "Metroid Fusion (USA) (Virtual Console)" - description "Metroid Fusion (USA) (Virtual Console)" - rom ( name "Metroid Fusion (USA) (Virtual Console).gba" size 8388608 crc 162a46b8 sha1 c63419a4ee7c2a5e412fa16645ee04cb24027724 ) -) - -game ( - name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Virtual Console)" - description "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Virtual Console)" - rom ( name "Metroid Fusion (Europe) (En,Fr,De,Es,It) (Virtual Console).gba" size 8388608 crc eee01b78 sha1 82e507863f647dc566bbf45227e8cd284052ecba ) -) - game ( name "Mezase! Koushien (Japan)" description "Mezase! Koushien (Japan)" @@ -12036,24 +11940,6 @@ game ( rom ( name "Mini Moni. - Onegai Ohoshi-sama! (Japan).gba" size 8388608 crc f11c35cc sha1 d34795cf3679c6f259177db52a138c0d6e9fcdfd ) ) -game ( - name "Minicraft (World) (v1.0) (Aftermarket) (Unl)" - description "Minicraft (World) (v1.0) (Aftermarket) (Unl)" - rom ( name "Minicraft (World) (v1.0) (Aftermarket) (Unl).gba" size 131072 crc e852c9e9 sha1 06faa5be11978666db6995d8fce40ce2c3641ce8 ) -) - -game ( - name "Minicraft (World) (v1.1) (Aftermarket) (Unl)" - description "Minicraft (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Minicraft (World) (v1.1) (Aftermarket) (Unl).gba" size 131072 crc 07595773 sha1 fee5cfa5b9e1f3383780432772f29764ac0fc443 ) -) - -game ( - name "Minicraft (World) (v1.2) (Aftermarket) (Unl)" - description "Minicraft (World) (v1.2) (Aftermarket) (Unl)" - rom ( name "Minicraft (World) (v1.2) (Aftermarket) (Unl).gba" size 131072 crc 37e7ee7d sha1 dc7faa4952986d5c5f0e3b32203936cd717f97eb ) -) - game ( name "Minna de Puyo Puyo (Japan) (En,Ja)" description "Minna de Puyo Puyo (Japan) (En,Ja)" @@ -12162,12 +12048,6 @@ game ( rom ( name "Mirakuru! Panzou - 7-tsu no Hoshi no Uchuu Kaizoku (Japan).gba" size 4194304 crc 3a87f78b sha1 ad916495bbb9c3ee34b68c13f118a4cbcdb18b3b ) ) -game ( - name "Misfortune Advance (World) (Aftermarket) (Unl)" - description "Misfortune Advance (World) (Aftermarket) (Unl)" - rom ( name "Misfortune Advance (World) (Aftermarket) (Unl).gba" size 5125100 crc 18f2166d sha1 68e215025ac963220f16ea3c100e51698f97c4eb ) -) - game ( name "Mission Impossible - Operation Surma (Europe) (En,Fr,De,Es,It)" description "Mission Impossible - Operation Surma (Europe) (En,Fr,De,Es,It)" @@ -12420,18 +12300,6 @@ game ( rom ( name "Monsters, Inc. (Europe) (En,Es,Nl).gba" size 4194304 crc d13177e0 sha1 36645b8de074f0b27dbe61528e70ae3af28fb3b9 ) ) -game ( - name "Mooncat's Trio (World) (Aftermarket) (Unl)" - description "Mooncat's Trio (World) (Aftermarket) (Unl)" - rom ( name "Mooncat's Trio (World) (Aftermarket) (Unl).gba" size 1175680 crc b05d5339 sha1 890de7d73723d235d9762e4866d569d3554d1480 flags verified ) -) - -game ( - name "Mooncat's Trio (World) (Beta) (Aftermarket) (Unl)" - description "Mooncat's Trio (World) (Beta) (Aftermarket) (Unl)" - rom ( name "Mooncat's Trio (World) (Beta) (Aftermarket) (Unl).gba" size 504220 crc cd3328ee sha1 c3ea5247f32c428bbcfd5c087218fc56779e3106 ) -) - game ( name "Moorhen 3 - The Chicken Chase! (Europe) (En,Fr,De,Es,It)" description "Moorhen 3 - The Chicken Chase! (Europe) (En,Fr,De,Es,It)" @@ -12699,7 +12567,7 @@ game ( game ( name "My Animal Centre in Africa (Europe) (En,Fr,De,Es,It)" description "My Animal Centre in Africa (Europe) (En,Fr,De,Es,It)" - rom ( name "My Animal Centre in Africa (Europe) (En,Fr,De,Es,It).gba" size 33554432 crc 16c0e028 sha1 e85cea8428d51e40cf1b7a90643e94604973679f ) + rom ( name "My Animal Centre in Africa (Europe) (En,Fr,De,Es,It).gba" size 33554432 crc d4f6c94d sha1 0f4f86e0c2243d847d16488e42b07e26679dc0ae ) ) game ( @@ -12765,7 +12633,7 @@ game ( game ( name "Namco Museum (Europe)" description "Namco Museum (Europe)" - rom ( name "Namco Museum (Europe).gba" size 4194304 crc bb82460a sha1 3e84508a0d2362a0abf31dede1d55b865566213c ) + rom ( name "Namco Museum (Europe).gba" size 4194304 crc bb82460a sha1 3e84508a0d2362a0abf31dede1d55b865566213c flags verified ) ) game ( @@ -12900,6 +12768,18 @@ game ( rom ( name "NBA Jam 2002 (USA, Europe).gba" size 4194304 crc ca428a7a sha1 38de98758669b120b895661bec3882c3474cf47e ) ) +game ( + name "Nebulus (World) (v1.2) (Unl)" + description "Nebulus (World) (v1.2) (Unl)" + rom ( name "Nebulus (World) (v1.2) (Unl).gba" size 557936 crc 77e2d5f0 sha1 086f7d7e86cfbaff43a4ce35c179e43adbccc4f6 ) +) + +game ( + name "Nebulus (World) (GBAX 2004) (Unl)" + description "Nebulus (World) (GBAX 2004) (Unl)" + rom ( name "Nebulus (World) (GBAX 2004) (Unl).gba" size 544372 crc fb414ccc sha1 4c25014b29e87dd53f3677339f89dd18d316d2f0 ) +) + game ( name "Need for Speed - Carbon - Own the City (USA, Europe) (En,Fr,De,Es,It)" description "Need for Speed - Carbon - Own the City (USA, Europe) (En,Fr,De,Es,It)" @@ -12936,12 +12816,6 @@ game ( rom ( name "Need for Speed - Underground 2 (USA, Europe) (En,Fr,De,It).gba" size 8388608 crc 9a0c5090 sha1 f772000fbdfb84d8d5de9f69bd9c0de551389929 flags verified ) ) -game ( - name "Nekketsu Monogatari Advance (Japan) (Demo) (Aftermarket) (Unl)" - description "Nekketsu Monogatari Advance (Japan) (Demo) (Aftermarket) (Unl)" - rom ( name "Nekketsu Monogatari Advance (Japan) (Demo) (Aftermarket) (Unl).gba" size 508972 crc 55a0734d sha1 79d6977803cd7ee6b1c97ee149cc1bc037c50fb2 ) -) - game ( name "Neoromance Game - Harukanaru Toki no Naka de (Japan) (Rev 1)" description "Neoromance Game - Harukanaru Toki no Naka de (Japan) (Rev 1)" @@ -13008,12 +12882,6 @@ game ( rom ( name "Nicktoons - Freeze Frame Frenzy (USA).gba" size 4194304 crc a8b6766e sha1 a200cdaf66606bd724ce7073fd7990ea3fe6bcdd ) ) -game ( - name "Nicktoons Racing (USA) (Beta)" - description "Nicktoons Racing (USA) (Beta)" - rom ( name "Nicktoons Racing (USA) (Beta).gba" size 4194304 crc 4ed6e860 sha1 d553a265d1405bb073034e16ea97e1a2df899025 ) -) - game ( name "Nicktoons Racing (USA)" description "Nicktoons Racing (USA)" @@ -13026,6 +12894,12 @@ game ( rom ( name "Nicktoons Racing (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc babccefd sha1 55b145de1810a4a6a8b5716ef4c9e9333a93e3ba ) ) +game ( + name "Nicktoons Racing (USA) (Beta)" + description "Nicktoons Racing (USA) (Beta)" + rom ( name "Nicktoons Racing (USA) (Beta).gba" size 4194304 crc 4ed6e860 sha1 d553a265d1405bb073034e16ea97e1a2df899025 ) +) + game ( name "Nicktoons Unite! (USA)" description "Nicktoons Unite! (USA)" @@ -13242,18 +13116,18 @@ game ( rom ( name "Oriental Blue - Ao no Tengai (Japan).gba" size 16777216 crc 05e80ecc sha1 414cad1aee67ab20f3c133f0259da7e8c3073bbc flags verified ) ) -game ( - name "Oshaberi Inko Club (Japan)" - description "Oshaberi Inko Club (Japan)" - rom ( name "Oshaberi Inko Club (Japan).gba" size 8388608 crc df6901f0 sha1 82e48090b9615282c58747a1f7b105196866f8c9 ) -) - game ( name "Oshaberi Inko Club (Japan) (Beta)" description "Oshaberi Inko Club (Japan) (Beta)" rom ( name "Oshaberi Inko Club (Japan) (Beta).gba" size 8388608 crc f896bb9e sha1 e293d18a8a0fb856edafafa03b33454b2d04efd9 ) ) +game ( + name "Oshaberi Inko Club (Japan)" + description "Oshaberi Inko Club (Japan)" + rom ( name "Oshaberi Inko Club (Japan).gba" size 8388608 crc df6901f0 sha1 82e48090b9615282c58747a1f7b105196866f8c9 ) +) + game ( name "Oshare Princess (Japan)" description "Oshare Princess (Japan)" @@ -13461,7 +13335,7 @@ game ( game ( name "Paws & Claws - Pet Vet (USA)" description "Paws & Claws - Pet Vet (USA)" - rom ( name "Paws & Claws - Pet Vet (USA).gba" size 8388608 crc efee1ddf sha1 c121eea8f816c4f8cbab32058d6b9bac57f0d7e3 ) + rom ( name "Paws & Claws - Pet Vet (USA).gba" size 8388608 crc efee1ddf sha1 c121eea8f816c4f8cbab32058d6b9bac57f0d7e3 flags verified ) ) game ( @@ -13597,9 +13471,9 @@ game ( ) game ( - name "Phantom, The (Italy) (It) (Proto)" - description "Phantom, The (Italy) (It) (Proto)" - rom ( name "Phantom, The (Italy) (It) (Proto).gba" size 8388608 crc 5833169c sha1 ccd8e9d092a9ded9c3785ac776d40df66512b9b5 ) + name "Phantom, The (Italy) (Proto)" + description "Phantom, The (Italy) (Proto)" + rom ( name "Phantom, The (Italy) (Proto).gba" size 8388608 crc 5833169c sha1 ccd8e9d092a9ded9c3785ac776d40df66512b9b5 ) ) game ( @@ -13674,12 +13548,6 @@ game ( rom ( name "Pinball Tycoon (USA).gba" size 4194304 crc 1c4d3fdf sha1 fac76a646d112a775f9877b53f1386716d968a79 ) ) -game ( - name "Ping-Pong Diplomacy Advance (World) (Aftermarket) (Unl)" - description "Ping-Pong Diplomacy Advance (World) (Aftermarket) (Unl)" - rom ( name "Ping-Pong Diplomacy Advance (World) (Aftermarket) (Unl).gba" size 1048576 crc 9ec140d3 sha1 9e19e8f97e8619a4755c3ceb482fa3e2ad5a4529 ) -) - game ( name "Pink Panther - Pinkadelic Pursuit (Europe) (En,Fr,De,Es,It)" description "Pink Panther - Pinkadelic Pursuit (Europe) (En,Fr,De,Es,It)" @@ -13830,12 +13698,6 @@ game ( rom ( name "Pocket Dogs (USA).gba" size 8388608 crc beddc67f sha1 79a90b119ea84c5812575d20ba6107be7edbfee7 ) ) -game ( - name "Pocket Meat (World) (Proto) (Aftermarket) (Unl)" - description "Pocket Meat (World) (Proto) (Aftermarket) (Unl)" - rom ( name "Pocket Meat (World) (Proto) (Aftermarket) (Unl).gba" size 861952 crc 0b029da3 sha1 9958d9a66742cc00e234a96c311b2acec40f69d1 ) -) - game ( name "Pocket Monsters - Emerald (Japan)" description "Pocket Monsters - Emerald (Japan)" @@ -14700,6 +14562,12 @@ game ( rom ( name "Punch King - Arcade Boxing (USA).gba" size 8388608 crc 540b6cc1 sha1 021fdd9420a81a3aa8f37de884ac2b8f42e691ed ) ) +game ( + name "Punch King - Arcade Boxing (World) (Evercade) (Unl)" + description "Punch King - Arcade Boxing (World) (Evercade) (Unl)" + rom ( name "Punch King - Arcade Boxing (World) (Evercade) (Unl).gba" size 8388608 crc 2afd6ff9 sha1 9e145758d3727c664c0612407f4b4d04f7b1733d ) +) + game ( name "Puppy Luv - Spa and Resort (USA)" description "Puppy Luv - Spa and Resort (USA)" @@ -14803,15 +14671,15 @@ game ( ) game ( - name "Racing Fever (Europe) (En,De,Es,It)" - description "Racing Fever (Europe) (En,De,Es,It)" - rom ( name "Racing Fever (Europe) (En,De,Es,It).gba" size 4194304 crc e40ec737 sha1 9bb5c036bca8f0d2e06013cac7ea6148a4f7f512 ) + name "Racing Fever (World) (En,De,Es,It) (Evercade) (Unl)" + description "Racing Fever (World) (En,De,Es,It) (Evercade) (Unl)" + rom ( name "Racing Fever (World) (En,De,Es,It) (Evercade) (Unl).gba" size 4194304 crc dbd09923 sha1 b10861c12a08826c58dffdbd3071ff72f753b76e ) ) game ( - name "Racing Gears Advance (USA) (Beta)" - description "Racing Gears Advance (USA) (Beta)" - rom ( name "Racing Gears Advance (USA) (Beta).gba" size 8388608 crc 7a3820b3 sha1 ff18dfe7d75a8154c0dcc3970e5d0d4cb75c3568 ) + name "Racing Fever (Europe) (En,De,Es,It)" + description "Racing Fever (Europe) (En,De,Es,It)" + rom ( name "Racing Fever (Europe) (En,De,Es,It).gba" size 4194304 crc e40ec737 sha1 9bb5c036bca8f0d2e06013cac7ea6148a4f7f512 ) ) game ( @@ -14826,6 +14694,12 @@ game ( rom ( name "Racing Gears Advance (USA).gba" size 8388608 crc bf648e5c sha1 3f053865f9a687a75927172cd281390b2560201c ) ) +game ( + name "Racing Gears Advance (USA) (Beta)" + description "Racing Gears Advance (USA) (Beta)" + rom ( name "Racing Gears Advance (USA) (Beta).gba" size 8388608 crc 7a3820b3 sha1 ff18dfe7d75a8154c0dcc3970e5d0d4cb75c3568 ) +) + game ( name "Rampage - Puzzle Attack (USA, Europe)" description "Rampage - Puzzle Attack (USA, Europe)" @@ -14838,6 +14712,12 @@ game ( rom ( name "Rapala Pro Fishing (USA, Europe).gba" size 4194304 crc 964d39a7 sha1 e3df6fe7a447ab30faf6fd7d4c57e88f987a5639 ) ) +game ( + name "Ratatouille (Australia, Greece) (En)" + description "Ratatouille (Australia, Greece) (En)" + rom ( name "Ratatouille (Australia, Greece) (En).gba" size 8388608 crc 3e1711c7 sha1 58f2fa1d7e531c7345b11db268e1bbc10372bebc flags verified ) +) + game ( name "Ratatouille (USA)" description "Ratatouille (USA)" @@ -14862,12 +14742,6 @@ game ( rom ( name "Ratatouille (Europe) (En,It,Sv,No,Da).gba" size 8388608 crc 82f9c596 sha1 a5c4a636979c06670a81428c778ff76ed2c65eee ) ) -game ( - name "Ratatouille (Australia, Greece) (En)" - description "Ratatouille (Australia, Greece) (En)" - rom ( name "Ratatouille (Australia, Greece) (En).gba" size 8388608 crc 3e1711c7 sha1 58f2fa1d7e531c7345b11db268e1bbc10372bebc flags verified ) -) - game ( name "Rave Master - Special Attack Force! (USA)" description "Rave Master - Special Attack Force! (USA)" @@ -15006,12 +14880,6 @@ game ( rom ( name "Ready 2 Rumble Boxing - Round 2 (Europe) (En,Fr,De).gba" size 4194304 crc e418e962 sha1 57d06e405b281f68800b986bd9ff1257e4466939 flags verified ) ) -game ( - name "Rebelstar - Tactical Command (Europe) (En,Fr,De,Es,It) (Beta)" - description "Rebelstar - Tactical Command (Europe) (En,Fr,De,Es,It) (Beta)" - rom ( name "Rebelstar - Tactical Command (Europe) (En,Fr,De,Es,It) (Beta).gba" size 4194304 crc 2189021c sha1 b6e2167272a68bd4e3833cccd68929d50a27a426 ) -) - game ( name "Rebelstar - Tactical Command (USA)" description "Rebelstar - Tactical Command (USA)" @@ -15024,6 +14892,12 @@ game ( rom ( name "Rebelstar - Tactical Command (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc e448c5d4 sha1 669c47e62f2388ce0ba676f3dc641b5ad2ddb5c5 flags verified ) ) +game ( + name "Rebelstar - Tactical Command (Europe) (En,Fr,De,Es,It) (Beta)" + description "Rebelstar - Tactical Command (Europe) (En,Fr,De,Es,It) (Beta)" + rom ( name "Rebelstar - Tactical Command (Europe) (En,Fr,De,Es,It) (Beta).gba" size 4194304 crc 2189021c sha1 b6e2167272a68bd4e3833cccd68929d50a27a426 ) +) + game ( name "Recca no Honoo - The Game (Japan)" description "Recca no Honoo - The Game (Japan)" @@ -15198,6 +15072,12 @@ game ( rom ( name "Robot Wars - Advanced Destruction (USA).gba" size 4194304 crc e6cb567d sha1 952adf4e17865abc2b983c79ad4080e9b4867370 ) ) +game ( + name "Robot Wars - Advanced Destruction (USA) (Beta) (2001-03-20)" + description "Robot Wars - Advanced Destruction (USA) (Beta) (2001-03-20)" + rom ( name "Robot Wars - Advanced Destruction (USA) (Beta) (2001-03-20).gba" size 585104 crc ce95bbd6 sha1 e045c21b0fef1959c1207bb46e509089b03fd6db ) +) + game ( name "Robot Wars - Extreme Destruction (Europe) (En,Fr,De,Es,It,Nl)" description "Robot Wars - Extreme Destruction (Europe) (En,Fr,De,Es,It,Nl)" @@ -15210,6 +15090,12 @@ game ( rom ( name "Robotech - The Macross Saga (USA, Europe) (En,Fr,De,Es,It,Nl).gba" size 8388608 crc 325a6596 sha1 3dbfe433a2376589a24754bb7337306c43176b34 flags verified ) ) +game ( + name "Robots (Japan)" + description "Robots (Japan)" + rom ( name "Robots (Japan).gba" size 16777216 crc 1beb9e91 sha1 b1a670daf53d47f237a4078388178c16c843d4dc ) +) + game ( name "Robots (USA)" description "Robots (USA)" @@ -15222,12 +15108,6 @@ game ( rom ( name "Robots (Europe) (En,Fr,De,Es,It).gba" size 16777216 crc 2acbdb64 sha1 26be826817f35433b3609d13ee75a3872e94d616 flags verified ) ) -game ( - name "Robots (Japan)" - description "Robots (Japan)" - rom ( name "Robots (Japan).gba" size 16777216 crc 1beb9e91 sha1 b1a670daf53d47f237a4078388178c16c843d4dc ) -) - game ( name "Rock 'N Roll Racing (USA)" description "Rock 'N Roll Racing (USA)" @@ -15279,7 +15159,7 @@ game ( game ( name "Rocket Power - Zero Gravity Zone (USA)" description "Rocket Power - Zero Gravity Zone (USA)" - rom ( name "Rocket Power - Zero Gravity Zone (USA).gba" size 8388608 crc 26d62d32 sha1 2e8fcf7afe49b57c2527f31288198a4b93df8bec ) + rom ( name "Rocket Power - Zero Gravity Zone (USA).gba" size 8388608 crc 26d62d32 sha1 2e8fcf7afe49b57c2527f31288198a4b93df8bec flags verified ) ) game ( @@ -15759,7 +15639,7 @@ game ( game ( name "Scorpion King, The - Sword of Osiris (Europe) (En,Fr,De,Es,It)" description "Scorpion King, The - Sword of Osiris (Europe) (En,Fr,De,Es,It)" - rom ( name "Scorpion King, The - Sword of Osiris (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc d5410d32 sha1 9a483e98d72b1d7d8579511cc9344e5d27bcee61 ) + rom ( name "Scorpion King, The - Sword of Osiris (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc d5410d32 sha1 9a483e98d72b1d7d8579511cc9344e5d27bcee61 flags verified ) ) game ( @@ -15981,7 +15861,7 @@ game ( game ( name "Shamu's Deep Sea Adventures (USA)" description "Shamu's Deep Sea Adventures (USA)" - rom ( name "Shamu's Deep Sea Adventures (USA).gba" size 33554432 crc 4e9426eb sha1 0bca9c4dd35d02c52a5db98b2097a50ef159de32 ) + rom ( name "Shamu's Deep Sea Adventures (USA).gba" size 33554432 crc 7ecb7529 sha1 1927b344bba21bcd80544a55734234610972f373 flags verified ) ) game ( @@ -16518,12 +16398,6 @@ game ( rom ( name "Sims, The - Bustin' Out (USA) (En,Fr,De,Es,It,Nl) (Rev 1).gba" size 16777216 crc d1183501 sha1 7038fa0e4cb8aeac9e48a0b45574db66cba39e73 flags verified ) ) -game ( - name "Sips (World) (Aftermarket) (Unl)" - description "Sips (World) (Aftermarket) (Unl)" - rom ( name "Sips (World) (Aftermarket) (Unl).gba" size 6235380 crc 5c1fb22d sha1 bb725df7226307d55df04365f85e5698b199c3c9 ) -) - game ( name "Sister Princess - RePure (Japan)" description "Sister Princess - RePure (Japan)" @@ -16572,30 +16446,6 @@ game ( rom ( name "Sky Dancers - They Magically Fly! (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc 3af1063b sha1 df749ac7e33a1c7ede3faadb6648a8e53fa77048 ) ) -game ( - name "Skyland (World) (v2023.5.5.0) (Proto) (Aftermarket) (Unl)" - description "Skyland (World) (v2023.5.5.0) (Proto) (Aftermarket) (Unl)" - rom ( name "Skyland (World) (v2023.5.5.0) (Proto) (Aftermarket) (Unl).gba" size 15887876 crc c798529d sha1 ea4a6494bcec25757f657c69550c91190e46cebd ) -) - -game ( - name "Skyland (World) (v2023.5.15.0) (Proto) (Aftermarket) (Unl)" - description "Skyland (World) (v2023.5.15.0) (Proto) (Aftermarket) (Unl)" - rom ( name "Skyland (World) (v2023.5.15.0) (Proto) (Aftermarket) (Unl).gba" size 15894868 crc af572de8 sha1 997bf192369d48433a7c35187c7e1d0b5fcc16e0 ) -) - -game ( - name "Skyland (World) (v2023.5.26.0) (Proto) (Aftermarket) (Unl)" - description "Skyland (World) (v2023.5.26.0) (Proto) (Aftermarket) (Unl)" - rom ( name "Skyland (World) (v2023.5.26.0) (Proto) (Aftermarket) (Unl).gba" size 15900084 crc df05edff sha1 1328d17668480b4e9bea338662532ace332c74a9 ) -) - -game ( - name "Skyland (World) (v2023.8.1.1) (Proto) (Aftermarket) (Unl)" - description "Skyland (World) (v2023.8.1.1) (Proto) (Aftermarket) (Unl)" - rom ( name "Skyland (World) (v2023.8.1.1) (Proto) (Aftermarket) (Unl).gba" size 16075456 crc d271c516 sha1 0dbdf16b23afb70229eff2de269fd5d73659d745 ) -) - game ( name "Slime Morimori Dragon Quest - Shougeki no Shippo Dan (Japan)" description "Slime Morimori Dragon Quest - Shougeki no Shippo Dan (Japan)" @@ -16653,7 +16503,7 @@ game ( game ( name "Snood (USA)" description "Snood (USA)" - rom ( name "Snood (USA).gba" size 4194304 crc f1f1f148 sha1 2c09548ae924ac0c1a3e15412d9a7aae7707a753 ) + rom ( name "Snood (USA).gba" size 4194304 crc f1f1f148 sha1 2c09548ae924ac0c1a3e15412d9a7aae7707a753 flags verified ) ) game ( @@ -16884,6 +16734,12 @@ game ( rom ( name "Space Invaders EX (Japan) (En).gba" size 4194304 crc 297b9854 sha1 ae8cace77baccdb8f25c9b44ea3cf64d881b91a8 ) ) +game ( + name "Space Twins (World) (Proto) (Unl)" + description "Space Twins (World) (Proto) (Unl)" + rom ( name "Space Twins (World) (Proto) (Unl).gba" size 1350536 crc 0edc97d9 sha1 4a9848cc2262b30aba7e87013c0a197e01cc9617 ) +) + game ( name "Speedball 2 (Europe) (En,Fr,De,Es,It)" description "Speedball 2 (Europe) (En,Fr,De,Es,It)" @@ -17070,6 +16926,18 @@ game ( rom ( name "SpongeBob SquarePants - Lights, Camera, Pants! (Europe) (En,Fr,De,Es,It,Nl,Sv).gba" size 8388608 crc c189013d sha1 09d945acc251000c49539a3f18b21e48520ec8ad flags verified ) ) +game ( + name "SpongeBob SquarePants - Lights, Camera, Pants! (USA) (Beta) (2005-08-03)" + description "SpongeBob SquarePants - Lights, Camera, Pants! (USA) (Beta) (2005-08-03)" + rom ( name "SpongeBob SquarePants - Lights, Camera, Pants! (USA) (Beta) (2005-08-03).gba" size 4291500 crc 52fd3771 sha1 72d84f52c796cbb06c2cd9291ca7952093d9b7dc ) +) + +game ( + name "SpongeBob SquarePants - Lights, Camera, Pants! (USA) (Beta) (2005-08-05)" + description "SpongeBob SquarePants - Lights, Camera, Pants! (USA) (Beta) (2005-08-05)" + rom ( name "SpongeBob SquarePants - Lights, Camera, Pants! (USA) (Beta) (2005-08-05).gba" size 4519932 crc e1461b58 sha1 b30dc120107a70796250b831e7174fc4c03ae58a ) +) + game ( name "SpongeBob SquarePants - Revenge of the Flying Dutchman (USA) (Beta)" description "SpongeBob SquarePants - Revenge of the Flying Dutchman (USA) (Beta)" @@ -17166,6 +17034,24 @@ game ( rom ( name "SpongeBob SquarePants - SuperSponge (USA, Europe) (Beta) (2001-07-31).gba" size 4194304 crc f2f67f40 sha1 bb298d490ec9d8657cbd2fc402ae1e0a5792d406 ) ) +game ( + name "SpongeBob SquarePants - SuperSponge (USA, Europe) (Beta) (2001-03-28)" + description "SpongeBob SquarePants - SuperSponge (USA, Europe) (Beta) (2001-03-28)" + rom ( name "SpongeBob SquarePants - SuperSponge (USA, Europe) (Beta) (2001-03-28).gba" size 4646712 crc 1407d86e sha1 2608c985c8ab5bffeae0687421bb21a46e34b681 ) +) + +game ( + name "SpongeBob SquarePants - SuperSponge (USA, Europe) (Beta) (2001-04-03)" + description "SpongeBob SquarePants - SuperSponge (USA, Europe) (Beta) (2001-04-03)" + rom ( name "SpongeBob SquarePants - SuperSponge (USA, Europe) (Beta) (2001-04-03).gba" size 5477108 crc 0bc6dfaf sha1 c617321d405f4a5bb07c4fa769321df46a944bb8 ) +) + +game ( + name "SpongeBob SquarePants - SuperSponge (USA, Europe) (Beta) (2001-04-04)" + description "SpongeBob SquarePants - SuperSponge (USA, Europe) (Beta) (2001-04-04)" + rom ( name "SpongeBob SquarePants - SuperSponge (USA, Europe) (Beta) (2001-04-04).gba" size 5477244 crc 23d7ba77 sha1 0177808f1bcd65738c10fd0fba477ecdd46a791f ) +) + game ( name "SpongeBob SquarePants and Friends - Battle for Volcano Island (Europe) (En,Fr,De,Es,It,Nl)" description "SpongeBob SquarePants and Friends - Battle for Volcano Island (Europe) (En,Fr,De,Es,It,Nl)" @@ -17277,7 +17163,7 @@ game ( game ( name "Spyro - Season of Ice (Europe) (En,Fr,De,Es,It)" description "Spyro - Season of Ice (Europe) (En,Fr,De,Es,It)" - rom ( name "Spyro - Season of Ice (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc afd25827 sha1 854e788e5e1316b7d5cdf6b961d0969e5cd62119 ) + rom ( name "Spyro - Season of Ice (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc afd25827 sha1 854e788e5e1316b7d5cdf6b961d0969e5cd62119 flags verified ) ) game ( @@ -17349,7 +17235,7 @@ game ( game ( name "SSX 3 (USA, Europe)" description "SSX 3 (USA, Europe)" - rom ( name "SSX 3 (USA, Europe).gba" size 8388608 crc 8232f58a sha1 4f2bd55bcd3118e10520179e285aae897aa21898 ) + rom ( name "SSX 3 (USA, Europe).gba" size 8388608 crc 8232f58a sha1 4f2bd55bcd3118e10520179e285aae897aa21898 flags verified ) ) game ( @@ -17385,7 +17271,7 @@ game ( game ( name "Star Wars - Episode III - Revenge of the Sith (Europe) (En,Fr,De,Es,It,Nl)" description "Star Wars - Episode III - Revenge of the Sith (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Star Wars - Episode III - Revenge of the Sith (Europe) (En,Fr,De,Es,It,Nl).gba" size 8388608 crc fd49236b sha1 4ba5e5a6174bad9369f088f801c743f88616c5f4 ) + rom ( name "Star Wars - Episode III - Revenge of the Sith (Europe) (En,Fr,De,Es,It,Nl).gba" size 8388608 crc fd49236b sha1 4ba5e5a6174bad9369f088f801c743f88616c5f4 flags verified ) ) game ( @@ -17439,7 +17325,7 @@ game ( game ( name "Star Wars Trilogy - Apprentice of the Force (Europe) (En,Fr,De,Es,It,Nl)" description "Star Wars Trilogy - Apprentice of the Force (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Star Wars Trilogy - Apprentice of the Force (Europe) (En,Fr,De,Es,It,Nl).gba" size 8388608 crc c9f0c492 sha1 51ffd3684d9bd8140d8c7969d7eb2096dd2424a5 ) + rom ( name "Star Wars Trilogy - Apprentice of the Force (Europe) (En,Fr,De,Es,It,Nl).gba" size 8388608 crc c9f0c492 sha1 51ffd3684d9bd8140d8c7969d7eb2096dd2424a5 flags verified ) ) game ( @@ -17571,7 +17457,7 @@ game ( game ( name "Stuart Little 2 (USA, Europe)" description "Stuart Little 2 (USA, Europe)" - rom ( name "Stuart Little 2 (USA, Europe).gba" size 8388608 crc 6eb7c688 sha1 fdb6d8098340966456cd05c7babe77b5a204608c ) + rom ( name "Stuart Little 2 (USA, Europe).gba" size 8388608 crc 6eb7c688 sha1 fdb6d8098340966456cd05c7babe77b5a204608c flags verified ) ) game ( @@ -17676,6 +17562,12 @@ game ( rom ( name "Super Bubble Pop (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv).gba" size 4194304 crc 25123d97 sha1 f62396b5502437651d26e1ad27a8ec8c18b4268e ) ) +game ( + name "Super Bubble Pop (World) (Evercade) (Unl)" + description "Super Bubble Pop (World) (Evercade) (Unl)" + rom ( name "Super Bubble Pop (World) (Evercade) (Unl).gba" size 4194304 crc 940f385e sha1 fa2c3b84014a84143f519609a8808d13ca33bf22 ) +) + game ( name "Super Bust-A-Move (Europe) (En,Fr,De,Es,It)" description "Super Bust-A-Move (Europe) (En,Fr,De,Es,It)" @@ -17701,15 +17593,9 @@ game ( ) game ( - name "Super Dodge Ball Advance (USA)" - description "Super Dodge Ball Advance (USA)" - rom ( name "Super Dodge Ball Advance (USA).gba" size 4194304 crc 1d31dc6b sha1 5fc95814ea7695d1301df4b545614a1ffae95218 ) -) - -game ( - name "Super Dodge Ball Advance (Europe)" - description "Super Dodge Ball Advance (Europe)" - rom ( name "Super Dodge Ball Advance (Europe).gba" size 4194304 crc 4ca4f528 sha1 a0ac6be19f385eef6bc48bca8d54520d4e8a00e7 flags verified ) + name "Super Dodge Ball Advance (USA) (Rev 1)" + description "Super Dodge Ball Advance (USA) (Rev 1)" + rom ( name "Super Dodge Ball Advance (USA) (Rev 1).gba" size 4194304 crc 63ca5050 sha1 29561789fcb3bcd106a5d27dea47f29b393191f6 ) ) game ( @@ -17719,9 +17605,15 @@ game ( ) game ( - name "Super Dodge Ball Advance (USA) (Rev 1)" - description "Super Dodge Ball Advance (USA) (Rev 1)" - rom ( name "Super Dodge Ball Advance (USA) (Rev 1).gba" size 4194304 crc 63ca5050 sha1 29561789fcb3bcd106a5d27dea47f29b393191f6 ) + name "Super Dodge Ball Advance (USA)" + description "Super Dodge Ball Advance (USA)" + rom ( name "Super Dodge Ball Advance (USA).gba" size 4194304 crc 1d31dc6b sha1 5fc95814ea7695d1301df4b545614a1ffae95218 ) +) + +game ( + name "Super Dodge Ball Advance (Europe)" + description "Super Dodge Ball Advance (Europe)" + rom ( name "Super Dodge Ball Advance (Europe).gba" size 4194304 crc 4ca4f528 sha1 a0ac6be19f385eef6bc48bca8d54520d4e8a00e7 flags verified ) ) game ( @@ -17775,7 +17667,7 @@ game ( game ( name "Super Hornet FA 18F (USA, Europe)" description "Super Hornet FA 18F (USA, Europe)" - rom ( name "Super Hornet FA 18F (USA, Europe).gba" size 4194304 crc 9653bac5 sha1 038b533bb09845ade7b0a13c7ca9923348eb1100 ) + rom ( name "Super Hornet FA 18F (USA, Europe).gba" size 4194304 crc 9653bac5 sha1 038b533bb09845ade7b0a13c7ca9923348eb1100 flags verified ) ) game ( @@ -18169,9 +18061,9 @@ game ( ) game ( - name "Sushi the Cat (World) (Aftermarket) (Unl)" - description "Sushi the Cat (World) (Aftermarket) (Unl)" - rom ( name "Sushi the Cat (World) (Aftermarket) (Unl).gba" size 540296 crc 6f019a88 sha1 f6d523a073c21639e15d615947167bba3871c67a ) + name "Sushi the Cat (World) (Unl)" + description "Sushi the Cat (World) (Unl)" + rom ( name "Sushi the Cat (World) (Unl).gba" size 540296 crc 6f019a88 sha1 f6d523a073c21639e15d615947167bba3871c67a ) ) game ( @@ -18249,7 +18141,7 @@ game ( game ( name "Tak - The Great Juju Challenge (USA, Europe)" description "Tak - The Great Juju Challenge (USA, Europe)" - rom ( name "Tak - The Great Juju Challenge (USA, Europe).gba" size 8388608 crc 881c8416 sha1 0999a8ee2bae78a223c992408e987422ba0c0af9 ) + rom ( name "Tak - The Great Juju Challenge (USA, Europe).gba" size 8388608 crc 881c8416 sha1 0999a8ee2bae78a223c992408e987422ba0c0af9 flags verified ) ) game ( @@ -18261,7 +18153,7 @@ game ( game ( name "Tak 2 - The Staff of Dreams (USA)" description "Tak 2 - The Staff of Dreams (USA)" - rom ( name "Tak 2 - The Staff of Dreams (USA).gba" size 8388608 crc 8f7eb026 sha1 f90219db6359332eb997a2717986a8c66eaded2b ) + rom ( name "Tak 2 - The Staff of Dreams (USA).gba" size 8388608 crc 8f7eb026 sha1 f90219db6359332eb997a2717986a8c66eaded2b flags verified ) ) game ( @@ -18537,7 +18429,7 @@ game ( game ( name "Tetris Worlds (Europe) (En,Fr,De,Nl)" description "Tetris Worlds (Europe) (En,Fr,De,Nl)" - rom ( name "Tetris Worlds (Europe) (En,Fr,De,Nl).gba" size 4194304 crc ad97eb3f sha1 4a1297b44208366a178cc1f2541f5ea8386f6f3e ) + rom ( name "Tetris Worlds (Europe) (En,Fr,De,Nl).gba" size 4194304 crc ad97eb3f sha1 4a1297b44208366a178cc1f2541f5ea8386f6f3e flags verified ) ) game ( @@ -18549,7 +18441,7 @@ game ( game ( name "Texas Hold 'em Poker (USA)" description "Texas Hold 'em Poker (USA)" - rom ( name "Texas Hold 'em Poker (USA).gba" size 4194304 crc 78b59aac sha1 5fcc9958210d8bde94a429516b15ca669427fe6d ) + rom ( name "Texas Hold 'em Poker (USA).gba" size 4194304 crc 78b59aac sha1 5fcc9958210d8bde94a429516b15ca669427fe6d flags verified ) ) game ( @@ -18609,13 +18501,13 @@ game ( game ( name "Thunder Alley (USA)" description "Thunder Alley (USA)" - rom ( name "Thunder Alley (USA).gba" size 4194304 crc 25e8e649 sha1 d63aaf9ac4468f1d0ead35606d9a4f56327b2537 ) + rom ( name "Thunder Alley (USA).gba" size 4194304 crc 25e8e649 sha1 d63aaf9ac4468f1d0ead35606d9a4f56327b2537 flags verified ) ) game ( name "Thunderbirds (USA, Europe)" description "Thunderbirds (USA, Europe)" - rom ( name "Thunderbirds (USA, Europe).gba" size 4194304 crc f09b7bb0 sha1 08c4b9b924f5cf0404cab5cd7fb6064fca872250 ) + rom ( name "Thunderbirds (USA, Europe).gba" size 4194304 crc f09b7bb0 sha1 08c4b9b924f5cf0404cab5cd7fb6064fca872250 flags verified ) ) game ( @@ -18633,7 +18525,7 @@ game ( game ( name "Tiger Woods PGA Tour Golf (USA, Europe)" description "Tiger Woods PGA Tour Golf (USA, Europe)" - rom ( name "Tiger Woods PGA Tour Golf (USA, Europe).gba" size 8388608 crc f3f26acc sha1 88b204b7b51995e41459b532580b3956d7db55ad ) + rom ( name "Tiger Woods PGA Tour Golf (USA, Europe).gba" size 8388608 crc f3f26acc sha1 88b204b7b51995e41459b532580b3956d7db55ad flags verified ) ) game ( @@ -18675,7 +18567,7 @@ game ( game ( name "Tiny Toon Adventures - Wacky Stackers (Europe) (En,Fr,De,Es,It)" description "Tiny Toon Adventures - Wacky Stackers (Europe) (En,Fr,De,Es,It)" - rom ( name "Tiny Toon Adventures - Wacky Stackers (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc 4ac770b6 sha1 cd9d810b29070d9f37df219bfd7e52ce9d52d2b0 ) + rom ( name "Tiny Toon Adventures - Wacky Stackers (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc 4ac770b6 sha1 cd9d810b29070d9f37df219bfd7e52ce9d52d2b0 flags verified ) ) game ( @@ -18798,6 +18690,12 @@ game ( rom ( name "Tom Clancy's Rainbow Six - Rogue Spear (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc 6863ce1a sha1 092179cd51657a4572fa855eb3e5bc3f46c1d76f ) ) +game ( + name "Tom Clancy's Rainbow Six - Rogue Spear (USA, Europe) (En,Fr,De,Es,It) (Beta) (2001-10-25)" + description "Tom Clancy's Rainbow Six - Rogue Spear (USA, Europe) (En,Fr,De,Es,It) (Beta) (2001-10-25)" + rom ( name "Tom Clancy's Rainbow Six - Rogue Spear (USA, Europe) (En,Fr,De,Es,It) (Beta) (2001-10-25).gba" size 7963152 crc 666e31b5 sha1 d8426022537149670871817ff9336261b31172b5 ) +) + game ( name "Tom Clancy's Splinter Cell (USA) (En,Fr,Es)" description "Tom Clancy's Splinter Cell (USA) (En,Fr,Es)" @@ -19047,7 +18945,7 @@ game ( game ( name "Tottoko Hamutarou - Hamu-Hamu Sports (Japan) (Demo) (Kiosk, GameCube)" description "Tottoko Hamutarou - Hamu-Hamu Sports (Japan) (Demo) (Kiosk, GameCube)" - rom ( name "Tottoko Hamutarou - Hamu-Hamu Sports (Japan) (Demo) (Kiosk, GameCube).gba" size 16777216 crc 7cd6839c sha1 ace1d3587636d17fd9ebfe7a7cfd3ee36bc51b43 flags verified ) + rom ( name "Tottoko Hamutarou - Hamu-Hamu Sports (Japan) (Demo) (Kiosk, GameCube).gba" size 16777216 crc 7cd6839c sha1 ace1d3587636d17fd9ebfe7a7cfd3ee36bc51b43 ) ) game ( @@ -19119,37 +19017,7 @@ game ( game ( name "Treasure Planet (Europe) (En,Fr,De,Es,It,Nl)" description "Treasure Planet (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Treasure Planet (Europe) (En,Fr,De,Es,It,Nl).gba" size 8388608 crc d52ddce1 sha1 d89a2515f4fe0d0ac90b20e4633a80a2549175fc ) -) - -game ( - name "Tremblay Island (World) (En) (v1.1) (Aftermarket) (Unl)" - description "Tremblay Island (World) (En) (v1.1) (Aftermarket) (Unl)" - rom ( name "Tremblay Island (World) (En) (v1.1) (Aftermarket) (Unl).gba" size 16239516 crc ce85ba07 sha1 b09b600bfc222c2d92829d8883feab700b013953 ) -) - -game ( - name "Tremblay Island (World) (En) (v1.1) (Solid State Version) (Aftermarket) (Unl)" - description "Tremblay Island (World) (En) (v1.1) (Solid State Version) (Aftermarket) (Unl)" - rom ( name "Tremblay Island (World) (En) (v1.1) (Solid State Version) (Aftermarket) (Unl).gba" size 16229600 crc bd57344d sha1 a2fcfe94c9b8b0feff31c1245c8b033222c9f668 ) -) - -game ( - name "Tremblay Island (World) (Fr) (v1.1) (Solid State Version) (Aftermarket) (Unl)" - description "Tremblay Island (World) (Fr) (v1.1) (Solid State Version) (Aftermarket) (Unl)" - rom ( name "Tremblay Island (World) (Fr) (v1.1) (Solid State Version) (Aftermarket) (Unl).gba" size 16204024 crc fa43669e sha1 a57392fa7cee61913b20a840fe8b2ee27f11d808 ) -) - -game ( - name "Tremblay Island (World) (En) (v1.1) (Kickstarter Edition) (Aftermarket) (Unl)" - description "Tremblay Island (World) (En) (v1.1) (Kickstarter Edition) (Aftermarket) (Unl)" - rom ( name "Tremblay Island (World) (En) (v1.1) (Kickstarter Edition) (Aftermarket) (Unl).gba" size 16777216 crc ff5d64ab sha1 645ab8d4dacb6666d8eb549d491f77d8cd63ce97 ) -) - -game ( - name "Tremblay Island (World) (Aftermarket) (Unl)" - description "Tremblay Island (World) (Aftermarket) (Unl)" - rom ( name "Tremblay Island (World) (Aftermarket) (Unl).gba" size 16225608 crc 95503690 sha1 634ea6be3df5ebd85c9c60871e34fc3c72ae5140 ) + rom ( name "Treasure Planet (Europe) (En,Fr,De,Es,It,Nl).gba" size 8388608 crc d52ddce1 sha1 d89a2515f4fe0d0ac90b20e4633a80a2549175fc flags verified ) ) game ( @@ -19461,7 +19329,7 @@ game ( game ( name "Unfabulous (USA)" description "Unfabulous (USA)" - rom ( name "Unfabulous (USA).gba" size 4194304 crc 2547f3a1 sha1 a56e96a46ed7264bddbfc132925d291e3e8f0e38 ) + rom ( name "Unfabulous (USA).gba" size 4194304 crc 2547f3a1 sha1 a56e96a46ed7264bddbfc132925d291e3e8f0e38 flags verified ) ) game ( @@ -19494,6 +19362,36 @@ game ( rom ( name "Uno 52 (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc 315360d0 sha1 f85709ec7a97c8b40504f2097497bd961531272d ) ) +game ( + name "Uranus (World) (Unl)" + description "Uranus (World) (Unl)" + rom ( name "Uranus (World) (Unl).gba" size 4194304 crc 8152384d sha1 2c99b0c66cea1ce8d203aaa0985baa43fcdd82bd ) +) + +game ( + name "Uranus 2 - Sun Tear (World) (En,Fr) (Unl)" + description "Uranus 2 - Sun Tear (World) (En,Fr) (Unl)" + rom ( name "Uranus 2 - Sun Tear (World) (En,Fr) (Unl).gba" size 4194304 crc f1c63552 sha1 7c68363212a7fb424429281a658cbadfe37de035 ) +) + +game ( + name "Uranus Zero - Sun Tear (World) (En,Fr) (Unl)" + description "Uranus Zero - Sun Tear (World) (En,Fr) (Unl)" + rom ( name "Uranus Zero - Sun Tear (World) (En,Fr) (Unl).gba" size 8388608 crc 117183cc sha1 258058fb9ca44a93478220e19d0cf09cde527003 ) +) + +game ( + name "Uranus Zero EV (World) (En,Fr) (v1.1) (Unl)" + description "Uranus Zero EV (World) (En,Fr) (v1.1) (Unl)" + rom ( name "Uranus Zero EV (World) (En,Fr) (v1.1) (Unl).gba" size 7609632 crc 1b463c9e sha1 bb2536ae8c6b625f3abfb66add7c1b3b74b942ee ) +) + +game ( + name "Uranus Zero EV (World) (En,Fr) (Unl)" + description "Uranus Zero EV (World) (En,Fr) (Unl)" + rom ( name "Uranus Zero EV (World) (En,Fr) (Unl).gba" size 7610684 crc adbcba92 sha1 405fb8cefb7ab0262a5f3bb7d290b9b60128db9b ) +) + game ( name "Urban Yeti! (USA, Europe)" description "Urban Yeti! (USA, Europe)" @@ -19611,7 +19509,7 @@ game ( game ( name "W.i.t.c.h. (Europe) (En,Fr,De,Es,It)" description "W.i.t.c.h. (Europe) (En,Fr,De,Es,It)" - rom ( name "W.i.t.c.h. (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc ca4f6d5d sha1 dce3603206745f3d9288f35eab33cc0f890c3751 ) + rom ( name "W.i.t.c.h. (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc ca4f6d5d sha1 dce3603206745f3d9288f35eab33cc0f890c3751 flags verified ) ) game ( @@ -19656,12 +19554,6 @@ game ( rom ( name "Wagamama Fairy Mirumo de Pon! - Yume no Kakera (Japan).gba" size 8388608 crc a606c803 sha1 0429693de0ff6e020b01807047dbb07b70b42529 ) ) -game ( - name "Waimanu - Grinding Blocks Adventure (World) (Homebrew)" - description "Waimanu - Grinding Blocks Adventure (World) (Homebrew)" - rom ( name "Waimanu - Grinding Blocks Adventure (World) (Homebrew).gba" size 1739504 crc 0fe153c5 sha1 c4ce156b04fb257875bc5f539f3d64accbc08451 ) -) - game ( name "Wakeboarding Unleashed Featuring Shaun Murray (Europe)" description "Wakeboarding Unleashed Featuring Shaun Murray (Europe)" @@ -19716,12 +19608,6 @@ game ( rom ( name "Wanwan Meitantei (Japan).gba" size 8388608 crc 5f41c9fe sha1 d438e3b030a814818ed7e96777ac3e46043922f9 ) ) -game ( - name "Wario Land 4 (USA, Europe)" - description "Wario Land 4 (USA, Europe)" - rom ( name "Wario Land 4 (USA, Europe).gba" size 8388608 crc d6141609 sha1 b9fe05a8080e124b67bce6a623234ee3b518a2c1 flags verified ) -) - game ( name "Wario Land 4 (USA, Europe) (Virtual Console)" description "Wario Land 4 (USA, Europe) (Virtual Console)" @@ -19729,9 +19615,9 @@ game ( ) game ( - name "Wario Land Advance - Youki no Otakara (Japan) (Virtual Console)" - description "Wario Land Advance - Youki no Otakara (Japan) (Virtual Console)" - rom ( name "Wario Land Advance - Youki no Otakara (Japan) (Virtual Console).gba" size 8388608 crc a8cd90f9 sha1 2d3e6b124c84877520b482ba1016b8e3c36bab14 ) + name "Wario Land 4 (USA, Europe)" + description "Wario Land 4 (USA, Europe)" + rom ( name "Wario Land 4 (USA, Europe).gba" size 8388608 crc d6141609 sha1 b9fe05a8080e124b67bce6a623234ee3b518a2c1 flags verified ) ) game ( @@ -19741,15 +19627,15 @@ game ( ) game ( - name "WarioWare - Twisted! (USA, Australia)" - description "WarioWare - Twisted! (USA, Australia)" - rom ( name "WarioWare - Twisted! (USA, Australia).gba" size 16777216 crc cb4e844b sha1 f0102d0d6f7596fe853d5d0a94682718278e083a flags verified ) + name "Wario Land Advance - Youki no Otakara (Japan) (Virtual Console)" + description "Wario Land Advance - Youki no Otakara (Japan) (Virtual Console)" + rom ( name "Wario Land Advance - Youki no Otakara (Japan) (Virtual Console).gba" size 8388608 crc a8cd90f9 sha1 2d3e6b124c84877520b482ba1016b8e3c36bab14 ) ) game ( - name "WarioWare, Inc. - Mega Microgame$! (USA)" - description "WarioWare, Inc. - Mega Microgame$! (USA)" - rom ( name "WarioWare, Inc. - Mega Microgame$! (USA).gba" size 8388608 crc 785d8b8c sha1 3f556448d290fa5406d6ed367fee16cc02387ad3 flags verified ) + name "WarioWare - Twisted! (USA, Australia)" + description "WarioWare - Twisted! (USA, Australia)" + rom ( name "WarioWare - Twisted! (USA, Australia).gba" size 16777216 crc cb4e844b sha1 f0102d0d6f7596fe853d5d0a94682718278e083a flags verified ) ) game ( @@ -19765,9 +19651,9 @@ game ( ) game ( - name "WarioWare, Inc. - Minigame Mania (Europe) (En,Fr,De,Es,It) (Virtual Console)" - description "WarioWare, Inc. - Minigame Mania (Europe) (En,Fr,De,Es,It) (Virtual Console)" - rom ( name "WarioWare, Inc. - Minigame Mania (Europe) (En,Fr,De,Es,It) (Virtual Console).gba" size 8388608 crc 1fe34e43 sha1 dca921c60b3686be6b3a5feeec7a4f37a921aee3 ) + name "WarioWare, Inc. - Mega Microgame$! (USA)" + description "WarioWare, Inc. - Mega Microgame$! (USA)" + rom ( name "WarioWare, Inc. - Mega Microgame$! (USA).gba" size 8388608 crc 785d8b8c sha1 3f556448d290fa5406d6ed367fee16cc02387ad3 flags verified ) ) game ( @@ -19776,6 +19662,12 @@ game ( rom ( name "WarioWare, Inc. - Minigame Mania (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc 500ca178 sha1 aad81e722aa88f98913c0354e559f845c4689cce flags verified ) ) +game ( + name "WarioWare, Inc. - Minigame Mania (Europe) (En,Fr,De,Es,It) (Virtual Console)" + description "WarioWare, Inc. - Minigame Mania (Europe) (En,Fr,De,Es,It) (Virtual Console)" + rom ( name "WarioWare, Inc. - Minigame Mania (Europe) (En,Fr,De,Es,It) (Virtual Console).gba" size 8388608 crc 1fe34e43 sha1 dca921c60b3686be6b3a5feeec7a4f37a921aee3 ) +) + game ( name "Weekend Miljonairs (Netherlands)" description "Weekend Miljonairs (Netherlands)" @@ -19908,18 +19800,18 @@ game ( rom ( name "Winning Post for Game Boy Advance (Japan) (Rev 2).gba" size 4194304 crc 9fb4af0a sha1 9151cf54475c4f773bdd9ab86a42d3e1ba462afa ) ) -game ( - name "Winning Post for Game Boy Advance (Japan)" - description "Winning Post for Game Boy Advance (Japan)" - rom ( name "Winning Post for Game Boy Advance (Japan).gba" size 4194304 crc 5ada60f6 sha1 cc7e9c2a9e1df985aed3dc4a018c93140d7a1b2c ) -) - game ( name "Winning Post for Game Boy Advance (Japan) (Rev 1)" description "Winning Post for Game Boy Advance (Japan) (Rev 1)" rom ( name "Winning Post for Game Boy Advance (Japan) (Rev 1).gba" size 4194304 crc f6180af5 sha1 0f395a384b9db2415196edc2f911ccc67eb5e038 ) ) +game ( + name "Winning Post for Game Boy Advance (Japan)" + description "Winning Post for Game Boy Advance (Japan)" + rom ( name "Winning Post for Game Boy Advance (Japan).gba" size 4194304 crc 5ada60f6 sha1 cc7e9c2a9e1df985aed3dc4a018c93140d7a1b2c ) +) + game ( name "Winter Sports (Europe) (En,Fr,De,Es,It)" description "Winter Sports (Europe) (En,Fr,De,Es,It)" @@ -19950,18 +19842,6 @@ game ( rom ( name "WinX Club - Quest for the Codex (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc 9eb09c77 sha1 84951f8baabc405eee8a1fb94d420397623265ad ) ) -game ( - name "With the Last Moonbeam (World) (v1.0.0) (Aftermarket) (Unl)" - description "With the Last Moonbeam (World) (v1.0.0) (Aftermarket) (Unl)" - rom ( name "With the Last Moonbeam (World) (v1.0.0) (Aftermarket) (Unl).gba" size 1449956 crc 4ffa611d sha1 89bbeb3fbce1533acf2f2113642ebe2a4f9f79a8 ) -) - -game ( - name "With the Last Moonbeam (World) (v1.0.1) (Aftermarket) (Unl)" - description "With the Last Moonbeam (World) (v1.0.1) (Aftermarket) (Unl)" - rom ( name "With the Last Moonbeam (World) (v1.0.1) (Aftermarket) (Unl).gba" size 1449956 crc 27055186 sha1 b9ce91d55870e07434509f6e2e91c2f90b4afc97 ) -) - game ( name "Wizardry Summoner (Japan) (Rev 1)" description "Wizardry Summoner (Japan) (Rev 1)" @@ -20011,15 +19891,15 @@ game ( ) game ( - name "World Championship Poker (Europe) (En,Fr,De,Es,It)" - description "World Championship Poker (Europe) (En,Fr,De,Es,It)" - rom ( name "World Championship Poker (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc 4776f86e sha1 731ef2646ad83750aff729cb2286de6ee60f8260 ) + name "World Championship Poker (USA)" + description "World Championship Poker (USA)" + rom ( name "World Championship Poker (USA).gba" size 4194304 crc 07f15152 sha1 1d72864021f88f8db2686c57cfc5176b33ce2015 flags verified ) ) game ( - name "World Championship Poker (USA)" - description "World Championship Poker (USA)" - rom ( name "World Championship Poker (USA).gba" size 4194304 crc 07f15152 sha1 1d72864021f88f8db2686c57cfc5176b33ce2015 ) + name "World Championship Poker (Europe) (En,Fr,De,Es,It)" + description "World Championship Poker (Europe) (En,Fr,De,Es,It)" + rom ( name "World Championship Poker (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc 4776f86e sha1 731ef2646ad83750aff729cb2286de6ee60f8260 ) ) game ( @@ -20041,9 +19921,9 @@ game ( ) game ( - name "World Reborn (USA) (Aftermarket) (Unl)" - description "World Reborn (USA) (Aftermarket) (Unl)" - rom ( name "World Reborn (USA) (Aftermarket) (Unl).gba" size 4194304 crc eefb32ff sha1 c7ec2f8d7d3dec40a893cdfe2a41a8ed43ed71c4 ) + name "World Tennis Stars (Europe)" + description "World Tennis Stars (Europe)" + rom ( name "World Tennis Stars (Europe).gba" size 4194304 crc b5830f5f sha1 2a93449943e85b7c5d75d0d7a9e1d8ad67c7a706 ) ) game ( @@ -20053,9 +19933,9 @@ game ( ) game ( - name "World Tennis Stars (Europe)" - description "World Tennis Stars (Europe)" - rom ( name "World Tennis Stars (Europe).gba" size 4194304 crc b5830f5f sha1 2a93449943e85b7c5d75d0d7a9e1d8ad67c7a706 ) + name "Worms - World Party (USA) (En,Fr,De,Es,It)" + description "Worms - World Party (USA) (En,Fr,De,Es,It)" + rom ( name "Worms - World Party (USA) (En,Fr,De,Es,It).gba" size 4194304 crc e8789c18 sha1 7b078976d9056aba7f81bb1ff33e5a36357f5f0b ) ) game ( @@ -20064,18 +19944,18 @@ game ( rom ( name "Worms - World Party (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc 8ee32cbe sha1 5e0abe3d94d1489fadebe897df1ed5a5c0212901 ) ) -game ( - name "Worms - World Party (USA) (En,Fr,De,Es,It)" - description "Worms - World Party (USA) (En,Fr,De,Es,It)" - rom ( name "Worms - World Party (USA) (En,Fr,De,Es,It).gba" size 4194304 crc e8789c18 sha1 7b078976d9056aba7f81bb1ff33e5a36357f5f0b ) -) - game ( name "Worms Blast (Europe) (En,Fr,De,Es,It)" description "Worms Blast (Europe) (En,Fr,De,Es,It)" rom ( name "Worms Blast (Europe) (En,Fr,De,Es,It).gba" size 4194304 crc 5223f5aa sha1 0da4ff24b61ae8b6d67ef59377770fd958517f2f ) ) +game ( + name "Worms Blast (World) (En,Fr,De,Es,It) (Evercade) (Unl)" + description "Worms Blast (World) (En,Fr,De,Es,It) (Evercade) (Unl)" + rom ( name "Worms Blast (World) (En,Fr,De,Es,It) (Evercade) (Unl).gba" size 4194304 crc 55c25c4a sha1 da4e430b5fef43bdb8a4c52a8fdec5ae98243ddb ) +) + game ( name "WTA Tour Tennis (USA)" description "WTA Tour Tennis (USA)" @@ -20118,18 +19998,18 @@ game ( rom ( name "X Zhan Jing (Taiwan) (Unl).gba" size 33554432 crc 652a2ebe sha1 a35c891af070819fd14e0704984197c8e04ae127 ) ) -game ( - name "X-Bladez - Inline Skater (USA)" - description "X-Bladez - Inline Skater (USA)" - rom ( name "X-Bladez - Inline Skater (USA).gba" size 4194304 crc 09fdd665 sha1 a8354a51738c6b28660ab74acc7f8445a9a570a1 ) -) - game ( name "X-Bladez - Inline Skater (Europe)" description "X-Bladez - Inline Skater (Europe)" rom ( name "X-Bladez - Inline Skater (Europe).gba" size 4194304 crc c05f9907 sha1 8a5dc506fd6e000116be2ca923a056bc15d5b553 ) ) +game ( + name "X-Bladez - Inline Skater (USA)" + description "X-Bladez - Inline Skater (USA)" + rom ( name "X-Bladez - Inline Skater (USA).gba" size 4194304 crc 09fdd665 sha1 a8354a51738c6b28660ab74acc7f8445a9a570a1 ) +) + game ( name "X-Man - Armour of Might (Russia) (Unl)" description "X-Man - Armour of Might (Russia) (Unl)" @@ -20217,19 +20097,19 @@ game ( game ( name "Yggdra Union (Japan)" description "Yggdra Union (Japan)" - rom ( name "Yggdra Union (Japan).gba" size 33554432 crc a86f844a sha1 4ac5874b98f0fa3c3aad4c3ebe927f7fbc5b3267 ) + rom ( name "Yggdra Union (Japan).gba" size 33554432 crc bf53a3d2 sha1 b55d786fd8f80e71d24097ae45f5fcc5948f395b ) ) game ( name "Yggdra Union - We'll Never Fight Alone (USA)" description "Yggdra Union - We'll Never Fight Alone (USA)" - rom ( name "Yggdra Union - We'll Never Fight Alone (USA).gba" size 33554432 crc 3bfa68f7 sha1 b289083b01f2f8fc726c664cf872d72b3f4986e3 ) + rom ( name "Yggdra Union - We'll Never Fight Alone (USA).gba" size 33554432 crc 84b5666c sha1 75697060a9c262fd00552ddd06faec82fc310282 ) ) game ( name "Yggdra Union - We'll Never Fight Alone (Europe)" description "Yggdra Union - We'll Never Fight Alone (Europe)" - rom ( name "Yggdra Union - We'll Never Fight Alone (Europe).gba" size 33554432 crc 3e0df130 sha1 e419c835200457f67d5ab7e3c236583980b922d9 ) + rom ( name "Yggdra Union - We'll Never Fight Alone (Europe).gba" size 33554432 crc 2931d6a8 sha1 7b65074cb5d75d8f12692a21e2be77fa963f10e2 ) ) game ( @@ -20268,6 +20148,12 @@ game ( rom ( name "Youkaidou (Japan).gba" size 8388608 crc 2a4a92b4 sha1 ed6578bb6a4f201ae5b269df5ce842158a34a421 ) ) +game ( + name "Yu Yu Hakusho - Ghostfiles - Spirit Detective (USA) (Beta)" + description "Yu Yu Hakusho - Ghostfiles - Spirit Detective (USA) (Beta)" + rom ( name "Yu Yu Hakusho - Ghostfiles - Spirit Detective (USA) (Beta).gba" size 16777216 crc 8cbfa66b sha1 d3906650386872a94b83c417ecef2369ece5b978 ) +) + game ( name "Yu Yu Hakusho - Ghostfiles - Spirit Detective (USA)" description "Yu Yu Hakusho - Ghostfiles - Spirit Detective (USA)" @@ -20280,12 +20166,6 @@ game ( rom ( name "Yu Yu Hakusho - Ghostfiles - Spirit Detective (Europe) (En,Fr,De,Es,It).gba" size 8388608 crc 208d77ec sha1 66dc426b71195c11761f7ce58ffef231e8e227b1 ) ) -game ( - name "Yu Yu Hakusho - Ghostfiles - Spirit Detective (USA) (Beta)" - description "Yu Yu Hakusho - Ghostfiles - Spirit Detective (USA) (Beta)" - rom ( name "Yu Yu Hakusho - Ghostfiles - Spirit Detective (USA) (Beta).gba" size 16777216 crc 8cbfa66b sha1 d3906650386872a94b83c417ecef2369ece5b978 ) -) - game ( name "Yu Yu Hakusho - Ghostfiles - Tournament Tactics (USA, Europe)" description "Yu Yu Hakusho - Ghostfiles - Tournament Tactics (USA, Europe)" @@ -20343,7 +20223,7 @@ game ( game ( name "Yu-Gi-Oh! - Reshef of Destruction (Europe) (En,Fr,De,Es,It)" description "Yu-Gi-Oh! - Reshef of Destruction (Europe) (En,Fr,De,Es,It)" - rom ( name "Yu-Gi-Oh! - Reshef of Destruction (Europe) (En,Fr,De,Es,It).gba" size 16777216 crc 460e073f sha1 1d33877dcc5ec94cc0d68460163208c7ebfb6ad3 ) + rom ( name "Yu-Gi-Oh! - Reshef of Destruction (Europe) (En,Fr,De,Es,It).gba" size 16777216 crc 460e073f sha1 1d33877dcc5ec94cc0d68460163208c7ebfb6ad3 flags verified ) ) game ( @@ -20721,7 +20601,7 @@ game ( clrmamepro ( name "Nintendo - Game Boy Advance (Multiboot)" description "Nintendo - Game Boy Advance (Multiboot)" - version 20220808-164416 + version 20240221-035028 author "Arctic Circle System, C. V. Reynolds, chillerecke, DeriLoko3, Hiccup, hking0036, niemand, norkmetnoil577, omonim2007, relax" homepage No-Intro url "https://www.no-intro.org" @@ -21311,8 +21191,8 @@ game ( clrmamepro ( name "Nintendo - Game Boy Advance (Video)" description "Nintendo - Game Boy Advance (Video)" - version 20230804-201325 - author "BigFred, C. V. Reynolds, DeadSkullzJr, Hiccup, kazumi213, omonim2007, relax, SonGoku, xuom2" + version 20240727-194101 + author "BigFred, C. V. Reynolds, DeadSkullzJr, Hiccup, kazumi213, omonim2007, Psychofox11, psykopat, relax, SonGoku, xuom2" homepage No-Intro url "https://www.no-intro.org" forcenodump required @@ -21364,18 +21244,18 @@ game ( rom ( name "Game Boy Advance Video - Cartoon Network Collection - Premium Edition (USA, Europe).gba" size 33554432 crc f2825729 sha1 d0fe380fcdf5b1bb99188ed95c8c3272cbb65ce8 flags verified ) ) -game ( - name "Game Boy Advance Video - Cartoon Network Collection - Special Edition (USA) (Rev 5)" - description "Game Boy Advance Video - Cartoon Network Collection - Special Edition (USA) (Rev 5)" - rom ( name "Game Boy Advance Video - Cartoon Network Collection - Special Edition (USA) (Rev 5).gba" size 33554432 crc 1baf372d sha1 86f257c7b8d8feaee0a7e7dd5f5ba48053fd633e flags verified ) -) - game ( name "Game Boy Advance Video - Cartoon Network Collection - Special Edition (USA, Europe)" description "Game Boy Advance Video - Cartoon Network Collection - Special Edition (USA, Europe)" rom ( name "Game Boy Advance Video - Cartoon Network Collection - Special Edition (USA, Europe).gba" size 33554432 crc e9b7b8a4 sha1 5f17d2ec1a3ba1d605d486b6f6abcde6d82df767 ) ) +game ( + name "Game Boy Advance Video - Cartoon Network Collection - Special Edition (USA) (Rev 5)" + description "Game Boy Advance Video - Cartoon Network Collection - Special Edition (USA) (Rev 5)" + rom ( name "Game Boy Advance Video - Cartoon Network Collection - Special Edition (USA) (Rev 5).gba" size 33554432 crc 1baf372d sha1 86f257c7b8d8feaee0a7e7dd5f5ba48053fd633e flags verified ) +) + game ( name "Game Boy Advance Video - Cartoon Network Collection - Volume 1 (USA, Europe)" description "Game Boy Advance Video - Cartoon Network Collection - Volume 1 (USA, Europe)" @@ -21460,18 +21340,18 @@ game ( rom ( name "Game Boy Advance Video - Pokemon - Volume 4 (USA).gba" size 33554432 crc be468496 sha1 fd79b821ff601e0091f19ab9c86b08f1c39ea2f3 ) ) -game ( - name "Game Boy Advance Video - Shark Tale (USA) (Rev 5)" - description "Game Boy Advance Video - Shark Tale (USA) (Rev 5)" - rom ( name "Game Boy Advance Video - Shark Tale (USA) (Rev 5).gba" size 67108864 crc 01468820 sha1 6128a476edb10e6839ac5bd2697e83b9b7a9b234 ) -) - game ( name "Game Boy Advance Video - Shark Tale (USA) (Rev 6)" description "Game Boy Advance Video - Shark Tale (USA) (Rev 6)" rom ( name "Game Boy Advance Video - Shark Tale (USA) (Rev 6).gba" size 67108864 crc d2cf417a sha1 9bc5b60793b8a6de3b80eb2c213cd125e1fa468e flags verified ) ) +game ( + name "Game Boy Advance Video - Shark Tale (USA) (Rev 5)" + description "Game Boy Advance Video - Shark Tale (USA) (Rev 5)" + rom ( name "Game Boy Advance Video - Shark Tale (USA) (Rev 5).gba" size 67108864 crc 01468820 sha1 6128a476edb10e6839ac5bd2697e83b9b7a9b234 flags verified ) +) + game ( name "Game Boy Advance Video - Shrek (USA) (Rev 5)" description "Game Boy Advance Video - Shrek (USA) (Rev 5)" @@ -21490,18 +21370,18 @@ game ( rom ( name "Game Boy Advance Video - Shrek + Shark Tale (USA) (Rev 5).gba" size 67108864 crc aadb3e3d sha1 f23390b7a62c605fbce6730addc29d381488e076 flags verified ) ) -game ( - name "Game Boy Advance Video - Shrek 2 (USA) (Rev 6)" - description "Game Boy Advance Video - Shrek 2 (USA) (Rev 6)" - rom ( name "Game Boy Advance Video - Shrek 2 (USA) (Rev 6).gba" size 67108864 crc 925b6c02 sha1 3bcb4acc5da539bc1b91c9537bf7ffa081ded1d4 ) -) - game ( name "Game Boy Advance Video - Shrek 2 (USA) (Rev 5)" description "Game Boy Advance Video - Shrek 2 (USA) (Rev 5)" rom ( name "Game Boy Advance Video - Shrek 2 (USA) (Rev 5).gba" size 67108864 crc 0d353654 sha1 5cd627e205020297b25d707131883be5850515fe flags verified ) ) +game ( + name "Game Boy Advance Video - Shrek 2 (USA) (Rev 6)" + description "Game Boy Advance Video - Shrek 2 (USA) (Rev 6)" + rom ( name "Game Boy Advance Video - Shrek 2 (USA) (Rev 6).gba" size 67108864 crc 925b6c02 sha1 3bcb4acc5da539bc1b91c9537bf7ffa081ded1d4 ) +) + game ( name "Game Boy Advance Video - Sonic X - Volume 1 (USA)" description "Game Boy Advance Video - Sonic X - Volume 1 (USA)" @@ -21574,23 +21454,23 @@ game ( rom ( name "Game Boy Advance Video - The Proud Family - Volume 1 (USA).gba" size 33554432 crc c6a91365 sha1 31a2cbb9b1b5adf7de399eecf2a9cec4f5412767 ) ) -game ( - name "Game Boy Advance Video - Yu-Gi-Oh! - Yugi vs. Joey (France)" - description "Game Boy Advance Video - Yu-Gi-Oh! - Yugi vs. Joey (France)" - rom ( name "Game Boy Advance Video - Yu-Gi-Oh! - Yugi vs. Joey (France).gba" size 33554432 crc c9b6ccf1 sha1 8fb43e5018cf2d4b1a2aa2d1693862ce248ab6b0 ) -) - game ( name "Game Boy Advance Video - Yu-Gi-Oh! - Yugi vs. Joey (USA, Europe)" description "Game Boy Advance Video - Yu-Gi-Oh! - Yugi vs. Joey (USA, Europe)" rom ( name "Game Boy Advance Video - Yu-Gi-Oh! - Yugi vs. Joey (USA, Europe).gba" size 33554432 crc 8d631f4e sha1 6daf15bb61a10d1bbf94009886d6a76f9c937f8b flags verified ) ) +game ( + name "Game Boy Advance Video - Yu-Gi-Oh! - Yugi vs. Joey (France)" + description "Game Boy Advance Video - Yu-Gi-Oh! - Yugi vs. Joey (France)" + rom ( name "Game Boy Advance Video - Yu-Gi-Oh! - Yugi vs. Joey (France).gba" size 33554432 crc c9b6ccf1 sha1 8fb43e5018cf2d4b1a2aa2d1693862ce248ab6b0 flags verified ) +) + clrmamepro ( - name "Nintendo - Game Boy" - description "Nintendo - Game Boy" - version 20240106-192522 - author "aci68, akubi, Arctic Circle System, Aringon, baldjared, Bent, BigFred, BitLooter, buckwheat, C. V. Reynolds, chillerecke, darthcloud, DeadSkullzJr, Densetsu, DeriLoko3, ElBarto, foxe, fuzzball, Gefflon, Hiccup, hking0036, InternalLoss, Jack, jimmsu, Just001Kim, kazumi213, leekindo, Lesserkuma, Madeline, NESBrew12, NGEfreak, nnssxx, norkmetnoil577, NovaAurora, omonim2007, Powerpuff, PPLToast, Psychofox11, rarenight, relax, RetroUprising, rpg2813, sCZther, SonGoku, Tauwasser, togemet2, UnlockerPT, xNo, xprism, xuom2" + name "Nintendo - Game Boy Advance (Aftermarket)" + description "Nintendo - Game Boy Advance (Aftermarket)" + version 20240807-214821 + author "aci68, Arctic Circle System, Aringon, Bent, BigFred, bikerspade, C. V. Reynolds, chillerecke, DeadSkullzJr, Densetsu, DeriLoko3, einstein95, ElBarto, Enker, FakeShemp, Flashfire42, fuzzball, Gefflon, Hiccup, hking0036, hydr0x, InternalLoss, Jack, jimmsu, Just001Kim, kazumi213, Larsenv, Lesserkuma, Madeline, MeguCocoa, Money_114, NESBrew12, niemand, nnssxx, norkmetnoil577, NovaAurora, omonim2007, Powerpuff, PPLToast, Prominos, Psychofox11, psykopat, rarenight, relax, RetroGamer, Rifu, sCZther, SonGoku, Tauwasser, Tescu, togemet2, ufocrossing, Vallaine01, Whovian9369, xprism, xuom2, zg" homepage No-Intro url "https://www.no-intro.org" forcenodump required @@ -21601,6315 +21481,6823 @@ emulator ( ) game ( - name "[BIOS] Maxstation Boot ROM (China) (En) (Unl)" - description "[BIOS] Maxstation Boot ROM (China) (En) (Unl)" - rom ( name "[BIOS] Maxstation Boot ROM (China) (En) (Unl).gb" size 256 crc 783e69c2 sha1 1776bd61b8db71fc4c4d4b5feab4a21b3c1fd95b ) + name "2-in-1 - Smickeonn the Game + Smickeonn the Game Deluxe (World) (Demo) (Aftermarket) (Unl)" + description "2-in-1 - Smickeonn the Game + Smickeonn the Game Deluxe (World) (Demo) (Aftermarket) (Unl)" + rom ( name "2-in-1 - Smickeonn the Game + Smickeonn the Game Deluxe (World) (Demo) (Aftermarket) (Unl).gba" size 1648884 crc 8ad5b73f sha1 eb85e372f15299cde6fefa8a2967e7e2886c9c56 ) ) game ( - name "[BIOS] Nintendo Game Boy Boot ROM (World) (Rev 1)" - description "[BIOS] Nintendo Game Boy Boot ROM (World) (Rev 1)" - rom ( name "[BIOS] Nintendo Game Boy Boot ROM (World) (Rev 1).gb" size 256 crc 59c8598e sha1 4ed31ec6b0b175bb109c0eb5fd3d193da823339f flags verified ) + name "2048 Pool (World) (Aftermarket) (Unl)" + description "2048 Pool (World) (Aftermarket) (Unl)" + rom ( name "2048 Pool (World) (Aftermarket) (Unl).gba" size 203440 crc 9df6ae4f sha1 c93a9cf3502237b474e70de8dee274901ee7ecb2 ) ) game ( - name "[BIOS] Nintendo Game Boy Boot ROM (Japan) (En)" - description "[BIOS] Nintendo Game Boy Boot ROM (Japan) (En)" - rom ( name "[BIOS] Nintendo Game Boy Boot ROM (Japan) (En).gb" size 256 crc c2f5cc97 sha1 8bd501e31921e9601788316dbd3ce9833a97bcbc flags verified ) + name "Advanced Ghost Wranglin' (World) (Demo) (Aftermarket) (Unl)" + description "Advanced Ghost Wranglin' (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Advanced Ghost Wranglin' (World) (Demo) (Aftermarket) (Unl).gba" size 354992 crc 739eb5ce sha1 9cf53301404407aae24ac7735006f594ca0fe969 ) ) game ( - name "[BIOS] Nintendo Game Boy Pocket Boot ROM (World)" - description "[BIOS] Nintendo Game Boy Pocket Boot ROM (World)" - rom ( name "[BIOS] Nintendo Game Boy Pocket Boot ROM (World).gb" size 256 crc e6920754 sha1 4e68f9da03c310e84c523654b9026e51f26ce7f0 flags verified ) + name "Anguna - Warriors of Virtue (World) (v0.95) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (v0.95) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (v0.95) (Aftermarket) (Unl).gba" size 1710888 crc 3346891f sha1 270c426705df767a4ad2dc69d039842442f779b2 flags verified ) ) game ( - name "10-Pin Bowling (USA) (Proto)" - description "10-Pin Bowling (USA) (Proto)" - rom ( name "10-Pin Bowling (USA) (Proto).gb" size 131072 crc 9a024415 sha1 952d154dd2c6189ef4b786ae37bd7887c8ca9037 ) + name "Anguna - Warriors of Virtue (World) (2021-02-28) (Patreon) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (2021-02-28) (Patreon) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (2021-02-28) (Patreon) (Aftermarket) (Unl).gba" size 1729120 crc a354d555 sha1 d7cd0ab9d622187d4ce55bf0c7f14a24ee781710 ) ) game ( - name "14 Juillet (World) (Fr) (Aftermarket) (Unl)" - description "14 Juillet (World) (Fr) (Aftermarket) (Unl)" - rom ( name "14 Juillet (World) (Fr) (Aftermarket) (Unl).gb" size 1048576 crc 7b66bee4 sha1 02f387457a779cbd2f493e52743cd32c169c098e ) + name "Anguna - Warriors of Virtue (World) (v0.95) (Itch.io) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (v0.95) (Itch.io) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (v0.95) (Itch.io) (Aftermarket) (Unl).gba" size 1775856 crc 41ea5b0b sha1 e351bc6a9046ec002fc2dfdee061047908bd4350 ) ) game ( - name "3 Choume no Tama - Tama and Friends - 3 Choume Obake Panic!! (Japan)" - description "3 Choume no Tama - Tama and Friends - 3 Choume Obake Panic!! (Japan)" - rom ( name "3 Choume no Tama - Tama and Friends - 3 Choume Obake Panic!! (Japan).gb" size 131072 crc b61cd120 sha1 0982bcc82deb9c4db08e602a22a2bb4f31e7e6ae ) + name "Anguna - Warriors of Virtue (World) (Retro-Bit Generations) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (Retro-Bit Generations) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (Retro-Bit Generations) (Aftermarket) (Unl).gba" size 1775660 crc a234813c sha1 ad904624bf198a164ba580eea326cd30fffebac8 ) ) game ( - name "3-pun Yosou - Umaban Club (Japan)" - description "3-pun Yosou - Umaban Club (Japan)" - rom ( name "3-pun Yosou - Umaban Club (Japan).gb" size 65536 crc cafe0d2b sha1 76643f3f3481f7e515a24482779870862dd8b373 ) + name "Anguna - Warriors of Virtue (World) (Demo) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (Demo) (Aftermarket) (Unl).gba" size 597104 crc 0a9098b4 sha1 0992fb6f38e49426adc834fb3831748a1caa1bc0 ) ) game ( - name "4 in 1 (Europe) (4B-002, Sachen) (Unl)" - description "4 in 1 (Europe) (4B-002, Sachen) (Unl)" - rom ( name "4 in 1 (Europe) (4B-002, Sachen) (Unl).gb" size 65536 crc 5e438db8 sha1 d9cb1721854709be7667f5dbce0adf2488c0919b flags verified ) + name "Anguna - Warriors of Virtue (World) (v2.0) (Demo) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (v2.0) (Demo) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (v2.0) (Demo) (Aftermarket) (Unl).gba" size 811840 crc 63c1cc2c sha1 faca8225ee20b8e5edb14e005af77b63c6f51446 ) ) game ( - name "4 in 1 (Europe) (4B-005, Sachen-Commin) (Unl)" - description "4 in 1 (Europe) (4B-005, Sachen-Commin) (Unl)" - rom ( name "4 in 1 (Europe) (4B-005, Sachen-Commin) (Unl).gb" size 262144 crc f4310eb3 sha1 2107979104cff88bcd635215a936bbc44354ea7c flags verified ) + name "Anguna - Warriors of Virtue (World) (v0.91) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (v0.91) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (v0.91) (Aftermarket) (Unl).gba" size 1714000 crc eebb016f sha1 008a9d06f78bccc540ca4ece4d1982de76f95901 ) ) game ( - name "4 in 1 (Europe) (4B-007, Sachen) (Unl)" - description "4 in 1 (Europe) (4B-007, Sachen) (Unl)" - rom ( name "4 in 1 (Europe) (4B-007, Sachen) (Unl).gb" size 262144 crc 62d9350e sha1 0eef7f3934508ab79e1cad4ddf3bfdb3216b6b4f flags verified ) + name "Anguna - Warriors of Virtue (World) (v0.92) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (v0.92) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (v0.92) (Aftermarket) (Unl).gba" size 1710624 crc ba271987 sha1 04f1e79e79e894d8f45ed1ea2ff5aa67053f0ab3 ) ) game ( - name "4 in 1 (Europe) (4B-001, Sachen-Commin) (Unl)" - description "4 in 1 (Europe) (4B-001, Sachen-Commin) (Unl)" - rom ( name "4 in 1 (Europe) (4B-001, Sachen-Commin) (Unl).gb" size 262144 crc 82f06e93 sha1 7506c75fdfa29935afb1e85f5b6013516b2e9f92 flags verified ) + name "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl).gba" size 1710624 crc df7108e3 sha1 bd267fd7e762acb8cd595e54bfd51a139864759e ) ) game ( - name "4 in 1 (Europe) (4B-008, Sachen) (Unl)" - description "4 in 1 (Europe) (4B-008, Sachen) (Unl)" - rom ( name "4 in 1 (Europe) (4B-008, Sachen) (Unl).gb" size 262144 crc 740e9bc8 sha1 d7c11d56a42ed7c4ef2fe3c752931a63160d7429 flags verified ) + name "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl) (Alt)" + description "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl) (Alt)" + rom ( name "Anguna - Warriors of Virtue (World) (v0.93) (Aftermarket) (Unl) (Alt).gba" size 1714000 crc 54ff2e56 sha1 0386315fc140db2a43a6f927c04de658bd800da9 ) ) game ( - name "4 in 1 (Europe) (4B-004, Sachen-Commin) (Unl)" - description "4 in 1 (Europe) (4B-004, Sachen-Commin) (Unl)" - rom ( name "4 in 1 (Europe) (4B-004, Sachen-Commin) (Unl).gb" size 262144 crc c69a19f6 sha1 ca7990dc03a3b3ada1dce37afc4490deaf872402 flags verified ) + name "Anguna - Warriors of Virtue (World) (v0.94) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (v0.94) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (v0.94) (Aftermarket) (Unl).gba" size 1710952 crc cb4e2768 sha1 a7297cf4ecffc1f93f86edde68e1ff42e8099f3b ) ) game ( - name "4 in 1 (Europe) (4B-006, Sachen) (Unl)" - description "4 in 1 (Europe) (4B-006, Sachen) (Unl)" - rom ( name "4 in 1 (Europe) (4B-006, Sachen) (Unl).gb" size 262144 crc 95398da5 sha1 2e856de768c7cb442a206de8c94a23548027bb60 flags verified ) + name "Anguna - Warriors of Virtue (World) (Evercade) (Aftermarket) (Unl)" + description "Anguna - Warriors of Virtue (World) (Evercade) (Aftermarket) (Unl)" + rom ( name "Anguna - Warriors of Virtue (World) (Evercade) (Aftermarket) (Unl).gba" size 1693656 crc 7d8c00d3 sha1 9fffd28c933ac88a441a2e262156c66a3a763829 ) ) game ( - name "4 in 1 (Europe) (4B-009, Sachen) (Unl)" - description "4 in 1 (Europe) (4B-009, Sachen) (Unl)" - rom ( name "4 in 1 (Europe) (4B-009, Sachen) (Unl).gb" size 262144 crc 114e1f1e sha1 39743e21935a9115fcb4ee86d67d51bdb4b5f6d6 flags verified ) + name "Apotris (World) (v3.4.5) (Aftermarket) (Unl)" + description "Apotris (World) (v3.4.5) (Aftermarket) (Unl)" + rom ( name "Apotris (World) (v3.4.5) (Aftermarket) (Unl).gba" size 4194304 crc 55ae4312 sha1 fb7142bcc30f71f187cc51b7fcbc5a3958374c6c ) ) game ( - name "4 in 1 (Taiwan) (En,Zh) (4B-003, Sachen-Commin) (Unl)" - description "4 in 1 (Taiwan) (En,Zh) (4B-003, Sachen-Commin) (Unl)" - rom ( name "4 in 1 (Taiwan) (En,Zh) (4B-003, Sachen-Commin) (Unl).gb" size 65536 crc c294aa21 sha1 b5a3ee09692476d801d873a703d508d17ee24fbd ) + name "Armadillo Run (World) (Demo) (Aftermarket) (Unl)" + description "Armadillo Run (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Armadillo Run (World) (Demo) (Aftermarket) (Unl).gba" size 1260068 crc 5151babd sha1 dfb706257d598a5ae845ddf6485e59a88c16d210 ) ) game ( - name "4-in-1 Fun Pak (Japan)" - description "4-in-1 Fun Pak (Japan)" - rom ( name "4-in-1 Fun Pak (Japan).gb" size 131072 crc 86f45343 sha1 f1cf115df0246f08d4e886cb046ebd2aa431a6c9 ) + name "Attack on Voxelburg (World) (Demo) (GBA Jam 2022) (Aftermarket) (Unl)" + description "Attack on Voxelburg (World) (Demo) (GBA Jam 2022) (Aftermarket) (Unl)" + rom ( name "Attack on Voxelburg (World) (Demo) (GBA Jam 2022) (Aftermarket) (Unl).gba" size 827676 crc 941c1fe0 sha1 cb3823420a6e2399db7fa4805fefd1b5366c778e ) ) game ( - name "4-in-1 Fun Pak (USA, Europe)" - description "4-in-1 Fun Pak (USA, Europe)" - rom ( name "4-in-1 Fun Pak (USA, Europe).gb" size 131072 crc 0e0216e6 sha1 b1443c09ee3f2bee5437111a635b6d84155f600e flags verified ) + name "Battery Chad - Shock the World (World) (Demo) (Aftermarket) (Unl)" + description "Battery Chad - Shock the World (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Battery Chad - Shock the World (World) (Demo) (Aftermarket) (Unl).gba" size 609400 crc e0a4bc38 sha1 3274c915fb78d10541efa69dfbb8f9391f974ffe ) ) game ( - name "4-in-1 Funpak - Volume II (USA, Europe)" - description "4-in-1 Funpak - Volume II (USA, Europe)" - rom ( name "4-in-1 Funpak - Volume II (USA, Europe).gb" size 131072 crc 018b4a02 sha1 5efeddce9e03ad56ee755c58fb658b045dc0fa53 ) + name "Blender Bros. (World) (Aftermarket) (Unl)" + description "Blender Bros. (World) (Aftermarket) (Unl)" + rom ( name "Blender Bros. (World) (Aftermarket) (Unl).gba" size 8388608 crc 440f2f06 sha1 8f9ca62306b7ab56d8da45673d7b7d0eb4c349c5 ) ) game ( - name "8-in-1 (Taiwan) (En) (Unl)" - description "8-in-1 (Taiwan) (En) (Unl)" - rom ( name "8-in-1 (Taiwan) (En) (Unl).gb" size 524288 crc fbc77225 sha1 f57efd4d5063cb87519fc3b574377cc9a2a841ee ) + name "Blind Jump (World) (En,Ja,Fr,It,Ru) (v2021.11.20.0) (Proto) (Aftermarket) (Unl)" + description "Blind Jump (World) (En,Ja,Fr,It,Ru) (v2021.11.20.0) (Proto) (Aftermarket) (Unl)" + rom ( name "Blind Jump (World) (En,Ja,Fr,It,Ru) (v2021.11.20.0) (Proto) (Aftermarket) (Unl).gba" size 16565008 crc 2342e91e sha1 2e5758789f7e109839ea302424c385c1247eab38 ) ) game ( - name "A-mazing Tater (USA)" - description "A-mazing Tater (USA)" - rom ( name "A-mazing Tater (USA).gb" size 65536 crc d229ac62 sha1 1e475cbd5fb7099df91155a103698e4e66da7a86 ) + name "Blood Drive (World) (GBA Jam Week) (Aftermarket) (Unl)" + description "Blood Drive (World) (GBA Jam Week) (Aftermarket) (Unl)" + rom ( name "Blood Drive (World) (GBA Jam Week) (Aftermarket) (Unl).gba" size 1523780 crc 3444a7ae sha1 12a3c114563684fdca4a4ee1b3fea43ceaf226c0 ) ) game ( - name "Aa Harimanada (Japan)" - description "Aa Harimanada (Japan)" - rom ( name "Aa Harimanada (Japan).gb" size 131072 crc 5bffcc28 sha1 ff3565fcac22b44bf542732d1b0b20ba96a6c961 ) + name "Broken Circle (World) (En,It) (Aftermarket) (Unl)" + description "Broken Circle (World) (En,It) (Aftermarket) (Unl)" + rom ( name "Broken Circle (World) (En,It) (Aftermarket) (Unl).gba" size 16777216 crc 3212c09b sha1 e04a71dbe7b640cc53e81f447856e60666e64aa3 ) ) game ( - name "Action Replay Pro (World)" - description "Action Replay Pro (World)" - rom ( name "Action Replay Pro (World).gb" size 16384 crc 2ea05daa sha1 e947b9264092168950ad1ce23bbe3d8ccfed765e ) + name "Brush Rush (World) (Proto) (GBA WinterJam 2023) (Aftermarket) (Unl)" + description "Brush Rush (World) (Proto) (GBA WinterJam 2023) (Aftermarket) (Unl)" + rom ( name "Brush Rush (World) (Proto) (GBA WinterJam 2023) (Aftermarket) (Unl).gba" size 371136 crc afdf2c03 sha1 d36f7bd6d0420597ba0f12f746f8ec8a628b3658 ) ) game ( - name "Addams Family, The (Europe) (En,Fr,De)" - description "Addams Family, The (Europe) (En,Fr,De)" - rom ( name "Addams Family, The (Europe) (En,Fr,De).gb" size 131072 crc 28fa451e sha1 2246dbdb6c58c77814cf034ae9224be8e73c5084 flags verified ) + name "Butano Fighter (World) (Aftermarket) (Unl)" + description "Butano Fighter (World) (Aftermarket) (Unl)" + rom ( name "Butano Fighter (World) (Aftermarket) (Unl).gba" size 3482456 crc 3c31501c sha1 36efe397badf199c0339222dc825013c06b86423 ) ) game ( - name "Addams Family, The (Japan)" - description "Addams Family, The (Japan)" - rom ( name "Addams Family, The (Japan).gb" size 131072 crc 4c749c14 sha1 10a7d1491001657272755559ed593cc4400014ee ) + name "Cat's Curse (World) (Aftermarket) (Unl)" + description "Cat's Curse (World) (Aftermarket) (Unl)" + rom ( name "Cat's Curse (World) (Aftermarket) (Unl).gba" size 353052 crc a35d87de sha1 4a149baad17840948c2d4ffdf068bfaf1116a024 ) ) game ( - name "Addams Family, The (USA)" - description "Addams Family, The (USA)" - rom ( name "Addams Family, The (USA).gb" size 131072 crc c170a732 sha1 8710ceecbe3e7ade67c0362cc3b455aceb67a90d flags verified ) + name "CCCP (World) (Aftermarket) (Unl)" + description "CCCP (World) (Aftermarket) (Unl)" + rom ( name "CCCP (World) (Aftermarket) (Unl).gba" size 499440 crc ad634c54 sha1 324f0375e3f4f89455122e2663b831917013bfc3 ) ) game ( - name "Addams Family, The - Pugsley's Scavenger Hunt (USA, Europe)" - description "Addams Family, The - Pugsley's Scavenger Hunt (USA, Europe)" - rom ( name "Addams Family, The - Pugsley's Scavenger Hunt (USA, Europe).gb" size 131072 crc 7e054a88 sha1 f9020e3d104cb5c5347e28f45ed9e24e6c0ebddd flags verified ) + name "Celeste Classic (World) (v1.0) (Aftermarket) (Unl)" + description "Celeste Classic (World) (v1.0) (Aftermarket) (Unl)" + rom ( name "Celeste Classic (World) (v1.0) (Aftermarket) (Unl).gba" size 5416932 crc f79b0d53 sha1 756f02396a150698e695ad4afd24445e2af70576 ) ) game ( - name "Adulting! (World) (v2.0) (Aftermarket) (Unl)" - description "Adulting! (World) (v2.0) (Aftermarket) (Unl)" - rom ( name "Adulting! (World) (v2.0) (Aftermarket) (Unl).gb" size 524288 crc e56d1244 sha1 d107bd8bf32d0d94a988466885fe1a44aae32c9a flags verified ) + name "Celeste Classic (World) (v1.1) (Aftermarket) (Unl)" + description "Celeste Classic (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Celeste Classic (World) (v1.1) (Aftermarket) (Unl).gba" size 5418248 crc f5d36ad2 sha1 95a86dff641b11b4c2ed0d0fe8152c33b462d927 ) ) game ( - name "Adventure Island (USA, Europe)" - description "Adventure Island (USA, Europe)" - rom ( name "Adventure Island (USA, Europe).gb" size 131072 crc 64f4fa44 sha1 4a61945c1e3a37301748314777835c0e122a67e6 flags verified ) + name "Celeste Classic (World) (v1.2) (Aftermarket) (Unl)" + description "Celeste Classic (World) (v1.2) (Aftermarket) (Unl)" + rom ( name "Celeste Classic (World) (v1.2) (Aftermarket) (Unl).gba" size 5418424 crc ff0e8ada sha1 08512605e5c02e81a72e24c2c8d4959d8e84e1f4 ) ) game ( - name "Adventure Island II - Aliens in Paradise (USA, Europe)" - description "Adventure Island II - Aliens in Paradise (USA, Europe)" - rom ( name "Adventure Island II - Aliens in Paradise (USA, Europe).gb" size 262144 crc 783066cf sha1 1964fd5708150aa9f71c0a79d552466fd5bf5bf8 flags verified ) + name "Codename Hacker (World) (En,Fr) (Aftermarket) (Unl)" + description "Codename Hacker (World) (En,Fr) (Aftermarket) (Unl)" + rom ( name "Codename Hacker (World) (En,Fr) (Aftermarket) (Unl).gba" size 4058684 crc 1ccfbe29 sha1 fbc6a366f773204b031b589aab4125e15a70dc9b ) ) game ( - name "Adventures of Lolo (Europe) (SGB Enhanced)" - description "Adventures of Lolo (Europe) (SGB Enhanced)" - rom ( name "Adventures of Lolo (Europe) (SGB Enhanced).gb" size 262144 crc 176d2eeb sha1 e09277358a7fd4f3a6206464dd9d39f3abe66a53 flags verified ) + name "Collie Defense (World) (Demo) (Aftermarket) (Unl)" + description "Collie Defense (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Collie Defense (World) (Demo) (Aftermarket) (Unl).gba" size 3714268 crc 08feb1ed sha1 4dce7b29bca3f8588cccb548c698d5d2ba53e188 ) ) game ( - name "Adventures of Pinocchio, The (Europe) (Proto)" - description "Adventures of Pinocchio, The (Europe) (Proto)" - rom ( name "Adventures of Pinocchio, The (Europe) (Proto).gb" size 65536 crc 0b9de1dc sha1 6808d5a5fba9b58d67e91f22a2860e4e72f6eec1 ) + name "DCPR (World) (Demo) (Aftermarket) (Unl)" + description "DCPR (World) (Demo) (Aftermarket) (Unl)" + rom ( name "DCPR (World) (Demo) (Aftermarket) (Unl).gba" size 107512 crc 6c27348a sha1 43d11a2e42aa56fa8851bb00a5467211ac195feb ) ) game ( - name "Adventures of Rocky and Bullwinkle and Friends, The (USA)" - description "Adventures of Rocky and Bullwinkle and Friends, The (USA)" - rom ( name "Adventures of Rocky and Bullwinkle and Friends, The (USA).gb" size 131072 crc 362c841c sha1 0ce98889e5d9d6167338e91119394537318810da ) + name "Donsol (World) (Aftermarket) (Unl)" + description "Donsol (World) (Aftermarket) (Unl)" + rom ( name "Donsol (World) (Aftermarket) (Unl).gba" size 52520 crc aec144b3 sha1 751675b0d77c341f2265b0edd38858b0dbdb7b50 ) ) game ( - name "Adventures of Star Saver, The (USA, Europe)" - description "Adventures of Star Saver, The (USA, Europe)" - rom ( name "Adventures of Star Saver, The (USA, Europe).gb" size 131072 crc 5d461374 sha1 408b19a92c73daa11b3b1a52aa6a987cc6615e97 flags verified ) + name "Drawing a Leviathan (World) (Aftermarket) (Unl)" + description "Drawing a Leviathan (World) (Aftermarket) (Unl)" + rom ( name "Drawing a Leviathan (World) (Aftermarket) (Unl).gba" size 9437768 crc 1eb0f64d sha1 745636d636b44a67ad078dae5416636fa58236ab ) ) game ( - name "Aerostar (Japan)" - description "Aerostar (Japan)" - rom ( name "Aerostar (Japan).gb" size 131072 crc dfa3b28a sha1 1088817172c10a9080ab6859da85a074569e2cba ) + name "Eliminator GBA (World) (v0.91) (Proto) (Aftermarket) (Unl)" + description "Eliminator GBA (World) (v0.91) (Proto) (Aftermarket) (Unl)" + rom ( name "Eliminator GBA (World) (v0.91) (Proto) (Aftermarket) (Unl).gba" size 747872 crc 637dc1aa sha1 13a4d5c2c647945cbbf17423afd45a25c4057527 ) ) game ( - name "Aerostar (USA, Europe)" - description "Aerostar (USA, Europe)" - rom ( name "Aerostar (USA, Europe).gb" size 131072 crc f6fd275e sha1 2cb231e616008f2c809e0b2caf40f477689e6d07 flags verified ) + name "Elite AGB (World) (v1.4.1) (Aftermarket) (Unl)" + description "Elite AGB (World) (v1.4.1) (Aftermarket) (Unl)" + rom ( name "Elite AGB (World) (v1.4.1) (Aftermarket) (Unl).gba" size 960088 crc 28985872 sha1 803095500e47772452433144f2cd7630d515a41b ) ) game ( - name "After Burst (Japan)" - description "After Burst (Japan)" - rom ( name "After Burst (Japan).gb" size 65536 crc c0049d77 sha1 459cb97524669b0de6cd7cfada61ad67339232f1 ) + name "Elite AGB (World) (v0.5.2) (Beta) (Aftermarket) (Unl)" + description "Elite AGB (World) (v0.5.2) (Beta) (Aftermarket) (Unl)" + rom ( name "Elite AGB (World) (v0.5.2) (Beta) (Aftermarket) (Unl).gba" size 327360 crc f00c939f sha1 ce5a236608c629c99d4ec7b35e3ccaf211e6bb60 ) ) game ( - name "Agro Soar (Australia)" - description "Agro Soar (Australia)" - rom ( name "Agro Soar (Australia).gb" size 131072 crc 9b7945ea sha1 d635761f247301fe6bae4d71ee67ceef384ca53a flags verified ) + name "Feline (World) (GBA Jam 2021) (Aftermarket) (Unl)" + description "Feline (World) (GBA Jam 2021) (Aftermarket) (Unl)" + rom ( name "Feline (World) (GBA Jam 2021) (Aftermarket) (Unl).gba" size 1504920 crc 09b777ea sha1 34b5aff6a7a3d752027ea1d2fd53e03bb8964529 ) ) game ( - name "Akazukin Chacha (Japan) (SGB Enhanced)" - description "Akazukin Chacha (Japan) (SGB Enhanced)" - rom ( name "Akazukin Chacha (Japan) (SGB Enhanced).gb" size 262144 crc 898609b4 sha1 d07970a7eae51aef8c4e8b4bcdd57aeed6360bdd ) + name "Flappy Bird (World) (Aftermarket) (Unl)" + description "Flappy Bird (World) (Aftermarket) (Unl)" + rom ( name "Flappy Bird (World) (Aftermarket) (Unl).gba" size 575204 crc 4d099541 sha1 55f611567e7ac2ad8f96529f4d7eac70ad283601 ) ) game ( - name "Akumajou Dracula - Shikkoku Taru Zensoukyoku - Dark Night Prelude (Japan) (SGB Enhanced)" - description "Akumajou Dracula - Shikkoku Taru Zensoukyoku - Dark Night Prelude (Japan) (SGB Enhanced)" - rom ( name "Akumajou Dracula - Shikkoku Taru Zensoukyoku - Dark Night Prelude (Japan) (SGB Enhanced).gb" size 262144 crc 4825b25f sha1 baaa12be322adc005e51b43c73a352420d7cd034 ) + name "GBA Tactics (World) (Proto) (NEO Coding Compo 2006) (Aftermarket) (Unl)" + description "GBA Tactics (World) (Proto) (NEO Coding Compo 2006) (Aftermarket) (Unl)" + rom ( name "GBA Tactics (World) (Proto) (NEO Coding Compo 2006) (Aftermarket) (Unl).gba" size 251816 crc 81b449a6 sha1 803834d8843a6689fe43c77921eaaea6bdaf6ed4 ) ) game ( - name "Akumajou Special - Boku Dracula-kun (Japan)" - description "Akumajou Special - Boku Dracula-kun (Japan)" - rom ( name "Akumajou Special - Boku Dracula-kun (Japan).gb" size 262144 crc e8335398 sha1 f2f15da8ed94bc8652c23965428f6d767e506e38 flags verified ) + name "Glacia Dungeon (World) (En,Es,Ru,Ro) (v1.5.2) (Aftermarket) (Unl)" + description "Glacia Dungeon (World) (En,Es,Ru,Ro) (v1.5.2) (Aftermarket) (Unl)" + rom ( name "Glacia Dungeon (World) (En,Es,Ru,Ro) (v1.5.2) (Aftermarket) (Unl).gba" size 1210608 crc ab5ae65b sha1 e35037ff9cc24f8a7043d9a9d378e86d2ef80f9b ) ) game ( - name "Aladdin (Europe) (SGB Enhanced)" - description "Aladdin (Europe) (SGB Enhanced)" - rom ( name "Aladdin (Europe) (SGB Enhanced).gb" size 262144 crc 283c58b7 sha1 a40694a808c5a0d3eeb386f81ad5b0c11163238f flags verified ) + name "Goldrunner (World) (Aftermarket) (Unl)" + description "Goldrunner (World) (Aftermarket) (Unl)" + rom ( name "Goldrunner (World) (Aftermarket) (Unl).gba" size 527040 crc 53f4cac1 sha1 517a400150a6ebca126b0a95aa3497c637cc8161 ) ) game ( - name "Aladdin (USA) (SGB Enhanced)" - description "Aladdin (USA) (SGB Enhanced)" - rom ( name "Aladdin (USA) (SGB Enhanced).gb" size 262144 crc af6bdc50 sha1 81b4e56ae235fbb123d7ad4bd7c1d96c3b69eb72 ) + name "Goodboy Galaxy (World) (En,Ja,Fr,De,Es,Pt-BR,Zh,Ar) (Evercade) (Aftermarket) (Unl)" + description "Goodboy Galaxy (World) (En,Ja,Fr,De,Es,Pt-BR,Zh,Ar) (Evercade) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy (World) (En,Ja,Fr,De,Es,Pt-BR,Zh,Ar) (Evercade) (Aftermarket) (Unl).gba" size 32524164 crc ebb81069 sha1 273bae3d794f2b5a6bea637f67f7d5163ae4bb62 ) ) game ( - name "Aladdin (World) (Disney Classic Games) (SGB Enhanced)" - description "Aladdin (World) (Disney Classic Games) (SGB Enhanced)" - rom ( name "Aladdin (World) (Disney Classic Games) (SGB Enhanced).gb" size 262144 crc 53918941 sha1 c59c44051e41dc6ac8c2f693cff2ba1feffd32f0 flags verified ) + name "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.6) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.6) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13224124 crc 19ba7d80 sha1 1bf95f8730ecdfa6665b85bea8764f42a88e8e3d ) ) game ( - name "Aladdin (Europe) (Sample) (SGB Enhanced)" - description "Aladdin (Europe) (Sample) (SGB Enhanced)" - rom ( name "Aladdin (Europe) (Sample) (SGB Enhanced).gb" size 262144 crc 28827ea5 sha1 6d925762a46e1996cf3702dfb85be09f546b2137 ) + name "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.6) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.6) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13219728 crc d4621e3e sha1 5bd59fac58c5f9a375216e9d1cf85fa5262f21f7 ) ) game ( - name "Alfred Chicken (Europe) (Beta)" - description "Alfred Chicken (Europe) (Beta)" - rom ( name "Alfred Chicken (Europe) (Beta).gb" size 131072 crc 2e19f638 sha1 a9aa7cf61ffa42a4097f0c900ad4463d6fd89a19 ) + name "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.6) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.6) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13225068 crc 21512022 sha1 8832d38f787f3e1da620fcae7514d7387445ccf2 ) ) game ( - name "Alfred Chicken (Europe)" - description "Alfred Chicken (Europe)" - rom ( name "Alfred Chicken (Europe).gb" size 131072 crc 3cab28d9 sha1 bc7327008de518ddfad0ad5c69896921dc2378e0 flags verified ) + name "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.6) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.6) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13223944 crc c1811c9b sha1 9d413bce82708df137215a2968306a5196b1638b ) ) game ( - name "Alfred Chicken (Japan) (SGB Enhanced)" - description "Alfred Chicken (Japan) (SGB Enhanced)" - rom ( name "Alfred Chicken (Japan) (SGB Enhanced).gb" size 262144 crc 1089098f sha1 e04ddf4df8b5ef70d85e0523d277abfc68c61496 ) + name "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.6) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.6) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13269108 crc 3360e114 sha1 50186922ff77714b9ac638948b464cdbf80ab5fb ) ) game ( - name "Alfred Chicken (USA)" - description "Alfred Chicken (USA)" - rom ( name "Alfred Chicken (USA).gb" size 131072 crc 3b9c3bc6 sha1 80c39d93ca58d0d6144fe7f7bdd47c3a4fcf0438 ) + name "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.6) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.6) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13223696 crc 3477ef15 sha1 4b447de09a23fbfdaa6d640824f8ceb5bbe56fab ) ) game ( - name "Alien 3 (Japan)" - description "Alien 3 (Japan)" - rom ( name "Alien 3 (Japan).gb" size 131072 crc e59049b2 sha1 4a3e7eb0edaefec096baa0019b3cba28b4796689 ) + name "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.6) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.6) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.6) (Demo) (Aftermarket) (Unl).gba" size 13250016 crc a4054c2b sha1 c3cd833b9bdf87a8481c9b05251bba782bc3527e ) ) game ( - name "Alien 3 (USA, Europe)" - description "Alien 3 (USA, Europe)" - rom ( name "Alien 3 (USA, Europe).gb" size 131072 crc effb960b sha1 ab4d11eee7faea42c637505469e0671c9d4a83f8 flags verified ) + name "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.7) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.7) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (En) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13220676 crc ab179d6e sha1 2ad1c4840f2f6c2138ed44b1a7aa36071c227a0a ) ) game ( - name "Alien Games (USA) (Proto)" - description "Alien Games (USA) (Proto)" - rom ( name "Alien Games (USA) (Proto).gb" size 131072 crc 67a8a76f sha1 6967e6897de511df2bb03e7c805a222b653ac63f ) + name "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.7) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.7) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Fr) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13221620 crc 3aa591f1 sha1 2548615eeaecd7498e32d02b5c758b713ada27f4 ) ) game ( - name "Alien Olympics (Europe)" - description "Alien Olympics (Europe)" - rom ( name "Alien Olympics (Europe).gb" size 131072 crc 583c0e4e sha1 c6a69416d3f18071942d222d528b1c9d25f980b7 ) + name "Goodboy Galaxy - Chapter Zero (World) (De) (v1.0.7) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (De) (v1.0.7) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (De) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13221368 crc d02cdb6a sha1 1e579e15bdc8dc1def99bcb3c30acfc185e0476b ) ) game ( - name "Alien vs Predator (Japan)" - description "Alien vs Predator (Japan)" - rom ( name "Alien vs Predator (Japan).gb" size 131072 crc e884682b sha1 5b21dc4a7b48e75da725657d1ccde868759e5699 ) + name "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.7) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.7) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Es) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13220496 crc 906717a5 sha1 31857a9ab4daa537322f80faa77482a4b8120483 ) ) game ( - name "Alien vs Predator - The Last of His Clan (USA)" - description "Alien vs Predator - The Last of His Clan (USA)" - rom ( name "Alien vs Predator - The Last of His Clan (USA).gb" size 131072 crc 4bbcf652 sha1 c0d39ee87b908cdbd68c59f73e5dc2a7a6ccbedc ) -) - -game ( - name "All-Star Baseball 99 (USA)" - description "All-Star Baseball 99 (USA)" - rom ( name "All-Star Baseball 99 (USA).gb" size 524288 crc d51ee6d3 sha1 49d13eef514d26cee37b10ff602e21a92b87b69d ) + name "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.7) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.7) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Pt) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13220252 crc d12372bd sha1 89ea5ea41133419c317fd28e7c7f172f5bb53ec3 ) ) game ( - name "Alleyway (World)" - description "Alleyway (World)" - rom ( name "Alleyway (World).gb" size 32768 crc 5cc01586 sha1 0cf2b8d0428f389f5361f67a0cd1ace05a1c75cc flags verified ) + name "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.7) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.7) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Ja) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13216280 crc d3c8dffd sha1 c41c0596a4c52b0e26bb9ffe5c9f7f1c064e0be6 ) ) game ( - name "Alphamax (World) (Aftermarket) (Unl)" - description "Alphamax (World) (Aftermarket) (Unl)" - rom ( name "Alphamax (World) (Aftermarket) (Unl).gb" size 131072 crc 8b493b41 sha1 798dda34d04a06dcee32f44f8a4a045caf734927 ) + name "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.7) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.7) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Zh) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13265660 crc 119f9ddc sha1 d6c23ff47b21a7bf2f8238ac916aeea3866042b5 ) ) game ( - name "Altered Space - A 3-D Alien Adventure (Europe)" - description "Altered Space - A 3-D Alien Adventure (Europe)" - rom ( name "Altered Space - A 3-D Alien Adventure (Europe).gb" size 131072 crc 24d5f785 sha1 218da72e38a847bc5152a226c98e843b4941a8a6 ) + name "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.7) (Demo) (Aftermarket) (Unl)" + description "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.7) (Demo) (Aftermarket) (Unl)" + rom ( name "Goodboy Galaxy - Chapter Zero (World) (Ar) (v1.0.7) (Demo) (Aftermarket) (Unl).gba" size 13246576 crc b14cd1b4 sha1 0d15bd0584148b1658f7d47a2dda604a936ea166 ) ) game ( - name "Altered Space - A 3-D Alien Adventure (Japan)" - description "Altered Space - A 3-D Alien Adventure (Japan)" - rom ( name "Altered Space - A 3-D Alien Adventure (Japan).gb" size 131072 crc ce36e36e sha1 6d19dfedf2c916f13a524acfd7c4e26de040e655 ) + name "Google Dino Advance (World) (v1.0.1) (Aftermarket) (Unl)" + description "Google Dino Advance (World) (v1.0.1) (Aftermarket) (Unl)" + rom ( name "Google Dino Advance (World) (v1.0.1) (Aftermarket) (Unl).gba" size 109072 crc 6534185e sha1 33cc0afc7fbac8948deb75c66b8e097c1d05b2e3 ) ) game ( - name "Altered Space - A 3-D Alien Adventure (USA)" - description "Altered Space - A 3-D Alien Adventure (USA)" - rom ( name "Altered Space - A 3-D Alien Adventure (USA).gb" size 131072 crc 141675d3 sha1 ca586c59b2473a8bec2f0f37504cb74e3a1e4d11 flags verified ) + name "Green Memories (World) (v1.2.0) (Aftermarket) (Unl)" + description "Green Memories (World) (v1.2.0) (Aftermarket) (Unl)" + rom ( name "Green Memories (World) (v1.2.0) (Aftermarket) (Unl).gba" size 6639328 crc 78b81bbc sha1 fb090890bd767a22afe07b3323dd0992d698c906 ) ) game ( - name "Amazing Penguin (USA, Europe)" - description "Amazing Penguin (USA, Europe)" - rom ( name "Amazing Penguin (USA, Europe).gb" size 65536 crc 3011d5ca sha1 84cc6452823eb05ee38679aec86e3cc6e4a50e6f ) + name "Green Memories (World) (v1.4.2) (Aftermarket) (Unl)" + description "Green Memories (World) (v1.4.2) (Aftermarket) (Unl)" + rom ( name "Green Memories (World) (v1.4.2) (Aftermarket) (Unl).gba" size 6937384 crc 9fa9f00f sha1 005f4dc0d615d36d32bbe36e9cc9007b22be2ecd ) ) game ( - name "Amazing Spider-Man, The (USA, Europe)" - description "Amazing Spider-Man, The (USA, Europe)" - rom ( name "Amazing Spider-Man, The (USA, Europe).gb" size 65536 crc 2a4eafe4 sha1 0effb4580efeaa323174a960bfd521fa28a18959 flags verified ) + name "Green Memories (World) (v1.4.4) (Aftermarket) (Unl)" + description "Green Memories (World) (v1.4.4) (Aftermarket) (Unl)" + rom ( name "Green Memories (World) (v1.4.4) (Aftermarket) (Unl).gba" size 6937812 crc 702b46c6 sha1 61f8ff01247e45888b8fd5da791176ff2c88f7f5 ) ) game ( - name "America Oudan Ultra Quiz (Japan)" - description "America Oudan Ultra Quiz (Japan)" - rom ( name "America Oudan Ultra Quiz (Japan).gb" size 262144 crc 3be275cd sha1 9761f22250faf9c241fd7f9e2d00436f3fd454e7 ) + name "Hero Core (World) (Aftermarket) (Unl)" + description "Hero Core (World) (Aftermarket) (Unl)" + rom ( name "Hero Core (World) (Aftermarket) (Unl).gba" size 23642396 crc a58bfa21 sha1 fa96ba52c2573add583cb051b387f6bbb3edf02e ) ) game ( - name "America Oudan Ultra Quiz Part 2 (Japan)" - description "America Oudan Ultra Quiz Part 2 (Japan)" - rom ( name "America Oudan Ultra Quiz Part 2 (Japan).gb" size 262144 crc 1b3231c8 sha1 34c417f6f9db7e8021fb1af6c12f22c9b48bb723 ) + name "Hero Core (World) (v0.1.2) (Beta) (GBA Jam 2022) (Aftermarket) (Unl)" + description "Hero Core (World) (v0.1.2) (Beta) (GBA Jam 2022) (Aftermarket) (Unl)" + rom ( name "Hero Core (World) (v0.1.2) (Beta) (GBA Jam 2022) (Aftermarket) (Unl).gba" size 22209300 crc 0a3fcad6 sha1 3b7b91c474a225d96118c4a4263007218a8ee2de ) ) game ( - name "America Oudan Ultra Quiz Part 2 (Japan) (Rev 1)" - description "America Oudan Ultra Quiz Part 2 (Japan) (Rev 1)" - rom ( name "America Oudan Ultra Quiz Part 2 (Japan) (Rev 1).gb" size 262144 crc 739c26fc sha1 cb3ed70f4d095405df2c322c528cab2a00d56557 ) + name "Hexa Virus (World) (Aftermarket) (Unl)" + description "Hexa Virus (World) (Aftermarket) (Unl)" + rom ( name "Hexa Virus (World) (Aftermarket) (Unl).gba" size 1414244 crc 92243509 sha1 358640dc9972dd839d0b527177e05d030ec12d79 ) ) game ( - name "America Oudan Ultra Quiz Part 3 - Champion Taikai (Japan)" - description "America Oudan Ultra Quiz Part 3 - Champion Taikai (Japan)" - rom ( name "America Oudan Ultra Quiz Part 3 - Champion Taikai (Japan).gb" size 262144 crc 80cac37c sha1 61acfb83a35b2d73fad607ddd7fc1ac49e41492e ) + name "Hexes (World) (Aftermarket) (Unl)" + description "Hexes (World) (Aftermarket) (Unl)" + rom ( name "Hexes (World) (Aftermarket) (Unl).gba" size 10436680 crc d8d17420 sha1 d5686671caa7ec17b811476c982f81147073f0ed ) ) game ( - name "America Oudan Ultra Quiz Part 4 (Japan)" - description "America Oudan Ultra Quiz Part 4 (Japan)" - rom ( name "America Oudan Ultra Quiz Part 4 (Japan).gb" size 262144 crc a76043c8 sha1 30184de60214b8d16d044433cd92f0b2a975e9d6 ) + name "Holy Hell (World) (Proto) (NEO Coding Compo 2012) (Aftermarket) (Unl)" + description "Holy Hell (World) (Proto) (NEO Coding Compo 2012) (Aftermarket) (Unl)" + rom ( name "Holy Hell (World) (Proto) (NEO Coding Compo 2012) (Aftermarket) (Unl).gba" size 5956804 crc 09e21865 sha1 98db9220dffb07fc14a729931e7197a678d92d21 ) ) game ( - name "Amida (Japan)" - description "Amida (Japan)" - rom ( name "Amida (Japan).gb" size 32768 crc 60128aa8 sha1 2b502583aa73cb72557589791dec7e28a2d29969 ) + name "Inheritors of the Oubliette (World) (v1.2) (Aftermarket) (Unl)" + description "Inheritors of the Oubliette (World) (v1.2) (Aftermarket) (Unl)" + rom ( name "Inheritors of the Oubliette (World) (v1.2) (Aftermarket) (Unl).gba" size 10592124 crc a9014760 sha1 2430c6c0784912ad2f0b51e633bf577f087f189f ) ) game ( - name "Animal Breeder (Japan) (SGB Enhanced)" - description "Animal Breeder (Japan) (SGB Enhanced)" - rom ( name "Animal Breeder (Japan) (SGB Enhanced).gb" size 524288 crc c2eec22f sha1 a34b7c4acc4454d96f93a7b04069adbcc3bc75a0 flags verified ) + name "Inheritors of the Oubliette (World) (GBA Jam 2021) (Aftermarket) (Unl)" + description "Inheritors of the Oubliette (World) (GBA Jam 2021) (Aftermarket) (Unl)" + rom ( name "Inheritors of the Oubliette (World) (GBA Jam 2021) (Aftermarket) (Unl).gba" size 25516708 crc 965a1a75 sha1 ae23cfba1f53a9bbde025490f3d7bdf52c3970e4 ) ) game ( - name "Animal Breeder 2 (Japan) (SGB Enhanced)" - description "Animal Breeder 2 (Japan) (SGB Enhanced)" - rom ( name "Animal Breeder 2 (Japan) (SGB Enhanced).gb" size 524288 crc 8d573f37 sha1 214d75221dbfb1a562740aa53e0239a73bee9a2d flags verified ) + name "Inky and the Alien Aquarium (World) (Demo 1) (Aftermarket) (Unl)" + description "Inky and the Alien Aquarium (World) (Demo 1) (Aftermarket) (Unl)" + rom ( name "Inky and the Alien Aquarium (World) (Demo 1) (Aftermarket) (Unl).gba" size 3145728 crc 7ee7ae7f sha1 73d870fad3caa86b6f659e13b57eddac80db2f37 ) ) game ( - name "Animaniacs (Europe) (SGB Enhanced)" - description "Animaniacs (Europe) (SGB Enhanced)" - rom ( name "Animaniacs (Europe) (SGB Enhanced).gb" size 262144 crc 7b23e05c sha1 031421f49f98a15187012dc3f15960b260b9979f flags verified ) + name "Inky and the Alien Aquarium (World) (Demo 2) (Aftermarket) (Unl)" + description "Inky and the Alien Aquarium (World) (Demo 2) (Aftermarket) (Unl)" + rom ( name "Inky and the Alien Aquarium (World) (Demo 2) (Aftermarket) (Unl).gba" size 3145728 crc 36f8ba9c sha1 3c05e1b3f40d9c16b85b05315472267b94e76471 ) ) game ( - name "Animaniacs (USA) (SGB Enhanced)" - description "Animaniacs (USA) (SGB Enhanced)" - rom ( name "Animaniacs (USA) (SGB Enhanced).gb" size 262144 crc 673c815d sha1 a0732f81e0c4f1bba592563bdc0eaae9d759ef28 flags verified ) + name "Iridion 3D (USA) (Aftermarket) (Unl)" + description "Iridion 3D (USA) (Aftermarket) (Unl)" + rom ( name "Iridion 3D (USA) (Aftermarket) (Unl).gba" size 4194304 crc 4c7ebe42 sha1 6f1c77ab88351d2d50da412e4788fc7ca8a6714d ) ) game ( - name "Another Bible (Japan) (SGB Enhanced)" - description "Another Bible (Japan) (SGB Enhanced)" - rom ( name "Another Bible (Japan) (SGB Enhanced).gb" size 524288 crc 4a486435 sha1 6a5d0da889247169135665dc91f153305e1c71b6 ) + name "Iridion II (USA) (Aftermarket) (Unl)" + description "Iridion II (USA) (Aftermarket) (Unl)" + rom ( name "Iridion II (USA) (Aftermarket) (Unl).gba" size 8388608 crc b371f070 sha1 cc788b38a047ff5ec8c445ce11efcd1852ad7c4d ) ) game ( - name "Aoki Densetsu Shoot! (Japan) (SGB Enhanced)" - description "Aoki Densetsu Shoot! (Japan) (SGB Enhanced)" - rom ( name "Aoki Densetsu Shoot! (Japan) (SGB Enhanced).gb" size 262144 crc 08727760 sha1 95574e1eef5fbebde6f068091bc7298000ea2397 ) + name "Join 4 Together (World) (Proto) (Aftermarket) (Unl)" + description "Join 4 Together (World) (Proto) (Aftermarket) (Unl)" + rom ( name "Join 4 Together (World) (Proto) (Aftermarket) (Unl).gba" size 1048576 crc 97d3c875 sha1 f9ffabd386d4d76d09e147f87f73de2638f875bb ) ) game ( - name "Aprilia - DiTech Interface (Unknown) (Unl) [b]" - description "Aprilia - DiTech Interface (Unknown) (Unl) [b]" - rom ( name "Aprilia - DiTech Interface (Unknown) (Unl) [b].gb" size 262144 crc 2e47d2d3 sha1 a921679b79191991eb75de3b6b21443f322a3699 flags baddump ) + name "Luggage Retrieval Officer (World) (Aftermarket) (Unl)" + description "Luggage Retrieval Officer (World) (Aftermarket) (Unl)" + rom ( name "Luggage Retrieval Officer (World) (Aftermarket) (Unl).gba" size 3336260 crc 5aa30d90 sha1 84c9b2d50c8af74b8b04f88af367d9fac1a24ef6 ) ) game ( - name "Arcade Classic No. 1 - Asteroids & Missile Command (USA, Europe) (SGB Enhanced)" - description "Arcade Classic No. 1 - Asteroids & Missile Command (USA, Europe) (SGB Enhanced)" - rom ( name "Arcade Classic No. 1 - Asteroids & Missile Command (USA, Europe) (SGB Enhanced).gb" size 131072 crc 8259ac54 sha1 a4849175191c44d878aff9ef1a86c3fe5e22e266 flags verified ) + name "Magic & Legend - Time Knights (World) (Beta) (Aftermarket) (Unl)" + description "Magic & Legend - Time Knights (World) (Beta) (Aftermarket) (Unl)" + rom ( name "Magic & Legend - Time Knights (World) (Beta) (Aftermarket) (Unl).gba" size 533996 crc 17af9e42 sha1 616342e07fa4c18a21e6b5de46b032c93bbbf34d ) ) game ( - name "Arcade Classic No. 2 - Centipede & Millipede (USA, Europe) (SGB Enhanced)" - description "Arcade Classic No. 2 - Centipede & Millipede (USA, Europe) (SGB Enhanced)" - rom ( name "Arcade Classic No. 2 - Centipede & Millipede (USA, Europe) (SGB Enhanced).gb" size 131072 crc b14c3b31 sha1 405bc3736cfbea3f2259ad3e53a9d64c6523de4a flags verified ) + name "Mandarin 2, The - Limoncello's Revenge (World) (Aftermarket) (Unl)" + description "Mandarin 2, The - Limoncello's Revenge (World) (Aftermarket) (Unl)" + rom ( name "Mandarin 2, The - Limoncello's Revenge (World) (Aftermarket) (Unl).gba" size 213684 crc cc2cb6a8 sha1 1937d06c2282152d6a9748c0e741c41c09583b77 ) ) game ( - name "Arcade Classic No. 3 - Galaga & Galaxian (Europe) (SGB Enhanced)" - description "Arcade Classic No. 3 - Galaga & Galaxian (Europe) (SGB Enhanced)" - rom ( name "Arcade Classic No. 3 - Galaga & Galaxian (Europe) (SGB Enhanced).gb" size 131072 crc d06b3f8a sha1 59ea594af8520732f78c337f5c96a5ba2bddf1cb flags verified ) + name "MazezaM (World) (v1.1) (NEO Coding Compo 2013) (Aftermarket) (Unl)" + description "MazezaM (World) (v1.1) (NEO Coding Compo 2013) (Aftermarket) (Unl)" + rom ( name "MazezaM (World) (v1.1) (NEO Coding Compo 2013) (Aftermarket) (Unl).gba" size 569944 crc f7bc9db0 sha1 4517fbb7c44e9e93b0f5e89661e5cf979c624658 ) ) game ( - name "Arcade Classic No. 3 - Galaga & Galaxian (USA) (SGB Enhanced)" - description "Arcade Classic No. 3 - Galaga & Galaxian (USA) (SGB Enhanced)" - rom ( name "Arcade Classic No. 3 - Galaga & Galaxian (USA) (SGB Enhanced).gb" size 131072 crc 6a6ecfec sha1 739671d6cf151fa5527d68f78345197d278cdf19 flags verified ) + name "MazezaM (World) (v1.0) (NEO Coding Compo 2013) (Aftermarket) (Unl)" + description "MazezaM (World) (v1.0) (NEO Coding Compo 2013) (Aftermarket) (Unl)" + rom ( name "MazezaM (World) (v1.0) (NEO Coding Compo 2013) (Aftermarket) (Unl).gba" size 569704 crc 7c200ed5 sha1 46053717cf638c428ce92186e6a51a4a08e15ffd ) ) game ( - name "Arcade Classic No. 4 - Defender & Joust (USA, Europe) (SGB Enhanced)" - description "Arcade Classic No. 4 - Defender & Joust (USA, Europe) (SGB Enhanced)" - rom ( name "Arcade Classic No. 4 - Defender & Joust (USA, Europe) (SGB Enhanced).gb" size 131072 crc 1c829ce3 sha1 6b046ca1e15e6cecb29e086a5b23eb0019419936 flags verified ) + name "Metal Warrior 4 - Agents of Metal (World) (v1.3) (Aftermarket) (Unl)" + description "Metal Warrior 4 - Agents of Metal (World) (v1.3) (Aftermarket) (Unl)" + rom ( name "Metal Warrior 4 - Agents of Metal (World) (v1.3) (Aftermarket) (Unl).gba" size 524288 crc 7ec3485e sha1 729592141bc160ead0af51d4322c7f9f17da0b82 ) ) game ( - name "Arcade Classics - Super Breakout & Battlezone (USA, Europe) (SGB Enhanced)" - description "Arcade Classics - Super Breakout & Battlezone (USA, Europe) (SGB Enhanced)" - rom ( name "Arcade Classics - Super Breakout & Battlezone (USA, Europe) (SGB Enhanced).gb" size 262144 crc 6c292739 sha1 7d78b06ad896fb949e28858d141f73a37c550fe2 ) + name "Metal Warrior 4 - Agents of Metal (World) (v1.1) (Aftermarket) (Unl)" + description "Metal Warrior 4 - Agents of Metal (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Metal Warrior 4 - Agents of Metal (World) (v1.1) (Aftermarket) (Unl).gba" size 524288 crc 5be69b8d sha1 5252dd4b67b56f591e9f8559d328433d5cf08f31 ) ) game ( - name "Aretha (Japan)" - description "Aretha (Japan)" - rom ( name "Aretha (Japan).gb" size 131072 crc 1db65649 sha1 eab8f13d110634f4ee750ac93e4f25d91a85000f flags verified ) + name "Minicraft (World) (v1.0) (Aftermarket) (Unl)" + description "Minicraft (World) (v1.0) (Aftermarket) (Unl)" + rom ( name "Minicraft (World) (v1.0) (Aftermarket) (Unl).gba" size 131072 crc e852c9e9 sha1 06faa5be11978666db6995d8fce40ce2c3641ce8 ) ) game ( - name "Aretha II (Japan)" - description "Aretha II (Japan)" - rom ( name "Aretha II (Japan).gb" size 262144 crc 086e4fc5 sha1 5634a05ea8e93af3dd0e41823576bf6295f8df1f ) + name "Minicraft (World) (v1.1) (Aftermarket) (Unl)" + description "Minicraft (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Minicraft (World) (v1.1) (Aftermarket) (Unl).gba" size 131072 crc 07595773 sha1 fee5cfa5b9e1f3383780432772f29764ac0fc443 ) ) game ( - name "Aretha III (Japan)" - description "Aretha III (Japan)" - rom ( name "Aretha III (Japan).gb" size 262144 crc 430d3d6b sha1 f57ff26d31283c88cc4c414b18ef6f182d07da9d ) + name "Minicraft (World) (v1.2) (Aftermarket) (Unl)" + description "Minicraft (World) (v1.2) (Aftermarket) (Unl)" + rom ( name "Minicraft (World) (v1.2) (Aftermarket) (Unl).gba" size 131072 crc 37e7ee7d sha1 dc7faa4952986d5c5f0e3b32203936cd717f97eb ) ) game ( - name "Art School Pocket (World) (En) (Aftermarket) (Unl)" - description "Art School Pocket (World) (En) (Aftermarket) (Unl)" - rom ( name "Art School Pocket (World) (En) (Aftermarket) (Unl).gb" size 1048576 crc b4eab528 sha1 c482cfc6ec40b1f33c4ba48ecdc45fef4730b653 ) + name "Minicraft (World) (v1.3) (Aftermarket) (Unl)" + description "Minicraft (World) (v1.3) (Aftermarket) (Unl)" + rom ( name "Minicraft (World) (v1.3) (Aftermarket) (Unl).gba" size 131072 crc cc48e03a sha1 7fe080bf9cc110aa78ce7248ff92ff3185083247 ) ) game ( - name "Art School Pocket (World) (Es) (Aftermarket) (Unl)" - description "Art School Pocket (World) (Es) (Aftermarket) (Unl)" - rom ( name "Art School Pocket (World) (Es) (Aftermarket) (Unl).gb" size 1048576 crc 240067df sha1 c8a75895c87b11f9493f629c19c54d0c607505bd ) + name "Misfortune Advance (World) (Aftermarket) (Unl)" + description "Misfortune Advance (World) (Aftermarket) (Unl)" + rom ( name "Misfortune Advance (World) (Aftermarket) (Unl).gba" size 5125100 crc 18f2166d sha1 68e215025ac963220f16ea3c100e51698f97c4eb ) ) game ( - name "Art School Pocket (World) (Fr) (Aftermarket) (Unl)" - description "Art School Pocket (World) (Fr) (Aftermarket) (Unl)" - rom ( name "Art School Pocket (World) (Fr) (Aftermarket) (Unl).gb" size 1048576 crc 49a5b74d sha1 73ecffaee185eb2caf1db385d04b863676c777fb ) + name "Mooncat's Trio (World) (Aftermarket) (Unl)" + description "Mooncat's Trio (World) (Aftermarket) (Unl)" + rom ( name "Mooncat's Trio (World) (Aftermarket) (Unl).gba" size 1175680 crc b05d5339 sha1 890de7d73723d235d9762e4866d569d3554d1480 flags verified ) ) game ( - name "Art School Pocket (World) (De) (Aftermarket) (Unl)" - description "Art School Pocket (World) (De) (Aftermarket) (Unl)" - rom ( name "Art School Pocket (World) (De) (Aftermarket) (Unl).gb" size 1048576 crc 82b73e5b sha1 7772e2b9d5e722e54d19fc6283ccb1fa5d19b641 ) + name "Mooncat's Trio (World) (Beta) (Aftermarket) (Unl)" + description "Mooncat's Trio (World) (Beta) (Aftermarket) (Unl)" + rom ( name "Mooncat's Trio (World) (Beta) (Aftermarket) (Unl).gba" size 504220 crc cd3328ee sha1 c3ea5247f32c428bbcfd5c087218fc56779e3106 ) ) game ( - name "Asmik-kun World 2 (Japan)" - description "Asmik-kun World 2 (Japan)" - rom ( name "Asmik-kun World 2 (Japan).gb" size 131072 crc caae6b11 sha1 4c738153a5c9f861117cc23cfedf2c37672e1097 ) + name "Nekketsu Monogatari Advance (Japan) (Demo) (Aftermarket) (Unl)" + description "Nekketsu Monogatari Advance (Japan) (Demo) (Aftermarket) (Unl)" + rom ( name "Nekketsu Monogatari Advance (Japan) (Demo) (Aftermarket) (Unl).gba" size 508972 crc 55a0734d sha1 79d6977803cd7ee6b1c97ee149cc1bc037c50fb2 ) ) game ( - name "Asterix (Europe) (En,Fr,De,Es,It)" - description "Asterix (Europe) (En,Fr,De,Es,It)" - rom ( name "Asterix (Europe) (En,Fr,De,Es,It).gb" size 131072 crc 097ffe2c sha1 7d4ca6925826c0ffca3e3004479b5e9a5b6b311b flags verified ) + name "Notebook Adventure (World) (v1.3) (Aftermarket) (Unl)" + description "Notebook Adventure (World) (v1.3) (Aftermarket) (Unl)" + rom ( name "Notebook Adventure (World) (v1.3) (Aftermarket) (Unl).gba" size 476392 crc cc110502 sha1 b730e401214fb348edcd2908cc9842e720f908d1 ) ) game ( - name "Asterix (USA) (Proto 3)" - description "Asterix (USA) (Proto 3)" - rom ( name "Asterix (USA) (Proto 3).gb" size 131072 crc a4cc3c3a sha1 54cd67ea3c3e7646fb5286a6274a40a77f0730cc ) + name "notenogram (World) (v1.1) (Aftermarket) (Unl)" + description "notenogram (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "notenogram (World) (v1.1) (Aftermarket) (Unl).gba" size 807876 crc 28108d5e sha1 426a19598624132356ff5d63a48eb874f19ead6b ) ) game ( - name "Asterix (USA) (Proto 1)" - description "Asterix (USA) (Proto 1)" - rom ( name "Asterix (USA) (Proto 1).gb" size 32768 crc 6ccfee1f sha1 5077f422e513877e9c4e3497111f853376748826 ) + name "notenogram (World) (GBA Jam 2022) (Aftermarket) (Unl)" + description "notenogram (World) (GBA Jam 2022) (Aftermarket) (Unl)" + rom ( name "notenogram (World) (GBA Jam 2022) (Aftermarket) (Unl).gba" size 784216 crc 3b936e97 sha1 fb2fadad0d41979df75e49ff09b67fa42b54fc79 ) ) game ( - name "Asterix (USA) (Proto 2)" - description "Asterix (USA) (Proto 2)" - rom ( name "Asterix (USA) (Proto 2).gb" size 32768 crc 0050b16f sha1 5e2423d1d4a1239af2ccafdd6c0a3f2316ae6b51 ) + name "Ping-Pong Diplomacy Advance (World) (Aftermarket) (Unl)" + description "Ping-Pong Diplomacy Advance (World) (Aftermarket) (Unl)" + rom ( name "Ping-Pong Diplomacy Advance (World) (Aftermarket) (Unl).gba" size 1048576 crc 9ec140d3 sha1 9e19e8f97e8619a4755c3ceb482fa3e2ad5a4529 ) ) game ( - name "Asterix & Obelix (Europe) (Fr,De) (Beta) (SGB Enhanced)" - description "Asterix & Obelix (Europe) (Fr,De) (Beta) (SGB Enhanced)" - rom ( name "Asterix & Obelix (Europe) (Fr,De) (Beta) (SGB Enhanced).gb" size 262144 crc bfa1d7be sha1 70472cbe59cfd426b0969150085cc97d31bd6470 ) + name "Pipe Spin (World) (GBA Jam 2021) (Aftermarket) (Unl)" + description "Pipe Spin (World) (GBA Jam 2021) (Aftermarket) (Unl)" + rom ( name "Pipe Spin (World) (GBA Jam 2021) (Aftermarket) (Unl).gba" size 3126100 crc 09d723e2 sha1 d4b4b99e644ca1d8202147a8c7ae0309a6f07e74 ) ) game ( - name "Asterix & Obelix (Spain) (En,Es) (SGB Enhanced)" - description "Asterix & Obelix (Spain) (En,Es) (SGB Enhanced)" - rom ( name "Asterix & Obelix (Spain) (En,Es) (SGB Enhanced).gb" size 262144 crc b1fd41d0 sha1 b6cd446962357d0f560a5c9fae4c917e039fbb77 flags verified ) + name "Pocket Meat (World) (Proto) (Aftermarket) (Unl)" + description "Pocket Meat (World) (Proto) (Aftermarket) (Unl)" + rom ( name "Pocket Meat (World) (Proto) (Aftermarket) (Unl).gba" size 861952 crc 0b029da3 sha1 9958d9a66742cc00e234a96c311b2acec40f69d1 ) ) game ( - name "Asterix & Obelix (Europe) (Fr,De) (SGB Enhanced)" - description "Asterix & Obelix (Europe) (Fr,De) (SGB Enhanced)" - rom ( name "Asterix & Obelix (Europe) (Fr,De) (SGB Enhanced).gb" size 262144 crc 5143e227 sha1 ebc68b180680c7037b151b9a1b511b681499ba30 flags verified ) + name "Powder (World) (v1.18) (Aftermarket) (Unl)" + description "Powder (World) (v1.18) (Aftermarket) (Unl)" + rom ( name "Powder (World) (v1.18) (Aftermarket) (Unl).gba" size 2278832 crc 44ea10fa sha1 3e0addefc22440c76b0eed06c91bc855f59838bf ) ) game ( - name "Asteroids (USA, Europe)" - description "Asteroids (USA, Europe)" - rom ( name "Asteroids (USA, Europe).gb" size 32768 crc c1f88833 sha1 435dbdaa9b9d2e0d0bc7c1c010cdc5ec9bd9f359 ) + name "Powerpig (World) (NEO Coding Compo 2013) (Aftermarket) (Unl)" + description "Powerpig (World) (NEO Coding Compo 2013) (Aftermarket) (Unl)" + rom ( name "Powerpig (World) (NEO Coding Compo 2013) (Aftermarket) (Unl).gba" size 2308528 crc 318f1504 sha1 af5e459df42d5317ce552bdb3062fcff53a9da8e ) ) game ( - name "Asteroids (USA, Europe) (Beta)" - description "Asteroids (USA, Europe) (Beta)" - rom ( name "Asteroids (USA, Europe) (Beta).gb" size 32768 crc eb31e472 sha1 28f4e2a076bfe5f7a77f695332705ea0085fccfb ) + name "Rick Dangerous (World) (NEO Coding Compo 2013) (Aftermarket) (Unl)" + description "Rick Dangerous (World) (NEO Coding Compo 2013) (Aftermarket) (Unl)" + rom ( name "Rick Dangerous (World) (NEO Coding Compo 2013) (Aftermarket) (Unl).gba" size 4238368 crc 7edb6e6e sha1 62c9b12c3790a7c1a28edd2043ef61706357ed41 ) ) game ( - name "Asteroids Chasers (World) (Aftermarket) (Unl)" - description "Asteroids Chasers (World) (Aftermarket) (Unl)" - rom ( name "Asteroids Chasers (World) (Aftermarket) (Unl).gb" size 131072 crc 58d8b1b8 sha1 f93a4e6788eaf0231a6ca269cca297f0d45ec830 flags verified ) + name "Rick Dangerous (World) (Aftermarket) (Unl)" + description "Rick Dangerous (World) (Aftermarket) (Unl)" + rom ( name "Rick Dangerous (World) (Aftermarket) (Unl).gba" size 4237460 crc 53d4f7c5 sha1 ed5a9eb155388f19c28a7f5069d32532a5c9a494 ) ) game ( - name "Astro Rabby (Japan)" - description "Astro Rabby (Japan)" - rom ( name "Astro Rabby (Japan).gb" size 65536 crc 61e48eef sha1 3e53fd25f350c78a29e0642ee6de80208930d469 ) + name "Rick Dangerous 2 (World) (Aftermarket) (Unl)" + description "Rick Dangerous 2 (World) (Aftermarket) (Unl)" + rom ( name "Rick Dangerous 2 (World) (Aftermarket) (Unl).gba" size 4934608 crc 65a8d986 sha1 5dd0cff0f112c43ee44db642b4bfdb38ca6355b7 ) ) game ( - name "Astro-Jump (World) (Aftermarket) (Unl)" - description "Astro-Jump (World) (Aftermarket) (Unl)" - rom ( name "Astro-Jump (World) (Aftermarket) (Unl).gb" size 262144 crc c35a3b39 sha1 1bcb4be684626ce061aad105701548fa3a77e254 ) + name "Rushed Hack Job, A (World) (GBA Jam 2022) (Aftermarket) (Unl)" + description "Rushed Hack Job, A (World) (GBA Jam 2022) (Aftermarket) (Unl)" + rom ( name "Rushed Hack Job, A (World) (GBA Jam 2022) (Aftermarket) (Unl).gba" size 332724 crc 730a5dd6 sha1 d8e03f4b1a12cf7a26813fb07aae2c4b503e2970 ) ) game ( - name "Athletic World (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" - description "Athletic World (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Athletic World (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl).gb" size 131072 crc afc128f2 sha1 956be9371990b18e351f2e10848b2ea8bb70c2b7 ) + name "Shadow - A Parable (World) (Audio) (Aftermarket) (Unl)" + description "Shadow - A Parable (World) (Audio) (Aftermarket) (Unl)" + rom ( name "Shadow - A Parable (World) (Audio) (Aftermarket) (Unl).gba" size 1352899 crc 3178488f sha1 dd90e7d76b751a0e748aae83777d449d963b774b ) ) game ( - name "Atomic Punk (USA)" - description "Atomic Punk (USA)" - rom ( name "Atomic Punk (USA).gb" size 131072 crc c4720897 sha1 4b364b4c12b83ab7adbec074fac951e2eb63dea8 ) + name "Shoot for the Moon (World) (Aftermarket) (Unl)" + description "Shoot for the Moon (World) (Aftermarket) (Unl)" + rom ( name "Shoot for the Moon (World) (Aftermarket) (Unl).gba" size 7374924 crc f3bd4f90 sha1 cf99dd8670a3af704b6994898fa521667aba09a6 ) ) game ( - name "Attack of the Killer Tomatoes (Japan)" - description "Attack of the Killer Tomatoes (Japan)" - rom ( name "Attack of the Killer Tomatoes (Japan).gb" size 131072 crc 23068679 sha1 96cd454513dfb363cda20bf0e72c6d74132a9487 ) + name "Sips (World) (GBA WinterJam 2023) (Aftermarket) (Unl)" + description "Sips (World) (GBA WinterJam 2023) (Aftermarket) (Unl)" + rom ( name "Sips (World) (GBA WinterJam 2023) (Aftermarket) (Unl).gba" size 6235380 crc 5c1fb22d sha1 bb725df7226307d55df04365f85e5698b199c3c9 ) ) game ( - name "Attack of the Killer Tomatoes (USA, Europe)" - description "Attack of the Killer Tomatoes (USA, Europe)" - rom ( name "Attack of the Killer Tomatoes (USA, Europe).gb" size 131072 crc b5b38860 sha1 cbbba5d4f80f2b4ab3e882ceb4f79c293a17904f flags verified ) + name "Skyland (World) (v2023.5.5.0) (Proto) (Aftermarket) (Unl)" + description "Skyland (World) (v2023.5.5.0) (Proto) (Aftermarket) (Unl)" + rom ( name "Skyland (World) (v2023.5.5.0) (Proto) (Aftermarket) (Unl).gba" size 15887876 crc c798529d sha1 ea4a6494bcec25757f657c69550c91190e46cebd ) ) game ( - name "Auto Zone (World) (Aftermarket) (Unl)" - description "Auto Zone (World) (Aftermarket) (Unl)" - rom ( name "Auto Zone (World) (Aftermarket) (Unl).gb" size 524288 crc cee73c14 sha1 3070ec215014633dac5dbbb487aade2e2993c049 ) + name "Skyland (World) (v2023.5.15.0) (Proto) (Aftermarket) (Unl)" + description "Skyland (World) (v2023.5.15.0) (Proto) (Aftermarket) (Unl)" + rom ( name "Skyland (World) (v2023.5.15.0) (Proto) (Aftermarket) (Unl).gba" size 15894868 crc af572de8 sha1 997bf192369d48433a7c35187c7e1d0b5fcc16e0 ) ) game ( - name "Avenging Spirit (USA, Europe)" - description "Avenging Spirit (USA, Europe)" - rom ( name "Avenging Spirit (USA, Europe).gb" size 262144 crc cf2ba5f7 sha1 d22cca80a0855d7724539ef71f38e3f8f9656d6b flags verified ) + name "Skyland (World) (v2023.5.26.0) (Proto) (Aftermarket) (Unl)" + description "Skyland (World) (v2023.5.26.0) (Proto) (Aftermarket) (Unl)" + rom ( name "Skyland (World) (v2023.5.26.0) (Proto) (Aftermarket) (Unl).gba" size 15900084 crc df05edff sha1 1328d17668480b4e9bea338662532ace332c74a9 ) ) game ( - name "Ayakashi no Shiro (Japan)" - description "Ayakashi no Shiro (Japan)" - rom ( name "Ayakashi no Shiro (Japan).gb" size 65536 crc da90f5fc sha1 dad3ec1a054cbd092eedfdb1d742b811c105181a flags verified ) + name "Skyland (World) (v2023.8.1.1) (Proto) (Aftermarket) (Unl)" + description "Skyland (World) (v2023.8.1.1) (Proto) (Aftermarket) (Unl)" + rom ( name "Skyland (World) (v2023.8.1.1) (Proto) (Aftermarket) (Unl).gba" size 16075456 crc d271c516 sha1 0dbdf16b23afb70229eff2de269fd5d73659d745 ) ) game ( - name "B.C. Kid (Europe)" - description "B.C. Kid (Europe)" - rom ( name "B.C. Kid (Europe).gb" size 262144 crc 373343e6 sha1 b91f99408e4a6b69d505f304c176434321f837e7 flags verified ) + name "Skyland (World) (v2024.5.24.0) (Proto) (Aftermarket) (Unl)" + description "Skyland (World) (v2024.5.24.0) (Proto) (Aftermarket) (Unl)" + rom ( name "Skyland (World) (v2024.5.24.0) (Proto) (Aftermarket) (Unl).gba" size 16250380 crc 4cfb40d2 sha1 d9936c4a776ce61ede6241a018683e3efc0fe12b ) ) game ( - name "B.C. Kid 2 (Europe) (SGB Enhanced)" - description "B.C. Kid 2 (Europe) (SGB Enhanced)" - rom ( name "B.C. Kid 2 (Europe) (SGB Enhanced).gb" size 262144 crc c28ef062 sha1 952a14298dcde28975f2cdd61f781000afb53125 ) + name "Spout GBA (World) (Aftermarket) (Unl)" + description "Spout GBA (World) (Aftermarket) (Unl)" + rom ( name "Spout GBA (World) (Aftermarket) (Unl).gba" size 752448 crc ab42f086 sha1 87654f792d847bb8f642c0fc754eb70419a57859 ) ) game ( - name "B.C. Kid 2 (Europe) (Beta) (SGB Enhanced)" - description "B.C. Kid 2 (Europe) (Beta) (SGB Enhanced)" - rom ( name "B.C. Kid 2 (Europe) (Beta) (SGB Enhanced).gb" size 262144 crc 11ffc359 sha1 dc70ba06fb2690c1b7e66963cc07da704f7a6d26 ) + name "Tiger Rescue (World) (Aftermarket) (Unl)" + description "Tiger Rescue (World) (Aftermarket) (Unl)" + rom ( name "Tiger Rescue (World) (Aftermarket) (Unl).gba" size 1575852 crc 34e118e5 sha1 8cc652cb0aee8649643386c8ffcc77fe6e5b0126 ) ) game ( - name "Baby T-Rex (Europe)" - description "Baby T-Rex (Europe)" - rom ( name "Baby T-Rex (Europe).gb" size 131072 crc 3f73fe7a sha1 30042c3fc60df0da25fa3db3955a2e4657c1cccf ) + name "Toadally Awesome (World) (GBA Jam 2021) (Aftermarket) (Unl)" + description "Toadally Awesome (World) (GBA Jam 2021) (Aftermarket) (Unl)" + rom ( name "Toadally Awesome (World) (GBA Jam 2021) (Aftermarket) (Unl).gba" size 964504 crc fa6f976c sha1 098f9e2ba7ba15225768eae3585591b9b09ef2d6 ) ) game ( - name "Baby's Day Out (USA) (Proto)" - description "Baby's Day Out (USA) (Proto)" - rom ( name "Baby's Day Out (USA) (Proto).gb" size 262144 crc 343f01ce sha1 d06b433a5d355490ebae150a45c47b0c5bce9087 ) + name "Toadally Awesome (World) (GBA Jam 2021) (Unlocked) (Aftermarket) (Unl)" + description "Toadally Awesome (World) (GBA Jam 2021) (Unlocked) (Aftermarket) (Unl)" + rom ( name "Toadally Awesome (World) (GBA Jam 2021) (Unlocked) (Aftermarket) (Unl).gba" size 964520 crc 11044eb3 sha1 ac83f9815f4bf3a9c6690c4437d7f2256b36dd40 ) ) game ( - name "Bakenou TV '94 (Japan) (SGB Enhanced)" - description "Bakenou TV '94 (Japan) (SGB Enhanced)" - rom ( name "Bakenou TV '94 (Japan) (SGB Enhanced).gb" size 131072 crc d1c3f371 sha1 c567bdd1ca17750c853019f244e208fe812772fd ) + name "Tremblay Island (World) (En) (v1.1) (Aftermarket) (Unl)" + description "Tremblay Island (World) (En) (v1.1) (Aftermarket) (Unl)" + rom ( name "Tremblay Island (World) (En) (v1.1) (Aftermarket) (Unl).gba" size 16239516 crc ce85ba07 sha1 b09b600bfc222c2d92829d8883feab700b013953 ) ) game ( - name "Bakenou V3 (Japan)" - description "Bakenou V3 (Japan)" - rom ( name "Bakenou V3 (Japan).gb" size 131072 crc 4e2fffe5 sha1 b1bf86f4ffb9af9c5f1c592f0cabedb95b405437 flags verified ) + name "Tremblay Island (World) (En) (v1.1) (Solid State Version) (Aftermarket) (Unl)" + description "Tremblay Island (World) (En) (v1.1) (Solid State Version) (Aftermarket) (Unl)" + rom ( name "Tremblay Island (World) (En) (v1.1) (Solid State Version) (Aftermarket) (Unl).gba" size 16229600 crc bd57344d sha1 a2fcfe94c9b8b0feff31c1245c8b033222c9f668 ) ) game ( - name "Bakuchou Retrieve Master (Japan) (SGB Enhanced)" - description "Bakuchou Retrieve Master (Japan) (SGB Enhanced)" - rom ( name "Bakuchou Retrieve Master (Japan) (SGB Enhanced).gb" size 524288 crc 8a546dec sha1 bfea17b22b3ac91366156d8db1a7dc619c7b5a28 ) + name "Tremblay Island (World) (Fr) (v1.1) (Solid State Version) (Aftermarket) (Unl)" + description "Tremblay Island (World) (Fr) (v1.1) (Solid State Version) (Aftermarket) (Unl)" + rom ( name "Tremblay Island (World) (Fr) (v1.1) (Solid State Version) (Aftermarket) (Unl).gba" size 16204024 crc fa43669e sha1 a57392fa7cee61913b20a840fe8b2ee27f11d808 ) ) game ( - name "Bakuchou Retsuden Shou - Hyper Fishing (Japan) (SGB Enhanced)" - description "Bakuchou Retsuden Shou - Hyper Fishing (Japan) (SGB Enhanced)" - rom ( name "Bakuchou Retsuden Shou - Hyper Fishing (Japan) (SGB Enhanced).gb" size 524288 crc ab3477c4 sha1 53808f56fa68ad8094d0e4ff62e06887b439be9a ) + name "Tremblay Island (World) (En) (v1.1) (Kickstarter Edition) (Aftermarket) (Unl)" + description "Tremblay Island (World) (En) (v1.1) (Kickstarter Edition) (Aftermarket) (Unl)" + rom ( name "Tremblay Island (World) (En) (v1.1) (Kickstarter Edition) (Aftermarket) (Unl).gba" size 16777216 crc ff5d64ab sha1 645ab8d4dacb6666d8eb549d491f77d8cd63ce97 ) ) game ( - name "Bakuretsu Senshi Warrior (Japan)" - description "Bakuretsu Senshi Warrior (Japan)" - rom ( name "Bakuretsu Senshi Warrior (Japan).gb" size 65536 crc ecf1b801 sha1 5f4e63796611a1ed72acd2a5bfe2e2ea3ba5b211 flags verified ) + name "Tremblay Island (World) (Aftermarket) (Unl)" + description "Tremblay Island (World) (Aftermarket) (Unl)" + rom ( name "Tremblay Island (World) (Aftermarket) (Unl).gba" size 16225608 crc 95503690 sha1 634ea6be3df5ebd85c9c60871e34fc3c72ae5140 ) ) game ( - name "Balloon Kid (USA, Europe)" - description "Balloon Kid (USA, Europe)" - rom ( name "Balloon Kid (USA, Europe).gb" size 131072 crc d4b655ec sha1 0cb5adc9bdef5320f3f156efed0d47a618e2299f flags verified ) + name "Tristam Island (World) (v9) (Digital) (Aftermarket) (Unl)" + description "Tristam Island (World) (v9) (Digital) (Aftermarket) (Unl)" + rom ( name "Tristam Island (World) (v9) (Digital) (Aftermarket) (Unl).gba" size 286184 crc 4baa947c sha1 4a90a81991d38ce08ded5da017d0567ecd00c1df flags verified ) ) game ( - name "Bamse (Sweden)" - description "Bamse (Sweden)" - rom ( name "Bamse (Sweden).gb" size 131072 crc 1b713de0 sha1 92c042a1b3b9704736b6d8b19259efc5110c267d flags verified ) + name "uCity Advance (World) (v1.0.1) (GBA Jam 2021) (Aftermarket) (Unl)" + description "uCity Advance (World) (v1.0.1) (GBA Jam 2021) (Aftermarket) (Unl)" + rom ( name "uCity Advance (World) (v1.0.1) (GBA Jam 2021) (Aftermarket) (Unl).gba" size 1925124 crc a6e47443 sha1 c3e8f7fe01e05eda8bdb52a35db0d6dc92554e42 ) ) game ( - name "Banishing Racer (Japan)" - description "Banishing Racer (Japan)" - rom ( name "Banishing Racer (Japan).gb" size 131072 crc 3d13ec6a sha1 df121645c367d5809ed77bfe48aa537f0d61d276 ) + name "Varooom 3D (World) (GBA Jam 2021) (Aftermarket) (Unl)" + description "Varooom 3D (World) (GBA Jam 2021) (Aftermarket) (Unl)" + rom ( name "Varooom 3D (World) (GBA Jam 2021) (Aftermarket) (Unl).gba" size 7957428 crc 3f127891 sha1 cc7e45a680f9a8701fe35a64c764d5e106bd9096 ) ) game ( - name "Barbie - Game Girl (USA, Europe)" - description "Barbie - Game Girl (USA, Europe)" - rom ( name "Barbie - Game Girl (USA, Europe).gb" size 131072 crc 94c26cdf sha1 6660e4457a1de3de1947a90c5ea9ff012d50336e flags verified ) + name "Waimanu - Grinding Blocks Adventure (World) (NEO Coding Compo 2013) (Aftermarket) (Unl)" + description "Waimanu - Grinding Blocks Adventure (World) (NEO Coding Compo 2013) (Aftermarket) (Unl)" + rom ( name "Waimanu - Grinding Blocks Adventure (World) (NEO Coding Compo 2013) (Aftermarket) (Unl).gba" size 1739504 crc 0fe153c5 sha1 c4ce156b04fb257875bc5f539f3d64accbc08451 ) ) game ( - name "Barbie - Game Girl (USA) (Beta)" - description "Barbie - Game Girl (USA) (Beta)" - rom ( name "Barbie - Game Girl (USA) (Beta).gb" size 131072 crc 4660e0ab sha1 24886a5f26f1969e595f420bf963439ba6a693bd ) + name "Werewolf Tale, A (World) (Proto) (NEO Coding Compo 2012) (Aftermarket) (Unl)" + description "Werewolf Tale, A (World) (Proto) (NEO Coding Compo 2012) (Aftermarket) (Unl)" + rom ( name "Werewolf Tale, A (World) (Proto) (NEO Coding Compo 2012) (Aftermarket) (Unl).gba" size 7359860 crc fa1a22d3 sha1 631fa1b513e1e4a45a5a60b10b7822b47832b866 ) ) game ( - name "Bart no Survival Camp (Japan)" - description "Bart no Survival Camp (Japan)" - rom ( name "Bart no Survival Camp (Japan).gb" size 131072 crc 0fd66b1a sha1 f0d855bba656b628c7dd9ed9e586853be75b790f ) + name "With the Last Moonbeam (World) (v1.0.0) (Aftermarket) (Unl)" + description "With the Last Moonbeam (World) (v1.0.0) (Aftermarket) (Unl)" + rom ( name "With the Last Moonbeam (World) (v1.0.0) (Aftermarket) (Unl).gba" size 1449956 crc 4ffa611d sha1 89bbeb3fbce1533acf2f2113642ebe2a4f9f79a8 ) ) game ( - name "Bart Simpson's Escape from Camp Deadly (USA, Europe)" - description "Bart Simpson's Escape from Camp Deadly (USA, Europe)" - rom ( name "Bart Simpson's Escape from Camp Deadly (USA, Europe).gb" size 131072 crc 5546a382 sha1 89b7b2d4684d703ea5d323e3aaf4910dcdbc47d3 flags verified ) + name "With the Last Moonbeam (World) (v1.0.1) (Aftermarket) (Unl)" + description "With the Last Moonbeam (World) (v1.0.1) (Aftermarket) (Unl)" + rom ( name "With the Last Moonbeam (World) (v1.0.1) (Aftermarket) (Unl).gba" size 1449956 crc 27055186 sha1 b9ce91d55870e07434509f6e2e91c2f90b4afc97 ) ) game ( - name "Baseball (World)" - description "Baseball (World)" - rom ( name "Baseball (World).gb" size 65536 crc 6eea2526 sha1 bb613ed8d492d49db35370bec38d9f2515dc24c9 flags verified ) + name "World Reborn (USA) (Aftermarket) (Unl)" + description "World Reborn (USA) (Aftermarket) (Unl)" + rom ( name "World Reborn (USA) (Aftermarket) (Unl).gba" size 4194304 crc eefb32ff sha1 c7ec2f8d7d3dec40a893cdfe2a41a8ed43ed71c4 ) ) game ( - name "Baseball Kids (Japan)" - description "Baseball Kids (Japan)" - rom ( name "Baseball Kids (Japan).gb" size 131072 crc a503cb07 sha1 e4a49a9ecd7a9ce8bb552981e90903f21c741428 ) + name "xniq (World) (Proto) (GBA Jam 2021) (Aftermarket) (Unl)" + description "xniq (World) (Proto) (GBA Jam 2021) (Aftermarket) (Unl)" + rom ( name "xniq (World) (Proto) (GBA Jam 2021) (Aftermarket) (Unl).gba" size 1436448 crc ddb5205d sha1 47dabc2d526aefc41cc82eeec315c986e3a9b8bc ) +) + +clrmamepro ( + name "Nintendo - Game Boy Advance (Video) (Aftermarket)" + description "Nintendo - Game Boy Advance (Video) (Aftermarket)" + version 20240727-194101 + author "BigFred, C. V. Reynolds, DeadSkullzJr, Hiccup, kazumi213, omonim2007, Psychofox11, psykopat, relax, SonGoku, xuom2" + homepage No-Intro + url "https://www.no-intro.org" + forcenodump required +) + +emulator ( + name "datafile" ) game ( - name "Bases Loaded (USA)" - description "Bases Loaded (USA)" - rom ( name "Bases Loaded (USA).gb" size 131072 crc d37a2fdf sha1 5220db2e87622648caeacdfb8d4f564c9bf479fc flags verified ) + name "Dinosaur Office (World) (Aftermarket) (Unl)" + description "Dinosaur Office (World) (Aftermarket) (Unl)" + rom ( name "Dinosaur Office (World) (Aftermarket) (Unl).gba" size 15237120 crc d8aae820 sha1 24feb8a0f36428461be8ecbb7add65f43dc1366e ) ) game ( - name "Bass Fishing Tatsujin Techou (Japan)" - description "Bass Fishing Tatsujin Techou (Japan)" - rom ( name "Bass Fishing Tatsujin Techou (Japan).gb" size 524288 crc 7625e5a5 sha1 503a4cdd6d80ce779ba293022b21f98881af2ab6 ) + name "Dinosaur Office - Bring Your Child to Work Day (World) (Aftermarket) (Unl)" + description "Dinosaur Office - Bring Your Child to Work Day (World) (Aftermarket) (Unl)" + rom ( name "Dinosaur Office - Bring Your Child to Work Day (World) (Aftermarket) (Unl).gba" size 12222464 crc 3de24b84 sha1 63938be2d2e357b9644de8dc452f6f4195911618 ) ) game ( - name "Bataille Navale (France) (En,Fr,De,Es)" - description "Bataille Navale (France) (En,Fr,De,Es)" - rom ( name "Bataille Navale (France) (En,Fr,De,Es).gb" size 131072 crc bab8b727 sha1 5c5162743546b258cc9c6316f1437137721f5e99 ) + name "Dinosaur Office - Computer Problems (World) (Aftermarket) (Unl)" + description "Dinosaur Office - Computer Problems (World) (Aftermarket) (Unl)" + rom ( name "Dinosaur Office - Computer Problems (World) (Aftermarket) (Unl).gba" size 15990784 crc 8a05677f sha1 664c1568e601bf6e51920bca85d096aa6e06f5e2 ) ) game ( - name "Batman - Return of the Joker (Japan)" - description "Batman - Return of the Joker (Japan)" - rom ( name "Batman - Return of the Joker (Japan).gb" size 131072 crc de459a47 sha1 149586120c3ae9c9614fa6e6a5e298cceae16c4d ) + name "Dinosaur Office - Gym (World) (Aftermarket) (Unl)" + description "Dinosaur Office - Gym (World) (Aftermarket) (Unl)" + rom ( name "Dinosaur Office - Gym (World) (Aftermarket) (Unl).gba" size 12419072 crc 9dc8f035 sha1 062fcb78d9f9058ff9427f123fbb36db77fca20b ) ) game ( - name "Batman - Return of the Joker (USA, Europe)" - description "Batman - Return of the Joker (USA, Europe)" - rom ( name "Batman - Return of the Joker (USA, Europe).gb" size 131072 crc 5124bbec sha1 345a332175f58304f91111a13b770662e5ea92c3 ) + name "Dinosaur Office - Office Party (World) (Aftermarket) (Unl)" + description "Dinosaur Office - Office Party (World) (Aftermarket) (Unl)" + rom ( name "Dinosaur Office - Office Party (World) (Aftermarket) (Unl).gba" size 12484608 crc 34c1df88 sha1 9ee6ca14c78a7e1949d8af9d52e6bfa4d09b7f9f ) ) game ( - name "Batman - The Animated Series (USA, Europe)" - description "Batman - The Animated Series (USA, Europe)" - rom ( name "Batman - The Animated Series (USA, Europe).gb" size 131072 crc c8e578bf sha1 4a8c1dd74b1279c0dc85ac2bebb5db2795cb67b0 flags verified ) + name "Dinosaur Office - Office Romance (World) (Aftermarket) (Unl)" + description "Dinosaur Office - Office Romance (World) (Aftermarket) (Unl)" + rom ( name "Dinosaur Office - Office Romance (World) (Aftermarket) (Unl).gba" size 13828096 crc c202e426 sha1 4a66f3db5bde55a33f4b9ca55ba231f806c8d2b9 ) ) game ( - name "Batman - The Video Game (World)" - description "Batman - The Video Game (World)" - rom ( name "Batman - The Video Game (World).gb" size 131072 crc 6c41d3cd sha1 ef7d6684a0f737c01a1f2cc2c6609e0f3ac1310e flags verified ) + name "Dinosaur Office - Team Building (World) (Aftermarket) (Unl)" + description "Dinosaur Office - Team Building (World) (Aftermarket) (Unl)" + rom ( name "Dinosaur Office - Team Building (World) (Aftermarket) (Unl).gba" size 17334272 crc 9cd0566e sha1 9dc93f4c8d25a0e5d52deb8c7edf656b8f0c059d ) ) game ( - name "Batman Forever (Japan)" - description "Batman Forever (Japan)" - rom ( name "Batman Forever (Japan).gb" size 262144 crc c2fd6244 sha1 4fab046d18addafbc625fe4cefec37098747d716 ) + name "Dinosaur Office - Traffic (World) (Aftermarket) (Unl)" + description "Dinosaur Office - Traffic (World) (Aftermarket) (Unl)" + rom ( name "Dinosaur Office - Traffic (World) (Aftermarket) (Unl).gba" size 13107200 crc 96d90be9 sha1 879d9c7f0951235607cedb9c8fd85e4fc9a1d452 ) ) game ( - name "Batman Forever (USA, Europe)" - description "Batman Forever (USA, Europe)" - rom ( name "Batman Forever (USA, Europe).gb" size 262144 crc ef3592cc sha1 cb76b6d3ec9903a734f70ff11195f40f13f4d83f flags verified ) + name "Dinosaur Office - Viral Videos (World) (Aftermarket) (Unl)" + description "Dinosaur Office - Viral Videos (World) (Aftermarket) (Unl)" + rom ( name "Dinosaur Office - Viral Videos (World) (Aftermarket) (Unl).gba" size 13139968 crc e7338b7c sha1 e6f089034f30757f8dce2eb6568e8f5d2d122d49 ) ) game ( - name "Battle Arena Toshinden (Europe) (SGB Enhanced)" - description "Battle Arena Toshinden (Europe) (SGB Enhanced)" - rom ( name "Battle Arena Toshinden (Europe) (SGB Enhanced).gb" size 524288 crc ce34cca4 sha1 f4cc9193ca0b98c69c966cc32e37eae444a8d53b flags verified ) + name "Eek! The Cat - A Sharkwork Orange (World) (Aftermarket) (Unl)" + description "Eek! The Cat - A Sharkwork Orange (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - A Sharkwork Orange (World) (Aftermarket) (Unl).gba" size 31129600 crc 4feab397 sha1 0bb061759804b46f201c39ccf9e7722a4407909e ) ) game ( - name "Battle Arena Toshinden (USA) (SGB Enhanced)" - description "Battle Arena Toshinden (USA) (SGB Enhanced)" - rom ( name "Battle Arena Toshinden (USA) (SGB Enhanced).gb" size 524288 crc 2d0c1073 sha1 9c337d3f56938aa46cfc8b85c0db4631bcbe217c flags verified ) + name "Eek! The Cat - Chariots of Fur (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Chariots of Fur (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Chariots of Fur (World) (Aftermarket) (Unl).gba" size 30998528 crc 5ea13d5a sha1 7022193f78fcb89988483cca1bacb8e66182ac55 ) ) game ( - name "Battle Bull (Japan)" - description "Battle Bull (Japan)" - rom ( name "Battle Bull (Japan).gb" size 131072 crc 5c69e449 sha1 74ed574d2179bdf34a6e618a86be9b3e70155370 ) + name "Eek! The Cat - Eek Space-9 (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Eek Space-9 (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Eek Space-9 (World) (Aftermarket) (Unl).gba" size 30801920 crc cfbb43d3 sha1 1b056d1449282c08eae0ed49ffc33f56346304fe ) ) game ( - name "Battle Bull (USA)" - description "Battle Bull (USA)" - rom ( name "Battle Bull (USA).gb" size 131072 crc d4d1aea2 sha1 a553b2cf2a5d223b6ac8aca4e9fd65b65087a1f4 flags verified ) + name "Eek! The Cat - Eek's Funny Thing That He Does (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Eek's Funny Thing That He Does (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Eek's Funny Thing That He Does (World) (Aftermarket) (Unl).gba" size 31064064 crc 3773b28d sha1 b13c1d3ae7f993deee10542390ac416b6c5cd1c6 ) ) game ( - name "Battle Crusher (Japan) (SGB Enhanced)" - description "Battle Crusher (Japan) (SGB Enhanced)" - rom ( name "Battle Crusher (Japan) (SGB Enhanced).gb" size 262144 crc ea4eb1a1 sha1 ae07172c69a7bdece4392016c6a6dd253623f5f8 ) + name "Eek! The Cat - Eekscaliber (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Eekscaliber (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Eekscaliber (World) (Aftermarket) (Unl).gba" size 31227904 crc ed5792d4 sha1 2a903b53a371ef4132291452f5d192dace6dc5e8 ) ) game ( - name "Battle Dodge Ball (Japan)" - description "Battle Dodge Ball (Japan)" - rom ( name "Battle Dodge Ball (Japan).gb" size 131072 crc a99242c0 sha1 ed63709af2dd22d2abaa7e99b9dd5373b6cc91c4 ) + name "Eek! The Cat - Eekstremely Dull (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Eekstremely Dull (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Eekstremely Dull (World) (Aftermarket) (Unl).gba" size 31162368 crc 28f73fe4 sha1 3ea9bfa0d937150574affdb8de271cf7873ab042 ) ) game ( - name "Battle of Kingdom (Japan)" - description "Battle of Kingdom (Japan)" - rom ( name "Battle of Kingdom (Japan).gb" size 131072 crc 35914deb sha1 5761f47a09f91a373bda96840fe2560bff1ffc97 ) + name "Eek! The Cat - Eeksy Rider (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Eeksy Rider (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Eeksy Rider (World) (Aftermarket) (Unl).gba" size 31096832 crc ec1f5d37 sha1 1359f5e802862b0a6f01e37fd5843a5b12edb7d4 ) ) game ( - name "Battle of Olympus, The (Europe) (En,Fr,De,Es,It)" - description "Battle of Olympus, The (Europe) (En,Fr,De,Es,It)" - rom ( name "Battle of Olympus, The (Europe) (En,Fr,De,Es,It).gb" size 262144 crc ca450e93 sha1 c0ca1948c4bfca795a29ce82aa5ab9215b9ed601 ) + name "Eek! The Cat - Fatal Eektraction (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Fatal Eektraction (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Fatal Eektraction (World) (Aftermarket) (Unl).gba" size 31096832 crc 494997c3 sha1 52e63ca7e162fe3a0296709b924b0dc4b19ce693 ) ) game ( - name "Battle Pingpong (Japan)" - description "Battle Pingpong (Japan)" - rom ( name "Battle Pingpong (Japan).gb" size 65536 crc 7c787bc4 sha1 5008699f7a31a1a0722114f83e94591e99b22cc0 ) + name "Eek! The Cat - Honey I Shrunk the Cat (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Honey I Shrunk the Cat (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Honey I Shrunk the Cat (World) (Aftermarket) (Unl).gba" size 15597568 crc 8bae90ef sha1 8ee80c6e4f54081c6b796983ab51d8c03e36c2d0 ) ) game ( - name "Battle Ships (Spain) (En,Fr,De,Es) (Beta)" - description "Battle Ships (Spain) (En,Fr,De,Es) (Beta)" - rom ( name "Battle Ships (Spain) (En,Fr,De,Es) (Beta).gb" size 131072 crc 1f8ccb71 sha1 4c04f79c670661fa46b17f7f980e6e7e88e886e7 ) + name "Eek! The Cat - Natural Bored Kittens (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Natural Bored Kittens (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Natural Bored Kittens (World) (Aftermarket) (Unl).gba" size 31129600 crc 941da25e sha1 8fa3d5d5f305ac32653527860caf153c97d20a24 ) ) game ( - name "Battle Space (Japan)" - description "Battle Space (Japan)" - rom ( name "Battle Space (Japan).gb" size 65536 crc a828fd4f sha1 76e47ad844abdde9eff09ea29a014f9a1eae5093 flags verified ) + name "Eek! The Cat - OutbrEek (World) (Aftermarket) (Unl)" + description "Eek! The Cat - OutbrEek (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - OutbrEek (World) (Aftermarket) (Unl).gba" size 30834688 crc 4fea7a72 sha1 344cdff52d4820932c3ba8ad5c57c91d61d93751 ) ) game ( - name "Battle Unit Zeoth (Japan)" - description "Battle Unit Zeoth (Japan)" - rom ( name "Battle Unit Zeoth (Japan).gb" size 131072 crc a1a1fe77 sha1 35413f3d4b4e68f521a90c3a48d4bd2b5bf90e09 ) + name "Eek! The Cat - Rock-Eek 6 (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Rock-Eek 6 (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Rock-Eek 6 (World) (Aftermarket) (Unl).gba" size 31096832 crc 7a05eb25 sha1 6b3789fd599bf7d30788be38872f5832cb5edfaa ) ) game ( - name "Battle Unit Zeoth (USA, Europe)" - description "Battle Unit Zeoth (USA, Europe)" - rom ( name "Battle Unit Zeoth (USA, Europe).gb" size 131072 crc e67a92b3 sha1 eba09c60cd60feba0a7a9e82597dad080ce78d22 flags verified ) + name "Eek! The Cat - Shark Doggy Dog (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Shark Doggy Dog (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Shark Doggy Dog (World) (Aftermarket) (Unl).gba" size 30965760 crc f8f2e313 sha1 f169a86d11602d84181fd0161bc7ec6747d5c750 ) ) game ( - name "BattleCity (Japan)" - description "BattleCity (Japan)" - rom ( name "BattleCity (Japan).gb" size 32768 crc a37a814a sha1 5c9a6077913b344c8889241ec5f9fdaac7f24c8b ) + name "Eek! The Cat - Shark Therapy (World) (Aftermarket) (Unl)" + description "Eek! The Cat - Shark Therapy (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - Shark Therapy (World) (Aftermarket) (Unl).gba" size 30998528 crc 81bc6107 sha1 9cca9b282e9441364e5acd7379c251674165eb13 ) ) game ( - name "Battleship (USA, Europe)" - description "Battleship (USA, Europe)" - rom ( name "Battleship (USA, Europe).gb" size 65536 crc fef62da5 sha1 d3efb4afebcf94b191a66797a6bae2c90ba92c6a ) + name "Eek! The Cat - The Sound of MusEek (World) (Aftermarket) (Unl)" + description "Eek! The Cat - The Sound of MusEek (World) (Aftermarket) (Unl)" + rom ( name "Eek! The Cat - The Sound of MusEek (World) (Aftermarket) (Unl).gba" size 31129600 crc 923aafde sha1 1f1071ba3a6e056357c04f653cc48d2333a6bff1 ) ) game ( - name "Battleship (USA, Europe) (Beta)" - description "Battleship (USA, Europe) (Beta)" - rom ( name "Battleship (USA, Europe) (Beta).gb" size 65536 crc ec382a5d sha1 d19343d62ec4a257e496ccb4d57c728cbad51e95 ) + name "GBA Groove - LoFi Lullabies (World) (Aftermarket) (Unl)" + description "GBA Groove - LoFi Lullabies (World) (Aftermarket) (Unl)" + rom ( name "GBA Groove - LoFi Lullabies (World) (Aftermarket) (Unl).gba" size 33128448 crc ff858ea8 sha1 e42166ed389ba80a38b91019b80b00fdca3252bd ) ) game ( - name "Battletoads (Japan)" - description "Battletoads (Japan)" - rom ( name "Battletoads (Japan).gb" size 131072 crc 331cf7de sha1 666ed5d34f508c8805a67f4400fc01a1f2817e03 ) + name "Legend of Lofi - High Quality - Part 1 (World) (v2.0) (Aftermarket) (Unl)" + description "Legend of Lofi - High Quality - Part 1 (World) (v2.0) (Aftermarket) (Unl)" + rom ( name "Legend of Lofi - High Quality - Part 1 (World) (v2.0) (Aftermarket) (Unl).gba" size 33095680 crc a29a4d08 sha1 5c5ba15aef8cf86fbfee102dd3d667c09a024215 ) ) game ( - name "Battletoads (USA, Europe)" - description "Battletoads (USA, Europe)" - rom ( name "Battletoads (USA, Europe).gb" size 131072 crc b0c3361b sha1 ba839bea8f76bf955e3edf7083d2cbe780244add flags verified ) + name "Legend of Lofi - High Quality - Part 2 (World) (v2.0) (Aftermarket) (Unl)" + description "Legend of Lofi - High Quality - Part 2 (World) (v2.0) (Aftermarket) (Unl)" + rom ( name "Legend of Lofi - High Quality - Part 2 (World) (v2.0) (Aftermarket) (Unl).gba" size 33292288 crc d30b0a69 sha1 1d0f5640c62823100802a9d99991c81321fd6a7e ) ) game ( - name "Battletoads in Ragnarok's World (Europe)" - description "Battletoads in Ragnarok's World (Europe)" - rom ( name "Battletoads in Ragnarok's World (Europe).gb" size 131072 crc 7ffc34ea sha1 1852bd23644e28109b66fa937053c689a63f7729 flags verified ) + name "Legend of Lofi - High Quality - Part 3 (World) (v2.0) (Aftermarket) (Unl)" + description "Legend of Lofi - High Quality - Part 3 (World) (v2.0) (Aftermarket) (Unl)" + rom ( name "Legend of Lofi - High Quality - Part 3 (World) (v2.0) (Aftermarket) (Unl).gba" size 33226752 crc 5514a608 sha1 0b942ca93b86a61710e437995fbe9b051b49f33b ) ) game ( - name "Battletoads in Ragnarok's World (USA)" - description "Battletoads in Ragnarok's World (USA)" - rom ( name "Battletoads in Ragnarok's World (USA).gb" size 131072 crc ce316c68 sha1 3df1384e699b91689f015d7aba65ab42410e24f5 ) + name "Legend of Lofi - High Quality - Part 4 (World) (v2.0) (Aftermarket) (Unl)" + description "Legend of Lofi - High Quality - Part 4 (World) (v2.0) (Aftermarket) (Unl)" + rom ( name "Legend of Lofi - High Quality - Part 4 (World) (v2.0) (Aftermarket) (Unl).gba" size 33226752 crc 996086fb sha1 cdae6017134b235c4b939c3718fef5c68c932046 ) ) game ( - name "Battletoads-Double Dragon (Europe)" - description "Battletoads-Double Dragon (Europe)" - rom ( name "Battletoads-Double Dragon (Europe).gb" size 262144 crc 7b217082 sha1 5a834e0dc81703906eb441555e1aa31de22d39d6 ) + name "Legend of Lofi - High Quality - Part 5 (World) (v2.1) (Aftermarket) (Unl)" + description "Legend of Lofi - High Quality - Part 5 (World) (v2.1) (Aftermarket) (Unl)" + rom ( name "Legend of Lofi - High Quality - Part 5 (World) (v2.1) (Aftermarket) (Unl).gba" size 33062912 crc 30394a33 sha1 677e3fbd22eac9661365f798e141844628869f09 ) ) game ( - name "Battletoads-Double Dragon (USA)" - description "Battletoads-Double Dragon (USA)" - rom ( name "Battletoads-Double Dragon (USA).gb" size 262144 crc a727f9cd sha1 ce68df4dc2d604625164430266017b237b72303d ) + name "Legend of Lofi - Low Quality - Part 1 (World) (Aftermarket) (Unl)" + description "Legend of Lofi - Low Quality - Part 1 (World) (Aftermarket) (Unl)" + rom ( name "Legend of Lofi - Low Quality - Part 1 (World) (Aftermarket) (Unl).gba" size 33456128 crc ec98d515 sha1 02d89347e83d030168916b1d5b5cb39f436564cf ) ) game ( - name "Beavis and Butt-head (USA, Europe)" - description "Beavis and Butt-head (USA, Europe)" - rom ( name "Beavis and Butt-head (USA, Europe).gb" size 524288 crc af1ae123 sha1 918e9cc878a61d8174918c897182604f0c27b1d9 ) + name "Legend of Lofi - Low Quality - Part 2 (World) (Aftermarket) (Unl)" + description "Legend of Lofi - Low Quality - Part 2 (World) (Aftermarket) (Unl)" + rom ( name "Legend of Lofi - Low Quality - Part 2 (World) (Aftermarket) (Unl).gba" size 33488896 crc 9a3ad572 sha1 90a4fefd48cc5024b88591a29a79c5a720593dcf ) ) game ( - name "Beethoven (Europe) (SGB Enhanced)" - description "Beethoven (Europe) (SGB Enhanced)" - rom ( name "Beethoven (Europe) (SGB Enhanced).gb" size 131072 crc 637e54e3 sha1 a175778faca00f096f0bfdbaa844a38816bbeb0f ) + name "Lizard of Aaaahs (World) (Aftermarket) (Unl)" + description "Lizard of Aaaahs (World) (Aftermarket) (Unl)" + rom ( name "Lizard of Aaaahs (World) (Aftermarket) (Unl).gba" size 30801920 crc 45d496d3 sha1 65b0a763932517d504abb0e39e9db316b2500c0a ) ) game ( - name "Beethoven (USA) (Proto) (SGB Enhanced)" - description "Beethoven (USA) (Proto) (SGB Enhanced)" - rom ( name "Beethoven (USA) (Proto) (SGB Enhanced).gb" size 131072 crc d7b75fa6 sha1 2e71fde9958466f8b484c757f726bcdc5e1ae456 ) + name "Lofi Radio (World) (Aftermarket) (Unl)" + description "Lofi Radio (World) (Aftermarket) (Unl)" + rom ( name "Lofi Radio (World) (Aftermarket) (Unl).gba" size 30965760 crc 4643636f sha1 7657efc85a8414a2d2065549e66bc0e0804a0153 ) ) game ( - name "Beetlejuice (USA)" - description "Beetlejuice (USA)" - rom ( name "Beetlejuice (USA).gb" size 131072 crc 33574ecb sha1 a8bb9681dbf0700d64a88c7d9ad0093f08087046 ) + name "Popeye The Sailor Meets Ali Baba's Forty Thieves (World) (Aftermarket) (Unl)" + description "Popeye The Sailor Meets Ali Baba's Forty Thieves (World) (Aftermarket) (Unl)" + rom ( name "Popeye The Sailor Meets Ali Baba's Forty Thieves (World) (Aftermarket) (Unl).gba" size 25067520 crc 3d2b7e9a sha1 7ed0b27ce1537610d62e3265ee1d8e7aa09ac649 ) ) game ( - name "Best of the Best - Championship Karate (Europe)" - description "Best of the Best - Championship Karate (Europe)" - rom ( name "Best of the Best - Championship Karate (Europe).gb" size 262144 crc d5c3da1d sha1 351446b94176360c0d9ad3cee43166ffbd9a51fa flags verified ) + name "Sleepy Time (World) (Aftermarket) (Unl)" + description "Sleepy Time (World) (Aftermarket) (Unl)" + rom ( name "Sleepy Time (World) (Aftermarket) (Unl).gba" size 33554432 crc b4a8e893 sha1 ba0a790b18de15009d711474aa25f29875e7f9fd ) ) game ( - name "Best of the Best - Championship Karate (USA)" - description "Best of the Best - Championship Karate (USA)" - rom ( name "Best of the Best - Championship Karate (USA).gb" size 262144 crc b20280e6 sha1 ba7d64c606cc0f654217e54a0bd5b8dda455a060 ) + name "Sonic Boom - Aim Low (World) (Aftermarket) (Unl)" + description "Sonic Boom - Aim Low (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Aim Low (World) (Aftermarket) (Unl).gba" size 32899072 crc a4b992a4 sha1 321716a5cc8035d2f3c834db70e21024b26e01ec ) ) game ( - name "Bikkuri Nekketsu Shin Kiroku! - Dokodemo Kin Medal (Japan)" - description "Bikkuri Nekketsu Shin Kiroku! - Dokodemo Kin Medal (Japan)" - rom ( name "Bikkuri Nekketsu Shin Kiroku! - Dokodemo Kin Medal (Japan).gb" size 262144 crc 86d11d10 sha1 baecee2dfd915a41363fef736f81853822d5dfcd ) + name "Sonic Boom - Anything You Can Do, I Can Do Worse-er (World) (Aftermarket) (Unl)" + description "Sonic Boom - Anything You Can Do, I Can Do Worse-er (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Anything You Can Do, I Can Do Worse-er (World) (Aftermarket) (Unl).gba" size 32669696 crc 3e19389e sha1 bd9e8e22ddde7426d8eb77772480c822a099044f ) ) game ( - name "Bill & Ted's Excellent Game Boy Adventure - A Bogus Journey! (USA, Europe)" - description "Bill & Ted's Excellent Game Boy Adventure - A Bogus Journey! (USA, Europe)" - rom ( name "Bill & Ted's Excellent Game Boy Adventure - A Bogus Journey! (USA, Europe).gb" size 131072 crc 5e8f656a sha1 e19a7e5a5bd8fde0f31773c22dbebc9b4cf3824e flags verified ) + name "Sonic Boom - Blue with Envy (World) (Aftermarket) (Unl)" + description "Sonic Boom - Blue with Envy (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Blue with Envy (World) (Aftermarket) (Unl).gba" size 33488896 crc c847a712 sha1 44c4d7a6ba6b3bea7f452f22ec7c419cf6cf6965 ) ) game ( - name "Bill & Ted's Excellent Portable Adventure - A Bogus Journey! (World) (Retro Collection)" - description "Bill & Ted's Excellent Portable Adventure - A Bogus Journey! (World) (Retro Collection)" - rom ( name "Bill & Ted's Excellent Portable Adventure - A Bogus Journey! (World) (Retro Collection).gb" size 131072 crc 7b5e19ca sha1 c6e606cb5e17f7530a529387ad2fb703a94b205a flags verified ) + name "Sonic Boom - Cabin Fever (World) (Aftermarket) (Unl)" + description "Sonic Boom - Cabin Fever (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Cabin Fever (World) (Aftermarket) (Unl).gba" size 32145408 crc 6a916ed9 sha1 e422c79d1b85942fcd9bae26105151c4e8a8352c ) ) game ( - name "Bill Elliott's NASCAR Fast Tracks (USA)" - description "Bill Elliott's NASCAR Fast Tracks (USA)" - rom ( name "Bill Elliott's NASCAR Fast Tracks (USA).gb" size 131072 crc 71cf43ce sha1 ebc2ca8b4503f0b05e00749d693462a54f2f95eb ) + name "Sonic Boom - Curse of the Cross Eyed Moose (World) (Aftermarket) (Unl)" + description "Sonic Boom - Curse of the Cross Eyed Moose (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Curse of the Cross Eyed Moose (World) (Aftermarket) (Unl).gba" size 32636928 crc 751a7c3c sha1 393a023540a261e14ab96ee341505fd6852e5040 ) ) game ( - name "Binding of Isaac, The - Game Boy Edition (World) (Aftermarket) (Unl)" - description "Binding of Isaac, The - Game Boy Edition (World) (Aftermarket) (Unl)" - rom ( name "Binding of Isaac, The - Game Boy Edition (World) (Aftermarket) (Unl).gb" size 32768 crc bf922249 sha1 187782720d4f7c0986a0d916b0c7efa2c488612e ) + name "Sonic Boom - Double Doomsday (World) (Aftermarket) (Unl)" + description "Sonic Boom - Double Doomsday (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Double Doomsday (World) (Aftermarket) (Unl).gba" size 33095680 crc e43df55f sha1 b0f7feb5f1b012ce4a486e6ad1331d83372a52e8 ) ) game ( - name "Bionic Battler (USA)" - description "Bionic Battler (USA)" - rom ( name "Bionic Battler (USA).gb" size 65536 crc a1e55dc2 sha1 9eca6a5fd1e537085598e8b2903ad75fe9c0b785 flags verified ) + name "Sonic Boom - Eggheads (World) (Aftermarket) (Unl)" + description "Sonic Boom - Eggheads (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Eggheads (World) (Aftermarket) (Unl).gba" size 32964608 crc 7be59036 sha1 6afd6a0e39a792422767f40d96d28683fe3f010b ) ) game ( - name "Bionic Commando (Europe)" - description "Bionic Commando (Europe)" - rom ( name "Bionic Commando (Europe).gb" size 262144 crc 4c5b4547 sha1 a8ab419b049aef5a04800efd6df58e4b3c3abbe3 flags verified ) + name "Sonic Boom - Fortress of Squalitude (World) (Aftermarket) (Unl)" + description "Sonic Boom - Fortress of Squalitude (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Fortress of Squalitude (World) (Aftermarket) (Unl).gba" size 32964608 crc 2732961a sha1 db37f535660f66d947ccd2fdb05631d6c3b53157 ) ) game ( - name "Bionic Commando (Japan)" - description "Bionic Commando (Japan)" - rom ( name "Bionic Commando (Japan).gb" size 262144 crc 3f4d5c84 sha1 12dc5b05751214be3ce55da0fecaf23a41eb1881 ) + name "Sonic Boom - Guilt Tripping (World) (Aftermarket) (Unl)" + description "Sonic Boom - Guilt Tripping (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Guilt Tripping (World) (Aftermarket) (Unl).gba" size 33095680 crc eb433ebc sha1 29648e120e9fd97f9c8b279b29246f165df3b9e6 ) ) game ( - name "Bionic Commando (USA)" - description "Bionic Commando (USA)" - rom ( name "Bionic Commando (USA).gb" size 262144 crc 41dbb5fb sha1 e0ef47568a017ccdd3dbe0db5d7654822b4e5ce1 ) + name "Sonic Boom - It Takes a Village to Defeat a Hedgehog (World) (Aftermarket) (Unl)" + description "Sonic Boom - It Takes a Village to Defeat a Hedgehog (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - It Takes a Village to Defeat a Hedgehog (World) (Aftermarket) (Unl).gba" size 33062912 crc 087a17bf sha1 5cfd8eb8d832d21d64fc150bcc6d26b52da86911 ) ) game ( - name "Birdie Bartender (World) (Aftermarket) (Unl)" - description "Birdie Bartender (World) (Aftermarket) (Unl)" - rom ( name "Birdie Bartender (World) (Aftermarket) (Unl).gb" size 262144 crc 0bf2a1c8 sha1 aa1325fc7160b84745b076de9b976a1b368da50e ) + name "Sonic Boom - Let's Play Musical Friends (World) (Aftermarket) (Unl)" + description "Sonic Boom - Let's Play Musical Friends (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Let's Play Musical Friends (World) (Aftermarket) (Unl).gba" size 33226752 crc 4f7e8a97 sha1 ad7d4f4833878ccc7055e65efbcb62fba20cd340 ) ) game ( - name "Bishoujo Senshi Sailor Moon (Japan)" - description "Bishoujo Senshi Sailor Moon (Japan)" - rom ( name "Bishoujo Senshi Sailor Moon (Japan).gb" size 131072 crc c2763e73 sha1 c008913a9fbb395a7a504fe65d1d29c530755cb3 ) + name "Sonic Boom - Nutwork (World) (Aftermarket) (Unl)" + description "Sonic Boom - Nutwork (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - Nutwork (World) (Aftermarket) (Unl).gba" size 32768000 crc ed3ead6a sha1 f89d6acee3095419d2eda71c1d79e73ba3dcf5e4 ) ) game ( - name "Bishoujo Senshi Sailor Moon R (Japan)" - description "Bishoujo Senshi Sailor Moon R (Japan)" - rom ( name "Bishoujo Senshi Sailor Moon R (Japan).gb" size 262144 crc ea759875 sha1 959f384998c43072ca154e531917e9aaa80a694d ) + name "Sonic Boom - The Evil Dr. Orbot (World) (Aftermarket) (Unl)" + description "Sonic Boom - The Evil Dr. Orbot (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - The Evil Dr. Orbot (World) (Aftermarket) (Unl).gba" size 33095680 crc e8c0b3b3 sha1 175126d3946e61295993982cb04758a5761233b1 ) ) game ( - name "Black Bass - Lure Fishing (USA)" - description "Black Bass - Lure Fishing (USA)" - rom ( name "Black Bass - Lure Fishing (USA).gb" size 262144 crc 2db3dace sha1 d9524ac9f7788172a55cc8ceb6e199f8a12e033d ) + name "Sonic Boom - The Meteor (World) (Aftermarket) (Unl)" + description "Sonic Boom - The Meteor (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - The Meteor (World) (Aftermarket) (Unl).gba" size 32931840 crc d3c8e3bc sha1 84a91ed46f4e055ef075b4e110091dd1510c6bab ) ) game ( - name "Black Castle (World) (Aftermarket) (Unl)" - description "Black Castle (World) (Aftermarket) (Unl)" - rom ( name "Black Castle (World) (Aftermarket) (Unl).gb" size 65536 crc 10f577c7 sha1 45d979be572bb820835d2ecd4e990cd1eadbf5a6 ) + name "Sonic Boom - The Sidekick (World) (Aftermarket) (Unl)" + description "Sonic Boom - The Sidekick (World) (Aftermarket) (Unl)" + rom ( name "Sonic Boom - The Sidekick (World) (Aftermarket) (Unl).gba" size 32964608 crc bca89ca3 sha1 93d24392e31fa7fa1b017eae2efbbb3d198739b7 ) ) game ( - name "Blade Warrior (Europe) (Proto)" - description "Blade Warrior (Europe) (Proto)" - rom ( name "Blade Warrior (Europe) (Proto).gb" size 32768 crc cfd54dbc sha1 53c1e67430f923f74a611e675ca0cad8d0b13d76 ) + name "Super Mario World - Episode 1 - Fire Sale (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 1 - Fire Sale (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 1 - Fire Sale (World) (Aftermarket) (Unl).gba" size 31522816 crc 5af74124 sha1 c715e8adff312d3ade93185d6cebcb2d493cc41e ) ) game ( - name "Blades of Steel (Europe)" - description "Blades of Steel (Europe)" - rom ( name "Blades of Steel (Europe).gb" size 131072 crc f7be0002 sha1 d030c46bc225fc92aa431276d9ae5812a30d6007 flags verified ) + name "Super Mario World - Episode 10 - Rock TV (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 10 - Rock TV (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 10 - Rock TV (World) (Aftermarket) (Unl).gba" size 30179328 crc ccb80716 sha1 3f05bfc29688ab70cc728bbe609d5b976730490e ) ) game ( - name "Blades of Steel (USA)" - description "Blades of Steel (USA)" - rom ( name "Blades of Steel (USA).gb" size 131072 crc e81c9fb9 sha1 82761dbf5abe276f8e0c82f575356aed87155141 flags verified ) + name "Super Mario World - Episode 11 - The Yoshi Shuffle (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 11 - The Yoshi Shuffle (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 11 - The Yoshi Shuffle (World) (Aftermarket) (Unl).gba" size 31129600 crc 733bb9b0 sha1 45875207d24653aa81c2bdd60bde639783c5c387 ) ) game ( - name "Blaster Master Boy (USA)" - description "Blaster Master Boy (USA)" - rom ( name "Blaster Master Boy (USA).gb" size 131072 crc 3b2c7118 sha1 21b1e574a6f4543651e96de65994e7b0b7a6a0f6 ) + name "Super Mario World - Episode 12 - A Little Learning (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 12 - A Little Learning (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 12 - A Little Learning (World) (Aftermarket) (Unl).gba" size 31227904 crc dd8717c1 sha1 26fcf34d2fd9f87f287d14fdeda9d8e234306db5 ) ) game ( - name "Blaster Master Boy (USA) (Beta)" - description "Blaster Master Boy (USA) (Beta)" - rom ( name "Blaster Master Boy (USA) (Beta).gb" size 131072 crc 4ea70173 sha1 f568f9c7fe9ef9726d602727beca13d6978cd770 ) + name "Super Mario World - Episode 13 - Mama Luigi (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 13 - Mama Luigi (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 13 - Mama Luigi (World) (Aftermarket) (Unl).gba" size 32112640 crc 3d2bf1b0 sha1 4a897d3de60f1bd3991803196f5b96c5916f9e8c ) ) game ( - name "Blaster Master Jr. (Europe)" - description "Blaster Master Jr. (Europe)" - rom ( name "Blaster Master Jr. (Europe).gb" size 131072 crc e9f9016f sha1 6a6deae1942e7cf048ce35d18e9540363c226727 ) + name "Super Mario World - Episode 2 - The Wheel Thing (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 2 - The Wheel Thing (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 2 - The Wheel Thing (World) (Aftermarket) (Unl).gba" size 32145408 crc 9c5140d6 sha1 30b6b51d60ba9213e5c472bf52070eab98b43c74 ) ) game ( - name "Blitz Bomber (World) (Aftermarket) (Unl)" - description "Blitz Bomber (World) (Aftermarket) (Unl)" - rom ( name "Blitz Bomber (World) (Aftermarket) (Unl).gb" size 262144 crc 5e9956de sha1 b72cbc6bfa6ceef940f49c9c82024071c6f82b90 ) + name "Super Mario World - Episode 3 - Send in the Clown (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 3 - Send in the Clown (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 3 - Send in the Clown (World) (Aftermarket) (Unl).gba" size 32112640 crc 88888a8c sha1 26c791180a1b35d8ab9cf7947d8db6c0367d7eb9 ) ) game ( - name "Block Kuzushi GB (Japan) (SGB Enhanced)" - description "Block Kuzushi GB (Japan) (SGB Enhanced)" - rom ( name "Block Kuzushi GB (Japan) (SGB Enhanced).gb" size 131072 crc 54b67501 sha1 7540fe9af69d8c7d48f50c2d5fe6d3ce07421f74 ) + name "Super Mario World - Episode 4 - Ghosts 'R' Us (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 4 - Ghosts 'R' Us (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 4 - Ghosts 'R' Us (World) (Aftermarket) (Unl).gba" size 32079872 crc ca0d9b45 sha1 a15fb94a371d783f78c069038c350e569ea9c370 ) ) game ( - name "Blockade (World) (Aftermarket) (Unl)" - description "Blockade (World) (Aftermarket) (Unl)" - rom ( name "Blockade (World) (Aftermarket) (Unl).gb" size 262144 crc b8cfab16 sha1 9e753048a0eb036ac17c08f5a64d860abd1aaaf5 ) + name "Super Mario World - Episode 5 - The Night Before Cave Christmas (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 5 - The Night Before Cave Christmas (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 5 - The Night Before Cave Christmas (World) (Aftermarket) (Unl).gba" size 31981568 crc 564582fa sha1 ce8b3589a67dcd930d2e437efa0bf754f438cfa7 ) ) game ( - name "Blodia (Japan)" - description "Blodia (Japan)" - rom ( name "Blodia (Japan).gb" size 65536 crc 51ff6e53 sha1 a3927543ca471f479ba7aae7295788434672464e ) + name "Super Mario World - Episode 6 - King Scoopa Koopa (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 6 - King Scoopa Koopa (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 6 - King Scoopa Koopa (World) (Aftermarket) (Unl).gba" size 32112640 crc edcb04de sha1 1e8e89daf7faed9660f2dc3b6aa113df6de527c0 ) ) game ( - name "Blues Brothers (USA, Europe) (Beta)" - description "Blues Brothers (USA, Europe) (Beta)" - rom ( name "Blues Brothers (USA, Europe) (Beta).gb" size 131072 crc 1f90d12a sha1 f7139bb55c3cc7bae672ade9022fb548b72f6f2f ) + name "Super Mario World - Episode 7 - Born to Ride (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 7 - Born to Ride (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 7 - Born to Ride (World) (Aftermarket) (Unl).gba" size 32145408 crc 0044466e sha1 105f0d0a500ea542f87b10b7c671b6c93e312f4a ) ) game ( - name "Blues Brothers, The (USA, Europe)" - description "Blues Brothers, The (USA, Europe)" - rom ( name "Blues Brothers, The (USA, Europe).gb" size 131072 crc adb66eff sha1 9dca8b83a5d73270319cf05396fcca8e6027e7b0 flags verified ) + name "Super Mario World - Episode 8 - Party Line (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 8 - Party Line (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 8 - Party Line (World) (Aftermarket) (Unl).gba" size 28672000 crc ed103f04 sha1 df5e947880b634482081ee82f79f37d5ff7d009c ) ) game ( - name "Blues Brothers, The - Jukebox Adventure (Europe)" - description "Blues Brothers, The - Jukebox Adventure (Europe)" - rom ( name "Blues Brothers, The - Jukebox Adventure (Europe).gb" size 131072 crc f1c0fb1d sha1 2005e94222a1f0edd30903411343f9570a91d4f3 ) + name "Super Mario World - Episode 9 - Gopher Bash (World) (Aftermarket) (Unl)" + description "Super Mario World - Episode 9 - Gopher Bash (World) (Aftermarket) (Unl)" + rom ( name "Super Mario World - Episode 9 - Gopher Bash (World) (Aftermarket) (Unl).gba" size 31031296 crc 3a8f46ad sha1 160895e7953a3323647c0c9d2d00eeff17b57db5 ) ) -game ( - name "Bo Jackson - Two Games in One (USA)" - description "Bo Jackson - Two Games in One (USA)" - rom ( name "Bo Jackson - Two Games in One (USA).gb" size 131072 crc 7edb78ab sha1 cb360f44a398ff5cd3818b0e244ffdf7019d85c7 flags verified ) +clrmamepro ( + name "Nintendo - Game Boy" + description "Nintendo - Game Boy" + version 20240809-004429 + author "aci68, akubi, Arctic Circle System, Aringon, baldjared, Bent, BigFred, BitLooter, buckwheat, C. V. Reynolds, chillerecke, darthcloud, DeadSkullzJr, Densetsu, DeriLoko3, ElBarto, foxe, fuzzball, Gefflon, Hiccup, hking0036, InternalLoss, Jack, jimmsu, Just001Kim, kazumi213, leekindo, Lesserkuma, Madeline, NESBrew12, NGEfreak, nnssxx, norkmetnoil577, NovaAurora, omonim2007, Powerpuff, PPLToast, Psychofox11, psykopat, rarenight, relax, RetroUprising, rpg2813, sCZther, SonGoku, Tauwasser, togemet2, UnlockerPT, xNo, xprism, xuom2" + homepage No-Intro + url "https://www.no-intro.org" + forcenodump required ) -game ( - name "Bobby's World (USA) (Proto) (SGB Enhanced)" - description "Bobby's World (USA) (Proto) (SGB Enhanced)" - rom ( name "Bobby's World (USA) (Proto) (SGB Enhanced).gb" size 131072 crc 531bf384 sha1 7c244ab1260c7d1d198cf61a0a1529f3baee9fbf ) +emulator ( + name "datafile" ) game ( - name "Bobby's World (Europe) (Proto) (SGB Enhanced)" - description "Bobby's World (Europe) (Proto) (SGB Enhanced)" - rom ( name "Bobby's World (Europe) (Proto) (SGB Enhanced).gb" size 131072 crc ffe34a16 sha1 7c67947726292b99d57aab17dc0f101ca5f8567f ) + name "[BIOS] Maxstation Boot ROM (China) (En) (Unl)" + description "[BIOS] Maxstation Boot ROM (China) (En) (Unl)" + rom ( name "[BIOS] Maxstation Boot ROM (China) (En) (Unl).gb" size 256 crc 783e69c2 sha1 1776bd61b8db71fc4c4d4b5feab4a21b3c1fd95b ) ) game ( - name "Boggle Plus (USA)" - description "Boggle Plus (USA)" - rom ( name "Boggle Plus (USA).gb" size 131072 crc 70c8c799 sha1 d6cf512f7301ccdc2d802f34fbbde2d0ba2cf3cd ) + name "[BIOS] Nintendo Game Boy Boot ROM (World) (Rev 1)" + description "[BIOS] Nintendo Game Boy Boot ROM (World) (Rev 1)" + rom ( name "[BIOS] Nintendo Game Boy Boot ROM (World) (Rev 1).gb" size 256 crc 59c8598e sha1 4ed31ec6b0b175bb109c0eb5fd3d193da823339f flags verified ) ) game ( - name "Bokujou Monogatari GB (Japan) (SGB Enhanced)" - description "Bokujou Monogatari GB (Japan) (SGB Enhanced)" - rom ( name "Bokujou Monogatari GB (Japan) (SGB Enhanced).gb" size 524288 crc d3e2fd02 sha1 60ecafdb13213b3ac2daa3d71431ef8a89754edb flags verified ) + name "[BIOS] Nintendo Game Boy Boot ROM (Japan) (En)" + description "[BIOS] Nintendo Game Boy Boot ROM (Japan) (En)" + rom ( name "[BIOS] Nintendo Game Boy Boot ROM (Japan) (En).gb" size 256 crc c2f5cc97 sha1 8bd501e31921e9601788316dbd3ce9833a97bcbc flags verified ) ) game ( - name "Bokujou Monogatari GB (Japan) (Rev 1) (SGB Enhanced)" - description "Bokujou Monogatari GB (Japan) (Rev 1) (SGB Enhanced)" - rom ( name "Bokujou Monogatari GB (Japan) (Rev 1) (SGB Enhanced).gb" size 524288 crc da218e44 sha1 a1637d7ba09335631eac1291803ade05adcf5fc7 flags verified ) + name "[BIOS] Nintendo Game Boy Pocket Boot ROM (World)" + description "[BIOS] Nintendo Game Boy Pocket Boot ROM (World)" + rom ( name "[BIOS] Nintendo Game Boy Pocket Boot ROM (World).gb" size 256 crc e6920754 sha1 4e68f9da03c310e84c523654b9026e51f26ce7f0 flags verified ) ) game ( - name "Bokujou Monogatari GB (Japan) (SGB Enhanced) (NP)" - description "Bokujou Monogatari GB (Japan) (SGB Enhanced) (NP)" - rom ( name "Bokujou Monogatari GB (Japan) (SGB Enhanced) (NP).gb" size 524288 crc 0424df85 sha1 551df2021d0e433e7f07cf881c7b1d534f54f6ad ) + name "10-Pin Bowling (USA) (Proto)" + description "10-Pin Bowling (USA) (Proto)" + rom ( name "10-Pin Bowling (USA) (Proto).gb" size 131072 crc 9a024415 sha1 952d154dd2c6189ef4b786ae37bd7887c8ca9037 ) ) game ( - name "Bomb Jack (Europe) (Beta 1)" - description "Bomb Jack (Europe) (Beta 1)" - rom ( name "Bomb Jack (Europe) (Beta 1).gb" size 32768 crc ffa0e67a sha1 a4c25218b2c35d6bd4fcf93ebdf81dfe22d4259a ) + name "3 Choume no Tama - Tama and Friends - 3 Choume Obake Panic!! (Japan)" + description "3 Choume no Tama - Tama and Friends - 3 Choume Obake Panic!! (Japan)" + rom ( name "3 Choume no Tama - Tama and Friends - 3 Choume Obake Panic!! (Japan).gb" size 131072 crc b61cd120 sha1 0982bcc82deb9c4db08e602a22a2bb4f31e7e6ae ) ) game ( - name "Bomb Jack (Europe) (Beta 2)" - description "Bomb Jack (Europe) (Beta 2)" - rom ( name "Bomb Jack (Europe) (Beta 2).gb" size 32768 crc 7ca8e543 sha1 6fc3794149f5e75ad82b4a7d47ad5497e1ee4e6a ) + name "3-pun Yosou - Umaban Club (Japan)" + description "3-pun Yosou - Umaban Club (Japan)" + rom ( name "3-pun Yosou - Umaban Club (Japan).gb" size 65536 crc cafe0d2b sha1 76643f3f3481f7e515a24482779870862dd8b373 ) ) game ( - name "Bomb Jack (Europe)" - description "Bomb Jack (Europe)" - rom ( name "Bomb Jack (Europe).gb" size 32768 crc 9bd8815e sha1 a2b2799e867777a5a19155ed1f2245630fc03560 ) + name "4 in 1 (Europe) (4B-002, Sachen) (Unl)" + description "4 in 1 (Europe) (4B-002, Sachen) (Unl)" + rom ( name "4 in 1 (Europe) (4B-002, Sachen) (Unl).gb" size 65536 crc 5e438db8 sha1 d9cb1721854709be7667f5dbce0adf2488c0919b flags verified ) ) game ( - name "Bomber Boy (Japan)" - description "Bomber Boy (Japan)" - rom ( name "Bomber Boy (Japan).gb" size 131072 crc ef9595ac sha1 a9baddfb693f20057b17c084422d7bfac590f2ba flags verified ) + name "4 in 1 (Europe) (4B-005, Sachen-Commin) (Unl)" + description "4 in 1 (Europe) (4B-005, Sachen-Commin) (Unl)" + rom ( name "4 in 1 (Europe) (4B-005, Sachen-Commin) (Unl).gb" size 262144 crc f4310eb3 sha1 2107979104cff88bcd635215a936bbc44354ea7c flags verified ) ) game ( - name "Bomber King - Scenario 2 (Japan)" - description "Bomber King - Scenario 2 (Japan)" - rom ( name "Bomber King - Scenario 2 (Japan).gb" size 131072 crc b8fe9077 sha1 79f978b9e85c675f7b54229a14d04926348bb70f ) + name "4 in 1 (Europe) (4B-007, Sachen) (Unl)" + description "4 in 1 (Europe) (4B-007, Sachen) (Unl)" + rom ( name "4 in 1 (Europe) (4B-007, Sachen) (Unl).gb" size 262144 crc 62d9350e sha1 0eef7f3934508ab79e1cad4ddf3bfdb3216b6b4f flags verified ) ) game ( - name "Bomberman Collection (Japan) (SGB Enhanced)" - description "Bomberman Collection (Japan) (SGB Enhanced)" - rom ( name "Bomberman Collection (Japan) (SGB Enhanced).gb" size 1048576 crc 509a6b73 sha1 385f8fafa53a83f8f65e1e619fe124bbf7db4a98 flags verified ) + name "4 in 1 (Europe) (4B-001, Sachen-Commin) (Unl)" + description "4 in 1 (Europe) (4B-001, Sachen-Commin) (Unl)" + rom ( name "4 in 1 (Europe) (4B-001, Sachen-Commin) (Unl).gb" size 262144 crc 82f06e93 sha1 7506c75fdfa29935afb1e85f5b6013516b2e9f92 flags verified ) ) game ( - name "Bomberman GB (Japan) (SGB Enhanced)" - description "Bomberman GB (Japan) (SGB Enhanced)" - rom ( name "Bomberman GB (Japan) (SGB Enhanced).gb" size 262144 crc 94337d56 sha1 5b989983c2f80a71dfc7cce29395de3e174fa848 ) + name "4 in 1 (Europe) (4B-008, Sachen) (Unl)" + description "4 in 1 (Europe) (4B-008, Sachen) (Unl)" + rom ( name "4 in 1 (Europe) (4B-008, Sachen) (Unl).gb" size 262144 crc 740e9bc8 sha1 d7c11d56a42ed7c4ef2fe3c752931a63160d7429 flags verified ) ) game ( - name "Bomberman GB (USA, Europe) (SGB Enhanced)" - description "Bomberman GB (USA, Europe) (SGB Enhanced)" - rom ( name "Bomberman GB (USA, Europe) (SGB Enhanced).gb" size 262144 crc f372d175 sha1 f7058f31ddaec63f3b9c45ee9caf3c8e2cae1ca8 flags verified ) + name "4 in 1 (Europe) (4B-004, Sachen-Commin) (Unl)" + description "4 in 1 (Europe) (4B-004, Sachen-Commin) (Unl)" + rom ( name "4 in 1 (Europe) (4B-004, Sachen-Commin) (Unl).gb" size 262144 crc c69a19f6 sha1 ca7990dc03a3b3ada1dce37afc4490deaf872402 flags verified ) ) game ( - name "Bomberman GB 2 (Japan) (SGB Enhanced)" - description "Bomberman GB 2 (Japan) (SGB Enhanced)" - rom ( name "Bomberman GB 2 (Japan) (SGB Enhanced).gb" size 262144 crc 6157443b sha1 004e540e8aed59e5aee1c88ef84975000a6efe6c flags verified ) + name "4 in 1 (Europe) (4B-006, Sachen) (Unl)" + description "4 in 1 (Europe) (4B-006, Sachen) (Unl)" + rom ( name "4 in 1 (Europe) (4B-006, Sachen) (Unl).gb" size 262144 crc 95398da5 sha1 2e856de768c7cb442a206de8c94a23548027bb60 flags verified ) ) game ( - name "Bomberman GB 3 (Japan) (SGB Enhanced)" - description "Bomberman GB 3 (Japan) (SGB Enhanced)" - rom ( name "Bomberman GB 3 (Japan) (SGB Enhanced).gb" size 262144 crc f658b7a7 sha1 98a6327639833e1a6696e4acc5ca162388d5f6e1 ) + name "4 in 1 (Europe) (4B-009, Sachen) (Unl)" + description "4 in 1 (Europe) (4B-009, Sachen) (Unl)" + rom ( name "4 in 1 (Europe) (4B-009, Sachen) (Unl).gb" size 262144 crc 114e1f1e sha1 39743e21935a9115fcb4ee86d67d51bdb4b5f6d6 flags verified ) ) game ( - name "Bonk's Adventure (USA)" - description "Bonk's Adventure (USA)" - rom ( name "Bonk's Adventure (USA).gb" size 262144 crc a7cdbb96 sha1 e27d941af0a006c4f5ffd03914265146aa140e2c ) + name "4 in 1 (Taiwan) (En,Zh) (4B-003, Sachen-Commin) (Unl)" + description "4 in 1 (Taiwan) (En,Zh) (4B-003, Sachen-Commin) (Unl)" + rom ( name "4 in 1 (Taiwan) (En,Zh) (4B-003, Sachen-Commin) (Unl).gb" size 65536 crc c294aa21 sha1 b5a3ee09692476d801d873a703d508d17ee24fbd ) ) game ( - name "Bonk's Adventure (USA) (Beta)" - description "Bonk's Adventure (USA) (Beta)" - rom ( name "Bonk's Adventure (USA) (Beta).gb" size 262144 crc 8d706dbc sha1 a26006158d90a61d22abf130f05297fd09a09b7c ) + name "4-in-1 Fun Pak (Japan)" + description "4-in-1 Fun Pak (Japan)" + rom ( name "4-in-1 Fun Pak (Japan).gb" size 131072 crc 86f45343 sha1 f1cf115df0246f08d4e886cb046ebd2aa431a6c9 ) ) game ( - name "Bonk's Revenge (USA) (SGB Enhanced)" - description "Bonk's Revenge (USA) (SGB Enhanced)" - rom ( name "Bonk's Revenge (USA) (SGB Enhanced).gb" size 262144 crc f1344b78 sha1 8d1b81e456b271ad8f49a2c6efc9ca2504a24591 ) + name "4-in-1 Fun Pak (USA, Europe)" + description "4-in-1 Fun Pak (USA, Europe)" + rom ( name "4-in-1 Fun Pak (USA, Europe).gb" size 131072 crc 0e0216e6 sha1 b1443c09ee3f2bee5437111a635b6d84155f600e flags verified ) ) game ( - name "Booby Boys (Japan)" - description "Booby Boys (Japan)" - rom ( name "Booby Boys (Japan).gb" size 262144 crc ec83c0b6 sha1 61fe27a4ce83bc6d9dba5d4d0652e83dbec45e6e ) + name "4-in-1 Funpak - Volume II (USA, Europe)" + description "4-in-1 Funpak - Volume II (USA, Europe)" + rom ( name "4-in-1 Funpak - Volume II (USA, Europe).gb" size 131072 crc 018b4a02 sha1 5efeddce9e03ad56ee755c58fb658b045dc0fa53 ) ) game ( - name "Boomer's Adventure in ASMIK World (USA)" - description "Boomer's Adventure in ASMIK World (USA)" - rom ( name "Boomer's Adventure in ASMIK World (USA).gb" size 65536 crc 105bc1c0 sha1 3d8a6fcc644290c9d88fe2918bfa6007ee811de8 flags verified ) + name "8-in-1 (Taiwan) (En) (Unl)" + description "8-in-1 (Taiwan) (En) (Unl)" + rom ( name "8-in-1 (Taiwan) (En) (Unl).gb" size 524288 crc fbc77225 sha1 f57efd4d5063cb87519fc3b574377cc9a2a841ee ) ) game ( - name "Bork Paw Kisses (World) (Aftermarket) (Unl)" - description "Bork Paw Kisses (World) (Aftermarket) (Unl)" - rom ( name "Bork Paw Kisses (World) (Aftermarket) (Unl).gb" size 262144 crc c29f0d35 sha1 8f1efe6982d2b4ebc1fbeb3ade68dd9b9aabb7a6 ) + name "A-mazing Tater (USA)" + description "A-mazing Tater (USA)" + rom ( name "A-mazing Tater (USA).gb" size 65536 crc d229ac62 sha1 1e475cbd5fb7099df91155a103698e4e66da7a86 ) ) game ( - name "Borruga - Neo Pinball (World) (Aftermarket) (Unl)" - description "Borruga - Neo Pinball (World) (Aftermarket) (Unl)" - rom ( name "Borruga - Neo Pinball (World) (Aftermarket) (Unl).gb" size 32768 crc 2bb55ca5 sha1 269f12091d5ab87362a2cb2cf5484f14bfcbd537 flags verified ) + name "Aa Harimanada (Japan)" + description "Aa Harimanada (Japan)" + rom ( name "Aa Harimanada (Japan).gb" size 131072 crc 5bffcc28 sha1 ff3565fcac22b44bf542732d1b0b20ba96a6c961 ) ) game ( - name "Bouken! Puzzle Road (Japan)" - description "Bouken! Puzzle Road (Japan)" - rom ( name "Bouken! Puzzle Road (Japan).gb" size 32768 crc 9f0f3606 sha1 16d54de69814e1c9aae67a59bb0dcd2a1216395b ) + name "Action Replay Pro (World) (Unl)" + description "Action Replay Pro (World) (Unl)" + rom ( name "Action Replay Pro (World) (Unl).gb" size 16384 crc 2ea05daa sha1 e947b9264092168950ad1ce23bbe3d8ccfed765e ) ) game ( - name "Boulder Dash (Europe)" - description "Boulder Dash (Europe)" - rom ( name "Boulder Dash (Europe).gb" size 65536 crc 644aec3e sha1 01cc570a16bad4c2c33b393620ec9e25f131d1f4 flags verified ) + name "Addams Family, The (Europe) (En,Fr,De)" + description "Addams Family, The (Europe) (En,Fr,De)" + rom ( name "Addams Family, The (Europe) (En,Fr,De).gb" size 131072 crc 28fa451e sha1 2246dbdb6c58c77814cf034ae9224be8e73c5084 flags verified ) ) game ( - name "Boulder Dash (Japan)" - description "Boulder Dash (Japan)" - rom ( name "Boulder Dash (Japan).gb" size 65536 crc b5b3f85b sha1 f5a4a5ccda4f559ce85567c4b68f758216aee2d4 ) + name "Addams Family, The (Japan)" + description "Addams Family, The (Japan)" + rom ( name "Addams Family, The (Japan).gb" size 131072 crc 4c749c14 sha1 10a7d1491001657272755559ed593cc4400014ee ) ) game ( - name "Bounce (World) (v1.1) (Aftermarket) (Unl)" - description "Bounce (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Bounce (World) (v1.1) (Aftermarket) (Unl).gb" size 32768 crc 827f2bd5 sha1 e9abf64de3faeb48151003ac8bb77dea61e838b5 ) + name "Addams Family, The (USA)" + description "Addams Family, The (USA)" + rom ( name "Addams Family, The (USA).gb" size 131072 crc c170a732 sha1 8710ceecbe3e7ade67c0362cc3b455aceb67a90d flags verified ) ) game ( - name "Bouncing Ball, The (World) (Aftermarket)" - description "Bouncing Ball, The (World) (Aftermarket)" - rom ( name "Bouncing Ball, The (World) (Aftermarket).gb" size 65536 crc 42ddf53e sha1 5d331f2e66d7d3f4b4b0fcbaf6ab4b1a0147db3e ) + name "Addams Family, The - Pugsley's Scavenger Hunt (USA, Europe)" + description "Addams Family, The - Pugsley's Scavenger Hunt (USA, Europe)" + rom ( name "Addams Family, The - Pugsley's Scavenger Hunt (USA, Europe).gb" size 131072 crc 7e054a88 sha1 f9020e3d104cb5c5347e28f45ed9e24e6c0ebddd flags verified ) ) game ( - name "Bourgogne Game Show 2022 (World) (Aftermarket) (Unl)" - description "Bourgogne Game Show 2022 (World) (Aftermarket) (Unl)" - rom ( name "Bourgogne Game Show 2022 (World) (Aftermarket) (Unl).gb" size 262144 crc 98222a4a sha1 0bdb8ad04469a329c8cee2fb0c55da35f7752042 ) + name "Adventure Island (USA, Europe)" + description "Adventure Island (USA, Europe)" + rom ( name "Adventure Island (USA, Europe).gb" size 131072 crc 64f4fa44 sha1 4a61945c1e3a37301748314777835c0e122a67e6 flags verified ) ) game ( - name "Boxing (Japan)" - description "Boxing (Japan)" - rom ( name "Boxing (Japan).gb" size 65536 crc ef7e9fa0 sha1 5af3a0b6e54ca67c3a4cab8833368725cc68e99f ) + name "Adventure Island II - Aliens in Paradise (USA, Europe)" + description "Adventure Island II - Aliens in Paradise (USA, Europe)" + rom ( name "Adventure Island II - Aliens in Paradise (USA, Europe).gb" size 262144 crc 783066cf sha1 1964fd5708150aa9f71c0a79d552466fd5bf5bf8 flags verified ) ) game ( - name "Boxxle (USA, Europe) (Rev 1)" - description "Boxxle (USA, Europe) (Rev 1)" - rom ( name "Boxxle (USA, Europe) (Rev 1).gb" size 32768 crc c09cee99 sha1 f9d5287bc9d6eda9ec36e9b5a8dbc38cf2cffecf flags verified ) + name "Adventures of Lolo (Europe) (SGB Enhanced)" + description "Adventures of Lolo (Europe) (SGB Enhanced)" + rom ( name "Adventures of Lolo (Europe) (SGB Enhanced).gb" size 262144 crc 176d2eeb sha1 e09277358a7fd4f3a6206464dd9d39f3abe66a53 flags verified ) ) game ( - name "Boxxle (USA)" - description "Boxxle (USA)" - rom ( name "Boxxle (USA).gb" size 32768 crc 24843867 sha1 3e169f1db16cc1c3ffbc8645aa7ce28194033d26 flags verified ) + name "Adventures of Pinocchio, The (Europe) (Proto)" + description "Adventures of Pinocchio, The (Europe) (Proto)" + rom ( name "Adventures of Pinocchio, The (Europe) (Proto).gb" size 65536 crc 0b9de1dc sha1 6808d5a5fba9b58d67e91f22a2860e4e72f6eec1 ) ) game ( - name "Boxxle II (USA, Europe)" - description "Boxxle II (USA, Europe)" - rom ( name "Boxxle II (USA, Europe).gb" size 32768 crc c08e9756 sha1 36315dab12915d2d2fad7a37fcb5ce6809118c8a ) + name "Adventures of Rocky and Bullwinkle and Friends, The (USA)" + description "Adventures of Rocky and Bullwinkle and Friends, The (USA)" + rom ( name "Adventures of Rocky and Bullwinkle and Friends, The (USA).gb" size 131072 crc 362c841c sha1 0ce98889e5d9d6167338e91119394537318810da ) ) game ( - name "Brain Bender (Europe)" - description "Brain Bender (Europe)" - rom ( name "Brain Bender (Europe).gb" size 32768 crc b651bf5d sha1 9502181c62d8343b98cef9b881c29e4573e4fbc9 flags verified ) + name "Adventures of Star Saver, The (USA, Europe)" + description "Adventures of Star Saver, The (USA, Europe)" + rom ( name "Adventures of Star Saver, The (USA, Europe).gb" size 131072 crc 5d461374 sha1 408b19a92c73daa11b3b1a52aa6a987cc6615e97 flags verified ) ) game ( - name "Brain Bender (USA)" - description "Brain Bender (USA)" - rom ( name "Brain Bender (USA).gb" size 32768 crc fbb1f2a1 sha1 56ff8684284765a56918d14620ad38477aaaf0ad ) + name "Aerostar (Japan)" + description "Aerostar (Japan)" + rom ( name "Aerostar (Japan).gb" size 131072 crc dfa3b28a sha1 1088817172c10a9080ab6859da85a074569e2cba ) ) game ( - name "Brain Drain (Europe) (SGB Enhanced)" - description "Brain Drain (Europe) (SGB Enhanced)" - rom ( name "Brain Drain (Europe) (SGB Enhanced).gb" size 131072 crc 8a7fb0e6 sha1 67e1796ed410ecc19efc2f73ef7f5226414cc8bb ) + name "Aerostar (USA, Europe)" + description "Aerostar (USA, Europe)" + rom ( name "Aerostar (USA, Europe).gb" size 131072 crc f6fd275e sha1 2cb231e616008f2c809e0b2caf40f477689e6d07 flags verified ) ) game ( - name "Brain Drain (Japan) (SGB Enhanced)" - description "Brain Drain (Japan) (SGB Enhanced)" - rom ( name "Brain Drain (Japan) (SGB Enhanced).gb" size 131072 crc e558aacd sha1 225c25d94854f509611b8c0b4b415daf48d51310 ) + name "After Burst (Japan)" + description "After Burst (Japan)" + rom ( name "After Burst (Japan).gb" size 65536 crc c0049d77 sha1 459cb97524669b0de6cd7cfada61ad67339232f1 ) ) game ( - name "Brain Drain (USA) (SGB Enhanced)" - description "Brain Drain (USA) (SGB Enhanced)" - rom ( name "Brain Drain (USA) (SGB Enhanced).gb" size 131072 crc aff0b159 sha1 da11b3909bef958abc9b3b184771f4f8fe498456 ) + name "Agro Soar (Australia)" + description "Agro Soar (Australia)" + rom ( name "Agro Soar (Australia).gb" size 131072 crc 9b7945ea sha1 d635761f247301fe6bae4d71ee67ceef384ca53a flags verified ) ) game ( - name "Bram Stoker's Dracula (USA, Europe)" - description "Bram Stoker's Dracula (USA, Europe)" - rom ( name "Bram Stoker's Dracula (USA, Europe).gb" size 131072 crc 00cd1876 sha1 d31cb69613a6f0504b4f3f72c18e96b5827686b9 flags verified ) + name "Akazukin Chacha (Japan) (SGB Enhanced)" + description "Akazukin Chacha (Japan) (SGB Enhanced)" + rom ( name "Akazukin Chacha (Japan) (SGB Enhanced).gb" size 262144 crc 898609b4 sha1 d07970a7eae51aef8c4e8b4bcdd57aeed6360bdd ) ) game ( - name "BreakThru! (USA)" - description "BreakThru! (USA)" - rom ( name "BreakThru! (USA).gb" size 131072 crc 5b8f0df2 sha1 d9a49a71e6b554c2fccce08c446274e886225d50 ) + name "Akumajou Dracula - Shikkoku Taru Zensoukyoku - Dark Night Prelude (Japan) (SGB Enhanced)" + description "Akumajou Dracula - Shikkoku Taru Zensoukyoku - Dark Night Prelude (Japan) (SGB Enhanced)" + rom ( name "Akumajou Dracula - Shikkoku Taru Zensoukyoku - Dark Night Prelude (Japan) (SGB Enhanced).gb" size 262144 crc 4825b25f sha1 baaa12be322adc005e51b43c73a352420d7cd034 ) ) game ( - name "Bubble Bobble (Japan)" - description "Bubble Bobble (Japan)" - rom ( name "Bubble Bobble (Japan).gb" size 131072 crc ad9b300c sha1 3f2e741e0dbdcc65e960f44a322e85748272f3f3 ) + name "Akumajou Special - Boku Dracula-kun (Japan)" + description "Akumajou Special - Boku Dracula-kun (Japan)" + rom ( name "Akumajou Special - Boku Dracula-kun (Japan).gb" size 262144 crc e8335398 sha1 f2f15da8ed94bc8652c23965428f6d767e506e38 flags verified ) ) game ( - name "Bubble Bobble (USA, Europe)" - description "Bubble Bobble (USA, Europe)" - rom ( name "Bubble Bobble (USA, Europe).gb" size 131072 crc d516841d sha1 569881bea21cf5fd542ff3dfc40e1626c6748ceb flags verified ) + name "Aladdin (Europe) (SGB Enhanced)" + description "Aladdin (Europe) (SGB Enhanced)" + rom ( name "Aladdin (Europe) (SGB Enhanced).gb" size 262144 crc 283c58b7 sha1 a40694a808c5a0d3eeb386f81ad5b0c11163238f flags verified ) ) game ( - name "Bubble Bobble Junior (Japan)" - description "Bubble Bobble Junior (Japan)" - rom ( name "Bubble Bobble Junior (Japan).gb" size 131072 crc 39e261b9 sha1 686c526a557065dc0005068eafdbc6736684f925 ) + name "Aladdin (USA) (SGB Enhanced)" + description "Aladdin (USA) (SGB Enhanced)" + rom ( name "Aladdin (USA) (SGB Enhanced).gb" size 262144 crc af6bdc50 sha1 81b4e56ae235fbb123d7ad4bd7c1d96c3b69eb72 ) ) game ( - name "Bubble Bobble Part 2 (USA, Europe)" - description "Bubble Bobble Part 2 (USA, Europe)" - rom ( name "Bubble Bobble Part 2 (USA, Europe).gb" size 131072 crc 4106d781 sha1 e258d852713f392454d4291032ce50ad325aba86 flags verified ) + name "Aladdin (World) (Disney Classic Games) (SGB Enhanced)" + description "Aladdin (World) (Disney Classic Games) (SGB Enhanced)" + rom ( name "Aladdin (World) (Disney Classic Games) (SGB Enhanced).gb" size 262144 crc 53918941 sha1 c59c44051e41dc6ac8c2f693cff2ba1feffd32f0 flags verified ) ) game ( - name "Bubble Ghost (Japan)" - description "Bubble Ghost (Japan)" - rom ( name "Bubble Ghost (Japan).gb" size 32768 crc 874d0d6f sha1 f93e37b60025c67d7fbfc035ed727c9a39d8c9f1 ) + name "Aladdin (Europe) (Sample) (SGB Enhanced)" + description "Aladdin (Europe) (Sample) (SGB Enhanced)" + rom ( name "Aladdin (Europe) (Sample) (SGB Enhanced).gb" size 262144 crc 28827ea5 sha1 6d925762a46e1996cf3702dfb85be09f546b2137 ) ) game ( - name "Bubble Ghost (USA, Europe)" - description "Bubble Ghost (USA, Europe)" - rom ( name "Bubble Ghost (USA, Europe).gb" size 32768 crc 843068fd sha1 b08b8a9bf742f7ca4b355a866b4167741252dcf6 flags verified ) + name "Alfred Chicken (Europe) (Beta)" + description "Alfred Chicken (Europe) (Beta)" + rom ( name "Alfred Chicken (Europe) (Beta).gb" size 131072 crc 2e19f638 sha1 a9aa7cf61ffa42a4097f0c900ad4463d6fd89a19 ) ) game ( - name "Bubble Ghost (USA, Europe) (Beta)" - description "Bubble Ghost (USA, Europe) (Beta)" - rom ( name "Bubble Ghost (USA, Europe) (Beta).gb" size 32768 crc 4a083f6f sha1 f5d063c70cecadda43d27d0c24f561a8f32b10f2 ) + name "Alfred Chicken (Europe)" + description "Alfred Chicken (Europe)" + rom ( name "Alfred Chicken (Europe).gb" size 131072 crc 3cab28d9 sha1 bc7327008de518ddfad0ad5c69896921dc2378e0 flags verified ) ) game ( - name "Bubsy II (Europe)" - description "Bubsy II (Europe)" - rom ( name "Bubsy II (Europe).gb" size 262144 crc a3164516 sha1 f59306da42c5d8bbf41c870828c83bbcf1e2f0ac ) + name "Alfred Chicken (Japan) (SGB Enhanced)" + description "Alfred Chicken (Japan) (SGB Enhanced)" + rom ( name "Alfred Chicken (Japan) (SGB Enhanced).gb" size 262144 crc 1089098f sha1 e04ddf4df8b5ef70d85e0523d277abfc68c61496 ) ) game ( - name "Bubsy II (USA)" - description "Bubsy II (USA)" - rom ( name "Bubsy II (USA).gb" size 262144 crc 600a6ad5 sha1 1ac9bf5043caf428994bca3e80158ca697e94c58 ) + name "Alfred Chicken (USA)" + description "Alfred Chicken (USA)" + rom ( name "Alfred Chicken (USA).gb" size 131072 crc 3b9c3bc6 sha1 80c39d93ca58d0d6144fe7f7bdd47c3a4fcf0438 ) ) game ( - name "Bug Bites! (World) (Aftermarket) (Unl)" - description "Bug Bites! (World) (Aftermarket) (Unl)" - rom ( name "Bug Bites! (World) (Aftermarket) (Unl).gb" size 262144 crc bb473d7a sha1 8d601612ac262e4548d8b8f6ac19a04cb92ecfb7 ) + name "Alien 3 (Japan)" + description "Alien 3 (Japan)" + rom ( name "Alien 3 (Japan).gb" size 131072 crc e59049b2 sha1 4a3e7eb0edaefec096baa0019b3cba28b4796689 ) ) game ( - name "Bugs Bunny Collection (Japan) (SGB Enhanced)" - description "Bugs Bunny Collection (Japan) (SGB Enhanced)" - rom ( name "Bugs Bunny Collection (Japan) (SGB Enhanced).gb" size 262144 crc d2dbea8f sha1 4f1f56b06364272033372230cfe0819cb3e25b50 ) + name "Alien 3 (USA, Europe)" + description "Alien 3 (USA, Europe)" + rom ( name "Alien 3 (USA, Europe).gb" size 131072 crc effb960b sha1 ab4d11eee7faea42c637505469e0671c9d4a83f8 flags verified ) ) game ( - name "Bugs Bunny Collection (Japan) (Rev 1) (SGB Enhanced)" - description "Bugs Bunny Collection (Japan) (Rev 1) (SGB Enhanced)" - rom ( name "Bugs Bunny Collection (Japan) (Rev 1) (SGB Enhanced).gb" size 262144 crc 8244220b sha1 9d69d72b7de0377cb0439aa301b1fb82d3ce786a ) + name "Alien Games (USA) (Proto)" + description "Alien Games (USA) (Proto)" + rom ( name "Alien Games (USA) (Proto).gb" size 131072 crc 67a8a76f sha1 6967e6897de511df2bb03e7c805a222b653ac63f ) ) game ( - name "Bugs Bunny Crazy Castle 2, The (USA)" - description "Bugs Bunny Crazy Castle 2, The (USA)" - rom ( name "Bugs Bunny Crazy Castle 2, The (USA).gb" size 131072 crc a973e604 sha1 1e4c8c8fe8b6c34f76cd0da876442f14299da725 flags verified ) + name "Alien Olympics (Europe)" + description "Alien Olympics (Europe)" + rom ( name "Alien Olympics (Europe).gb" size 131072 crc 583c0e4e sha1 c6a69416d3f18071942d222d528b1c9d25f980b7 ) ) game ( - name "Bugs Bunny Crazy Castle, The (USA, Europe)" - description "Bugs Bunny Crazy Castle, The (USA, Europe)" - rom ( name "Bugs Bunny Crazy Castle, The (USA, Europe).gb" size 65536 crc 403e1b7e sha1 2a3e982e542a849f95b4497025ca5b04db2abe8c flags verified ) + name "Alien vs Predator (Japan)" + description "Alien vs Predator (Japan)" + rom ( name "Alien vs Predator (Japan).gb" size 131072 crc e884682b sha1 5b21dc4a7b48e75da725657d1ccde868759e5699 ) ) game ( - name "Bung Greetings Demo (World) (Demo) (Unl)" - description "Bung Greetings Demo (World) (Demo) (Unl)" - rom ( name "Bung Greetings Demo (World) (Demo) (Unl).gb" size 65536 crc 1ae05af4 sha1 bb01f845d330377749aeb6df1f7bea0eff78bb89 ) + name "Alien vs Predator - The Last of His Clan (USA)" + description "Alien vs Predator - The Last of His Clan (USA)" + rom ( name "Alien vs Predator - The Last of His Clan (USA).gb" size 131072 crc 4bbcf652 sha1 c0d39ee87b908cdbd68c59f73e5dc2a7a6ccbedc ) ) game ( - name "Bung New Year's Greetings Demo (World) (Demo) (Unl)" - description "Bung New Year's Greetings Demo (World) (Demo) (Unl)" - rom ( name "Bung New Year's Greetings Demo (World) (Demo) (Unl).gb" size 65536 crc 493d4a1e sha1 737402fe70924f893fc212393eeb7f46f225745a ) + name "All-Star Baseball 99 (USA)" + description "All-Star Baseball 99 (USA)" + rom ( name "All-Star Baseball 99 (USA).gb" size 524288 crc d51ee6d3 sha1 49d13eef514d26cee37b10ff602e21a92b87b69d ) ) game ( - name "Bung's Math Test (World) (Unl)" - description "Bung's Math Test (World) (Unl)" - rom ( name "Bung's Math Test (World) (Unl).gb" size 32768 crc ebeda9d2 sha1 68581c24793e8ea63f3273efa7bc098309d77d1a ) + name "Alleyway (World)" + description "Alleyway (World)" + rom ( name "Alleyway (World).gb" size 32768 crc 5cc01586 sha1 0cf2b8d0428f389f5361f67a0cd1ace05a1c75cc flags verified ) ) game ( - name "Burai Fighter Deluxe (USA, Europe)" - description "Burai Fighter Deluxe (USA, Europe)" - rom ( name "Burai Fighter Deluxe (USA, Europe).gb" size 65536 crc 3c86f5db sha1 178e18b7e6e65e726b4e06f80d89c55332ea868b flags verified ) + name "Altered Space - A 3-D Alien Adventure (Europe)" + description "Altered Space - A 3-D Alien Adventure (Europe)" + rom ( name "Altered Space - A 3-D Alien Adventure (Europe).gb" size 131072 crc 24d5f785 sha1 218da72e38a847bc5152a226c98e843b4941a8a6 ) ) game ( - name "Burai Senshi Deluxe (Japan)" - description "Burai Senshi Deluxe (Japan)" - rom ( name "Burai Senshi Deluxe (Japan).gb" size 65536 crc 5a1a20f3 sha1 f8c17e07d25420b7717f4415820c09491bb6a04c ) + name "Altered Space - A 3-D Alien Adventure (Japan)" + description "Altered Space - A 3-D Alien Adventure (Japan)" + rom ( name "Altered Space - A 3-D Alien Adventure (Japan).gb" size 131072 crc ce36e36e sha1 6d19dfedf2c916f13a524acfd7c4e26de040e655 ) ) game ( - name "BurgerTime Deluxe (World)" - description "BurgerTime Deluxe (World)" - rom ( name "BurgerTime Deluxe (World).gb" size 65536 crc 88219a49 sha1 1aafcef0dd5fbb8e95188631e0b2decdf84e9aed flags verified ) + name "Altered Space - A 3-D Alien Adventure (USA)" + description "Altered Space - A 3-D Alien Adventure (USA)" + rom ( name "Altered Space - A 3-D Alien Adventure (USA).gb" size 131072 crc 141675d3 sha1 ca586c59b2473a8bec2f0f37504cb74e3a1e4d11 flags verified ) ) game ( - name "Burning Paper (Japan)" - description "Burning Paper (Japan)" - rom ( name "Burning Paper (Japan).gb" size 131072 crc 88f8c991 sha1 8e2bce98cc840e52d47680f9b1e425bfc9102ac7 ) + name "Amazing Penguin (USA, Europe)" + description "Amazing Penguin (USA, Europe)" + rom ( name "Amazing Penguin (USA, Europe).gb" size 65536 crc 3011d5ca sha1 84cc6452823eb05ee38679aec86e3cc6e4a50e6f ) ) game ( - name "Bust-A-Move 2 - Arcade Edition (USA, Europe)" - description "Bust-A-Move 2 - Arcade Edition (USA, Europe)" - rom ( name "Bust-A-Move 2 - Arcade Edition (USA, Europe).gb" size 131072 crc b94724e6 sha1 6b0942c231890d3e2f6c18e7804040eb4c66dcb3 flags verified ) + name "Amazing Penguin (World) (Limited Run Games)" + description "Amazing Penguin (World) (Limited Run Games)" + rom ( name "Amazing Penguin (World) (Limited Run Games).gb" size 65536 crc 82d4664c sha1 01f11e0746a511b35b2c873d6a190f6e10204676 ) ) game ( - name "Bust-A-Move 3 DX (Europe)" - description "Bust-A-Move 3 DX (Europe)" - rom ( name "Bust-A-Move 3 DX (Europe).gb" size 131072 crc e555c612 sha1 e89dc67087205c4113a4d152347eba38204e270b ) + name "Amazing Spider-Man, The (USA, Europe)" + description "Amazing Spider-Man, The (USA, Europe)" + rom ( name "Amazing Spider-Man, The (USA, Europe).gb" size 65536 crc 2a4eafe4 sha1 0effb4580efeaa323174a960bfd521fa28a18959 flags verified ) ) game ( - name "Buster Bros. (USA)" - description "Buster Bros. (USA)" - rom ( name "Buster Bros. (USA).gb" size 131072 crc b4245ca3 sha1 0d1692ff60ef1f6a97bbfd2bf8c1548f1f7439ed ) + name "America Oudan Ultra Quiz (Japan)" + description "America Oudan Ultra Quiz (Japan)" + rom ( name "America Oudan Ultra Quiz (Japan).gb" size 262144 crc 3be275cd sha1 9761f22250faf9c241fd7f9e2d00436f3fd454e7 ) ) game ( - name "Busty Bunny the Bounty Babe (World) (v1.02) (Aftermarket) (Unl)" - description "Busty Bunny the Bounty Babe (World) (v1.02) (Aftermarket) (Unl)" - rom ( name "Busty Bunny the Bounty Babe (World) (v1.02) (Aftermarket) (Unl).gb" size 1048576 crc d0ed199c sha1 a1cbaacdf32cb8fb9a9c59fcb624c729e0ca17bf ) + name "America Oudan Ultra Quiz Part 2 (Japan)" + description "America Oudan Ultra Quiz Part 2 (Japan)" + rom ( name "America Oudan Ultra Quiz Part 2 (Japan).gb" size 262144 crc 1b3231c8 sha1 34c417f6f9db7e8021fb1af6c12f22c9b48bb723 ) ) game ( - name "Cadillac II (Japan)" - description "Cadillac II (Japan)" - rom ( name "Cadillac II (Japan).gb" size 65536 crc a6c98122 sha1 a5d405fe7b4ea23708acb3cb71104f63057df6d4 ) + name "America Oudan Ultra Quiz Part 2 (Japan) (Rev 1)" + description "America Oudan Ultra Quiz Part 2 (Japan) (Rev 1)" + rom ( name "America Oudan Ultra Quiz Part 2 (Japan) (Rev 1).gb" size 262144 crc 739c26fc sha1 cb3ed70f4d095405df2c322c528cab2a00d56557 ) ) game ( - name "Caesars Palace (Europe) (En,Fr,De,Es,It)" - description "Caesars Palace (Europe) (En,Fr,De,Es,It)" - rom ( name "Caesars Palace (Europe) (En,Fr,De,Es,It).gb" size 131072 crc 78bf3633 sha1 6d77ce1b212406ba9737dd99ffd9443a3887ef79 flags verified ) + name "America Oudan Ultra Quiz Part 3 - Champion Taikai (Japan)" + description "America Oudan Ultra Quiz Part 3 - Champion Taikai (Japan)" + rom ( name "America Oudan Ultra Quiz Part 3 - Champion Taikai (Japan).gb" size 262144 crc 80cac37c sha1 61acfb83a35b2d73fad607ddd7fc1ac49e41492e ) ) game ( - name "Caesars Palace (Japan)" - description "Caesars Palace (Japan)" - rom ( name "Caesars Palace (Japan).gb" size 131072 crc 000aaa74 sha1 2cf0e21f7be55e3246d615550c8459a3659094ef ) + name "America Oudan Ultra Quiz Part 4 (Japan)" + description "America Oudan Ultra Quiz Part 4 (Japan)" + rom ( name "America Oudan Ultra Quiz Part 4 (Japan).gb" size 262144 crc a76043c8 sha1 30184de60214b8d16d044433cd92f0b2a975e9d6 ) ) game ( - name "Caesars Palace (USA)" - description "Caesars Palace (USA)" - rom ( name "Caesars Palace (USA).gb" size 131072 crc d9f901a9 sha1 c1ed80f33fc3603edaba1bdf5c317f1a205da3dc ) + name "Amida (Japan)" + description "Amida (Japan)" + rom ( name "Amida (Japan).gb" size 32768 crc 60128aa8 sha1 2b502583aa73cb72557589791dec7e28a2d29969 ) ) game ( - name "Caesars Palace (USA) (Rev 1)" - description "Caesars Palace (USA) (Rev 1)" - rom ( name "Caesars Palace (USA) (Rev 1).gb" size 131072 crc 87a9d605 sha1 126e9ef9e975bbbc6303d5d62a379d4dbd404cf0 flags verified ) + name "Animal Breeder (Japan) (SGB Enhanced)" + description "Animal Breeder (Japan) (SGB Enhanced)" + rom ( name "Animal Breeder (Japan) (SGB Enhanced).gb" size 524288 crc c2eec22f sha1 a34b7c4acc4454d96f93a7b04069adbcc3bc75a0 flags verified ) ) game ( - name "Caihong Zhanshi - Rainbow Prince (Taiwan) (Unl)" - description "Caihong Zhanshi - Rainbow Prince (Taiwan) (Unl)" - rom ( name "Caihong Zhanshi - Rainbow Prince (Taiwan) (Unl).gb" size 131072 crc 7c80ea40 sha1 13b5bbe649f4b679596df83589af6f6482997726 ) + name "Animal Breeder 2 (Japan) (SGB Enhanced)" + description "Animal Breeder 2 (Japan) (SGB Enhanced)" + rom ( name "Animal Breeder 2 (Japan) (SGB Enhanced).gb" size 524288 crc 8d573f37 sha1 214d75221dbfb1a562740aa53e0239a73bee9a2d flags verified ) ) game ( - name "Calculator (Unknown) (Proto)" - description "Calculator (Unknown) (Proto)" - rom ( name "Calculator (Unknown) (Proto).gb" size 32768 crc dce47d39 sha1 fb21bbf3cacc52a81bbe0c7d33280e8d703f0fcc ) + name "Animaniacs (Europe) (SGB Enhanced)" + description "Animaniacs (Europe) (SGB Enhanced)" + rom ( name "Animaniacs (Europe) (SGB Enhanced).gb" size 262144 crc 7b23e05c sha1 031421f49f98a15187012dc3f15960b260b9979f flags verified ) ) game ( - name "Capcom Quiz - Hatena no Daibouken (Japan)" - description "Capcom Quiz - Hatena no Daibouken (Japan)" - rom ( name "Capcom Quiz - Hatena no Daibouken (Japan).gb" size 262144 crc 8042afc5 sha1 168583ea18e02647f0b35f9bd0365e37bec076cc ) + name "Animaniacs (USA) (SGB Enhanced)" + description "Animaniacs (USA) (SGB Enhanced)" + rom ( name "Animaniacs (USA) (SGB Enhanced).gb" size 262144 crc 673c815d sha1 a0732f81e0c4f1bba592563bdc0eaae9d759ef28 flags verified ) ) game ( - name "Captain America and the Avengers (USA)" - description "Captain America and the Avengers (USA)" - rom ( name "Captain America and the Avengers (USA).gb" size 131072 crc c762b783 sha1 a067c4e20642a6c17f35a855e2d4815470fc6c6b ) + name "Another Bible (Japan) (SGB Enhanced)" + description "Another Bible (Japan) (SGB Enhanced)" + rom ( name "Another Bible (Japan) (SGB Enhanced).gb" size 524288 crc 4a486435 sha1 6a5d0da889247169135665dc91f153305e1c71b6 ) ) game ( - name "Captain Tsubasa J - Zenkoku Seiha e no Chousen (Japan) (SGB Enhanced)" - description "Captain Tsubasa J - Zenkoku Seiha e no Chousen (Japan) (SGB Enhanced)" - rom ( name "Captain Tsubasa J - Zenkoku Seiha e no Chousen (Japan) (SGB Enhanced).gb" size 524288 crc 33a1e1cf sha1 d3f9c5700389f7a876a4a821db1f99e7da4a6f68 ) + name "Aoki Densetsu Shoot! (Japan) (SGB Enhanced)" + description "Aoki Densetsu Shoot! (Japan) (SGB Enhanced)" + rom ( name "Aoki Densetsu Shoot! (Japan) (SGB Enhanced).gb" size 262144 crc 08727760 sha1 95574e1eef5fbebde6f068091bc7298000ea2397 ) ) game ( - name "Captain Tsubasa VS (Japan)" - description "Captain Tsubasa VS (Japan)" - rom ( name "Captain Tsubasa VS (Japan).gb" size 262144 crc a795e851 sha1 1d48763a64c127b7ecff9876f20ae0761347b4c7 ) + name "Aprilia - DiTech Interface (Unknown) (Unl) [b]" + description "Aprilia - DiTech Interface (Unknown) (Unl) [b]" + rom ( name "Aprilia - DiTech Interface (Unknown) (Unl) [b].gb" size 262144 crc 2e47d2d3 sha1 a921679b79191991eb75de3b6b21443f322a3699 flags baddump ) ) game ( - name "Card Game (Japan)" - description "Card Game (Japan)" - rom ( name "Card Game (Japan).gb" size 65536 crc d05f4c90 sha1 9ac64030c1e1ca89828ea54ac1fb0d884d6d92bb ) + name "Arcade Classic No. 1 - Asteroids & Missile Command (USA, Europe) (SGB Enhanced)" + description "Arcade Classic No. 1 - Asteroids & Missile Command (USA, Europe) (SGB Enhanced)" + rom ( name "Arcade Classic No. 1 - Asteroids & Missile Command (USA, Europe) (SGB Enhanced).gb" size 131072 crc 8259ac54 sha1 a4849175191c44d878aff9ef1a86c3fe5e22e266 flags verified ) ) game ( - name "Card Games (USA) (Proto)" - description "Card Games (USA) (Proto)" - rom ( name "Card Games (USA) (Proto).gb" size 65536 crc 8217204a sha1 a5a260c56ab07f88a9c942fa06c7e67c9c1ea244 ) + name "Arcade Classic No. 2 - Centipede & Millipede (USA, Europe) (SGB Enhanced)" + description "Arcade Classic No. 2 - Centipede & Millipede (USA, Europe) (SGB Enhanced)" + rom ( name "Arcade Classic No. 2 - Centipede & Millipede (USA, Europe) (SGB Enhanced).gb" size 131072 crc b14c3b31 sha1 405bc3736cfbea3f2259ad3e53a9d64c6523de4a flags verified ) ) game ( - name "Casino FunPak (USA, Europe)" - description "Casino FunPak (USA, Europe)" - rom ( name "Casino FunPak (USA, Europe).gb" size 131072 crc 8641ba55 sha1 4418a8b2029f431efd8888817589af6c8b0e76cc flags verified ) + name "Arcade Classic No. 3 - Galaga & Galaxian (Europe) (SGB Enhanced)" + description "Arcade Classic No. 3 - Galaga & Galaxian (Europe) (SGB Enhanced)" + rom ( name "Arcade Classic No. 3 - Galaga & Galaxian (Europe) (SGB Enhanced).gb" size 131072 crc d06b3f8a sha1 59ea594af8520732f78c337f5c96a5ba2bddf1cb flags verified ) ) game ( - name "Casper (Europe)" - description "Casper (Europe)" - rom ( name "Casper (Europe).gb" size 131072 crc e4b30634 sha1 1a3d272d8afe81731862a240a77c0d3b80b1d62f ) + name "Arcade Classic No. 3 - Galaga & Galaxian (USA) (SGB Enhanced)" + description "Arcade Classic No. 3 - Galaga & Galaxian (USA) (SGB Enhanced)" + rom ( name "Arcade Classic No. 3 - Galaga & Galaxian (USA) (SGB Enhanced).gb" size 131072 crc 6a6ecfec sha1 739671d6cf151fa5527d68f78345197d278cdf19 flags verified ) ) game ( - name "Casper (USA)" - description "Casper (USA)" - rom ( name "Casper (USA).gb" size 131072 crc e67a10e1 sha1 18b90172789c87819fe4d606aa7874109bcd8024 ) + name "Arcade Classic No. 4 - Defender & Joust (USA, Europe) (SGB Enhanced)" + description "Arcade Classic No. 4 - Defender & Joust (USA, Europe) (SGB Enhanced)" + rom ( name "Arcade Classic No. 4 - Defender & Joust (USA, Europe) (SGB Enhanced).gb" size 131072 crc 1c829ce3 sha1 6b046ca1e15e6cecb29e086a5b23eb0019419936 flags verified ) ) game ( - name "Casper (USA) (Beta)" - description "Casper (USA) (Beta)" - rom ( name "Casper (USA) (Beta).gb" size 131072 crc e0ab72fb sha1 1d036bed67da4dc57add0e9e266fbdb993778823 ) + name "Arcade Classics - Super Breakout & Battlezone (USA, Europe) (SGB Enhanced)" + description "Arcade Classics - Super Breakout & Battlezone (USA, Europe) (SGB Enhanced)" + rom ( name "Arcade Classics - Super Breakout & Battlezone (USA, Europe) (SGB Enhanced).gb" size 262144 crc 6c292739 sha1 7d78b06ad896fb949e28858d141f73a37c550fe2 ) ) game ( - name "Castelian (USA) (Beta)" - description "Castelian (USA) (Beta)" - rom ( name "Castelian (USA) (Beta).gb" size 32768 crc a08cb239 sha1 0c69cee488d7589c6bf0a1b7e2c3d20f2b4d3042 ) + name "Aretha (Japan)" + description "Aretha (Japan)" + rom ( name "Aretha (Japan).gb" size 131072 crc 1db65649 sha1 eab8f13d110634f4ee750ac93e4f25d91a85000f flags verified ) ) game ( - name "Castelian (Europe)" - description "Castelian (Europe)" - rom ( name "Castelian (Europe).gb" size 32768 crc 2f752404 sha1 6720d86d420831a0a4865d4a59c4ba6fe98fa34d flags verified ) + name "Aretha II (Japan)" + description "Aretha II (Japan)" + rom ( name "Aretha II (Japan).gb" size 262144 crc 086e4fc5 sha1 5634a05ea8e93af3dd0e41823576bf6295f8df1f ) ) game ( - name "Castelian (USA)" - description "Castelian (USA)" - rom ( name "Castelian (USA).gb" size 32768 crc f2d739e4 sha1 a03982e2ffa9aa368fe11bc09f024207bada45eb ) + name "Aretha III (Japan)" + description "Aretha III (Japan)" + rom ( name "Aretha III (Japan).gb" size 262144 crc 430d3d6b sha1 f57ff26d31283c88cc4c414b18ef6f182d07da9d ) ) game ( - name "Castle Quest (Europe)" - description "Castle Quest (Europe)" - rom ( name "Castle Quest (Europe).gb" size 131072 crc 2f8aaf6f sha1 45b38a334481f620bb7165fee81391036a54a748 ) + name "Asmik-kun World 2 (Japan)" + description "Asmik-kun World 2 (Japan)" + rom ( name "Asmik-kun World 2 (Japan).gb" size 131072 crc caae6b11 sha1 4c738153a5c9f861117cc23cfedf2c37672e1097 ) ) game ( - name "Castle Quest (Europe) (Beta)" - description "Castle Quest (Europe) (Beta)" - rom ( name "Castle Quest (Europe) (Beta).gb" size 131072 crc 8a5636ea sha1 356c8510b0647e56a558aba9d5dc4cc9d3ccd94c ) + name "Asterix (Europe) (En,Fr,De,Es,It)" + description "Asterix (Europe) (En,Fr,De,Es,It)" + rom ( name "Asterix (Europe) (En,Fr,De,Es,It).gb" size 131072 crc 097ffe2c sha1 7d4ca6925826c0ffca3e3004479b5e9a5b6b311b flags verified ) ) game ( - name "Castledark (World) (v2.0) (Demo) (Aftermarket) (Unl)" - description "Castledark (World) (v2.0) (Demo) (Aftermarket) (Unl)" - rom ( name "Castledark (World) (v2.0) (Demo) (Aftermarket) (Unl).gb" size 524288 crc 3c492b31 sha1 0861af0039dab4b4f5bce747c6fcd586eced401a ) + name "Asterix (USA) (Proto 3)" + description "Asterix (USA) (Proto 3)" + rom ( name "Asterix (USA) (Proto 3).gb" size 131072 crc a4cc3c3a sha1 54cd67ea3c3e7646fb5286a6274a40a77f0730cc ) ) game ( - name "Castlevania - The Adventure (USA) (Castlevania Anniversary Collection)" - description "Castlevania - The Adventure (USA) (Castlevania Anniversary Collection)" - rom ( name "Castlevania - The Adventure (USA) (Castlevania Anniversary Collection).gb" size 65536 crc 548ce311 sha1 0d1a75cf0e6e7f6b106cfed7aa0b716daf5f9dc8 flags verified ) + name "Asterix (USA) (Proto 1)" + description "Asterix (USA) (Proto 1)" + rom ( name "Asterix (USA) (Proto 1).gb" size 32768 crc 6ccfee1f sha1 5077f422e513877e9c4e3497111f853376748826 ) ) game ( - name "Castlevania - The Adventure (Europe)" - description "Castlevania - The Adventure (Europe)" - rom ( name "Castlevania - The Adventure (Europe).gb" size 65536 crc 6977c265 sha1 d54888039344597fa038f2c5eedc0726dd35cc46 flags verified ) + name "Asterix (USA) (Proto 2)" + description "Asterix (USA) (Proto 2)" + rom ( name "Asterix (USA) (Proto 2).gb" size 32768 crc 0050b16f sha1 5e2423d1d4a1239af2ccafdd6c0a3f2316ae6b51 ) ) game ( - name "Castlevania - The Adventure (USA)" - description "Castlevania - The Adventure (USA)" - rom ( name "Castlevania - The Adventure (USA).gb" size 65536 crc 216e6aa1 sha1 fd9116efcd8eb9698f483cc5745f83b3674d7d13 flags verified ) + name "Asterix & Obelix (Europe) (Fr,De) (Beta) (SGB Enhanced)" + description "Asterix & Obelix (Europe) (Fr,De) (Beta) (SGB Enhanced)" + rom ( name "Asterix & Obelix (Europe) (Fr,De) (Beta) (SGB Enhanced).gb" size 262144 crc bfa1d7be sha1 70472cbe59cfd426b0969150085cc97d31bd6470 ) ) game ( - name "Castlevania II - Belmont's Revenge (USA, Europe)" - description "Castlevania II - Belmont's Revenge (USA, Europe)" - rom ( name "Castlevania II - Belmont's Revenge (USA, Europe).gb" size 131072 crc 8875c8fe sha1 696b9ad1e9cfb7112977c9a7c05cf64fe8423d8a flags verified ) + name "Asterix & Obelix (Spain) (En,Es) (SGB Enhanced)" + description "Asterix & Obelix (Spain) (En,Es) (SGB Enhanced)" + rom ( name "Asterix & Obelix (Spain) (En,Es) (SGB Enhanced).gb" size 262144 crc b1fd41d0 sha1 b6cd446962357d0f560a5c9fae4c917e039fbb77 flags verified ) ) game ( - name "Castlevania II - Belmont's Revenge (USA, Europe) (Castlevania Anniversary Collection)" - description "Castlevania II - Belmont's Revenge (USA, Europe) (Castlevania Anniversary Collection)" - rom ( name "Castlevania II - Belmont's Revenge (USA, Europe) (Castlevania Anniversary Collection).gb" size 131072 crc bd28ba07 sha1 823e3c0f2de29f1f2548a9c4f74a956fb39dd3b8 flags verified ) + name "Asterix & Obelix (Europe) (Fr,De) (SGB Enhanced)" + description "Asterix & Obelix (Europe) (Fr,De) (SGB Enhanced)" + rom ( name "Asterix & Obelix (Europe) (Fr,De) (SGB Enhanced).gb" size 262144 crc 5143e227 sha1 ebc68b180680c7037b151b9a1b511b681499ba30 flags verified ) ) game ( - name "Castlevania Legends (USA, Europe) (SGB Enhanced)" - description "Castlevania Legends (USA, Europe) (SGB Enhanced)" - rom ( name "Castlevania Legends (USA, Europe) (SGB Enhanced).gb" size 262144 crc ad9c17fb sha1 91a8e49bf6eac5fe62ec2cc5e6decbd08ce9b515 flags verified ) + name "Asteroids (USA, Europe)" + description "Asteroids (USA, Europe)" + rom ( name "Asteroids (USA, Europe).gb" size 32768 crc c1f88833 sha1 435dbdaa9b9d2e0d0bc7c1c010cdc5ec9bd9f359 ) ) game ( - name "Catrap (USA)" - description "Catrap (USA)" - rom ( name "Catrap (USA).gb" size 32768 crc adb96150 sha1 171e4d54f22f8dc137d12828fcc2da9874c56970 ) + name "Asteroids (USA, Europe) (Beta)" + description "Asteroids (USA, Europe) (Beta)" + rom ( name "Asteroids (USA, Europe) (Beta).gb" size 32768 crc eb31e472 sha1 28f4e2a076bfe5f7a77f695332705ea0085fccfb ) ) game ( - name "Catrap (USA) (Beta)" - description "Catrap (USA) (Beta)" - rom ( name "Catrap (USA) (Beta).gb" size 32768 crc ca3bc888 sha1 928b9b3cb2ed5e6d6fc754679b3c994f7ed803c3 ) + name "Astro Rabby (Japan)" + description "Astro Rabby (Japan)" + rom ( name "Astro Rabby (Japan).gb" size 65536 crc 61e48eef sha1 3e53fd25f350c78a29e0642ee6de80208930d469 ) ) game ( - name "Cave Fighter (World) (Aftermarket) (Unl)" - description "Cave Fighter (World) (Aftermarket) (Unl)" - rom ( name "Cave Fighter (World) (Aftermarket) (Unl).gb" size 262144 crc e8f91f6a sha1 290048717d0a8cabb3cc591161339550eb53c161 ) + name "Atomic Punk (USA)" + description "Atomic Punk (USA)" + rom ( name "Atomic Punk (USA).gb" size 131072 crc c4720897 sha1 4b364b4c12b83ab7adbec074fac951e2eb63dea8 ) ) game ( - name "Cave Noire (Japan)" - description "Cave Noire (Japan)" - rom ( name "Cave Noire (Japan).gb" size 131072 crc 44256a2f sha1 6acdf05aac8e3792a98a199cb6e90180e95230cd ) + name "Attack of the Killer Tomatoes (Japan)" + description "Attack of the Killer Tomatoes (Japan)" + rom ( name "Attack of the Killer Tomatoes (Japan).gb" size 131072 crc 23068679 sha1 96cd454513dfb363cda20bf0e72c6d74132a9487 ) ) game ( - name "Centipede (USA) (Majesco)" - description "Centipede (USA) (Majesco)" - rom ( name "Centipede (USA) (Majesco).gb" size 131072 crc e957014f sha1 a3a5755020c9cbe13fc1a815288830d2e143367f ) + name "Attack of the Killer Tomatoes (USA, Europe)" + description "Attack of the Killer Tomatoes (USA, Europe)" + rom ( name "Attack of the Killer Tomatoes (USA, Europe).gb" size 131072 crc b5b38860 sha1 cbbba5d4f80f2b4ab3e882ceb4f79c293a17904f flags verified ) ) game ( - name "Centipede (USA, Europe) (Accolade)" - description "Centipede (USA, Europe) (Accolade)" - rom ( name "Centipede (USA, Europe) (Accolade).gb" size 32768 crc 245afcdc sha1 0106c3dc8016398e9d24e2472c867487c3bd376f flags verified ) + name "Avenging Spirit (USA, Europe)" + description "Avenging Spirit (USA, Europe)" + rom ( name "Avenging Spirit (USA, Europe).gb" size 262144 crc cf2ba5f7 sha1 d22cca80a0855d7724539ef71f38e3f8f9656d6b flags verified ) ) game ( - name "Chachamaru Boukenki 3 - Abyss no Tou (Japan)" - description "Chachamaru Boukenki 3 - Abyss no Tou (Japan)" - rom ( name "Chachamaru Boukenki 3 - Abyss no Tou (Japan).gb" size 131072 crc 9dfd4bc0 sha1 9a92ccc5758506a7ad07d251bf6c401fe33ad215 ) + name "Ayakashi no Shiro (Japan)" + description "Ayakashi no Shiro (Japan)" + rom ( name "Ayakashi no Shiro (Japan).gb" size 65536 crc da90f5fc sha1 dad3ec1a054cbd092eedfdb1d742b811c105181a flags verified ) ) game ( - name "Chachamaru Panic (Japan)" - description "Chachamaru Panic (Japan)" - rom ( name "Chachamaru Panic (Japan).gb" size 65536 crc aa920298 sha1 c6cbb08d3bb9a4deccf1df880465ce5d23907839 ) + name "B.C. Kid (Europe)" + description "B.C. Kid (Europe)" + rom ( name "B.C. Kid (Europe).gb" size 262144 crc 373343e6 sha1 b91f99408e4a6b69d505f304c176434321f837e7 flags verified ) ) game ( - name "Chalvo 55 - Super Puzzle Action (Japan)" - description "Chalvo 55 - Super Puzzle Action (Japan)" - rom ( name "Chalvo 55 - Super Puzzle Action (Japan).gb" size 524288 crc 74d50b47 sha1 55aad975351670c3f632e1ebcc939c48410d29b3 flags verified ) + name "B.C. Kid 2 (Europe) (SGB Enhanced)" + description "B.C. Kid 2 (Europe) (SGB Enhanced)" + rom ( name "B.C. Kid 2 (Europe) (SGB Enhanced).gb" size 262144 crc c28ef062 sha1 952a14298dcde28975f2cdd61f781000afb53125 ) ) game ( - name "Championship Pool (USA)" - description "Championship Pool (USA)" - rom ( name "Championship Pool (USA).gb" size 131072 crc ef02beb6 sha1 5698fa095f737a4345f02649b4b0b96ad66660d0 flags verified ) + name "B.C. Kid 2 (Europe) (Beta) (SGB Enhanced)" + description "B.C. Kid 2 (Europe) (Beta) (SGB Enhanced)" + rom ( name "B.C. Kid 2 (Europe) (Beta) (SGB Enhanced).gb" size 262144 crc 11ffc359 sha1 dc70ba06fb2690c1b7e66963cc07da704f7a6d26 ) ) game ( - name "Chase H.Q. (USA, Europe)" - description "Chase H.Q. (USA, Europe)" - rom ( name "Chase H.Q. (USA, Europe).gb" size 131072 crc 67a45d19 sha1 cbcd6254b1b0227ba6aa8d95c979abb7fe8e4d38 flags verified ) + name "Baby T-Rex (Europe)" + description "Baby T-Rex (Europe)" + rom ( name "Baby T-Rex (Europe).gb" size 131072 crc 3f73fe7a sha1 30042c3fc60df0da25fa3db3955a2e4657c1cccf ) ) game ( - name "Cheesy Town (World) (En,Ja) (Aftermarket) (Unl)" - description "Cheesy Town (World) (En,Ja) (Aftermarket) (Unl)" - rom ( name "Cheesy Town (World) (En,Ja) (Aftermarket) (Unl).gb" size 262144 crc 3e20c1a8 sha1 f76645a2830fcc733b7392a52112df628f0b7a4a ) + name "Baby's Day Out (USA) (Proto)" + description "Baby's Day Out (USA) (Proto)" + rom ( name "Baby's Day Out (USA) (Proto).gb" size 262144 crc 343f01ce sha1 d06b433a5d355490ebae150a45c47b0c5bce9087 ) ) game ( - name "Cherry Rescue! (World) (Aftermarket) (Unl)" - description "Cherry Rescue! (World) (Aftermarket) (Unl)" - rom ( name "Cherry Rescue! (World) (Aftermarket) (Unl).gb" size 524288 crc ba65812a sha1 740dba1827c730cc5d8bf67495bcede3a5352643 ) + name "Bakenou TV '94 (Japan) (SGB Enhanced)" + description "Bakenou TV '94 (Japan) (SGB Enhanced)" + rom ( name "Bakenou TV '94 (Japan) (SGB Enhanced).gb" size 131072 crc d1c3f371 sha1 c567bdd1ca17750c853019f244e208fe812772fd ) ) game ( - name "Chessmaster, The (Europe)" - description "Chessmaster, The (Europe)" - rom ( name "Chessmaster, The (Europe).gb" size 65536 crc 02852e24 sha1 26f1d9cbb392ff07eafb8cd59526470849de9f38 flags verified ) + name "Bakenou V3 (Japan)" + description "Bakenou V3 (Japan)" + rom ( name "Bakenou V3 (Japan).gb" size 131072 crc 4e2fffe5 sha1 b1bf86f4ffb9af9c5f1c592f0cabedb95b405437 flags verified ) ) game ( - name "Chessmaster, The (Japan)" - description "Chessmaster, The (Japan)" - rom ( name "Chessmaster, The (Japan).gb" size 65536 crc 82150e4a sha1 092d878bb8431ac1334dfa9cb91c4b12f1a4f365 ) + name "Bakuchou Retrieve Master (Japan) (SGB Enhanced)" + description "Bakuchou Retrieve Master (Japan) (SGB Enhanced)" + rom ( name "Bakuchou Retrieve Master (Japan) (SGB Enhanced).gb" size 524288 crc 8a546dec sha1 bfea17b22b3ac91366156d8db1a7dc619c7b5a28 ) ) game ( - name "Chessmaster, The (USA, Europe)" - description "Chessmaster, The (USA, Europe)" - rom ( name "Chessmaster, The (USA, Europe).gb" size 65536 crc 0c1d2b68 sha1 0e167c8ba379103775ae8e18ec9e0b819bdd5897 flags verified ) + name "Bakuchou Retsuden Shou - Hyper Fishing (Japan) (SGB Enhanced)" + description "Bakuchou Retsuden Shou - Hyper Fishing (Japan) (SGB Enhanced)" + rom ( name "Bakuchou Retsuden Shou - Hyper Fishing (Japan) (SGB Enhanced).gb" size 524288 crc ab3477c4 sha1 53808f56fa68ad8094d0e4ff62e06887b439be9a ) ) game ( - name "Chessmaster, The (USA) (Rev 1)" - description "Chessmaster, The (USA) (Rev 1)" - rom ( name "Chessmaster, The (USA) (Rev 1).gb" size 65536 crc 59ed370c sha1 f0351faab8b912967552684d4160f5cf94540d41 ) + name "Bakuretsu Senshi Warrior (Japan)" + description "Bakuretsu Senshi Warrior (Japan)" + rom ( name "Bakuretsu Senshi Warrior (Japan).gb" size 65536 crc ecf1b801 sha1 5f4e63796611a1ed72acd2a5bfe2e2ea3ba5b211 flags verified ) ) game ( - name "Chibi Maruko-chan - Maruko Deluxe Theater (Japan) (SGB Enhanced)" - description "Chibi Maruko-chan - Maruko Deluxe Theater (Japan) (SGB Enhanced)" - rom ( name "Chibi Maruko-chan - Maruko Deluxe Theater (Japan) (SGB Enhanced).gb" size 131072 crc 886049f9 sha1 0e774a12ed2d99b5a62a5ad3f634f2c32da5929a ) + name "Balloon Kid (USA, Europe)" + description "Balloon Kid (USA, Europe)" + rom ( name "Balloon Kid (USA, Europe).gb" size 131072 crc d4b655ec sha1 0cb5adc9bdef5320f3f156efed0d47a618e2299f flags verified ) ) game ( - name "Chibi Maruko-chan - Okozukai Daisakusen! (Japan)" - description "Chibi Maruko-chan - Okozukai Daisakusen! (Japan)" - rom ( name "Chibi Maruko-chan - Okozukai Daisakusen! (Japan).gb" size 65536 crc eab175ff sha1 1b6838b9711ecbc6c09606da53d53309593103b2 ) + name "Bamse (Sweden)" + description "Bamse (Sweden)" + rom ( name "Bamse (Sweden).gb" size 131072 crc 1b713de0 sha1 92c042a1b3b9704736b6d8b19259efc5110c267d flags verified ) ) game ( - name "Chibi Maruko-chan 2 - Deluxe Maruko World (Japan)" - description "Chibi Maruko-chan 2 - Deluxe Maruko World (Japan)" - rom ( name "Chibi Maruko-chan 2 - Deluxe Maruko World (Japan).gb" size 131072 crc abff3314 sha1 4fd5eb092086ed62aa978eacc1c3904c921f9615 ) + name "Banishing Racer (Japan)" + description "Banishing Racer (Japan)" + rom ( name "Banishing Racer (Japan).gb" size 131072 crc 3d13ec6a sha1 df121645c367d5809ed77bfe48aa537f0d61d276 ) ) game ( - name "Chibi Maruko-chan 3 - Mezase! Game Taishou no Maki (Japan)" - description "Chibi Maruko-chan 3 - Mezase! Game Taishou no Maki (Japan)" - rom ( name "Chibi Maruko-chan 3 - Mezase! Game Taishou no Maki (Japan).gb" size 131072 crc 44e933c8 sha1 127fa75126fbd45ea0e3f95f862fbd4f8182780e ) + name "Barbie - Game Girl (USA, Europe)" + description "Barbie - Game Girl (USA, Europe)" + rom ( name "Barbie - Game Girl (USA, Europe).gb" size 131072 crc 94c26cdf sha1 6660e4457a1de3de1947a90c5ea9ff012d50336e flags verified ) ) game ( - name "Chibi Maruko-chan 4 - Kore ga Nihon Da yo! Ouji-sama (Japan)" - description "Chibi Maruko-chan 4 - Kore ga Nihon Da yo! Ouji-sama (Japan)" - rom ( name "Chibi Maruko-chan 4 - Kore ga Nihon Da yo! Ouji-sama (Japan).gb" size 131072 crc e55138be sha1 a4b268924e2fb500b8b13461a9cb20aec648a52f ) + name "Barbie - Game Girl (USA) (Beta)" + description "Barbie - Game Girl (USA) (Beta)" + rom ( name "Barbie - Game Girl (USA) (Beta).gb" size 131072 crc 4660e0ab sha1 24886a5f26f1969e595f420bf963439ba6a693bd ) ) game ( - name "Chiki Chiki Machine Mou Race (Japan)" - description "Chiki Chiki Machine Mou Race (Japan)" - rom ( name "Chiki Chiki Machine Mou Race (Japan).gb" size 131072 crc 7e40044a sha1 45963623bc09e0a132867e1a78173b2c747c3b6f ) + name "Bart no Survival Camp (Japan)" + description "Bart no Survival Camp (Japan)" + rom ( name "Bart no Survival Camp (Japan).gb" size 131072 crc 0fd66b1a sha1 f0d855bba656b628c7dd9ed9e586853be75b790f ) ) game ( - name "Chiki Chiki Tengoku (Japan)" - description "Chiki Chiki Tengoku (Japan)" - rom ( name "Chiki Chiki Tengoku (Japan).gb" size 32768 crc eb33f601 sha1 56012e7f9150ec8f9117b0540dcbd2bf82c948bb ) + name "Bart Simpson's Escape from Camp Deadly (USA, Europe)" + description "Bart Simpson's Escape from Camp Deadly (USA, Europe)" + rom ( name "Bart Simpson's Escape from Camp Deadly (USA, Europe).gb" size 131072 crc 5546a382 sha1 89b7b2d4684d703ea5d323e3aaf4910dcdbc47d3 flags verified ) ) game ( - name "Chikyuu Kaihou Gun ZAS (Japan) (En)" - description "Chikyuu Kaihou Gun ZAS (Japan) (En)" - rom ( name "Chikyuu Kaihou Gun ZAS (Japan) (En).gb" size 131072 crc 7bfd1cff sha1 2ff6d0242d845669445e3d97fffae5c5f7943cfd ) + name "Baseball (World)" + description "Baseball (World)" + rom ( name "Baseball (World).gb" size 65536 crc 6eea2526 sha1 bb613ed8d492d49db35370bec38d9f2515dc24c9 flags verified ) ) game ( - name "Choplifter II (Japan)" - description "Choplifter II (Japan)" - rom ( name "Choplifter II (Japan).gb" size 131072 crc 5109f484 sha1 9392ffc6831d5f029f5ad906af40b607b8eb221b ) + name "Baseball Kids (Japan)" + description "Baseball Kids (Japan)" + rom ( name "Baseball Kids (Japan).gb" size 131072 crc a503cb07 sha1 e4a49a9ecd7a9ce8bb552981e90903f21c741428 ) ) game ( - name "Choplifter II - Rescue & Survive (Europe)" - description "Choplifter II - Rescue & Survive (Europe)" - rom ( name "Choplifter II - Rescue & Survive (Europe).gb" size 131072 crc 5e2e4e19 sha1 08f5cdbcb650be51fe3998a28174e40997618349 flags verified ) + name "Bases Loaded (USA)" + description "Bases Loaded (USA)" + rom ( name "Bases Loaded (USA).gb" size 131072 crc d37a2fdf sha1 5220db2e87622648caeacdfb8d4f564c9bf479fc flags verified ) ) game ( - name "Choplifter II - Rescue & Survive (USA)" - description "Choplifter II - Rescue & Survive (USA)" - rom ( name "Choplifter II - Rescue & Survive (USA).gb" size 131072 crc 9c7d5e79 sha1 76ef770b9c75485cc29869fca6118887aee208da ) + name "Bass Fishing Tatsujin Techou (Japan)" + description "Bass Fishing Tatsujin Techou (Japan)" + rom ( name "Bass Fishing Tatsujin Techou (Japan).gb" size 524288 crc 7625e5a5 sha1 503a4cdd6d80ce779ba293022b21f98881af2ab6 ) ) game ( - name "Choplifter III (Europe)" - description "Choplifter III (Europe)" - rom ( name "Choplifter III (Europe).gb" size 131072 crc 1b3b46ef sha1 fb1c83ee69fa32c26cdc7031733f17b90cdb0570 flags verified ) + name "Bataille Navale (France) (En,Fr,De,Es)" + description "Bataille Navale (France) (En,Fr,De,Es)" + rom ( name "Bataille Navale (France) (En,Fr,De,Es).gb" size 131072 crc bab8b727 sha1 5c5162743546b258cc9c6316f1437137721f5e99 ) ) game ( - name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (SGB Enhanced)" - description "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (SGB Enhanced)" - rom ( name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (SGB Enhanced).gb" size 524288 crc b3e8028d sha1 66e8df39ac137fe2b92581f2d88adfa0b0c3ac14 flags verified ) + name "Batman - Return of the Joker (Japan)" + description "Batman - Return of the Joker (Japan)" + rom ( name "Batman - Return of the Joker (Japan).gb" size 131072 crc de459a47 sha1 149586120c3ae9c9614fa6e6a5e298cceae16c4d ) ) game ( - name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (Beta) (SGB Enhanced)" - description "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (Beta) (SGB Enhanced)" - rom ( name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (Beta) (SGB Enhanced).gb" size 524288 crc e6c3a473 sha1 ac2360d790c855fde91fca26ee88a4814a1f2e9f ) + name "Batman - Return of the Joker (USA, Europe)" + description "Batman - Return of the Joker (USA, Europe)" + rom ( name "Batman - Return of the Joker (USA, Europe).gb" size 131072 crc 5124bbec sha1 345a332175f58304f91111a13b770662e5ea92c3 ) ) game ( - name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster 2 (Japan) (SGB Enhanced)" - description "Chou Mashin Eiyuu Den Wataru - Mazekko Monster 2 (Japan) (SGB Enhanced)" - rom ( name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster 2 (Japan) (SGB Enhanced).gb" size 524288 crc e5520693 sha1 54d2672d9720fa4322a7a45244aa898d321c1dd1 ) + name "Batman - The Animated Series (USA, Europe)" + description "Batman - The Animated Series (USA, Europe)" + rom ( name "Batman - The Animated Series (USA, Europe).gb" size 131072 crc c8e578bf sha1 4a8c1dd74b1279c0dc85ac2bebb5db2795cb67b0 flags verified ) ) game ( - name "Chousoku Spinner (Japan) (SGB Enhanced)" - description "Chousoku Spinner (Japan) (SGB Enhanced)" - rom ( name "Chousoku Spinner (Japan) (SGB Enhanced).gb" size 524288 crc b4fa9cf2 sha1 057a3251bbb7eb4e04b01f786bd2986af5eabc58 ) + name "Batman - The Video Game (World)" + description "Batman - The Video Game (World)" + rom ( name "Batman - The Video Game (World).gb" size 131072 crc 6c41d3cd sha1 ef7d6684a0f737c01a1f2cc2c6609e0f3ac1310e flags verified ) ) game ( - name "Christmas Carols (World) (Aftermarket) (Unl)" - description "Christmas Carols (World) (Aftermarket) (Unl)" - rom ( name "Christmas Carols (World) (Aftermarket) (Unl).gb" size 262144 crc a00bb310 sha1 e19b0a698d8194467d57c00664f00f9898ee5368 ) + name "Batman Forever (Japan)" + description "Batman Forever (Japan)" + rom ( name "Batman Forever (Japan).gb" size 262144 crc c2fd6244 sha1 4fab046d18addafbc625fe4cefec37098747d716 ) ) game ( - name "Chuck Rock (USA, Europe)" - description "Chuck Rock (USA, Europe)" - rom ( name "Chuck Rock (USA, Europe).gb" size 131072 crc c5951d9e sha1 601453f98ba7d92ebe71f3e86952a584cbea090c ) + name "Batman Forever (USA, Europe)" + description "Batman Forever (USA, Europe)" + rom ( name "Batman Forever (USA, Europe).gb" size 262144 crc ef3592cc sha1 cb76b6d3ec9903a734f70ff11195f40f13f4d83f flags verified ) ) game ( - name "Ciao Nonna (World) (v1.1) (Aftermarket) (Unl)" - description "Ciao Nonna (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Ciao Nonna (World) (v1.1) (Aftermarket) (Unl).gb" size 1048576 crc 2165f2e4 sha1 f8e5020298183c3f47836da3890b6bb398e2ecab ) + name "Battle Arena Toshinden (Europe) (SGB Enhanced)" + description "Battle Arena Toshinden (Europe) (SGB Enhanced)" + rom ( name "Battle Arena Toshinden (Europe) (SGB Enhanced).gb" size 524288 crc ce34cca4 sha1 f4cc9193ca0b98c69c966cc32e37eae444a8d53b flags verified ) ) game ( - name "Ciao Nonna (World) (v2.0) (Aftermarket) (Unl)" - description "Ciao Nonna (World) (v2.0) (Aftermarket) (Unl)" - rom ( name "Ciao Nonna (World) (v2.0) (Aftermarket) (Unl).gb" size 1048576 crc 6afee818 sha1 602709c8655febb42899881a8ef598fb4b3da0c9 ) + name "Battle Arena Toshinden (USA) (SGB Enhanced)" + description "Battle Arena Toshinden (USA) (SGB Enhanced)" + rom ( name "Battle Arena Toshinden (USA) (SGB Enhanced).gb" size 524288 crc 2d0c1073 sha1 9c337d3f56938aa46cfc8b85c0db4631bcbe217c flags verified ) ) game ( - name "Ciao Nonna (World) (v2.1) (Aftermarket) (Unl)" - description "Ciao Nonna (World) (v2.1) (Aftermarket) (Unl)" - rom ( name "Ciao Nonna (World) (v2.1) (Aftermarket) (Unl).gb" size 1048576 crc 225ce296 sha1 45aebfe4e7f5382a4b31c3db270b75d2c458d1b2 ) + name "Battle Bull (Japan)" + description "Battle Bull (Japan)" + rom ( name "Battle Bull (Japan).gb" size 131072 crc 5c69e449 sha1 74ed574d2179bdf34a6e618a86be9b3e70155370 ) ) game ( - name "Ciao Nonna (World) (Aftermarket) (Unl)" - description "Ciao Nonna (World) (Aftermarket) (Unl)" - rom ( name "Ciao Nonna (World) (Aftermarket) (Unl).gb" size 1048576 crc dd7576d6 sha1 0556eb6160fdca6e7959bba1a619b8e34d974375 ) + name "Battle Bull (USA)" + description "Battle Bull (USA)" + rom ( name "Battle Bull (USA).gb" size 131072 crc d4d1aea2 sha1 a553b2cf2a5d223b6ac8aca4e9fd65b65087a1f4 flags verified ) ) game ( - name "Cliffhanger (USA, Europe)" - description "Cliffhanger (USA, Europe)" - rom ( name "Cliffhanger (USA, Europe).gb" size 131072 crc aa133439 sha1 c74f85035842f8a2d9560066d7065ff86d9107e2 flags verified ) + name "Battle Crusher (Japan) (SGB Enhanced)" + description "Battle Crusher (Japan) (SGB Enhanced)" + rom ( name "Battle Crusher (Japan) (SGB Enhanced).gb" size 262144 crc ea4eb1a1 sha1 ae07172c69a7bdece4392016c6a6dd253623f5f8 ) ) game ( - name "Collection Pocket (Japan) (SGB Enhanced)" - description "Collection Pocket (Japan) (SGB Enhanced)" - rom ( name "Collection Pocket (Japan) (SGB Enhanced).gb" size 262144 crc 34e62c8b sha1 daad5ec53da0e375cee3962c0a9031d8a67020fd ) + name "Battle Dodge Ball (Japan)" + description "Battle Dodge Ball (Japan)" + rom ( name "Battle Dodge Ball (Japan).gb" size 131072 crc a99242c0 sha1 ed63709af2dd22d2abaa7e99b9dd5373b6cc91c4 ) ) game ( - name "College Slam (USA)" - description "College Slam (USA)" - rom ( name "College Slam (USA).gb" size 524288 crc a549a572 sha1 84dc6269fbe4ee4c157f940b0a9630412e099cc6 ) + name "Battle of Kingdom (Japan)" + description "Battle of Kingdom (Japan)" + rom ( name "Battle of Kingdom (Japan).gb" size 131072 crc 35914deb sha1 5761f47a09f91a373bda96840fe2560bff1ffc97 ) ) game ( - name "Commando (World) (Aftermarket) (Unl)" - description "Commando (World) (Aftermarket) (Unl)" - rom ( name "Commando (World) (Aftermarket) (Unl).gb" size 262144 crc 48173941 sha1 c861858e9f2cf7470e739c26ae9f17d3834ce464 ) + name "Battle of Olympus, The (Europe) (En,Fr,De,Es,It)" + description "Battle of Olympus, The (Europe) (En,Fr,De,Es,It)" + rom ( name "Battle of Olympus, The (Europe) (En,Fr,De,Es,It).gb" size 262144 crc ca450e93 sha1 c0ca1948c4bfca795a29ce82aa5ab9215b9ed601 ) ) game ( - name "Contra (World) (Contra Anniversary Collection)" - description "Contra (World) (Contra Anniversary Collection)" - rom ( name "Contra (World) (Contra Anniversary Collection).gb" size 131072 crc cc67a046 sha1 6fea1350ac04f418095cca5f157a9c770a0505bc flags verified ) + name "Battle Pingpong (Japan)" + description "Battle Pingpong (Japan)" + rom ( name "Battle Pingpong (Japan).gb" size 65536 crc 7c787bc4 sha1 5008699f7a31a1a0722114f83e94591e99b22cc0 ) ) game ( - name "Contra (Japan) (En)" - description "Contra (Japan) (En)" - rom ( name "Contra (Japan) (En).gb" size 131072 crc cde6de15 sha1 c8b34b5aba3d448e357b59cdf106ee9b134713db ) + name "Battle Ships (Spain) (En,Fr,De,Es) (Beta)" + description "Battle Ships (Spain) (En,Fr,De,Es) (Beta)" + rom ( name "Battle Ships (Spain) (En,Fr,De,Es) (Beta).gb" size 131072 crc 1f8ccb71 sha1 4c04f79c670661fa46b17f7f980e6e7e88e886e7 ) ) game ( - name "Contra - The Alien Wars (USA) (SGB Enhanced)" - description "Contra - The Alien Wars (USA) (SGB Enhanced)" - rom ( name "Contra - The Alien Wars (USA) (SGB Enhanced).gb" size 131072 crc f1c81eb0 sha1 2e23477eb8738d7fb45e13b02f054422222c9c4f flags verified ) + name "Battle Space (Japan)" + description "Battle Space (Japan)" + rom ( name "Battle Space (Japan).gb" size 65536 crc a828fd4f sha1 76e47ad844abdde9eff09ea29a014f9a1eae5093 flags verified ) ) game ( - name "Contra Spirits (Japan) (SGB Enhanced)" - description "Contra Spirits (Japan) (SGB Enhanced)" - rom ( name "Contra Spirits (Japan) (SGB Enhanced).gb" size 131072 crc 7fc22df5 sha1 72213c5d8af05cad5f17a42566f7383066612eee ) + name "Battle Unit Zeoth (Japan)" + description "Battle Unit Zeoth (Japan)" + rom ( name "Battle Unit Zeoth (Japan).gb" size 131072 crc a1a1fe77 sha1 35413f3d4b4e68f521a90c3a48d4bd2b5bf90e09 ) ) game ( - name "Cool Ball (USA)" - description "Cool Ball (USA)" - rom ( name "Cool Ball (USA).gb" size 32768 crc e045b886 sha1 f1932d4a3f063c5395e8558a63c64e5840789ce6 ) + name "Battle Unit Zeoth (USA, Europe)" + description "Battle Unit Zeoth (USA, Europe)" + rom ( name "Battle Unit Zeoth (USA, Europe).gb" size 131072 crc e67a92b3 sha1 eba09c60cd60feba0a7a9e82597dad080ce78d22 flags verified ) ) game ( - name "Cool Hand (Europe)" - description "Cool Hand (Europe)" - rom ( name "Cool Hand (Europe).gb" size 262144 crc 0d430d1a sha1 a6fe59bcc29b6d9ae6712d99822a123d2434f3b3 flags verified ) + name "BattleCity (Japan)" + description "BattleCity (Japan)" + rom ( name "BattleCity (Japan).gb" size 32768 crc a37a814a sha1 5c9a6077913b344c8889241ec5f9fdaac7f24c8b ) ) game ( - name "Cool Hand (Europe) (Fr,De)" - description "Cool Hand (Europe) (Fr,De)" - rom ( name "Cool Hand (Europe) (Fr,De).gb" size 262144 crc a2f01695 sha1 b26441e13b9dc806b182999ff8784cef46961010 ) + name "Battleship (USA, Europe)" + description "Battleship (USA, Europe)" + rom ( name "Battleship (USA, Europe).gb" size 65536 crc fef62da5 sha1 d3efb4afebcf94b191a66797a6bae2c90ba92c6a ) ) game ( - name "Cool Spot (Europe)" - description "Cool Spot (Europe)" - rom ( name "Cool Spot (Europe).gb" size 131072 crc 1987eacc sha1 51efa64a6047879b4b9e6e521e65c9d7f191556f flags verified ) + name "Battleship (USA, Europe) (Beta)" + description "Battleship (USA, Europe) (Beta)" + rom ( name "Battleship (USA, Europe) (Beta).gb" size 65536 crc ec382a5d sha1 d19343d62ec4a257e496ccb4d57c728cbad51e95 ) ) game ( - name "Cool Spot (USA)" - description "Cool Spot (USA)" - rom ( name "Cool Spot (USA).gb" size 131072 crc aba1dac9 sha1 b23f3259fdec43ce004e536d30255e1c2a642ffc flags verified ) + name "Battletoads (Japan)" + description "Battletoads (Japan)" + rom ( name "Battletoads (Japan).gb" size 131072 crc 331cf7de sha1 666ed5d34f508c8805a67f4400fc01a1f2817e03 ) ) game ( - name "Cool World (USA, Europe)" - description "Cool World (USA, Europe)" - rom ( name "Cool World (USA, Europe).gb" size 131072 crc a193c0d0 sha1 1919495cc83c4126c90d6cfa2e14427b6364da3a flags verified ) + name "Battletoads (USA, Europe)" + description "Battletoads (USA, Europe)" + rom ( name "Battletoads (USA, Europe).gb" size 131072 crc b0c3361b sha1 ba839bea8f76bf955e3edf7083d2cbe780244add flags verified ) ) game ( - name "Cosmic Courier - Trapped in Limbo (World) (Aftermarket) (Unl)" - description "Cosmic Courier - Trapped in Limbo (World) (Aftermarket) (Unl)" - rom ( name "Cosmic Courier - Trapped in Limbo (World) (Aftermarket) (Unl).gb" size 262144 crc fd304687 sha1 7df11ec2946099d49dd62928118b6d76703dc57c ) + name "Battletoads in Ragnarok's World (Europe)" + description "Battletoads in Ragnarok's World (Europe)" + rom ( name "Battletoads in Ragnarok's World (Europe).gb" size 131072 crc 7ffc34ea sha1 1852bd23644e28109b66fa937053c689a63f7729 flags verified ) ) game ( - name "Cosmo Tank (Japan) (Beta)" - description "Cosmo Tank (Japan) (Beta)" - rom ( name "Cosmo Tank (Japan) (Beta).gb" size 131072 crc 2022bbb9 sha1 8963c2e8e42c452528078f10df699fd266f01749 ) + name "Battletoads in Ragnarok's World (USA)" + description "Battletoads in Ragnarok's World (USA)" + rom ( name "Battletoads in Ragnarok's World (USA).gb" size 131072 crc ce316c68 sha1 3df1384e699b91689f015d7aba65ab42410e24f5 ) ) game ( - name "Cosmo Tank (USA) (Beta)" - description "Cosmo Tank (USA) (Beta)" - rom ( name "Cosmo Tank (USA) (Beta).gb" size 131072 crc 1c6770f0 sha1 863bf21877b5f5993b9e64710f304b8db194d2e7 ) + name "Battletoads-Double Dragon (Europe)" + description "Battletoads-Double Dragon (Europe)" + rom ( name "Battletoads-Double Dragon (Europe).gb" size 262144 crc 7b217082 sha1 5a834e0dc81703906eb441555e1aa31de22d39d6 ) ) game ( - name "Cosmo Tank (Japan)" - description "Cosmo Tank (Japan)" - rom ( name "Cosmo Tank (Japan).gb" size 131072 crc 80b21df1 sha1 0d6a0a95f4fc9f2c61e2fccee0321236d3a6f5e5 flags verified ) + name "Battletoads-Double Dragon (USA)" + description "Battletoads-Double Dragon (USA)" + rom ( name "Battletoads-Double Dragon (USA).gb" size 262144 crc a727f9cd sha1 ce68df4dc2d604625164430266017b237b72303d ) ) game ( - name "Cosmo Tank (USA)" - description "Cosmo Tank (USA)" - rom ( name "Cosmo Tank (USA).gb" size 131072 crc 2e767d25 sha1 48a8f5c50a237f11c8e18efd03a5282f493312bc ) + name "Beavis and Butt-head (USA, Europe)" + description "Beavis and Butt-head (USA, Europe)" + rom ( name "Beavis and Butt-head (USA, Europe).gb" size 524288 crc af1ae123 sha1 918e9cc878a61d8174918c897182604f0c27b1d9 ) ) game ( - name "Coucou (World) (Aftermarket) (Unl)" - description "Coucou (World) (Aftermarket) (Unl)" - rom ( name "Coucou (World) (Aftermarket) (Unl).gb" size 32768 crc e6aabd72 sha1 5283268e3640e2924d00aea3b12b2d3930bef43c ) + name "Beethoven (Europe) (SGB Enhanced)" + description "Beethoven (Europe) (SGB Enhanced)" + rom ( name "Beethoven (Europe) (SGB Enhanced).gb" size 131072 crc 637e54e3 sha1 a175778faca00f096f0bfdbaa844a38816bbeb0f ) ) game ( - name "Counting Sheep (World) (Aftermarket) (Unl)" - description "Counting Sheep (World) (Aftermarket) (Unl)" - rom ( name "Counting Sheep (World) (Aftermarket) (Unl).GB" size 65536 crc 6e97c837 sha1 e7e251ad86fa00803837cf871de62d3f100c83ce ) + name "Beethoven (USA) (Proto) (SGB Enhanced)" + description "Beethoven (USA) (Proto) (SGB Enhanced)" + rom ( name "Beethoven (USA) (Proto) (SGB Enhanced).gb" size 131072 crc d7b75fa6 sha1 2e71fde9958466f8b484c757f726bcdc5e1ae456 ) ) game ( - name "Crayon Shin-chan - Ora no Gokigen Collection (Japan) (SGB Enhanced)" - description "Crayon Shin-chan - Ora no Gokigen Collection (Japan) (SGB Enhanced)" - rom ( name "Crayon Shin-chan - Ora no Gokigen Collection (Japan) (SGB Enhanced).gb" size 262144 crc dc723a9e sha1 1dbd23b639b8a4b20ed28c3637608e03ebf59dad ) + name "Beetlejuice (USA)" + description "Beetlejuice (USA)" + rom ( name "Beetlejuice (USA).gb" size 131072 crc 33574ecb sha1 a8bb9681dbf0700d64a88c7d9ad0093f08087046 ) ) game ( - name "Crayon Shin-chan - Ora to Shiro wa Otomodachi Da yo (Japan)" - description "Crayon Shin-chan - Ora to Shiro wa Otomodachi Da yo (Japan)" - rom ( name "Crayon Shin-chan - Ora to Shiro wa Otomodachi Da yo (Japan).gb" size 131072 crc 2699942c sha1 e8da27b1b782c154b65ba6cdc2e3915925a67566 ) + name "Best of the Best - Championship Karate (Europe)" + description "Best of the Best - Championship Karate (Europe)" + rom ( name "Best of the Best - Championship Karate (Europe).gb" size 262144 crc d5c3da1d sha1 351446b94176360c0d9ad3cee43166ffbd9a51fa flags verified ) ) game ( - name "Crayon Shin-chan 2 - Ora to Wanpaku Gokko Dazo (Japan)" - description "Crayon Shin-chan 2 - Ora to Wanpaku Gokko Dazo (Japan)" - rom ( name "Crayon Shin-chan 2 - Ora to Wanpaku Gokko Dazo (Japan).gb" size 131072 crc ca6e0be0 sha1 f034cc9c8b5962c548eba445033c8c912e3a19e2 ) + name "Best of the Best - Championship Karate (USA)" + description "Best of the Best - Championship Karate (USA)" + rom ( name "Best of the Best - Championship Karate (USA).gb" size 262144 crc b20280e6 sha1 ba7d64c606cc0f654217e54a0bd5b8dda455a060 ) ) game ( - name "Crayon Shin-chan 3 - Ora no Gokigen Athletic (Japan)" - description "Crayon Shin-chan 3 - Ora no Gokigen Athletic (Japan)" - rom ( name "Crayon Shin-chan 3 - Ora no Gokigen Athletic (Japan).gb" size 131072 crc 24a12807 sha1 2d0119ec7b44bb89964c98024c46afd39490b5c9 flags verified ) + name "Bikkuri Nekketsu Shin Kiroku! - Dokodemo Kin Medal (Japan)" + description "Bikkuri Nekketsu Shin Kiroku! - Dokodemo Kin Medal (Japan)" + rom ( name "Bikkuri Nekketsu Shin Kiroku! - Dokodemo Kin Medal (Japan).gb" size 262144 crc 86d11d10 sha1 baecee2dfd915a41363fef736f81853822d5dfcd ) ) game ( - name "Crayon Shin-chan 4 - Ora no Itazura Daihenshin (Japan) (SGB Enhanced)" - description "Crayon Shin-chan 4 - Ora no Itazura Daihenshin (Japan) (SGB Enhanced)" - rom ( name "Crayon Shin-chan 4 - Ora no Itazura Daihenshin (Japan) (SGB Enhanced).gb" size 131072 crc 37d4aa8c sha1 b5bb01ad7e25e9e83c564ccf604a59f8930cd0d5 ) + name "Bill & Ted's Excellent Game Boy Adventure - A Bogus Journey! (USA, Europe)" + description "Bill & Ted's Excellent Game Boy Adventure - A Bogus Journey! (USA, Europe)" + rom ( name "Bill & Ted's Excellent Game Boy Adventure - A Bogus Journey! (USA, Europe).gb" size 131072 crc 5e8f656a sha1 e19a7e5a5bd8fde0f31773c22dbebc9b4cf3824e flags verified ) ) game ( - name "Crystal Quest (USA)" - description "Crystal Quest (USA)" - rom ( name "Crystal Quest (USA).gb" size 32768 crc 51300cfd sha1 6c3ba1e407ff378dc004ac58d6a16180bd76a1b3 ) + name "Bill & Ted's Excellent Portable Adventure - A Bogus Journey! (World) (Retro Collection)" + description "Bill & Ted's Excellent Portable Adventure - A Bogus Journey! (World) (Retro Collection)" + rom ( name "Bill & Ted's Excellent Portable Adventure - A Bogus Journey! (World) (Retro Collection).gb" size 131072 crc 7b5e19ca sha1 c6e606cb5e17f7530a529387ad2fb703a94b205a flags verified ) ) game ( - name "Cult Jump (Japan)" - description "Cult Jump (Japan)" - rom ( name "Cult Jump (Japan).gb" size 262144 crc 943059ba sha1 6a67820ef648d2e24c1212079f5cac43e04cf0bf ) + name "Bill Elliott's NASCAR Fast Tracks (USA)" + description "Bill Elliott's NASCAR Fast Tracks (USA)" + rom ( name "Bill Elliott's NASCAR Fast Tracks (USA).gb" size 131072 crc 71cf43ce sha1 ebc2ca8b4503f0b05e00749d693462a54f2f95eb ) ) game ( - name "Cult Master - Ultraman ni Miserarete (Japan)" - description "Cult Master - Ultraman ni Miserarete (Japan)" - rom ( name "Cult Master - Ultraman ni Miserarete (Japan).gb" size 262144 crc c3eb82ef sha1 f0e63a0a4e7b576c7460e810eb6f50d4c5b68769 ) + name "Binary Monsters II - Adventure of Hell (Taiwan) (En) (Unl)" + description "Binary Monsters II - Adventure of Hell (Taiwan) (En) (Unl)" + rom ( name "Binary Monsters II - Adventure of Hell (Taiwan) (En) (Unl).gb" size 131072 crc 3bf1e911 sha1 5a7ea252cc344f239e48eee0eba6a9ba97d799ea ) ) game ( - name "Cuthbert in the Cooler (World) (Aftermarket) (Unl)" - description "Cuthbert in the Cooler (World) (Aftermarket) (Unl)" - rom ( name "Cuthbert in the Cooler (World) (Aftermarket) (Unl).gb" size 262144 crc 10838580 sha1 c740bc995adf2bb638bb125a36edc416558fd4c6 ) + name "Bionic Battler (USA)" + description "Bionic Battler (USA)" + rom ( name "Bionic Battler (USA).gb" size 65536 crc a1e55dc2 sha1 9eca6a5fd1e537085598e8b2903ad75fe9c0b785 flags verified ) ) game ( - name "CutThroat Island (Japan) (En) (Proto)" - description "CutThroat Island (Japan) (En) (Proto)" - rom ( name "CutThroat Island (Japan) (En) (Proto).gb" size 262144 crc 6a5f5a0d sha1 51eab74e5d5180497d37fc642c585f202914d1f2 ) + name "Bionic Commando (Europe)" + description "Bionic Commando (Europe)" + rom ( name "Bionic Commando (Europe).gb" size 262144 crc 4c5b4547 sha1 a8ab419b049aef5a04800efd6df58e4b3c3abbe3 flags verified ) ) game ( - name "CutThroat Island (USA, Europe)" - description "CutThroat Island (USA, Europe)" - rom ( name "CutThroat Island (USA, Europe).gb" size 262144 crc eebdd360 sha1 5e99ea51b383cdcd53874eb027ebd59d2a3156b9 flags verified ) + name "Bionic Commando (Japan)" + description "Bionic Commando (Japan)" + rom ( name "Bionic Commando (Japan).gb" size 262144 crc 3f4d5c84 sha1 12dc5b05751214be3ce55da0fecaf23a41eb1881 ) ) game ( - name "Cyber Dreamscape Battle-Deckers 2199 (World) (Aftermarket) (Unl)" - description "Cyber Dreamscape Battle-Deckers 2199 (World) (Aftermarket) (Unl)" - rom ( name "Cyber Dreamscape Battle-Deckers 2199 (World) (Aftermarket) (Unl).gb" size 1048576 crc e3a78253 sha1 45c9c6a7a4ec985146a4a616a49dba45decc6d3e ) + name "Bionic Commando (USA)" + description "Bionic Commando (USA)" + rom ( name "Bionic Commando (USA).gb" size 262144 crc 41dbb5fb sha1 e0ef47568a017ccdd3dbe0db5d7654822b4e5ce1 ) ) game ( - name "Cyraid (USA)" - description "Cyraid (USA)" - rom ( name "Cyraid (USA).gb" size 65536 crc 9d00da55 sha1 e295fce5531be0df7f5a10628608e0dcf54da71b ) + name "Bishoujo Senshi Sailor Moon (Japan)" + description "Bishoujo Senshi Sailor Moon (Japan)" + rom ( name "Bishoujo Senshi Sailor Moon (Japan).gb" size 131072 crc c2763e73 sha1 c008913a9fbb395a7a504fe65d1d29c530755cb3 ) ) game ( - name "Daedalian Opus (USA)" - description "Daedalian Opus (USA)" - rom ( name "Daedalian Opus (USA).gb" size 32768 crc b6b51fce sha1 7a9294de582f7d3ffd8d14a786774c56af7ce7bc flags verified ) + name "Bishoujo Senshi Sailor Moon R (Japan)" + description "Bishoujo Senshi Sailor Moon R (Japan)" + rom ( name "Bishoujo Senshi Sailor Moon R (Japan).gb" size 262144 crc ea759875 sha1 959f384998c43072ca154e531917e9aaa80a694d ) ) game ( - name "Daffy Duck (USA, Europe) (SGB Enhanced)" - description "Daffy Duck (USA, Europe) (SGB Enhanced)" - rom ( name "Daffy Duck (USA, Europe) (SGB Enhanced).gb" size 262144 crc c47671f3 sha1 75b384222d07947baed2213c288385c4b91e1911 flags verified ) + name "Black Bass - Lure Fishing (USA)" + description "Black Bass - Lure Fishing (USA)" + rom ( name "Black Bass - Lure Fishing (USA).gb" size 262144 crc 2db3dace sha1 d9524ac9f7788172a55cc8ceb6e199f8a12e033d ) ) game ( - name "Daffy Duck (Europe)" - description "Daffy Duck (Europe)" - rom ( name "Daffy Duck (Europe).gb" size 131072 crc 13dd647d sha1 344c3409410fe5f88796aafd125c522319b78012 flags verified ) + name "Blade Warrior (Europe) (Proto)" + description "Blade Warrior (Europe) (Proto)" + rom ( name "Blade Warrior (Europe) (Proto).gb" size 32768 crc cfd54dbc sha1 53c1e67430f923f74a611e675ca0cad8d0b13d76 ) ) game ( - name "Dai-2-ji Super Robot Taisen G (Japan) (SGB Enhanced)" - description "Dai-2-ji Super Robot Taisen G (Japan) (SGB Enhanced)" - rom ( name "Dai-2-ji Super Robot Taisen G (Japan) (SGB Enhanced).gb" size 524288 crc df8b2b20 sha1 0baa751363c05f9830656f98e77902d543822656 flags verified ) + name "Blades of Steel (Europe)" + description "Blades of Steel (Europe)" + rom ( name "Blades of Steel (Europe).gb" size 131072 crc f7be0002 sha1 d030c46bc225fc92aa431276d9ae5812a30d6007 flags verified ) ) game ( - name "Daikaijuu Monogatari - The Miracle of the Zone (Japan) (SGB Enhanced)" - description "Daikaijuu Monogatari - The Miracle of the Zone (Japan) (SGB Enhanced)" - rom ( name "Daikaijuu Monogatari - The Miracle of the Zone (Japan) (SGB Enhanced).gb" size 524288 crc 26d2d5c2 sha1 44cafcb56f470881b67e57c0649afbc638cda136 flags verified ) + name "Blades of Steel (USA)" + description "Blades of Steel (USA)" + rom ( name "Blades of Steel (USA).gb" size 131072 crc e81c9fb9 sha1 82761dbf5abe276f8e0c82f575356aed87155141 flags verified ) ) game ( - name "Daiku no Gen-san - Ghost Building Company (Japan)" - description "Daiku no Gen-san - Ghost Building Company (Japan)" - rom ( name "Daiku no Gen-san - Ghost Building Company (Japan).gb" size 262144 crc 9e0d2b45 sha1 90574cc899210515e83dec714eb4d69416dcf3a3 flags verified ) + name "Blaster Master Boy (USA)" + description "Blaster Master Boy (USA)" + rom ( name "Blaster Master Boy (USA).gb" size 131072 crc 3b2c7118 sha1 21b1e574a6f4543651e96de65994e7b0b7a6a0f6 ) ) game ( - name "Daiku no Gen-san - Robot Teikoku no Yabou (Japan)" - description "Daiku no Gen-san - Robot Teikoku no Yabou (Japan)" - rom ( name "Daiku no Gen-san - Robot Teikoku no Yabou (Japan).gb" size 262144 crc 70819e03 sha1 0c68250aadca89027b05659122c89682ff833298 ) + name "Blaster Master Boy (USA) (Beta)" + description "Blaster Master Boy (USA) (Beta)" + rom ( name "Blaster Master Boy (USA) (Beta).gb" size 131072 crc 4ea70173 sha1 f568f9c7fe9ef9726d602727beca13d6978cd770 ) ) game ( - name "Daisenryaku (Japan)" - description "Daisenryaku (Japan)" - rom ( name "Daisenryaku (Japan).gb" size 131072 crc c8f80d90 sha1 79e724619d21ebb3cd5de5438535a7ee25009de0 ) + name "Blaster Master Jr. (Europe)" + description "Blaster Master Jr. (Europe)" + rom ( name "Blaster Master Jr. (Europe).gb" size 131072 crc e9f9016f sha1 6a6deae1942e7cf048ce35d18e9540363c226727 ) ) game ( - name "Dangan GB (World) (v1.1) (Aftermarket) (Unl)" - description "Dangan GB (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Dangan GB (World) (v1.1) (Aftermarket) (Unl).gb" size 262144 crc 5359d6db sha1 10029774046dabec2d8c0533caf94091f6e19071 ) + name "Block Kuzushi GB (Japan) (SGB Enhanced)" + description "Block Kuzushi GB (Japan) (SGB Enhanced)" + rom ( name "Block Kuzushi GB (Japan) (SGB Enhanced).gb" size 131072 crc 54b67501 sha1 7540fe9af69d8c7d48f50c2d5fe6d3ce07421f74 ) ) game ( - name "Dangan GB (World) (Aftermarket) (Unl)" - description "Dangan GB (World) (Aftermarket) (Unl)" - rom ( name "Dangan GB (World) (Aftermarket) (Unl).gb" size 262144 crc daa59c9c sha1 8375d845fcfe4c236cd68f3d56a290f8c7b76c06 ) + name "Blodia (Japan)" + description "Blodia (Japan)" + rom ( name "Blodia (Japan).gb" size 65536 crc 51ff6e53 sha1 a3927543ca471f479ba7aae7295788434672464e ) ) game ( - name "Darkman (USA, Europe)" - description "Darkman (USA, Europe)" - rom ( name "Darkman (USA, Europe).gb" size 131072 crc ff858da9 sha1 f168733ddf4f083559e52198a503e4f295fabf0d flags verified ) + name "Blues Brothers (USA, Europe) (Beta)" + description "Blues Brothers (USA, Europe) (Beta)" + rom ( name "Blues Brothers (USA, Europe) (Beta).gb" size 131072 crc 1f90d12a sha1 f7139bb55c3cc7bae672ade9022fb548b72f6f2f ) ) game ( - name "Darkwing Duck (Europe)" - description "Darkwing Duck (Europe)" - rom ( name "Darkwing Duck (Europe).gb" size 131072 crc be975b4f sha1 4e51919597aa72dd32182f9afee34f148036655f flags verified ) + name "Blues Brothers, The (USA, Europe)" + description "Blues Brothers, The (USA, Europe)" + rom ( name "Blues Brothers, The (USA, Europe).gb" size 131072 crc adb66eff sha1 9dca8b83a5d73270319cf05396fcca8e6027e7b0 flags verified ) ) game ( - name "Darkwing Duck (USA)" - description "Darkwing Duck (USA)" - rom ( name "Darkwing Duck (USA).gb" size 131072 crc 238b9646 sha1 cc1f12f3ec3852657a14d11c13d1ef91fbdda5bb ) + name "Blues Brothers, The - Jukebox Adventure (Europe)" + description "Blues Brothers, The - Jukebox Adventure (Europe)" + rom ( name "Blues Brothers, The - Jukebox Adventure (Europe).gb" size 131072 crc f1c0fb1d sha1 2005e94222a1f0edd30903411343f9570a91d4f3 ) ) game ( - name "Darkwing Duck (Germany)" - description "Darkwing Duck (Germany)" - rom ( name "Darkwing Duck (Germany).gb" size 131072 crc 176c1fa2 sha1 5960dc01e06f19e166646504bc3097248f4a22cb flags verified ) + name "Bo Jackson - Two Games in One (USA)" + description "Bo Jackson - Two Games in One (USA)" + rom ( name "Bo Jackson - Two Games in One (USA).gb" size 131072 crc 7edb78ab sha1 cb360f44a398ff5cd3818b0e244ffdf7019d85c7 flags verified ) ) game ( - name "Darkwing Duck (Spain)" - description "Darkwing Duck (Spain)" - rom ( name "Darkwing Duck (Spain).gb" size 131072 crc a1d4c544 sha1 3d4b301aab995bdf19b15ed5040df7426a2e8057 ) + name "Bobby's World (USA) (Proto) (SGB Enhanced)" + description "Bobby's World (USA) (Proto) (SGB Enhanced)" + rom ( name "Bobby's World (USA) (Proto) (SGB Enhanced).gb" size 131072 crc 531bf384 sha1 7c244ab1260c7d1d198cf61a0a1529f3baee9fbf ) ) game ( - name "Darkwing Duck (USA) (Beta)" - description "Darkwing Duck (USA) (Beta)" - rom ( name "Darkwing Duck (USA) (Beta).gb" size 131072 crc 311ade03 sha1 2883b8854529369cce4d473e71fa0193c7df02b6 ) + name "Bobby's World (Europe) (Proto) (SGB Enhanced)" + description "Bobby's World (Europe) (Proto) (SGB Enhanced)" + rom ( name "Bobby's World (Europe) (Proto) (SGB Enhanced).gb" size 131072 crc ffe34a16 sha1 7c67947726292b99d57aab17dc0f101ca5f8567f ) ) game ( - name "Dash (World) (Aftermarket) (Unl)" - description "Dash (World) (Aftermarket) (Unl)" - rom ( name "Dash (World) (Aftermarket) (Unl).gb" size 262144 crc 73868683 sha1 c1ffe7c25a34d65ed166293bc7d2b48b65ca922b ) + name "Boggle Plus (USA)" + description "Boggle Plus (USA)" + rom ( name "Boggle Plus (USA).gb" size 131072 crc 70c8c799 sha1 d6cf512f7301ccdc2d802f34fbbde2d0ba2cf3cd ) ) game ( - name "David Crane's The Rescue of Princess Blobette (Europe)" - description "David Crane's The Rescue of Princess Blobette (Europe)" - rom ( name "David Crane's The Rescue of Princess Blobette (Europe).gb" size 65536 crc 25f82bb1 sha1 4800e5d5a4230918ec751ceeae7ac9342e0b8d83 flags verified ) + name "Bokujou Monogatari GB (Japan) (SGB Enhanced)" + description "Bokujou Monogatari GB (Japan) (SGB Enhanced)" + rom ( name "Bokujou Monogatari GB (Japan) (SGB Enhanced).gb" size 524288 crc d3e2fd02 sha1 60ecafdb13213b3ac2daa3d71431ef8a89754edb flags verified ) ) game ( - name "David Crane's The Rescue of Princess Blobette (USA)" - description "David Crane's The Rescue of Princess Blobette (USA)" - rom ( name "David Crane's The Rescue of Princess Blobette (USA).gb" size 65536 crc 8210a03f sha1 0a45d1b98646fd7832b5119b04bc8d6d6d0f657a ) + name "Bokujou Monogatari GB (Japan) (Rev 1) (SGB Enhanced)" + description "Bokujou Monogatari GB (Japan) (Rev 1) (SGB Enhanced)" + rom ( name "Bokujou Monogatari GB (Japan) (Rev 1) (SGB Enhanced).gb" size 524288 crc da218e44 sha1 a1637d7ba09335631eac1291803ade05adcf5fc7 flags verified ) ) game ( - name "Days of Thunder (USA, Europe)" - description "Days of Thunder (USA, Europe)" - rom ( name "Days of Thunder (USA, Europe).gb" size 131072 crc 35d9be0e sha1 1bf54293a332fd822911218dcc4a94fcda949ccf ) + name "Bokujou Monogatari GB (Japan) (SGB Enhanced) (NP)" + description "Bokujou Monogatari GB (Japan) (SGB Enhanced) (NP)" + rom ( name "Bokujou Monogatari GB (Japan) (SGB Enhanced) (NP).gb" size 524288 crc 0424df85 sha1 551df2021d0e433e7f07cf881c7b1d534f54f6ad ) ) game ( - name "Dead Heat Scramble (Japan)" - description "Dead Heat Scramble (Japan)" - rom ( name "Dead Heat Scramble (Japan).gb" size 65536 crc a8301bdd sha1 395c0c80ad5c9a24c00d6d8dfe5894e73e672639 ) + name "Bomb Jack (Europe) (Beta 1)" + description "Bomb Jack (Europe) (Beta 1)" + rom ( name "Bomb Jack (Europe) (Beta 1).gb" size 32768 crc ffa0e67a sha1 a4c25218b2c35d6bd4fcf93ebdf81dfe22d4259a ) ) game ( - name "Dead Heat Scramble (USA)" - description "Dead Heat Scramble (USA)" - rom ( name "Dead Heat Scramble (USA).gb" size 65536 crc 9e3e3656 sha1 71e560dd2b5f5c4f4dcca0837c74bb1b843a15aa ) + name "Bomb Jack (Europe) (Beta 2)" + description "Bomb Jack (Europe) (Beta 2)" + rom ( name "Bomb Jack (Europe) (Beta 2).gb" size 32768 crc 7ca8e543 sha1 6fc3794149f5e75ad82b4a7d47ad5497e1ee4e6a ) ) game ( - name "Deadeus (World) (v1.3.8) (Aftermarket) (Unl)" - description "Deadeus (World) (v1.3.8) (Aftermarket) (Unl)" - rom ( name "Deadeus (World) (v1.3.8) (Aftermarket) (Unl).gb" size 1048576 crc 7da95971 sha1 23cff594ef4b0bb21883b422940526c7fe81f1fd flags verified ) + name "Bomb Jack (Europe)" + description "Bomb Jack (Europe)" + rom ( name "Bomb Jack (Europe).gb" size 32768 crc 9bd8815e sha1 a2b2799e867777a5a19155ed1f2245630fc03560 ) ) game ( - name "Deadeus (World) (v1.2.5) (Aftermarket) (Unl)" - description "Deadeus (World) (v1.2.5) (Aftermarket) (Unl)" - rom ( name "Deadeus (World) (v1.2.5) (Aftermarket) (Unl).gb" size 1048576 crc 9e2bf649 sha1 3feeba5c438880f70cdfdc4ea7e29f77e645e9be flags verified ) + name "Bomber Boy (Japan)" + description "Bomber Boy (Japan)" + rom ( name "Bomber Boy (Japan).gb" size 131072 crc ef9595ac sha1 a9baddfb693f20057b17c084422d7bfac590f2ba flags verified ) ) game ( - name "Deadeus (World) (v1.1.0) (Aftermarket) (Unl)" - description "Deadeus (World) (v1.1.0) (Aftermarket) (Unl)" - rom ( name "Deadeus (World) (v1.1.0) (Aftermarket) (Unl).gb" size 1048576 crc 818a7db7 sha1 43a93dc6f7bef002271e583edaeaf2e7162b8af4 ) + name "Bomber King - Scenario 2 (Japan)" + description "Bomber King - Scenario 2 (Japan)" + rom ( name "Bomber King - Scenario 2 (Japan).gb" size 131072 crc b8fe9077 sha1 79f978b9e85c675f7b54229a14d04926348bb70f ) ) game ( - name "Death Track (Europe) (Proto)" - description "Death Track (Europe) (Proto)" - rom ( name "Death Track (Europe) (Proto).gb" size 524288 crc c495a707 sha1 abc95b27be454405a6a22fb9e048537d1df60d75 ) + name "Bomberman Collection (Japan) (SGB Enhanced)" + description "Bomberman Collection (Japan) (SGB Enhanced)" + rom ( name "Bomberman Collection (Japan) (SGB Enhanced).gb" size 1048576 crc 509a6b73 sha1 385f8fafa53a83f8f65e1e619fe124bbf7db4a98 flags verified ) ) game ( - name "Deep Forest (World) (v1.1) (Aftermarket) (Unl)" - description "Deep Forest (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Deep Forest (World) (v1.1) (Aftermarket) (Unl).gb" size 1048576 crc 3ddf177d sha1 517302d20cb5140975e6cd1b3c495786b6390aaf ) + name "Bomberman GB (Japan) (SGB Enhanced)" + description "Bomberman GB (Japan) (SGB Enhanced)" + rom ( name "Bomberman GB (Japan) (SGB Enhanced).gb" size 262144 crc 94337d56 sha1 5b989983c2f80a71dfc7cce29395de3e174fa848 ) ) game ( - name "Dennis (Europe) (Beta) (1993-09-13)" - description "Dennis (Europe) (Beta) (1993-09-13)" - rom ( name "Dennis (Europe) (Beta) (1993-09-13).gb" size 131072 crc 807d34a4 sha1 fab382a28f9d7fefae7dc9a16bf86f309d89e037 ) + name "Bomberman GB (USA, Europe) (SGB Enhanced)" + description "Bomberman GB (USA, Europe) (SGB Enhanced)" + rom ( name "Bomberman GB (USA, Europe) (SGB Enhanced).gb" size 262144 crc f372d175 sha1 f7058f31ddaec63f3b9c45ee9caf3c8e2cae1ca8 flags verified ) ) game ( - name "Dennis (Europe)" - description "Dennis (Europe)" - rom ( name "Dennis (Europe).gb" size 131072 crc 896a30a8 sha1 9b5c289f25829534020951f84732177036837aea ) + name "Bomberman GB 2 (Japan) (SGB Enhanced)" + description "Bomberman GB 2 (Japan) (SGB Enhanced)" + rom ( name "Bomberman GB 2 (Japan) (SGB Enhanced).gb" size 262144 crc 6157443b sha1 004e540e8aed59e5aee1c88ef84975000a6efe6c flags verified ) ) game ( - name "Dennis the Menace (USA)" - description "Dennis the Menace (USA)" - rom ( name "Dennis the Menace (USA).gb" size 131072 crc 7eb0cd32 sha1 4695b50738add92926dc5d4b48568b037df7cdb9 ) + name "Bomberman GB 3 (Japan) (SGB Enhanced)" + description "Bomberman GB 3 (Japan) (SGB Enhanced)" + rom ( name "Bomberman GB 3 (Japan) (SGB Enhanced).gb" size 262144 crc f658b7a7 sha1 98a6327639833e1a6696e4acc5ca162388d5f6e1 ) ) game ( - name "Desert Strike - Return to the Gulf (Europe) (SGB Enhanced)" - description "Desert Strike - Return to the Gulf (Europe) (SGB Enhanced)" - rom ( name "Desert Strike - Return to the Gulf (Europe) (SGB Enhanced).gb" size 262144 crc b700f7f7 sha1 b49bc8f5d292f0e2b71957c8c4af37b20cfead80 ) + name "Bonk's Adventure (USA)" + description "Bonk's Adventure (USA)" + rom ( name "Bonk's Adventure (USA).gb" size 262144 crc a7cdbb96 sha1 e27d941af0a006c4f5ffd03914265146aa140e2c ) ) game ( - name "Desert Strike - Return to the Gulf (USA) (SGB Enhanced)" - description "Desert Strike - Return to the Gulf (USA) (SGB Enhanced)" - rom ( name "Desert Strike - Return to the Gulf (USA) (SGB Enhanced).gb" size 262144 crc 6a702c32 sha1 325ee739ecf5aa403741e8dad36abcfa441dd26b ) + name "Bonk's Adventure (USA) (Beta)" + description "Bonk's Adventure (USA) (Beta)" + rom ( name "Bonk's Adventure (USA) (Beta).gb" size 262144 crc 8d706dbc sha1 a26006158d90a61d22abf130f05297fd09a09b7c ) ) game ( - name "Dexterity (USA, Europe)" - description "Dexterity (USA, Europe)" - rom ( name "Dexterity (USA, Europe).gb" size 65536 crc 659e2283 sha1 85f0a9ff87ece93097a855d238bc6c7014893c08 flags verified ) + name "Bonk's Revenge (USA) (SGB Enhanced)" + description "Bonk's Revenge (USA) (SGB Enhanced)" + rom ( name "Bonk's Revenge (USA) (SGB Enhanced).gb" size 262144 crc f1344b78 sha1 8d1b81e456b271ad8f49a2c6efc9ca2504a24591 ) ) game ( - name "Diablo (USA) (Proto)" - description "Diablo (USA) (Proto)" - rom ( name "Diablo (USA) (Proto).gb" size 131072 crc aaaad0b6 sha1 8982410ac627618628a8b823c0608cc8b5653f41 ) + name "Booby Boys (Japan)" + description "Booby Boys (Japan)" + rom ( name "Booby Boys (Japan).gb" size 262144 crc ec83c0b6 sha1 61fe27a4ce83bc6d9dba5d4d0652e83dbec45e6e ) ) game ( - name "DiaMaze (World) (Aftermarket) (Unl)" - description "DiaMaze (World) (Aftermarket) (Unl)" - rom ( name "DiaMaze (World) (Aftermarket) (Unl).gb" size 262144 crc 956fa901 sha1 f41b98ac4669920ffede1736ddbd9e1f62d4cb0d ) + name "Boomer's Adventure in ASMIK World (USA)" + description "Boomer's Adventure in ASMIK World (USA)" + rom ( name "Boomer's Adventure in ASMIK World (USA).gb" size 65536 crc 105bc1c0 sha1 3d8a6fcc644290c9d88fe2918bfa6007ee811de8 flags verified ) ) game ( - name "Dick Tracy (USA)" - description "Dick Tracy (USA)" - rom ( name "Dick Tracy (USA).gb" size 131072 crc a308b86b sha1 906361b2066c2b48500b9b709f7b4ed1018309c0 ) + name "Bouken! Puzzle Road (Japan)" + description "Bouken! Puzzle Road (Japan)" + rom ( name "Bouken! Puzzle Road (Japan).gb" size 32768 crc 9f0f3606 sha1 16d54de69814e1c9aae67a59bb0dcd2a1216395b ) ) game ( - name "Dig Dug (Europe)" - description "Dig Dug (Europe)" - rom ( name "Dig Dug (Europe).gb" size 131072 crc 0af905c0 sha1 9e008ee24c627309b22bf42ec5a3e08af0af8efe ) + name "Boulder Dash (Europe)" + description "Boulder Dash (Europe)" + rom ( name "Boulder Dash (Europe).gb" size 65536 crc 644aec3e sha1 01cc570a16bad4c2c33b393620ec9e25f131d1f4 flags verified ) ) game ( - name "Dig Dug (USA)" - description "Dig Dug (USA)" - rom ( name "Dig Dug (USA).gb" size 131072 crc 6c742478 sha1 951753904389332412d4b0a80b48d7ac61a494fc ) + name "Boulder Dash (Japan)" + description "Boulder Dash (Japan)" + rom ( name "Boulder Dash (Japan).gb" size 65536 crc b5b3f85b sha1 f5a4a5ccda4f559ce85567c4b68f758216aee2d4 ) ) game ( - name "Dijon Gameboy (World) (En,Fr) (Demo) (Aftermarket) (Unl)" - description "Dijon Gameboy (World) (En,Fr) (Demo) (Aftermarket) (Unl)" - rom ( name "Dijon Gameboy (World) (En,Fr) (Demo) (Aftermarket) (Unl).gb" size 1048576 crc b230b782 sha1 f1796dcbfb6f0f5e01c60222c376cc1c46945806 ) + name "Boxing (Japan)" + description "Boxing (Japan)" + rom ( name "Boxing (Japan).gb" size 65536 crc ef7e9fa0 sha1 5af3a0b6e54ca67c3a4cab8833368725cc68e99f ) ) game ( - name "Dino Breeder (Japan) (SGB Enhanced)" - description "Dino Breeder (Japan) (SGB Enhanced)" - rom ( name "Dino Breeder (Japan) (SGB Enhanced).gb" size 262144 crc 3f0aafec sha1 80ccbf87dcd4d4e76f1f6a7a94e00ec2857e530a flags verified ) + name "Boxxle (USA, Europe) (Rev 1)" + description "Boxxle (USA, Europe) (Rev 1)" + rom ( name "Boxxle (USA, Europe) (Rev 1).gb" size 32768 crc c09cee99 sha1 f9d5287bc9d6eda9ec36e9b5a8dbc38cf2cffecf flags verified ) ) game ( - name "Dino Breeder (Japan) (Rev 1) (SGB Enhanced)" - description "Dino Breeder (Japan) (Rev 1) (SGB Enhanced)" - rom ( name "Dino Breeder (Japan) (Rev 1) (SGB Enhanced).gb" size 262144 crc 5b289ab4 sha1 a6e24e442de0541c3f5ec4d28650256c5d25f751 ) + name "Boxxle (USA)" + description "Boxxle (USA)" + rom ( name "Boxxle (USA).gb" size 32768 crc 24843867 sha1 3e169f1db16cc1c3ffbc8645aa7ce28194033d26 flags verified ) ) game ( - name "Dino Breeder 2 (Japan) (SGB Enhanced)" - description "Dino Breeder 2 (Japan) (SGB Enhanced)" - rom ( name "Dino Breeder 2 (Japan) (SGB Enhanced).gb" size 524288 crc 05a3ab7a sha1 ac4b1fe0e917298d81725d7a9bdf46c285502ac7 flags verified ) + name "Boxxle II (USA, Europe)" + description "Boxxle II (USA, Europe)" + rom ( name "Boxxle II (USA, Europe).gb" size 32768 crc c08e9756 sha1 36315dab12915d2d2fad7a37fcb5ce6809118c8a ) ) game ( - name "Dino's Offline Adventure (World) (Aftermarket) (Unl)" - description "Dino's Offline Adventure (World) (Aftermarket) (Unl)" - rom ( name "Dino's Offline Adventure (World) (Aftermarket) (Unl).gb" size 32768 crc d6bd0e6a sha1 6d11c145606f8e7ab25b2b07c299e36c8b442d23 ) + name "Brain Bender (Europe)" + description "Brain Bender (Europe)" + rom ( name "Brain Bender (Europe).gb" size 32768 crc b651bf5d sha1 9502181c62d8343b98cef9b881c29e4573e4fbc9 flags verified ) ) game ( - name "Dirty Racing (Europe) (Proto)" - description "Dirty Racing (Europe) (Proto)" - rom ( name "Dirty Racing (Europe) (Proto).gb" size 131072 crc 974a3cbe sha1 9dc43a8636970dd6bf9d37943e3b1d7c2aa5d570 ) + name "Brain Bender (USA)" + description "Brain Bender (USA)" + rom ( name "Brain Bender (USA).gb" size 32768 crc fbb1f2a1 sha1 56ff8684284765a56918d14620ad38477aaaf0ad ) ) game ( - name "Dirty Racing (Japan)" - description "Dirty Racing (Japan)" - rom ( name "Dirty Racing (Japan).gb" size 131072 crc 43af45b1 sha1 5b58b4d02987ce3a16774bc4a6707d12ac404c1c ) + name "Brain Drain (Europe) (SGB Enhanced)" + description "Brain Drain (Europe) (SGB Enhanced)" + rom ( name "Brain Drain (Europe) (SGB Enhanced).gb" size 131072 crc 8a7fb0e6 sha1 67e1796ed410ecc19efc2f73ef7f5226414cc8bb ) ) game ( - name "DMG Deals Damage (World) (Aftermarket) (Unl)" - description "DMG Deals Damage (World) (Aftermarket) (Unl)" - rom ( name "DMG Deals Damage (World) (Aftermarket) (Unl).gb" size 32768 crc 250e0cbd sha1 a15539199e4b6bd2a71d1ac0e7c61ae4f19a65e7 flags verified ) + name "Brain Drain (Japan) (En) (SGB Enhanced)" + description "Brain Drain (Japan) (En) (SGB Enhanced)" + rom ( name "Brain Drain (Japan) (En) (SGB Enhanced).gb" size 131072 crc e558aacd sha1 225c25d94854f509611b8c0b4b415daf48d51310 ) ) game ( - name "Do I Pass (World) (En) (Demo) (Aftermarket) (Unl)" - description "Do I Pass (World) (En) (Demo) (Aftermarket) (Unl)" - rom ( name "Do I Pass (World) (En) (Demo) (Aftermarket) (Unl).gb" size 1048576 crc f339fa82 sha1 bdbc082017bdf2e4caa84e7d00dad9707727e9d4 ) + name "Brain Drain (USA) (SGB Enhanced)" + description "Brain Drain (USA) (SGB Enhanced)" + rom ( name "Brain Drain (USA) (SGB Enhanced).gb" size 131072 crc aff0b159 sha1 da11b3909bef958abc9b3b184771f4f8fe498456 ) ) game ( - name "Do I Pass (World) (En) (v1.4) (Aftermarket) (Unl)" - description "Do I Pass (World) (En) (v1.4) (Aftermarket) (Unl)" - rom ( name "Do I Pass (World) (En) (v1.4) (Aftermarket) (Unl).gb" size 1048576 crc cfb44d68 sha1 6dde71bbec8b807af5132d1ef2e99c6bb6af3a1c ) + name "Bram Stoker's Dracula (USA, Europe)" + description "Bram Stoker's Dracula (USA, Europe)" + rom ( name "Bram Stoker's Dracula (USA, Europe).gb" size 131072 crc 00cd1876 sha1 d31cb69613a6f0504b4f3f72c18e96b5827686b9 flags verified ) ) game ( - name "Do I Pass (World) (En) (v1.4) (Web) (Aftermarket) (Unl)" - description "Do I Pass (World) (En) (v1.4) (Web) (Aftermarket) (Unl)" - rom ( name "Do I Pass (World) (En) (v1.4) (Web) (Aftermarket) (Unl).gb" size 1048576 crc 62e0c3a2 sha1 e1b516e472e0c681b4ad1c7f4aeda55c91e7f340 ) + name "BreakThru! (USA)" + description "BreakThru! (USA)" + rom ( name "BreakThru! (USA).gb" size 131072 crc 5b8f0df2 sha1 d9a49a71e6b554c2fccce08c446274e886225d50 ) ) game ( - name "Do I Pass (World) (Fr) (v1.4.2) (Aftermarket) (Unl)" - description "Do I Pass (World) (Fr) (v1.4.2) (Aftermarket) (Unl)" - rom ( name "Do I Pass (World) (Fr) (v1.4.2) (Aftermarket) (Unl).gb" size 1048576 crc e393d4aa sha1 d45dfcab4a76b62ea1e10730d01f755e12137484 ) + name "Bubble Bobble (Japan)" + description "Bubble Bobble (Japan)" + rom ( name "Bubble Bobble (Japan).gb" size 131072 crc ad9b300c sha1 3f2e741e0dbdcc65e960f44a322e85748272f3f3 ) ) game ( - name "Do I Pass (World) (En) (v1.5) (Aftermarket) (Unl)" - description "Do I Pass (World) (En) (v1.5) (Aftermarket) (Unl)" - rom ( name "Do I Pass (World) (En) (v1.5) (Aftermarket) (Unl).gb" size 1048576 crc 3890e0a4 sha1 6998e1bbf2ccb9db3d661ddac2d7edf7571d0af7 ) + name "Bubble Bobble (USA, Europe)" + description "Bubble Bobble (USA, Europe)" + rom ( name "Bubble Bobble (USA, Europe).gb" size 131072 crc d516841d sha1 569881bea21cf5fd542ff3dfc40e1626c6748ceb flags verified ) ) game ( - name "Doctor GB Card 16M Loader (World) (Unl)" - description "Doctor GB Card 16M Loader (World) (Unl)" - rom ( name "Doctor GB Card 16M Loader (World) (Unl).gb" size 32768 crc 1bddf36f sha1 c298eacc0c73e648e81fbf5192aec3b6a438e053 ) + name "Bubble Bobble Junior (Japan)" + description "Bubble Bobble Junior (Japan)" + rom ( name "Bubble Bobble Junior (Japan).gb" size 131072 crc 39e261b9 sha1 686c526a557065dc0005068eafdbc6736684f925 ) ) game ( - name "Doctor GB Card 4M (World) (Unl)" - description "Doctor GB Card 4M (World) (Unl)" - rom ( name "Doctor GB Card 4M (World) (Unl).gb" size 524288 crc 5d2e8cff sha1 43962a7459c8ccc0e5988060abd0f8668f30dfde ) + name "Bubble Bobble Part 2 (USA, Europe)" + description "Bubble Bobble Part 2 (USA, Europe)" + rom ( name "Bubble Bobble Part 2 (USA, Europe).gb" size 131072 crc 4106d781 sha1 e258d852713f392454d4291032ce50ad325aba86 flags verified ) ) game ( - name "Doctor GB Card Demo (World) (Demo) (Unl)" - description "Doctor GB Card Demo (World) (Demo) (Unl)" - rom ( name "Doctor GB Card Demo (World) (Demo) (Unl).gb" size 32768 crc b5dfdc26 sha1 1d403b254971faa5834bc48adfd42cc0bbed3fe4 ) + name "Bubble Ghost (Japan)" + description "Bubble Ghost (Japan)" + rom ( name "Bubble Ghost (Japan).gb" size 32768 crc 874d0d6f sha1 f93e37b60025c67d7fbfc035ed727c9a39d8c9f1 ) ) game ( - name "Doctor GB Card Demo (World) (Demo) (Unl) (Alt)" - description "Doctor GB Card Demo (World) (Demo) (Unl) (Alt)" - rom ( name "Doctor GB Card Demo (World) (Demo) (Unl) (Alt).gb" size 32768 crc 3592390b sha1 a6e3b81b8664f41eb18770cd5757ed4d8338be54 ) + name "Bubble Ghost (USA, Europe)" + description "Bubble Ghost (USA, Europe)" + rom ( name "Bubble Ghost (USA, Europe).gb" size 32768 crc 843068fd sha1 b08b8a9bf742f7ca4b355a866b4167741252dcf6 flags verified ) ) game ( - name "Dodge Boy (Japan)" - description "Dodge Boy (Japan)" - rom ( name "Dodge Boy (Japan).gb" size 131072 crc f58dc358 sha1 b48eb2bdc34588847728936491dadda67394f9b7 ) + name "Bubble Ghost (USA, Europe) (Beta)" + description "Bubble Ghost (USA, Europe) (Beta)" + rom ( name "Bubble Ghost (USA, Europe) (Beta).gb" size 32768 crc 4a083f6f sha1 f5d063c70cecadda43d27d0c24f561a8f32b10f2 ) ) game ( - name "Dog's Muck Island (World) (Aftermarket) (Unl)" - description "Dog's Muck Island (World) (Aftermarket) (Unl)" - rom ( name "Dog's Muck Island (World) (Aftermarket) (Unl).gb" size 262144 crc 79a7a06c sha1 eb4cea3b9db770bf3b586578af1ad7427d88ee8e ) + name "Bubsy II (Europe)" + description "Bubsy II (Europe)" + rom ( name "Bubsy II (Europe).gb" size 262144 crc a3164516 sha1 f59306da42c5d8bbf41c870828c83bbcf1e2f0ac ) ) game ( - name "Don't Call Me Mama But Yes I Am Your Mama (World) (v2.0) (Aftermarket) (Unl)" - description "Don't Call Me Mama But Yes I Am Your Mama (World) (v2.0) (Aftermarket) (Unl)" - rom ( name "Don't Call Me Mama But Yes I Am Your Mama (World) (v2.0) (Aftermarket) (Unl).gb" size 1048576 crc 83247308 sha1 4579eaa45e2bf8f17f4dc99bdfb0b98270b871f5 ) + name "Bubsy II (USA)" + description "Bubsy II (USA)" + rom ( name "Bubsy II (USA).gb" size 262144 crc 600a6ad5 sha1 1ac9bf5043caf428994bca3e80158ca697e94c58 ) ) game ( - name "Donkey Kong (Japan, USA) (En) (SGB Enhanced)" - description "Donkey Kong (Japan, USA) (En) (SGB Enhanced)" - rom ( name "Donkey Kong (Japan, USA) (En) (SGB Enhanced).gb" size 524288 crc edab3378 sha1 6ed661bd1d6d8cdd48e1c10f8ca4e8dcba49128e flags verified ) + name "Bugs Bunny Collection (Japan) (SGB Enhanced)" + description "Bugs Bunny Collection (Japan) (SGB Enhanced)" + rom ( name "Bugs Bunny Collection (Japan) (SGB Enhanced).gb" size 262144 crc d2dbea8f sha1 4f1f56b06364272033372230cfe0819cb3e25b50 ) ) game ( - name "Donkey Kong (World) (Rev 1) (SGB Enhanced)" - description "Donkey Kong (World) (Rev 1) (SGB Enhanced)" - rom ( name "Donkey Kong (World) (Rev 1) (SGB Enhanced).gb" size 524288 crc f777a5d8 sha1 397ad2ff25627b83e02c71b54c72bb4deb39e0c0 flags verified ) + name "Bugs Bunny Collection (Japan) (Rev 1) (SGB Enhanced)" + description "Bugs Bunny Collection (Japan) (Rev 1) (SGB Enhanced)" + rom ( name "Bugs Bunny Collection (Japan) (Rev 1) (SGB Enhanced).gb" size 262144 crc 8244220b sha1 9d69d72b7de0377cb0439aa301b1fb82d3ce786a ) ) game ( - name "Donkey Kong Land (Japan) (SGB Enhanced)" - description "Donkey Kong Land (Japan) (SGB Enhanced)" - rom ( name "Donkey Kong Land (Japan) (SGB Enhanced).gb" size 524288 crc 9aeca05c sha1 18fd3fcf90e60122da92079669942b0363049d8f flags verified ) + name "Bugs Bunny Crazy Castle 2, The (USA)" + description "Bugs Bunny Crazy Castle 2, The (USA)" + rom ( name "Bugs Bunny Crazy Castle 2, The (USA).gb" size 131072 crc a973e604 sha1 1e4c8c8fe8b6c34f76cd0da876442f14299da725 flags verified ) ) game ( - name "Donkey Kong Land (USA, Europe) (SGB Enhanced)" - description "Donkey Kong Land (USA, Europe) (SGB Enhanced)" - rom ( name "Donkey Kong Land (USA, Europe) (SGB Enhanced).gb" size 524288 crc 49dc0d37 sha1 4e6d8f085ca197479d59912c1d58e4f3b40c28ac flags verified ) + name "Bugs Bunny Crazy Castle, The (USA, Europe)" + description "Bugs Bunny Crazy Castle, The (USA, Europe)" + rom ( name "Bugs Bunny Crazy Castle, The (USA, Europe).gb" size 65536 crc 403e1b7e sha1 2a3e982e542a849f95b4497025ca5b04db2abe8c flags verified ) ) game ( - name "Donkey Kong Land 2 (USA, Europe) (SGB Enhanced)" - description "Donkey Kong Land 2 (USA, Europe) (SGB Enhanced)" - rom ( name "Donkey Kong Land 2 (USA, Europe) (SGB Enhanced).gb" size 524288 crc 2827e5d4 sha1 89cc4f01653a6105ee5c00e10fc65aa1437fd320 flags verified ) + name "Bung Greetings Demo (World) (Demo) (Unl)" + description "Bung Greetings Demo (World) (Demo) (Unl)" + rom ( name "Bung Greetings Demo (World) (Demo) (Unl).gb" size 65536 crc 1ae05af4 sha1 bb01f845d330377749aeb6df1f7bea0eff78bb89 ) ) game ( - name "Donkey Kong Land 2 (Japan) (Proto) (SGB Enhanced)" - description "Donkey Kong Land 2 (Japan) (Proto) (SGB Enhanced)" - rom ( name "Donkey Kong Land 2 (Japan) (Proto) (SGB Enhanced).gb" size 524288 crc 68e5fc2a sha1 af66548c1a96468dae76e61823e9a9fe439c227c ) + name "Bung New Year's Greetings Demo (World) (Demo) (Unl)" + description "Bung New Year's Greetings Demo (World) (Demo) (Unl)" + rom ( name "Bung New Year's Greetings Demo (World) (Demo) (Unl).gb" size 65536 crc 493d4a1e sha1 737402fe70924f893fc212393eeb7f46f225745a ) ) game ( - name "Donkey Kong Land III (USA, Europe) (Beta) (SGB Enhanced)" - description "Donkey Kong Land III (USA, Europe) (Beta) (SGB Enhanced)" - rom ( name "Donkey Kong Land III (USA, Europe) (Beta) (SGB Enhanced).gb" size 524288 crc 872bbd5e sha1 9d17bc07bd3c48f8bb8a3315faf817d055417f53 ) + name "Bung's Math Test (World) (Unl)" + description "Bung's Math Test (World) (Unl)" + rom ( name "Bung's Math Test (World) (Unl).gb" size 32768 crc ebeda9d2 sha1 68581c24793e8ea63f3273efa7bc098309d77d1a ) ) game ( - name "Donkey Kong Land III (USA, Europe) (SGB Enhanced)" - description "Donkey Kong Land III (USA, Europe) (SGB Enhanced)" - rom ( name "Donkey Kong Land III (USA, Europe) (SGB Enhanced).gb" size 524288 crc b40c159c sha1 a33f10194b5b228863c04abd0e65c7cc5d73fc3e flags verified ) + name "Burai Fighter Deluxe (USA, Europe)" + description "Burai Fighter Deluxe (USA, Europe)" + rom ( name "Burai Fighter Deluxe (USA, Europe).gb" size 65536 crc 3c86f5db sha1 178e18b7e6e65e726b4e06f80d89c55332ea868b flags verified ) ) game ( - name "Donkey Kong Land III (USA, Europe) (Rev 1) (SGB Enhanced)" - description "Donkey Kong Land III (USA, Europe) (Rev 1) (SGB Enhanced)" - rom ( name "Donkey Kong Land III (USA, Europe) (Rev 1) (SGB Enhanced).gb" size 524288 crc a19acdb6 sha1 a6ce883727212e1afb45b48431a46cfbc6f7f6ef flags verified ) + name "Burai Senshi Deluxe (Japan)" + description "Burai Senshi Deluxe (Japan)" + rom ( name "Burai Senshi Deluxe (Japan).gb" size 65536 crc 5a1a20f3 sha1 f8c17e07d25420b7717f4415820c09491bb6a04c ) ) game ( - name "Doomsayer - A Hero's Crusade (USA) (Proto)" - description "Doomsayer - A Hero's Crusade (USA) (Proto)" - rom ( name "Doomsayer - A Hero's Crusade (USA) (Proto).gb" size 131072 crc e74cb320 sha1 565c719e0526330e6573c7ac61322f641ce9324b ) + name "BurgerTime Deluxe (World)" + description "BurgerTime Deluxe (World)" + rom ( name "BurgerTime Deluxe (World).gb" size 65536 crc 88219a49 sha1 1aafcef0dd5fbb8e95188631e0b2decdf84e9aed flags verified ) ) game ( - name "Doraemon - Taiketsu HimitsuDougu!! (Japan)" - description "Doraemon - Taiketsu HimitsuDougu!! (Japan)" - rom ( name "Doraemon - Taiketsu HimitsuDougu!! (Japan).gb" size 131072 crc a42524a3 sha1 5e89e34a2cec89e0aba4e12d18d96671151730ec ) + name "Burning Paper (Japan)" + description "Burning Paper (Japan)" + rom ( name "Burning Paper (Japan).gb" size 131072 crc 88f8c991 sha1 8e2bce98cc840e52d47680f9b1e425bfc9102ac7 ) ) game ( - name "Doraemon 2 - Animal Planet Densetsu (Japan)" - description "Doraemon 2 - Animal Planet Densetsu (Japan)" - rom ( name "Doraemon 2 - Animal Planet Densetsu (Japan).gb" size 131072 crc 843bd5bc sha1 0d72e0310bbf0b23483f37688df61543048c4b31 ) + name "Bust-A-Move 2 - Arcade Edition (USA, Europe)" + description "Bust-A-Move 2 - Arcade Edition (USA, Europe)" + rom ( name "Bust-A-Move 2 - Arcade Edition (USA, Europe).gb" size 131072 crc b94724e6 sha1 6b0942c231890d3e2f6c18e7804040eb4c66dcb3 flags verified ) ) game ( - name "Doraemon Kart (Japan) (SGB Enhanced)" - description "Doraemon Kart (Japan) (SGB Enhanced)" - rom ( name "Doraemon Kart (Japan) (SGB Enhanced).gb" size 262144 crc dd4e588f sha1 f19734b2cb19de0be2d9e80297f567806ce4cad5 ) + name "Bust-A-Move 3 DX (Europe)" + description "Bust-A-Move 3 DX (Europe)" + rom ( name "Bust-A-Move 3 DX (Europe).gb" size 131072 crc e555c612 sha1 e89dc67087205c4113a4d152347eba38204e270b ) ) game ( - name "Doraemon no Game Boy de Asobouyo Deluxe 10 (Japan) (SGB Enhanced)" - description "Doraemon no Game Boy de Asobouyo Deluxe 10 (Japan) (SGB Enhanced)" - rom ( name "Doraemon no Game Boy de Asobouyo Deluxe 10 (Japan) (SGB Enhanced).gb" size 262144 crc b368e717 sha1 7ad70061c8afbbe0890e3d50accd40b2a8cb9790 ) + name "Buster Bros. (USA)" + description "Buster Bros. (USA)" + rom ( name "Buster Bros. (USA).gb" size 131072 crc b4245ca3 sha1 0d1692ff60ef1f6a97bbfd2bf8c1548f1f7439ed ) ) game ( - name "Doraemon no Study Boy 1 - Shou 1 Kokugo Kanji (Japan)" - description "Doraemon no Study Boy 1 - Shou 1 Kokugo Kanji (Japan)" - rom ( name "Doraemon no Study Boy 1 - Shou 1 Kokugo Kanji (Japan).gb" size 524288 crc 652b3ca4 sha1 7be5e001f60338fd605cb3cd918df66a9ebf2ad2 flags verified ) + name "Cadillac II (Japan)" + description "Cadillac II (Japan)" + rom ( name "Cadillac II (Japan).gb" size 65536 crc a6c98122 sha1 a5d405fe7b4ea23708acb3cb71104f63057df6d4 ) ) game ( - name "Doraemon no Study Boy 2 - Shou 1 Sansuu Keisan (Japan)" - description "Doraemon no Study Boy 2 - Shou 1 Sansuu Keisan (Japan)" - rom ( name "Doraemon no Study Boy 2 - Shou 1 Sansuu Keisan (Japan).gb" size 524288 crc 5333d083 sha1 38b9fafd4604bd69a59f0445508f15bfbba459c6 flags verified ) + name "Caesars Palace (Europe) (En,Fr,De,Es,It)" + description "Caesars Palace (Europe) (En,Fr,De,Es,It)" + rom ( name "Caesars Palace (Europe) (En,Fr,De,Es,It).gb" size 131072 crc 78bf3633 sha1 6d77ce1b212406ba9737dd99ffd9443a3887ef79 flags verified ) ) game ( - name "Doraemon no Study Boy 3 - Ku Ku Master (Japan)" - description "Doraemon no Study Boy 3 - Ku Ku Master (Japan)" - rom ( name "Doraemon no Study Boy 3 - Ku Ku Master (Japan).gb" size 524288 crc 0356a509 sha1 7fdd0855dce2c5bbd229c2ba8485a3a020b873a1 flags verified ) + name "Caesars Palace (Japan)" + description "Caesars Palace (Japan)" + rom ( name "Caesars Palace (Japan).gb" size 131072 crc 000aaa74 sha1 2cf0e21f7be55e3246d615550c8459a3659094ef ) ) game ( - name "Doraemon no Study Boy 4 - Shou ni Kokugo Kanji (Japan)" - description "Doraemon no Study Boy 4 - Shou ni Kokugo Kanji (Japan)" - rom ( name "Doraemon no Study Boy 4 - Shou ni Kokugo Kanji (Japan).gb" size 524288 crc 45e3e8f2 sha1 996a57958c9971070cf881f475cfa815361409c4 ) + name "Caesars Palace (USA)" + description "Caesars Palace (USA)" + rom ( name "Caesars Palace (USA).gb" size 131072 crc d9f901a9 sha1 c1ed80f33fc3603edaba1bdf5c317f1a205da3dc flags verified ) ) game ( - name "Doraemon no Study Boy 5 - Shou 2 Sansuu Keisan (Japan)" - description "Doraemon no Study Boy 5 - Shou 2 Sansuu Keisan (Japan)" - rom ( name "Doraemon no Study Boy 5 - Shou 2 Sansuu Keisan (Japan).gb" size 524288 crc 6b39f607 sha1 8bc5692de1850b68767bee01fe4506455aac8cc6 ) + name "Caesars Palace (USA) (Rev 1)" + description "Caesars Palace (USA) (Rev 1)" + rom ( name "Caesars Palace (USA) (Rev 1).gb" size 131072 crc 87a9d605 sha1 126e9ef9e975bbbc6303d5d62a379d4dbd404cf0 flags verified ) ) game ( - name "Doraemon no Study Boy 6 - Gakushuu Kanji Master 1006 (Japan)" - description "Doraemon no Study Boy 6 - Gakushuu Kanji Master 1006 (Japan)" - rom ( name "Doraemon no Study Boy 6 - Gakushuu Kanji Master 1006 (Japan).gb" size 1048576 crc 5a16c88d sha1 1bfbd1aa188cfa1a2168b5e245b87bd67090d810 flags verified ) + name "Caihong Zhanshi - Rainbow Prince (Taiwan) (Unl)" + description "Caihong Zhanshi - Rainbow Prince (Taiwan) (Unl)" + rom ( name "Caihong Zhanshi - Rainbow Prince (Taiwan) (Unl).gb" size 131072 crc 7c80ea40 sha1 13b5bbe649f4b679596df83589af6f6482997726 ) ) game ( - name "Double Dragon (Japan)" - description "Double Dragon (Japan)" - rom ( name "Double Dragon (Japan).gb" size 131072 crc a0645e8a sha1 7dccd7d3ca7223815e7b00a3b664f5e7d7d433b2 ) + name "Calculator (Unknown) (Proto)" + description "Calculator (Unknown) (Proto)" + rom ( name "Calculator (Unknown) (Proto).gb" size 32768 crc dce47d39 sha1 fb21bbf3cacc52a81bbe0c7d33280e8d703f0fcc ) ) game ( - name "Double Dragon (USA, Europe)" - description "Double Dragon (USA, Europe)" - rom ( name "Double Dragon (USA, Europe).gb" size 131072 crc 40a8bf12 sha1 6565a3d89827717d8e5d2e041c743266ba14b412 flags verified ) + name "Capcom Quiz - Hatena no Daibouken (Japan)" + description "Capcom Quiz - Hatena no Daibouken (Japan)" + rom ( name "Capcom Quiz - Hatena no Daibouken (Japan).gb" size 262144 crc 8042afc5 sha1 168583ea18e02647f0b35f9bd0365e37bec076cc ) ) game ( - name "Double Dragon 3 - The Arcade Game (USA, Europe)" - description "Double Dragon 3 - The Arcade Game (USA, Europe)" - rom ( name "Double Dragon 3 - The Arcade Game (USA, Europe).gb" size 131072 crc fc970aef sha1 c596d069d9fbd6372757e5d669a5144e2eb9d8ff flags verified ) + name "Captain America and the Avengers (USA)" + description "Captain America and the Avengers (USA)" + rom ( name "Captain America and the Avengers (USA).gb" size 131072 crc c762b783 sha1 a067c4e20642a6c17f35a855e2d4815470fc6c6b ) ) game ( - name "Double Dragon II (USA, Europe)" - description "Double Dragon II (USA, Europe)" - rom ( name "Double Dragon II (USA, Europe).gb" size 131072 crc 5b96e474 sha1 3532462be3ab1a569890261d20a1a37bfe79e1ea flags verified ) + name "Captain Tsubasa J - Zenkoku Seiha e no Chousen (Japan) (SGB Enhanced)" + description "Captain Tsubasa J - Zenkoku Seiha e no Chousen (Japan) (SGB Enhanced)" + rom ( name "Captain Tsubasa J - Zenkoku Seiha e no Chousen (Japan) (SGB Enhanced).gb" size 524288 crc 33a1e1cf sha1 d3f9c5700389f7a876a4a821db1f99e7da4a6f68 ) ) game ( - name "Double Dribble - 5 on 5 (USA)" - description "Double Dribble - 5 on 5 (USA)" - rom ( name "Double Dribble - 5 on 5 (USA).gb" size 131072 crc ee28749d sha1 d0f18c97b48dd8b355d195d2ddaeee910c5fc2b1 ) + name "Captain Tsubasa VS (Japan)" + description "Captain Tsubasa VS (Japan)" + rom ( name "Captain Tsubasa VS (Japan).gb" size 262144 crc a795e851 sha1 1d48763a64c127b7ecff9876f20ae0761347b4c7 ) ) game ( - name "Double Yakuman (Japan)" - description "Double Yakuman (Japan)" - rom ( name "Double Yakuman (Japan).gb" size 131072 crc 252c32b5 sha1 24dd6ba6a82ca3e6aca44aa471cf03d08371dc80 ) + name "Card Game (Japan)" + description "Card Game (Japan)" + rom ( name "Card Game (Japan).gb" size 65536 crc d05f4c90 sha1 9ac64030c1e1ca89828ea54ac1fb0d884d6d92bb ) ) game ( - name "Double Yakuman II (Japan)" - description "Double Yakuman II (Japan)" - rom ( name "Double Yakuman II (Japan).gb" size 131072 crc a3d77a55 sha1 7f6ed21bf0cce0d524dcbce56af5cab61c85d729 ) + name "Card Games (USA) (Proto)" + description "Card Games (USA) (Proto)" + rom ( name "Card Games (USA) (Proto).gb" size 65536 crc 8217204a sha1 a5a260c56ab07f88a9c942fa06c7e67c9c1ea244 ) ) game ( - name "Double Yakuman Jr. (Japan)" - description "Double Yakuman Jr. (Japan)" - rom ( name "Double Yakuman Jr. (Japan).gb" size 131072 crc 34ac7268 sha1 7d72bc65297f21605521f7320a5b49193e584cd0 ) + name "Casino FunPak (USA, Europe)" + description "Casino FunPak (USA, Europe)" + rom ( name "Casino FunPak (USA, Europe).gb" size 131072 crc 8641ba55 sha1 4418a8b2029f431efd8888817589af6c8b0e76cc flags verified ) ) game ( - name "Downtown - Nekketsu Koushinkyoku - Dokodemo Daiundoukai (Japan)" - description "Downtown - Nekketsu Koushinkyoku - Dokodemo Daiundoukai (Japan)" - rom ( name "Downtown - Nekketsu Koushinkyoku - Dokodemo Daiundoukai (Japan).gb" size 262144 crc 82511a8f sha1 1b8f59467ddce14db359e22567e29f6955c7c92a ) + name "Casper (Europe)" + description "Casper (Europe)" + rom ( name "Casper (Europe).gb" size 131072 crc e4b30634 sha1 1a3d272d8afe81731862a240a77c0d3b80b1d62f ) ) game ( - name "Downtown Special - Kunio-kun no Jidaigeki Da yo Zenin Shuugou! (Japan)" - description "Downtown Special - Kunio-kun no Jidaigeki Da yo Zenin Shuugou! (Japan)" - rom ( name "Downtown Special - Kunio-kun no Jidaigeki Da yo Zenin Shuugou! (Japan).gb" size 262144 crc 229e9113 sha1 97ff2392f126b195ac8a1700a9a91aa364549dfd ) + name "Casper (USA)" + description "Casper (USA)" + rom ( name "Casper (USA).gb" size 131072 crc e67a10e1 sha1 18b90172789c87819fe4d606aa7874109bcd8024 ) ) game ( - name "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv)" - description "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv)" - rom ( name "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv).gb" size 262144 crc f13a60b8 sha1 ba5aaac92c4a2ca2d6a752c521e4d95108444a4e ) + name "Casper (USA) (Beta)" + description "Casper (USA) (Beta)" + rom ( name "Casper (USA) (Beta).gb" size 131072 crc e0ab72fb sha1 1d036bed67da4dc57add0e9e266fbdb993778823 ) ) game ( - name "Dr. Franken (Japan)" - description "Dr. Franken (Japan)" - rom ( name "Dr. Franken (Japan).gb" size 131072 crc 3d04b8e7 sha1 6350ec30e51f388e0e290f387989cb1c7a24a91c ) + name "Castelian (USA) (Beta)" + description "Castelian (USA) (Beta)" + rom ( name "Castelian (USA) (Beta).gb" size 32768 crc a08cb239 sha1 0c69cee488d7589c6bf0a1b7e2c3d20f2b4d3042 ) ) game ( - name "Dr. Franken (USA)" - description "Dr. Franken (USA)" - rom ( name "Dr. Franken (USA).gb" size 131072 crc d409375b sha1 2b136ef8e3dd082ccb4716035545fb2e03438c66 flags verified ) + name "Castelian (Europe)" + description "Castelian (Europe)" + rom ( name "Castelian (Europe).gb" size 32768 crc 2f752404 sha1 6720d86d420831a0a4865d4a59c4ba6fe98fa34d flags verified ) ) game ( - name "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta)" - description "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta)" - rom ( name "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta).gb" size 262144 crc a65adc31 sha1 440eb30e54bf257246923149d44bab3dfafed2aa ) + name "Castelian (USA)" + description "Castelian (USA)" + rom ( name "Castelian (USA).gb" size 32768 crc f2d739e4 sha1 a03982e2ffa9aa368fe11bc09f024207bada45eb ) ) game ( - name "Dr. Franken II (USA, Europe) (En,Fr,De,Es,It,Nl,Sv)" - description "Dr. Franken II (USA, Europe) (En,Fr,De,Es,It,Nl,Sv)" - rom ( name "Dr. Franken II (USA, Europe) (En,Fr,De,Es,It,Nl,Sv).gb" size 262144 crc 0d62473d sha1 8d578ce74907131114279854a0dc376f4426120c flags verified ) + name "Castle Quest (Europe)" + description "Castle Quest (Europe)" + rom ( name "Castle Quest (Europe).gb" size 131072 crc 2f8aaf6f sha1 45b38a334481f620bb7165fee81391036a54a748 ) ) game ( - name "Dr. Mario (World)" - description "Dr. Mario (World)" - rom ( name "Dr. Mario (World).gb" size 32768 crc 10c98dd1 sha1 f1006d6cf77469092f3b9f266d0a65da9c91ac42 flags verified ) + name "Castle Quest (Europe) (Beta)" + description "Castle Quest (Europe) (Beta)" + rom ( name "Castle Quest (Europe) (Beta).gb" size 131072 crc 8a5636ea sha1 356c8510b0647e56a558aba9d5dc4cc9d3ccd94c ) ) game ( - name "Dr. Mario (World) (Rev 1)" - description "Dr. Mario (World) (Rev 1)" - rom ( name "Dr. Mario (World) (Rev 1).gb" size 32768 crc f0225dd0 sha1 d31d67d0682515c7c85deaa1752b02231150e5bf flags verified ) + name "Castlevania - The Adventure (USA) (Castlevania Anniversary Collection)" + description "Castlevania - The Adventure (USA) (Castlevania Anniversary Collection)" + rom ( name "Castlevania - The Adventure (USA) (Castlevania Anniversary Collection).gb" size 65536 crc 548ce311 sha1 0d1a75cf0e6e7f6b106cfed7aa0b716daf5f9dc8 flags verified ) ) game ( - name "Dr. Mario (World) (Beta)" - description "Dr. Mario (World) (Beta)" - rom ( name "Dr. Mario (World) (Beta).gb" size 32768 crc 2b2f4f8f sha1 4b2343f40e7ca3c583108ed70a870c7bd906b108 ) + name "Castlevania - The Adventure (Europe)" + description "Castlevania - The Adventure (Europe)" + rom ( name "Castlevania - The Adventure (Europe).gb" size 65536 crc 6977c265 sha1 d54888039344597fa038f2c5eedc0726dd35cc46 flags verified ) ) game ( - name "Dracula Densetsu (Japan) (Castlevania Anniversary Collection)" - description "Dracula Densetsu (Japan) (Castlevania Anniversary Collection)" - rom ( name "Dracula Densetsu (Japan) (Castlevania Anniversary Collection).gb" size 65536 crc 4d57af56 sha1 5a79f9d5d6b710216921a89450b727a9741e0d83 flags verified ) + name "Castlevania - The Adventure (USA)" + description "Castlevania - The Adventure (USA)" + rom ( name "Castlevania - The Adventure (USA).gb" size 65536 crc 216e6aa1 sha1 fd9116efcd8eb9698f483cc5745f83b3674d7d13 flags verified ) ) game ( - name "Dracula Densetsu (Japan)" - description "Dracula Densetsu (Japan)" - rom ( name "Dracula Densetsu (Japan).gb" size 65536 crc a35b9ef5 sha1 bedeb390391779400de14196d24f07a451184ece flags verified ) + name "Castlevania II - Belmont's Revenge (USA, Europe)" + description "Castlevania II - Belmont's Revenge (USA, Europe)" + rom ( name "Castlevania II - Belmont's Revenge (USA, Europe).gb" size 131072 crc 8875c8fe sha1 696b9ad1e9cfb7112977c9a7c05cf64fe8423d8a flags verified ) ) game ( - name "Dracula Densetsu II (Japan)" - description "Dracula Densetsu II (Japan)" - rom ( name "Dracula Densetsu II (Japan).gb" size 131072 crc 7582ae14 sha1 bca90edddbf50d0d05630852c092fc5d3e0df9d4 ) + name "Castlevania II - Belmont's Revenge (USA, Europe) (Castlevania Anniversary Collection)" + description "Castlevania II - Belmont's Revenge (USA, Europe) (Castlevania Anniversary Collection)" + rom ( name "Castlevania II - Belmont's Revenge (USA, Europe) (Castlevania Anniversary Collection).gb" size 131072 crc bd28ba07 sha1 823e3c0f2de29f1f2548a9c4f74a956fb39dd3b8 flags verified ) ) game ( - name "Dracula Densetsu II (Japan) (Castlevania Anniversary Collection)" - description "Dracula Densetsu II (Japan) (Castlevania Anniversary Collection)" - rom ( name "Dracula Densetsu II (Japan) (Castlevania Anniversary Collection).gb" size 131072 crc 8709434b sha1 3d0c52d7f566fd717e9117ca4b948174b7864769 flags verified ) + name "Castlevania Legends (USA, Europe) (SGB Enhanced)" + description "Castlevania Legends (USA, Europe) (SGB Enhanced)" + rom ( name "Castlevania Legends (USA, Europe) (SGB Enhanced).gb" size 262144 crc ad9c17fb sha1 91a8e49bf6eac5fe62ec2cc5e6decbd08ce9b515 flags verified ) ) game ( - name "Dragon Ball Z - Gokuu Gekitouden (Japan) (SGB Enhanced)" - description "Dragon Ball Z - Gokuu Gekitouden (Japan) (SGB Enhanced)" - rom ( name "Dragon Ball Z - Gokuu Gekitouden (Japan) (SGB Enhanced).gb" size 524288 crc ff3c027d sha1 1f7a08d2e51e90d770d9dbf4092166b2bfa5697e ) + name "Catrap (USA) (Beta)" + description "Catrap (USA) (Beta)" + rom ( name "Catrap (USA) (Beta).gb" size 32768 crc ca3bc888 sha1 928b9b3cb2ed5e6d6fc754679b3c994f7ed803c3 ) ) game ( - name "Dragon Ball Z - Gokuu Hishouden (Japan) (SGB Enhanced)" - description "Dragon Ball Z - Gokuu Hishouden (Japan) (SGB Enhanced)" - rom ( name "Dragon Ball Z - Gokuu Hishouden (Japan) (SGB Enhanced).gb" size 262144 crc 38da46d7 sha1 6bf8f3400bf323edecc2152c4a86f6b0cae628fe ) + name "Catrap (USA)" + description "Catrap (USA)" + rom ( name "Catrap (USA).gb" size 32768 crc adb96150 sha1 171e4d54f22f8dc137d12828fcc2da9874c56970 ) ) game ( - name "Dragon Ball Z 3 (USA) (SGB Enhanced) (Unl)" - description "Dragon Ball Z 3 (USA) (SGB Enhanced) (Unl)" - rom ( name "Dragon Ball Z 3 (USA) (SGB Enhanced) (Unl).gb" size 1048576 crc 71b8ea17 sha1 c43eb3906f77dda5fee94a0fce0b6d783461238c ) + name "Cave Noire (Japan)" + description "Cave Noire (Japan)" + rom ( name "Cave Noire (Japan).gb" size 131072 crc 44256a2f sha1 6acdf05aac8e3792a98a199cb6e90180e95230cd ) ) game ( - name "Dragon Battle (World) (Demo) (Aftermarket) (Unl)" - description "Dragon Battle (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Dragon Battle (World) (Demo) (Aftermarket) (Unl).gb" size 4194304 crc c1e1e52c sha1 c5ac56e266c421a1c5b82de46859a44f75d03359 ) + name "Centipede (USA) (Majesco)" + description "Centipede (USA) (Majesco)" + rom ( name "Centipede (USA) (Majesco).gb" size 131072 crc e957014f sha1 a3a5755020c9cbe13fc1a815288830d2e143367f ) ) game ( - name "Dragon Slayer Gaiden - Nemuri no Oukan (Japan)" - description "Dragon Slayer Gaiden - Nemuri no Oukan (Japan)" - rom ( name "Dragon Slayer Gaiden - Nemuri no Oukan (Japan).gb" size 131072 crc 10dcbdc3 sha1 ef58063d896533398288a4f07245f23efa3aee4a ) + name "Centipede (USA, Europe) (Accolade)" + description "Centipede (USA, Europe) (Accolade)" + rom ( name "Centipede (USA, Europe) (Accolade).gb" size 32768 crc 245afcdc sha1 0106c3dc8016398e9d24e2472c867487c3bd376f flags verified ) ) game ( - name "Dragon Slayer I (Japan)" - description "Dragon Slayer I (Japan)" - rom ( name "Dragon Slayer I (Japan).gb" size 32768 crc 308a2465 sha1 7d987446f67d8bee42482a4932d0fa60318238e4 ) + name "Chachamaru Boukenki 3 - Abyss no Tou (Japan)" + description "Chachamaru Boukenki 3 - Abyss no Tou (Japan)" + rom ( name "Chachamaru Boukenki 3 - Abyss no Tou (Japan).gb" size 131072 crc 9dfd4bc0 sha1 9a92ccc5758506a7ad07d251bf6c401fe33ad215 ) ) game ( - name "Dragon Tail (Japan)" - description "Dragon Tail (Japan)" - rom ( name "Dragon Tail (Japan).gb" size 131072 crc 1d1155af sha1 390addf6bb52452dc6370eb54c702972e51968a2 ) + name "Chachamaru Panic (Japan)" + description "Chachamaru Panic (Japan)" + rom ( name "Chachamaru Panic (Japan).gb" size 65536 crc aa920298 sha1 c6cbb08d3bb9a4deccf1df880465ce5d23907839 ) ) game ( - name "Dragon's Lair (Japan)" - description "Dragon's Lair (Japan)" - rom ( name "Dragon's Lair (Japan).gb" size 131072 crc 73c994a0 sha1 e344b536e3edcf1628d09773f694e14ab2864b7a ) + name "Chalvo 55 - Super Puzzle Action (Japan)" + description "Chalvo 55 - Super Puzzle Action (Japan)" + rom ( name "Chalvo 55 - Super Puzzle Action (Japan).gb" size 524288 crc 74d50b47 sha1 55aad975351670c3f632e1ebcc939c48410d29b3 flags verified ) ) game ( - name "Dragon's Lair - The Legend (Europe)" - description "Dragon's Lair - The Legend (Europe)" - rom ( name "Dragon's Lair - The Legend (Europe).gb" size 131072 crc 00a14889 sha1 babc3c70d5b73df268cd5c9e5e841fe277b57003 flags verified ) + name "Championship Pool (USA)" + description "Championship Pool (USA)" + rom ( name "Championship Pool (USA).gb" size 131072 crc ef02beb6 sha1 5698fa095f737a4345f02649b4b0b96ad66660d0 flags verified ) ) game ( - name "Dragon's Lair - The Legend (USA)" - description "Dragon's Lair - The Legend (USA)" - rom ( name "Dragon's Lair - The Legend (USA).gb" size 131072 crc 7a38b5c3 sha1 4e947908fde7ef9892c59021c6eea0607771f6d2 ) + name "Chase H.Q. (USA, Europe)" + description "Chase H.Q. (USA, Europe)" + rom ( name "Chase H.Q. (USA, Europe).gb" size 131072 crc 67a45d19 sha1 cbcd6254b1b0227ba6aa8d95c979abb7fe8e4d38 flags verified ) ) game ( - name "Dragonborne (World) (Aftermarket) (Unl)" - description "Dragonborne (World) (Aftermarket) (Unl)" - rom ( name "Dragonborne (World) (Aftermarket) (Unl).gb" size 2097152 crc 0ae28712 sha1 e3cd09069ee59ed3f7915a79af0667de4ebd7d50 ) + name "Chessmaster, The (Europe)" + description "Chessmaster, The (Europe)" + rom ( name "Chessmaster, The (Europe).gb" size 65536 crc 02852e24 sha1 26f1d9cbb392ff07eafb8cd59526470849de9f38 flags verified ) ) game ( - name "Dragonborne (World) (Demo) (Aftermarket) (Unl)" - description "Dragonborne (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Dragonborne (World) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc eda66890 sha1 3a5bcd9daa830842da60d8ebf35fa7036a259d76 ) + name "Chessmaster, The (Japan)" + description "Chessmaster, The (Japan)" + rom ( name "Chessmaster, The (Japan).gb" size 65536 crc 82150e4a sha1 092d878bb8431ac1334dfa9cb91c4b12f1a4f365 ) ) game ( - name "DragonHeart (France)" - description "DragonHeart (France)" - rom ( name "DragonHeart (France).gb" size 524288 crc 8d089356 sha1 6b01e78df8a7dc3fb171d488cae38501fce3b660 ) + name "Chessmaster, The (USA, Europe)" + description "Chessmaster, The (USA, Europe)" + rom ( name "Chessmaster, The (USA, Europe).gb" size 65536 crc 0c1d2b68 sha1 0e167c8ba379103775ae8e18ec9e0b819bdd5897 flags verified ) ) game ( - name "DragonHeart (USA, Europe)" - description "DragonHeart (USA, Europe)" - rom ( name "DragonHeart (USA, Europe).gb" size 524288 crc 5129a518 sha1 1800ceeba6ed491e5f85997c945ab52b09f6e4ba flags verified ) + name "Chessmaster, The (USA) (Rev 1)" + description "Chessmaster, The (USA) (Rev 1)" + rom ( name "Chessmaster, The (USA) (Rev 1).gb" size 65536 crc 59ed370c sha1 f0351faab8b912967552684d4160f5cf94540d41 ) ) game ( - name "Dropzone (Europe)" - description "Dropzone (Europe)" - rom ( name "Dropzone (Europe).gb" size 32768 crc 351a7277 sha1 0bf73ffa90fdba5a4ee4e2338bb2f0d01af6fb88 ) + name "Chibi Maruko-chan - Maruko Deluxe Theater (Japan) (SGB Enhanced)" + description "Chibi Maruko-chan - Maruko Deluxe Theater (Japan) (SGB Enhanced)" + rom ( name "Chibi Maruko-chan - Maruko Deluxe Theater (Japan) (SGB Enhanced).gb" size 131072 crc 886049f9 sha1 0e774a12ed2d99b5a62a5ad3f634f2c32da5929a ) ) game ( - name "Dropzone (Europe) (Beta)" - description "Dropzone (Europe) (Beta)" - rom ( name "Dropzone (Europe) (Beta).gb" size 131072 crc 374f80b0 sha1 ac64c854dfea6387f262a2870f85c369d2cd14f5 ) + name "Chibi Maruko-chan - Okozukai Daisakusen! (Japan)" + description "Chibi Maruko-chan - Okozukai Daisakusen! (Japan)" + rom ( name "Chibi Maruko-chan - Okozukai Daisakusen! (Japan).gb" size 65536 crc eab175ff sha1 1b6838b9711ecbc6c09606da53d53309593103b2 ) ) game ( - name "Druaga no Tou (Japan)" - description "Druaga no Tou (Japan)" - rom ( name "Druaga no Tou (Japan).gb" size 131072 crc f924bdb1 sha1 7701f8c535f612943d736fef342973e9c77011df flags verified ) + name "Chibi Maruko-chan 2 - Deluxe Maruko World (Japan)" + description "Chibi Maruko-chan 2 - Deluxe Maruko World (Japan)" + rom ( name "Chibi Maruko-chan 2 - Deluxe Maruko World (Japan).gb" size 131072 crc abff3314 sha1 4fd5eb092086ed62aa978eacc1c3904c921f9615 ) ) game ( - name "DuckTales (Europe)" - description "DuckTales (Europe)" - rom ( name "DuckTales (Europe).gb" size 65536 crc ac6483dc sha1 04aa9c515c2ede8fdf37b29e69c44481f8a8630c flags verified ) + name "Chibi Maruko-chan 3 - Mezase! Game Taishou no Maki (Japan)" + description "Chibi Maruko-chan 3 - Mezase! Game Taishou no Maki (Japan)" + rom ( name "Chibi Maruko-chan 3 - Mezase! Game Taishou no Maki (Japan).gb" size 131072 crc 44e933c8 sha1 127fa75126fbd45ea0e3f95f862fbd4f8182780e ) ) game ( - name "DuckTales (Japan)" - description "DuckTales (Japan)" - rom ( name "DuckTales (Japan).gb" size 65536 crc 5b5410f5 sha1 ce734cc3548f1d5a0cb26017b29b714f23d80c0f ) + name "Chibi Maruko-chan 4 - Kore ga Nihon Da yo! Ouji-sama (Japan)" + description "Chibi Maruko-chan 4 - Kore ga Nihon Da yo! Ouji-sama (Japan)" + rom ( name "Chibi Maruko-chan 4 - Kore ga Nihon Da yo! Ouji-sama (Japan).gb" size 131072 crc e55138be sha1 a4b268924e2fb500b8b13461a9cb20aec648a52f ) ) game ( - name "DuckTales (USA)" - description "DuckTales (USA)" - rom ( name "DuckTales (USA).gb" size 65536 crc 2bbbb54d sha1 93460364e33e8fb09a0659738044d0297cd4df69 ) + name "Chiki Chiki Machine Mou Race (Japan)" + description "Chiki Chiki Machine Mou Race (Japan)" + rom ( name "Chiki Chiki Machine Mou Race (Japan).gb" size 131072 crc 7e40044a sha1 45963623bc09e0a132867e1a78173b2c747c3b6f ) ) game ( - name "DuckTales 2 (Europe)" - description "DuckTales 2 (Europe)" - rom ( name "DuckTales 2 (Europe).gb" size 131072 crc 169b00c1 sha1 68113dcd6482a8a54e48c69223fcf2e2dedea844 flags verified ) + name "Chiki Chiki Tengoku (Japan)" + description "Chiki Chiki Tengoku (Japan)" + rom ( name "Chiki Chiki Tengoku (Japan).gb" size 32768 crc eb33f601 sha1 56012e7f9150ec8f9117b0540dcbd2bf82c948bb ) ) game ( - name "DuckTales 2 (Japan)" - description "DuckTales 2 (Japan)" - rom ( name "DuckTales 2 (Japan).gb" size 131072 crc 2b693cde sha1 d7c33c30e9921d119c4f4c9a77be9406207368eb ) + name "Chikyuu Kaihou Gun ZAS (Japan) (En)" + description "Chikyuu Kaihou Gun ZAS (Japan) (En)" + rom ( name "Chikyuu Kaihou Gun ZAS (Japan) (En).gb" size 131072 crc 7bfd1cff sha1 2ff6d0242d845669445e3d97fffae5c5f7943cfd ) ) game ( - name "DuckTales 2 (USA)" - description "DuckTales 2 (USA)" - rom ( name "DuckTales 2 (USA).gb" size 131072 crc b151509d sha1 c9d5b7a71badcc7b198897b4888482f663f03504 flags verified ) + name "Choplifter II (Japan)" + description "Choplifter II (Japan)" + rom ( name "Choplifter II (Japan).gb" size 131072 crc 5109f484 sha1 9392ffc6831d5f029f5ad906af40b607b8eb221b ) ) game ( - name "Dungeon Land (Japan)" - description "Dungeon Land (Japan)" - rom ( name "Dungeon Land (Japan).gb" size 131072 crc 11be4b45 sha1 e354b0e78992f66bd598399998790231ff81b86f flags verified ) + name "Choplifter II - Rescue & Survive (Europe)" + description "Choplifter II - Rescue & Survive (Europe)" + rom ( name "Choplifter II - Rescue & Survive (Europe).gb" size 131072 crc 5e2e4e19 sha1 08f5cdbcb650be51fe3998a28174e40997618349 flags verified ) ) game ( - name "Dungeon Warrior (Europe) (Proto)" - description "Dungeon Warrior (Europe) (Proto)" - rom ( name "Dungeon Warrior (Europe) (Proto).gb" size 65536 crc 2910429c sha1 21a6fba83faa7649fbb2e75176649bcd7d846d25 ) + name "Choplifter II - Rescue & Survive (USA)" + description "Choplifter II - Rescue & Survive (USA)" + rom ( name "Choplifter II - Rescue & Survive (USA).gb" size 131072 crc 9c7d5e79 sha1 76ef770b9c75485cc29869fca6118887aee208da ) ) game ( - name "DX Bakenou Z (Japan)" - description "DX Bakenou Z (Japan)" - rom ( name "DX Bakenou Z (Japan).gb" size 131072 crc 3ef2e823 sha1 346ed92c1f56221d1feda2a008ead2e3940bcbcb ) + name "Choplifter III (Europe)" + description "Choplifter III (Europe)" + rom ( name "Choplifter III (Europe).gb" size 131072 crc 1b3b46ef sha1 fb1c83ee69fa32c26cdc7031733f17b90cdb0570 flags verified ) ) game ( - name "DX Bakenou Z (Japan) (Rev 1)" - description "DX Bakenou Z (Japan) (Rev 1)" - rom ( name "DX Bakenou Z (Japan) (Rev 1).gb" size 131072 crc fadfd0f6 sha1 6e2b9b21ea7d8d482be1f17722a579f720f2029d flags verified ) + name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (SGB Enhanced)" + description "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (SGB Enhanced)" + rom ( name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (SGB Enhanced).gb" size 524288 crc b3e8028d sha1 66e8df39ac137fe2b92581f2d88adfa0b0c3ac14 flags verified ) ) game ( - name "Dynablaster (Europe)" - description "Dynablaster (Europe)" - rom ( name "Dynablaster (Europe).gb" size 131072 crc 9677d157 sha1 3c284831353be165e20b56f3728b0421eaea274a flags verified ) + name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (Beta) (SGB Enhanced)" + description "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (Beta) (SGB Enhanced)" + rom ( name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster (Japan) (Beta) (SGB Enhanced).gb" size 524288 crc e6c3a473 sha1 ac2360d790c855fde91fca26ee88a4814a1f2e9f ) ) game ( - name "Earthworm Jim (Europe)" - description "Earthworm Jim (Europe)" - rom ( name "Earthworm Jim (Europe).gb" size 262144 crc b1a7a008 sha1 4249abe39285b02ccb0e739b5a2cf96ace1281ff flags verified ) + name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster 2 (Japan) (SGB Enhanced)" + description "Chou Mashin Eiyuu Den Wataru - Mazekko Monster 2 (Japan) (SGB Enhanced)" + rom ( name "Chou Mashin Eiyuu Den Wataru - Mazekko Monster 2 (Japan) (SGB Enhanced).gb" size 524288 crc e5520693 sha1 54d2672d9720fa4322a7a45244aa898d321c1dd1 ) ) game ( - name "Earthworm Jim (USA)" - description "Earthworm Jim (USA)" - rom ( name "Earthworm Jim (USA).gb" size 262144 crc 259ff267 sha1 f5d3085de17a5181c07739e49be7637faa5ff932 ) + name "Chousoku Spinner (Japan) (SGB Enhanced)" + description "Chousoku Spinner (Japan) (SGB Enhanced)" + rom ( name "Chousoku Spinner (Japan) (SGB Enhanced).gb" size 524288 crc b4fa9cf2 sha1 057a3251bbb7eb4e04b01f786bd2986af5eabc58 ) ) game ( - name "Eclipse (Europe) (Proto)" - description "Eclipse (Europe) (Proto)" - rom ( name "Eclipse (Europe) (Proto).gb" size 65536 crc 6b507efd sha1 de02a34675a57d450284103681951436a4c830cd ) + name "Chuck Rock (USA, Europe)" + description "Chuck Rock (USA, Europe)" + rom ( name "Chuck Rock (USA, Europe).gb" size 131072 crc c5951d9e sha1 601453f98ba7d92ebe71f3e86952a584cbea090c ) ) game ( - name "Edd the Duck (Europe) (Proto)" - description "Edd the Duck (Europe) (Proto)" - rom ( name "Edd the Duck (Europe) (Proto).gb" size 131072 crc 486463a4 sha1 4ee8fa0c4f4c9268182945835f19c25eb055ceb3 ) + name "Cliffhanger (USA, Europe)" + description "Cliffhanger (USA, Europe)" + rom ( name "Cliffhanger (USA, Europe).gb" size 131072 crc aa133439 sha1 c74f85035842f8a2d9560066d7065ff86d9107e2 flags verified ) ) game ( - name "Eddie's Puzzle Time (USA) (Proto)" - description "Eddie's Puzzle Time (USA) (Proto)" - rom ( name "Eddie's Puzzle Time (USA) (Proto).gb" size 65536 crc f2600f02 sha1 cd2695295831737d0f8a7eb825bbfe870b9c0bfd ) + name "Collection Pocket (Japan) (SGB Enhanced)" + description "Collection Pocket (Japan) (SGB Enhanced)" + rom ( name "Collection Pocket (Japan) (SGB Enhanced).gb" size 262144 crc 34e62c8b sha1 daad5ec53da0e375cee3962c0a9031d8a67020fd ) ) game ( - name "Elden Ring GB (World) (Aftermarket) (Unl)" - description "Elden Ring GB (World) (Aftermarket) (Unl)" - rom ( name "Elden Ring GB (World) (Aftermarket) (Unl).gb" size 524288 crc e7a420f3 sha1 2e0bec6acf1a94ae3f2f6cf2040323862933d95a ) + name "College Slam (USA)" + description "College Slam (USA)" + rom ( name "College Slam (USA).gb" size 524288 crc a549a572 sha1 84dc6269fbe4ee4c157f940b0a9630412e099cc6 ) ) game ( - name "Elevator Action (Japan)" - description "Elevator Action (Japan)" - rom ( name "Elevator Action (Japan).gb" size 65536 crc bead8ae4 sha1 16dbf00df012c1216d9d4abec9abcd5512d053a3 ) + name "Contra (World) (Contra Anniversary Collection)" + description "Contra (World) (Contra Anniversary Collection)" + rom ( name "Contra (World) (Contra Anniversary Collection).gb" size 131072 crc cc67a046 sha1 6fea1350ac04f418095cca5f157a9c770a0505bc flags verified ) ) game ( - name "Elevator Action (USA, Europe)" - description "Elevator Action (USA, Europe)" - rom ( name "Elevator Action (USA, Europe).gb" size 65536 crc b749a927 sha1 c0c9de672a31f314e98392160fc343cf46ee98b9 flags verified ) + name "Contra (Japan) (En)" + description "Contra (Japan) (En)" + rom ( name "Contra (Japan) (En).gb" size 131072 crc cde6de15 sha1 c8b34b5aba3d448e357b59cdf106ee9b134713db ) ) game ( - name "Elite Soccer (USA) (SGB Enhanced)" - description "Elite Soccer (USA) (SGB Enhanced)" - rom ( name "Elite Soccer (USA) (SGB Enhanced).gb" size 131072 crc f54158a6 sha1 4576881ea25e29ebba91c49c89f8e70e105fbc60 ) + name "Contra - The Alien Wars (USA) (SGB Enhanced)" + description "Contra - The Alien Wars (USA) (SGB Enhanced)" + rom ( name "Contra - The Alien Wars (USA) (SGB Enhanced).gb" size 131072 crc f1c81eb0 sha1 2e23477eb8738d7fb45e13b02f054422222c9c4f flags verified ) ) game ( - name "Exodus - Journey to the Promised Land (USA) (Unl)" - description "Exodus - Journey to the Promised Land (USA) (Unl)" - rom ( name "Exodus - Journey to the Promised Land (USA) (Unl).gb" size 131072 crc 2e5497ef sha1 685d5a47a1fc386d7b451c8b2733e654b7779b71 ) + name "Contra Spirits (Japan) (SGB Enhanced)" + description "Contra Spirits (Japan) (SGB Enhanced)" + rom ( name "Contra Spirits (Japan) (SGB Enhanced).gb" size 131072 crc 7fc22df5 sha1 72213c5d8af05cad5f17a42566f7383066612eee ) ) game ( - name "Extra Bases (USA)" - description "Extra Bases (USA)" - rom ( name "Extra Bases (USA).gb" size 131072 crc 19608641 sha1 bf44f14a948e8816fb9deea229512d979cb42aec ) + name "Cool Ball (USA)" + description "Cool Ball (USA)" + rom ( name "Cool Ball (USA).gb" size 32768 crc e045b886 sha1 f1932d4a3f063c5395e8558a63c64e5840789ce6 ) ) game ( - name "F-1 Race (World)" - description "F-1 Race (World)" - rom ( name "F-1 Race (World).gb" size 131072 crc 7e4febdf sha1 96490be847aeeded0b635f45b05683a6defdf2e8 ) + name "Cool Hand (Europe)" + description "Cool Hand (Europe)" + rom ( name "Cool Hand (Europe).gb" size 262144 crc 0d430d1a sha1 a6fe59bcc29b6d9ae6712d99822a123d2434f3b3 flags verified ) ) game ( - name "F-1 Race (World) (Rev 1)" - description "F-1 Race (World) (Rev 1)" - rom ( name "F-1 Race (World) (Rev 1).gb" size 131072 crc ab83bd70 sha1 0256082f482af57e0472f5713a432a22bfa4d2fc flags verified ) + name "Cool Hand (Europe) (Fr,De)" + description "Cool Hand (Europe) (Fr,De)" + rom ( name "Cool Hand (Europe) (Fr,De).gb" size 262144 crc a2f01695 sha1 b26441e13b9dc806b182999ff8784cef46961010 ) ) game ( - name "F-1 Spirit (Japan)" - description "F-1 Spirit (Japan)" - rom ( name "F-1 Spirit (Japan).gb" size 131072 crc f9e08783 sha1 4f950151001c2c7e157bc407601d9a8eb9d2523c ) + name "Cool Spot (Europe)" + description "Cool Spot (Europe)" + rom ( name "Cool Spot (Europe).gb" size 131072 crc 1987eacc sha1 51efa64a6047879b4b9e6e521e65c9d7f191556f flags verified ) ) game ( - name "F-15 Strike Eagle (USA, Europe)" - description "F-15 Strike Eagle (USA, Europe)" - rom ( name "F-15 Strike Eagle (USA, Europe).gb" size 131072 crc 045dee8c sha1 237a08abe860bce316f1ce337afb11ee0e566037 ) + name "Cool Spot (USA)" + description "Cool Spot (USA)" + rom ( name "Cool Spot (USA).gb" size 131072 crc aba1dac9 sha1 b23f3259fdec43ce004e536d30255e1c2a642ffc flags verified ) ) game ( - name "F-15 Strike Eagle II (USA, Europe) (Beta) (July, 1992)" - description "F-15 Strike Eagle II (USA, Europe) (Beta) (July, 1992)" - rom ( name "F-15 Strike Eagle II (USA, Europe) (Beta) (July, 1992).gb" size 131072 crc d80bdbba sha1 298c07ef596ab3a3c4a320b2f2d7e2c0dbaf764d ) + name "Cool World (USA, Europe)" + description "Cool World (USA, Europe)" + rom ( name "Cool World (USA, Europe).gb" size 131072 crc a193c0d0 sha1 1919495cc83c4126c90d6cfa2e14427b6364da3a flags verified ) ) game ( - name "F-Zero - Project (World) (Aftermarket) (Unl)" - description "F-Zero - Project (World) (Aftermarket) (Unl)" - rom ( name "F-Zero - Project (World) (Aftermarket) (Unl).gb" size 1048576 crc 4c707059 sha1 5b823ee17691d286a45f0667cddd59ccaaab5d8b ) + name "Cosmo Tank (Japan) (Beta)" + description "Cosmo Tank (Japan) (Beta)" + rom ( name "Cosmo Tank (Japan) (Beta).gb" size 131072 crc 2022bbb9 sha1 8963c2e8e42c452528078f10df699fd266f01749 ) ) game ( - name "F1 Boy (Japan)" - description "F1 Boy (Japan)" - rom ( name "F1 Boy (Japan).gb" size 65536 crc fac1f53b sha1 632f0ccc2bcb1c33ad46724d7b1bc66b256303a2 ) + name "Cosmo Tank (USA) (Beta)" + description "Cosmo Tank (USA) (Beta)" + rom ( name "Cosmo Tank (USA) (Beta).gb" size 131072 crc 1c6770f0 sha1 863bf21877b5f5993b9e64710f304b8db194d2e7 ) ) game ( - name "F1 Challenge (Europe) (Beta)" - description "F1 Challenge (Europe) (Beta)" - rom ( name "F1 Challenge (Europe) (Beta).gb" size 262144 crc bc505a3b sha1 9849276839efdf7c2270a2fa7acd0d814cac026b ) + name "Cosmo Tank (Japan)" + description "Cosmo Tank (Japan)" + rom ( name "Cosmo Tank (Japan).gb" size 131072 crc 80b21df1 sha1 0d6a0a95f4fc9f2c61e2fccee0321236d3a6f5e5 flags verified ) ) game ( - name "F1 Pole Position (USA, Europe)" - description "F1 Pole Position (USA, Europe)" - rom ( name "F1 Pole Position (USA, Europe).gb" size 262144 crc aabe61bb sha1 a0087bd7421d73e1f8f339a266e62c2d03d081d6 ) + name "Cosmo Tank (USA)" + description "Cosmo Tank (USA)" + rom ( name "Cosmo Tank (USA).gb" size 131072 crc 2e767d25 sha1 48a8f5c50a237f11c8e18efd03a5282f493312bc ) ) game ( - name "Faceball 2000 (USA)" - description "Faceball 2000 (USA)" - rom ( name "Faceball 2000 (USA).gb" size 131072 crc 7d890cd0 sha1 b0bd15bace04e0a3eb89773f231ac3a532181a0a flags verified ) + name "Crayon Shin-chan - Ora no Gokigen Collection (Japan) (SGB Enhanced)" + description "Crayon Shin-chan - Ora no Gokigen Collection (Japan) (SGB Enhanced)" + rom ( name "Crayon Shin-chan - Ora no Gokigen Collection (Japan) (SGB Enhanced).gb" size 262144 crc dc723a9e sha1 1dbd23b639b8a4b20ed28c3637608e03ebf59dad ) ) game ( - name "Fairy-chan (World) (v0.1.4) (Demo) (Aftermarket) (Unl)" - description "Fairy-chan (World) (v0.1.4) (Demo) (Aftermarket) (Unl)" - rom ( name "Fairy-chan (World) (v0.1.4) (Demo) (Aftermarket) (Unl).gb" size 262144 crc 4f04cdfc sha1 591980cb5e17104d826c2a915f53bfc8a21affca ) + name "Crayon Shin-chan - Ora to Shiro wa Otomodachi Da yo (Japan)" + description "Crayon Shin-chan - Ora to Shiro wa Otomodachi Da yo (Japan)" + rom ( name "Crayon Shin-chan - Ora to Shiro wa Otomodachi Da yo (Japan).gb" size 131072 crc 2699942c sha1 e8da27b1b782c154b65ba6cdc2e3915925a67566 ) ) game ( - name "Family Jockey (Japan)" - description "Family Jockey (Japan)" - rom ( name "Family Jockey (Japan).gb" size 131072 crc d6ef1450 sha1 e463999d178489e050504298f4a3ffe30b48494a flags verified ) + name "Crayon Shin-chan 2 - Ora to Wanpaku Gokko Dazo (Japan)" + description "Crayon Shin-chan 2 - Ora to Wanpaku Gokko Dazo (Japan)" + rom ( name "Crayon Shin-chan 2 - Ora to Wanpaku Gokko Dazo (Japan).gb" size 131072 crc ca6e0be0 sha1 f034cc9c8b5962c548eba445033c8c912e3a19e2 ) ) game ( - name "Family Jockey 2 - Meiba no Kettou (Japan)" - description "Family Jockey 2 - Meiba no Kettou (Japan)" - rom ( name "Family Jockey 2 - Meiba no Kettou (Japan).gb" size 131072 crc 0325e729 sha1 d858fcdfce099435fa632859a9f8e8c82823bbcb ) + name "Crayon Shin-chan 3 - Ora no Gokigen Athletic (Japan)" + description "Crayon Shin-chan 3 - Ora no Gokigen Athletic (Japan)" + rom ( name "Crayon Shin-chan 3 - Ora no Gokigen Athletic (Japan).gb" size 131072 crc 24a12807 sha1 2d0119ec7b44bb89964c98024c46afd39490b5c9 flags verified ) ) game ( - name "Famista (Japan)" - description "Famista (Japan)" - rom ( name "Famista (Japan).gb" size 131072 crc 3d3c059e sha1 5cb8e63906d32c5408b7f959a75c41578a444c3b ) + name "Crayon Shin-chan 4 - Ora no Itazura Daihenshin (Japan) (SGB Enhanced)" + description "Crayon Shin-chan 4 - Ora no Itazura Daihenshin (Japan) (SGB Enhanced)" + rom ( name "Crayon Shin-chan 4 - Ora no Itazura Daihenshin (Japan) (SGB Enhanced).gb" size 131072 crc 37d4aa8c sha1 b5bb01ad7e25e9e83c564ccf604a59f8930cd0d5 ) ) game ( - name "Famista 2 (Japan)" - description "Famista 2 (Japan)" - rom ( name "Famista 2 (Japan).gb" size 131072 crc 241a6e4c sha1 e6f4ca432c36ec421935e6d4ecfc65c46764bc9c ) + name "Crystal Quest (USA)" + description "Crystal Quest (USA)" + rom ( name "Crystal Quest (USA).gb" size 32768 crc 51300cfd sha1 6c3ba1e407ff378dc004ac58d6a16180bd76a1b3 ) ) game ( - name "Famista 3 (Japan)" - description "Famista 3 (Japan)" - rom ( name "Famista 3 (Japan).gb" size 262144 crc bdc4ccc3 sha1 ac4b03e11e2ba135d0427c8b1da7de57c006b4a6 ) + name "Cult Jump (Japan)" + description "Cult Jump (Japan)" + rom ( name "Cult Jump (Japan).gb" size 262144 crc 943059ba sha1 6a67820ef648d2e24c1212079f5cac43e04cf0bf ) ) game ( - name "Farm, The (World) (Aftermarket) (Unl)" - description "Farm, The (World) (Aftermarket) (Unl)" - rom ( name "Farm, The (World) (Aftermarket) (Unl).gb" size 524288 crc fbc1b5e8 sha1 d0fe06920f7e771d76507f60881904370ffbc145 ) + name "Cult Master - Ultraman ni Miserarete (Japan)" + description "Cult Master - Ultraman ni Miserarete (Japan)" + rom ( name "Cult Master - Ultraman ni Miserarete (Japan).gb" size 262144 crc c3eb82ef sha1 f0e63a0a4e7b576c7460e810eb6f50d4c5b68769 ) ) game ( - name "Fastest Lap (USA)" - description "Fastest Lap (USA)" - rom ( name "Fastest Lap (USA).gb" size 131072 crc a9ba7875 sha1 25bf89b112c9b134b2e4d07354d1a762ab0d4e92 ) + name "CutThroat Island (Japan) (En) (Proto)" + description "CutThroat Island (Japan) (En) (Proto)" + rom ( name "CutThroat Island (Japan) (En) (Proto).gb" size 262144 crc 6a5f5a0d sha1 51eab74e5d5180497d37fc642c585f202914d1f2 ) ) game ( - name "Fastest Lap (Japan) (En)" - description "Fastest Lap (Japan) (En)" - rom ( name "Fastest Lap (Japan) (En).gb" size 131072 crc 59285f0a sha1 f1abe89a52e4f06e0479277d8681feaa09fcff2f ) + name "CutThroat Island (USA, Europe)" + description "CutThroat Island (USA, Europe)" + rom ( name "CutThroat Island (USA, Europe).gb" size 262144 crc eebdd360 sha1 5e99ea51b383cdcd53874eb027ebd59d2a3156b9 flags verified ) ) game ( - name "Felix the Cat (USA, Europe)" - description "Felix the Cat (USA, Europe)" - rom ( name "Felix the Cat (USA, Europe).gb" size 131072 crc f53f7f00 sha1 c4a0d02d5964335a18839c7c30ac05b6f40c33b3 ) + name "Cyraid (USA)" + description "Cyraid (USA)" + rom ( name "Cyraid (USA).gb" size 65536 crc 9d00da55 sha1 e295fce5531be0df7f5a10628608e0dcf54da71b ) ) game ( - name "Felix the Cat (USA, Europe) (Beta)" - description "Felix the Cat (USA, Europe) (Beta)" - rom ( name "Felix the Cat (USA, Europe) (Beta).gb" size 131072 crc b1734088 sha1 66fe01233643fb63e758d1f2e9932f63d545e288 ) + name "Daedalian Opus (USA)" + description "Daedalian Opus (USA)" + rom ( name "Daedalian Opus (USA).gb" size 32768 crc b6b51fce sha1 7a9294de582f7d3ffd8d14a786774c56af7ce7bc flags verified ) ) game ( - name "Ferrari (Japan)" - description "Ferrari (Japan)" - rom ( name "Ferrari (Japan).gb" size 131072 crc a7bdfec8 sha1 f9883af35e5f49736f9dc073ce00f3779e93cf3f ) + name "Daffy Duck (USA, Europe) (SGB Enhanced)" + description "Daffy Duck (USA, Europe) (SGB Enhanced)" + rom ( name "Daffy Duck (USA, Europe) (SGB Enhanced).gb" size 262144 crc c47671f3 sha1 75b384222d07947baed2213c288385c4b91e1911 flags verified ) ) game ( - name "Ferrari Grand Prix Challenge (USA, Europe)" - description "Ferrari Grand Prix Challenge (USA, Europe)" - rom ( name "Ferrari Grand Prix Challenge (USA, Europe).gb" size 131072 crc ed6771db sha1 ecdbe43db8714367bd606127e3276d8a3431841c flags verified ) + name "Daffy Duck (Europe)" + description "Daffy Duck (Europe)" + rom ( name "Daffy Duck (Europe).gb" size 131072 crc 13dd647d sha1 344c3409410fe5f88796aafd125c522319b78012 flags verified ) ) game ( - name "Fidgetts, The (Japan)" - description "Fidgetts, The (Japan)" - rom ( name "Fidgetts, The (Japan).gb" size 262144 crc ffd4a9e3 sha1 c701ce4c62c414aada502f8c17aa9261dd635685 ) + name "Dai-2-ji Super Robot Taisen G (Japan) (SGB Enhanced)" + description "Dai-2-ji Super Robot Taisen G (Japan) (SGB Enhanced)" + rom ( name "Dai-2-ji Super Robot Taisen G (Japan) (SGB Enhanced).gb" size 524288 crc df8b2b20 sha1 0baa751363c05f9830656f98e77902d543822656 flags verified ) ) game ( - name "Fidgetts, The (USA, Europe) (En,Fr,De,Es,It,Nl,Sv)" - description "Fidgetts, The (USA, Europe) (En,Fr,De,Es,It,Nl,Sv)" - rom ( name "Fidgetts, The (USA, Europe) (En,Fr,De,Es,It,Nl,Sv).gb" size 262144 crc b3fd3e36 sha1 1100f259fe30857d1103beb116b888497f6fbdaa flags verified ) + name "Daikaijuu Monogatari - The Miracle of the Zone (Japan) (SGB Enhanced)" + description "Daikaijuu Monogatari - The Miracle of the Zone (Japan) (SGB Enhanced)" + rom ( name "Daikaijuu Monogatari - The Miracle of the Zone (Japan) (SGB Enhanced).gb" size 524288 crc 26d2d5c2 sha1 44cafcb56f470881b67e57c0649afbc638cda136 flags verified ) ) game ( - name "FIFA - Road to World Cup 98 (Europe) (SGB Enhanced)" - description "FIFA - Road to World Cup 98 (Europe) (SGB Enhanced)" - rom ( name "FIFA - Road to World Cup 98 (Europe) (SGB Enhanced).gb" size 524288 crc cdf6a5ac sha1 5ef615a919ea967e749febb046f9d097d91fab0d flags verified ) + name "Daiku no Gen-san - Ghost Building Company (Japan)" + description "Daiku no Gen-san - Ghost Building Company (Japan)" + rom ( name "Daiku no Gen-san - Ghost Building Company (Japan).gb" size 262144 crc 9e0d2b45 sha1 90574cc899210515e83dec714eb4d69416dcf3a3 flags verified ) ) game ( - name "FIFA - Road to World Cup 98 (Europe) (Rev 1) (SGB Enhanced)" - description "FIFA - Road to World Cup 98 (Europe) (Rev 1) (SGB Enhanced)" - rom ( name "FIFA - Road to World Cup 98 (Europe) (Rev 1) (SGB Enhanced).gb" size 524288 crc 8dc0d46c sha1 8dc3ab8f020e4377af1e1f636396cc3881268a1f ) + name "Daiku no Gen-san - Robot Teikoku no Yabou (Japan)" + description "Daiku no Gen-san - Robot Teikoku no Yabou (Japan)" + rom ( name "Daiku no Gen-san - Robot Teikoku no Yabou (Japan).gb" size 262144 crc 70819e03 sha1 0c68250aadca89027b05659122c89682ff833298 ) ) game ( - name "FIFA International Soccer (USA, Europe) (En,Fr,De,Es) (SGB Enhanced)" - description "FIFA International Soccer (USA, Europe) (En,Fr,De,Es) (SGB Enhanced)" - rom ( name "FIFA International Soccer (USA, Europe) (En,Fr,De,Es) (SGB Enhanced).gb" size 524288 crc e5989908 sha1 6f0affdec339d7beb9c565dc51abe59ee0398b7b ) + name "Daisenryaku (Japan)" + description "Daisenryaku (Japan)" + rom ( name "Daisenryaku (Japan).gb" size 131072 crc c8f80d90 sha1 79e724619d21ebb3cd5de5438535a7ee25009de0 ) ) game ( - name "FIFA Soccer 96 (USA, Europe) (En,Fr,De,Es) (SGB Enhanced)" - description "FIFA Soccer 96 (USA, Europe) (En,Fr,De,Es) (SGB Enhanced)" - rom ( name "FIFA Soccer 96 (USA, Europe) (En,Fr,De,Es) (SGB Enhanced).gb" size 524288 crc af4a5de1 sha1 a434f0f96d1aa3ec50d35f82eb5ef876bcd22115 ) + name "Darkman (USA, Europe)" + description "Darkman (USA, Europe)" + rom ( name "Darkman (USA, Europe).gb" size 131072 crc ff858da9 sha1 f168733ddf4f083559e52198a503e4f295fabf0d flags verified ) ) game ( - name "FIFA Soccer 97 (USA, Europe) (SGB Enhanced)" - description "FIFA Soccer 97 (USA, Europe) (SGB Enhanced)" - rom ( name "FIFA Soccer 97 (USA, Europe) (SGB Enhanced).gb" size 524288 crc dcab906c sha1 dd9b9b99bd663cdf55187ff5867eccd52615f025 ) + name "Darkwing Duck (Europe)" + description "Darkwing Duck (Europe)" + rom ( name "Darkwing Duck (Europe).gb" size 131072 crc be975b4f sha1 4e51919597aa72dd32182f9afee34f148036655f flags verified ) ) game ( - name "Fighting Simulator 2 in 1 - Flying Warriors (USA, Europe)" - description "Fighting Simulator 2 in 1 - Flying Warriors (USA, Europe)" - rom ( name "Fighting Simulator 2 in 1 - Flying Warriors (USA, Europe).gb" size 131072 crc 52678ae8 sha1 9073276d8adf1e59829ae48073b42ae19c9770ce flags verified ) + name "Darkwing Duck (USA)" + description "Darkwing Duck (USA)" + rom ( name "Darkwing Duck (USA).gb" size 131072 crc 238b9646 sha1 cc1f12f3ec3852657a14d11c13d1ef91fbdda5bb ) ) game ( - name "Final Fantasy Adventure (USA)" - description "Final Fantasy Adventure (USA)" - rom ( name "Final Fantasy Adventure (USA).gb" size 262144 crc 18c78b3a sha1 8b93c55ee2660c60cf86dd70058f96ace98782c8 flags verified ) + name "Darkwing Duck (Germany)" + description "Darkwing Duck (Germany)" + rom ( name "Darkwing Duck (Germany).gb" size 131072 crc 176c1fa2 sha1 5960dc01e06f19e166646504bc3097248f4a22cb flags verified ) ) game ( - name "Final Fantasy Adventure (World) (Collection of Mana)" - description "Final Fantasy Adventure (World) (Collection of Mana)" - rom ( name "Final Fantasy Adventure (World) (Collection of Mana).gb" size 262144 crc 8e5e5097 sha1 bd8369977cfbbaf3cc57f6268b564d6b11c27d45 flags verified ) + name "Darkwing Duck (Spain)" + description "Darkwing Duck (Spain)" + rom ( name "Darkwing Duck (Spain).gb" size 131072 crc a1d4c544 sha1 3d4b301aab995bdf19b15ed5040df7426a2e8057 ) ) game ( - name "Final Fantasy Legend II (World) (Collection of SaGa)" - description "Final Fantasy Legend II (World) (Collection of SaGa)" - rom ( name "Final Fantasy Legend II (World) (Collection of SaGa).gb" size 262144 crc e84e051a sha1 eedf962d01b733b5eaf2413905e59e671e04a51c ) + name "Darkwing Duck (USA) (Beta)" + description "Darkwing Duck (USA) (Beta)" + rom ( name "Darkwing Duck (USA) (Beta).gb" size 131072 crc 311ade03 sha1 2883b8854529369cce4d473e71fa0193c7df02b6 ) ) game ( - name "Final Fantasy Legend II (USA)" - description "Final Fantasy Legend II (USA)" - rom ( name "Final Fantasy Legend II (USA).gb" size 262144 crc 58314182 sha1 6ab6890e8f688bcd87e97886a1748a4d9d341909 flags verified ) + name "David Crane's The Rescue of Princess Blobette (World) (Limited Run Games)" + description "David Crane's The Rescue of Princess Blobette (World) (Limited Run Games)" + rom ( name "David Crane's The Rescue of Princess Blobette (World) (Limited Run Games).gb" size 65536 crc 0c24923e sha1 e1f391102aba5ea75572b04180b31bcaaa47e593 ) ) game ( - name "Final Fantasy Legend III (USA)" - description "Final Fantasy Legend III (USA)" - rom ( name "Final Fantasy Legend III (USA).gb" size 262144 crc 3e454710 sha1 3864afa48a97db826ffda1d31a7ff9c6c315d5c9 ) + name "David Crane's The Rescue of Princess Blobette (Europe)" + description "David Crane's The Rescue of Princess Blobette (Europe)" + rom ( name "David Crane's The Rescue of Princess Blobette (Europe).gb" size 65536 crc 25f82bb1 sha1 4800e5d5a4230918ec751ceeae7ac9342e0b8d83 flags verified ) ) game ( - name "Final Fantasy Legend III (World) (Collection of SaGa)" - description "Final Fantasy Legend III (World) (Collection of SaGa)" - rom ( name "Final Fantasy Legend III (World) (Collection of SaGa).gb" size 262144 crc 0c5171ef sha1 5190b0ef6264e26af21dc0097fd5608cb619fb63 ) + name "David Crane's The Rescue of Princess Blobette (USA)" + description "David Crane's The Rescue of Princess Blobette (USA)" + rom ( name "David Crane's The Rescue of Princess Blobette (USA).gb" size 65536 crc 8210a03f sha1 0a45d1b98646fd7832b5119b04bc8d6d6d0f657a ) ) game ( - name "Final Fantasy Legend, The (World) (Collection of SaGa)" - description "Final Fantasy Legend, The (World) (Collection of SaGa)" - rom ( name "Final Fantasy Legend, The (World) (Collection of SaGa).gb" size 131072 crc 00388844 sha1 42450483c9894863c7543f9695c0cbaffdcb7e99 ) + name "Days of Thunder (USA, Europe)" + description "Days of Thunder (USA, Europe)" + rom ( name "Days of Thunder (USA, Europe).gb" size 131072 crc 35d9be0e sha1 1bf54293a332fd822911218dcc4a94fcda949ccf ) ) game ( - name "Final Fantasy Legend, The (USA)" - description "Final Fantasy Legend, The (USA)" - rom ( name "Final Fantasy Legend, The (USA).gb" size 131072 crc 8046148f sha1 901dfc83c72e172d35a376835807fc788444a9bb flags verified ) + name "Dead Heat Scramble (Japan)" + description "Dead Heat Scramble (Japan)" + rom ( name "Dead Heat Scramble (Japan).gb" size 65536 crc a8301bdd sha1 395c0c80ad5c9a24c00d6d8dfe5894e73e672639 ) ) game ( - name "Final Fantasy XI Adventure (World) (Aftermarket) (Unl)" - description "Final Fantasy XI Adventure (World) (Aftermarket) (Unl)" - rom ( name "Final Fantasy XI Adventure (World) (Aftermarket) (Unl).gb" size 1048576 crc 6cfb4669 sha1 339fd673509a5ac8f25426af25b4ccc96e8d2880 ) + name "Dead Heat Scramble (USA)" + description "Dead Heat Scramble (USA)" + rom ( name "Dead Heat Scramble (USA).gb" size 65536 crc 9e3e3656 sha1 71e560dd2b5f5c4f4dcca0837c74bb1b843a15aa ) ) game ( - name "Final Reverse (Japan)" - description "Final Reverse (Japan)" - rom ( name "Final Reverse (Japan).gb" size 65536 crc e94a6942 sha1 e4b08e702f3b6c575b31dbd62615619126e03af5 ) + name "Death Track (Europe) (Proto)" + description "Death Track (Europe) (Proto)" + rom ( name "Death Track (Europe) (Proto).gb" size 524288 crc c495a707 sha1 abc95b27be454405a6a22fb9e048537d1df60d75 ) ) game ( - name "Finders Keepers (World) (Aftermarket) (Unl)" - description "Finders Keepers (World) (Aftermarket) (Unl)" - rom ( name "Finders Keepers (World) (Aftermarket) (Unl).gb" size 524288 crc 6a98ac61 sha1 e40dd804388df8c08d3890d79eeafd8542cc8805 ) + name "Dennis (Europe) (Beta) (1993-09-13)" + description "Dennis (Europe) (Beta) (1993-09-13)" + rom ( name "Dennis (Europe) (Beta) (1993-09-13).gb" size 131072 crc 807d34a4 sha1 fab382a28f9d7fefae7dc9a16bf86f309d89e037 ) ) game ( - name "Fire Fighter (Europe)" - description "Fire Fighter (Europe)" - rom ( name "Fire Fighter (Europe).gb" size 131072 crc c46bbd49 sha1 a26a4f0a51fb3aad3f138eedfe326a04af9a1b56 ) + name "Dennis (Europe)" + description "Dennis (Europe)" + rom ( name "Dennis (Europe).gb" size 131072 crc 896a30a8 sha1 9b5c289f25829534020951f84732177036837aea ) ) game ( - name "Fish Dude (USA)" - description "Fish Dude (USA)" - rom ( name "Fish Dude (USA).gb" size 65536 crc 4b929719 sha1 72d11ae07b6701efe109d20dad6107ff6f603ea5 ) + name "Dennis the Menace (USA)" + description "Dennis the Menace (USA)" + rom ( name "Dennis the Menace (USA).gb" size 131072 crc 7eb0cd32 sha1 4695b50738add92926dc5d4b48568b037df7cdb9 ) ) game ( - name "Fist of the North Star (USA)" - description "Fist of the North Star (USA)" - rom ( name "Fist of the North Star (USA).gb" size 131072 crc 9a84b6cf sha1 0bf60583da14cd32947f8e8e6b995c2b176d95c5 ) + name "Desert Strike - Return to the Gulf (Europe) (SGB Enhanced)" + description "Desert Strike - Return to the Gulf (Europe) (SGB Enhanced)" + rom ( name "Desert Strike - Return to the Gulf (Europe) (SGB Enhanced).gb" size 262144 crc b700f7f7 sha1 b49bc8f5d292f0e2b71957c8c4af37b20cfead80 ) ) game ( - name "Flappy Special (Japan)" - description "Flappy Special (Japan)" - rom ( name "Flappy Special (Japan).gb" size 32768 crc 3b6cdda4 sha1 6517aee7caa2fa60750005ef1dacaeaecee7c2f6 ) + name "Desert Strike - Return to the Gulf (USA) (SGB Enhanced)" + description "Desert Strike - Return to the Gulf (USA) (SGB Enhanced)" + rom ( name "Desert Strike - Return to the Gulf (USA) (SGB Enhanced).gb" size 262144 crc 6a702c32 sha1 325ee739ecf5aa403741e8dad36abcfa441dd26b ) ) game ( - name "Flappy Special (USA) (Proto)" - description "Flappy Special (USA) (Proto)" - rom ( name "Flappy Special (USA) (Proto).gb" size 32768 crc 617d0d9f sha1 75347d9f708da85487b779ed79b9c1e84954020d ) + name "Dexterity (USA, Europe)" + description "Dexterity (USA, Europe)" + rom ( name "Dexterity (USA, Europe).gb" size 65536 crc 659e2283 sha1 85f0a9ff87ece93097a855d238bc6c7014893c08 flags verified ) ) game ( - name "Flash, The (USA, Europe)" - description "Flash, The (USA, Europe)" - rom ( name "Flash, The (USA, Europe).gb" size 131072 crc 6deb1f06 sha1 f7e5701e6fa8fe4440988d1207517668c35088c6 ) + name "Diablo (USA) (Proto)" + description "Diablo (USA) (Proto)" + rom ( name "Diablo (USA) (Proto).gb" size 131072 crc aaaad0b6 sha1 8982410ac627618628a8b823c0608cc8b5653f41 ) ) game ( - name "Fleet Commander VS. (Japan)" - description "Fleet Commander VS. (Japan)" - rom ( name "Fleet Commander VS. (Japan).gb" size 262144 crc 71bf3256 sha1 b858d597e5eea575c5baa953785c96459d9be593 ) + name "Dick Tracy (USA)" + description "Dick Tracy (USA)" + rom ( name "Dick Tracy (USA).gb" size 131072 crc a308b86b sha1 906361b2066c2b48500b9b709f7b4ed1018309c0 ) ) game ( - name "Flintstones, The (USA, Europe)" - description "Flintstones, The (USA, Europe)" - rom ( name "Flintstones, The (USA, Europe).gb" size 262144 crc 503d3613 sha1 506a647137bcaad81589f1b3592884b3bbed8aa3 ) + name "Dig Dug (Europe)" + description "Dig Dug (Europe)" + rom ( name "Dig Dug (Europe).gb" size 131072 crc 0af905c0 sha1 9e008ee24c627309b22bf42ec5a3e08af0af8efe ) ) game ( - name "Flintstones, The - King Rock Treasure Island (USA, Europe)" - description "Flintstones, The - King Rock Treasure Island (USA, Europe)" - rom ( name "Flintstones, The - King Rock Treasure Island (USA, Europe).gb" size 131072 crc 508282d0 sha1 4ea1609dc273623c677aaa0accd0cd8d4a03efca flags verified ) + name "Dig Dug (USA)" + description "Dig Dug (USA)" + rom ( name "Dig Dug (USA).gb" size 131072 crc 6c742478 sha1 951753904389332412d4b0a80b48d7ac61a494fc ) ) game ( - name "Flintstones, The - King Rock Treasure Island (Japan) (Proto)" - description "Flintstones, The - King Rock Treasure Island (Japan) (Proto)" - rom ( name "Flintstones, The - King Rock Treasure Island (Japan) (Proto).gb" size 131072 crc 437600bb sha1 bf6ba87bbc9ce4252c91f0e72121ab7c496a7dec ) + name "Dino Breeder (Japan) (SGB Enhanced)" + description "Dino Breeder (Japan) (SGB Enhanced)" + rom ( name "Dino Breeder (Japan) (SGB Enhanced).gb" size 262144 crc 3f0aafec sha1 80ccbf87dcd4d4e76f1f6a7a94e00ec2857e530a flags verified ) ) game ( - name "Flipull (USA)" - description "Flipull (USA)" - rom ( name "Flipull (USA).gb" size 32768 crc a2f30b4b sha1 54cf45a997d390729dd23b9ed46a967b77cb7664 ) + name "Dino Breeder (Japan) (Rev 1) (SGB Enhanced)" + description "Dino Breeder (Japan) (Rev 1) (SGB Enhanced)" + rom ( name "Dino Breeder (Japan) (Rev 1) (SGB Enhanced).gb" size 262144 crc 5b289ab4 sha1 a6e24e442de0541c3f5ec4d28650256c5d25f751 ) ) game ( - name "Flipull - An Exciting Cube Game (Japan)" - description "Flipull - An Exciting Cube Game (Japan)" - rom ( name "Flipull - An Exciting Cube Game (Japan).gb" size 32768 crc 198f147d sha1 090c88ae19892c35608f4fa844a6e9efcbe23893 ) + name "Dino Breeder 2 (Japan) (SGB Enhanced)" + description "Dino Breeder 2 (Japan) (SGB Enhanced)" + rom ( name "Dino Breeder 2 (Japan) (SGB Enhanced).gb" size 524288 crc 05a3ab7a sha1 ac4b1fe0e917298d81725d7a9bdf46c285502ac7 flags verified ) ) game ( - name "Fly O'Clock (World) (Aftermarket) (Unl)" - description "Fly O'Clock (World) (Aftermarket) (Unl)" - rom ( name "Fly O'Clock (World) (Aftermarket) (Unl).gb" size 32768 crc 93df7f55 sha1 83dc8498bdbabc14a8f81a715c9da19970c1f0b9 ) + name "Dirty Racing (Europe) (Proto)" + description "Dirty Racing (Europe) (Proto)" + rom ( name "Dirty Racing (Europe) (Proto).gb" size 131072 crc 974a3cbe sha1 9dc43a8636970dd6bf9d37943e3b1d7c2aa5d570 ) ) game ( - name "Football International (Europe)" - description "Football International (Europe)" - rom ( name "Football International (Europe).gb" size 131072 crc 6e659690 sha1 30be5422b15e1960d22dc77d646642d7365b243c ) + name "Dirty Racing (Japan)" + description "Dirty Racing (Japan)" + rom ( name "Dirty Racing (Japan).gb" size 131072 crc 43af45b1 sha1 5b58b4d02987ce3a16774bc4a6707d12ac404c1c ) ) game ( - name "Foreman for Real (Japan)" - description "Foreman for Real (Japan)" - rom ( name "Foreman for Real (Japan).gb" size 262144 crc 860ea816 sha1 835b3208458e8ca1956e27a693fab036d4b25974 ) + name "Doctor GB Card 16M Loader (World) (Unl)" + description "Doctor GB Card 16M Loader (World) (Unl)" + rom ( name "Doctor GB Card 16M Loader (World) (Unl).gb" size 32768 crc 1bddf36f sha1 c298eacc0c73e648e81fbf5192aec3b6a438e053 ) ) game ( - name "Foreman for Real (USA, Europe)" - description "Foreman for Real (USA, Europe)" - rom ( name "Foreman for Real (USA, Europe).gb" size 262144 crc 77083ae0 sha1 7b088c7b3a0ad275d340ca27f64a99c1bd6c34e6 ) + name "Doctor GB Card 4M (World) (Unl)" + description "Doctor GB Card 4M (World) (Unl)" + rom ( name "Doctor GB Card 4M (World) (Unl).gb" size 524288 crc 5d2e8cff sha1 43962a7459c8ccc0e5988060abd0f8668f30dfde ) ) game ( - name "Fortified Zone (USA, Europe)" - description "Fortified Zone (USA, Europe)" - rom ( name "Fortified Zone (USA, Europe).gb" size 131072 crc e3b59b7e sha1 232d2f57ab4bef748eb832dfb4085cc3df1fd532 flags verified ) + name "Doctor GB Card Demo (World) (Demo) (Unl)" + description "Doctor GB Card Demo (World) (Demo) (Unl)" + rom ( name "Doctor GB Card Demo (World) (Demo) (Unl).gb" size 32768 crc b5dfdc26 sha1 1d403b254971faa5834bc48adfd42cc0bbed3fe4 ) ) game ( - name "Frank Thomas Big Hurt Baseball (USA, Europe)" - description "Frank Thomas Big Hurt Baseball (USA, Europe)" - rom ( name "Frank Thomas Big Hurt Baseball (USA, Europe).gb" size 524288 crc 9a494ae6 sha1 ccea5b85ed334a2bf7bd4449f07bbf3a86841dfd flags verified ) + name "Doctor GB Card Demo (World) (Demo) (Unl) (Alt)" + description "Doctor GB Card Demo (World) (Demo) (Unl) (Alt)" + rom ( name "Doctor GB Card Demo (World) (Demo) (Unl) (Alt).gb" size 32768 crc 3592390b sha1 a6e3b81b8664f41eb18770cd5757ed4d8338be54 ) ) game ( - name "Franky, Joe & Dirk - On the Tiles (Europe) (En,Fr,De,Es,It,Nl)" - description "Franky, Joe & Dirk - On the Tiles (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Franky, Joe & Dirk - On the Tiles (Europe) (En,Fr,De,Es,It,Nl).gb" size 131072 crc caf5b372 sha1 b7e292cfd34d64546f158e548afa92efaf8c2acd ) + name "Dodge Boy (Japan)" + description "Dodge Boy (Japan)" + rom ( name "Dodge Boy (Japan).gb" size 131072 crc f58dc358 sha1 b48eb2bdc34588847728936491dadda67394f9b7 ) ) game ( - name "Frisky Tom (Japan) (SGB Enhanced)" - description "Frisky Tom (Japan) (SGB Enhanced)" - rom ( name "Frisky Tom (Japan) (SGB Enhanced).gb" size 131072 crc 0bef84a1 sha1 4162ca88c94c40e3fa6e09067b956cf4953ccf89 ) + name "Donkey Kong (Japan, USA) (En) (SGB Enhanced)" + description "Donkey Kong (Japan, USA) (En) (SGB Enhanced)" + rom ( name "Donkey Kong (Japan, USA) (En) (SGB Enhanced).gb" size 524288 crc edab3378 sha1 6ed661bd1d6d8cdd48e1c10f8ca4e8dcba49128e flags verified ) ) game ( - name "Frogger (USA)" - description "Frogger (USA)" - rom ( name "Frogger (USA).gb" size 131072 crc 4d933c08 sha1 1dbb26dd94c9710b029f2f88473aed0267db491c flags verified ) + name "Donkey Kong (World) (Rev 1) (SGB Enhanced)" + description "Donkey Kong (World) (Rev 1) (SGB Enhanced)" + rom ( name "Donkey Kong (World) (Rev 1) (SGB Enhanced).gb" size 524288 crc f777a5d8 sha1 397ad2ff25627b83e02c71b54c72bb4deb39e0c0 flags verified ) ) game ( - name "From TV Animation Slam Dunk - Gakeppuchi no Kesshou League (Japan) (SGB Enhanced)" - description "From TV Animation Slam Dunk - Gakeppuchi no Kesshou League (Japan) (SGB Enhanced)" - rom ( name "From TV Animation Slam Dunk - Gakeppuchi no Kesshou League (Japan) (SGB Enhanced).gb" size 262144 crc ae478a6f sha1 0faf2c66a916c979450810ec16029c2258f90f83 ) + name "Donkey Kong Land (Japan) (SGB Enhanced)" + description "Donkey Kong Land (Japan) (SGB Enhanced)" + rom ( name "Donkey Kong Land (Japan) (SGB Enhanced).gb" size 524288 crc 9aeca05c sha1 18fd3fcf90e60122da92079669942b0363049d8f flags verified ) ) game ( - name "From TV Animation Slam Dunk 2 - Zenkoku e no Tip Off (Japan) (SGB Enhanced)" - description "From TV Animation Slam Dunk 2 - Zenkoku e no Tip Off (Japan) (SGB Enhanced)" - rom ( name "From TV Animation Slam Dunk 2 - Zenkoku e no Tip Off (Japan) (SGB Enhanced).gb" size 524288 crc cb35900a sha1 b8223ce166121ae7224d4431fdf27750c737b3f2 ) + name "Donkey Kong Land (USA, Europe) (SGB Enhanced)" + description "Donkey Kong Land (USA, Europe) (SGB Enhanced)" + rom ( name "Donkey Kong Land (USA, Europe) (SGB Enhanced).gb" size 524288 crc 49dc0d37 sha1 4e6d8f085ca197479d59912c1d58e4f3b40c28ac flags verified ) ) game ( - name "From TV Animation Slam Dunk Limited Edition (Japan) (SGB Enhanced)" - description "From TV Animation Slam Dunk Limited Edition (Japan) (SGB Enhanced)" - rom ( name "From TV Animation Slam Dunk Limited Edition (Japan) (SGB Enhanced).gb" size 262144 crc ad55dbf0 sha1 ac878552813e3715b7de992f3dc6362c2150cce9 ) + name "Donkey Kong Land 2 (USA, Europe) (SGB Enhanced)" + description "Donkey Kong Land 2 (USA, Europe) (SGB Enhanced)" + rom ( name "Donkey Kong Land 2 (USA, Europe) (SGB Enhanced).gb" size 524288 crc 2827e5d4 sha1 89cc4f01653a6105ee5c00e10fc65aa1437fd320 flags verified ) ) game ( - name "Funny Field (Japan)" - description "Funny Field (Japan)" - rom ( name "Funny Field (Japan).gb" size 65536 crc bfd87aa4 sha1 0b74e84ce50454057f78e4178be2599e57c91855 ) + name "Donkey Kong Land 2 (Japan) (Proto) (SGB Enhanced)" + description "Donkey Kong Land 2 (Japan) (Proto) (SGB Enhanced)" + rom ( name "Donkey Kong Land 2 (Japan) (Proto) (SGB Enhanced).gb" size 524288 crc 68e5fc2a sha1 af66548c1a96468dae76e61823e9a9fe439c227c ) ) game ( - name "Fushigi na Blobby - Princess Blob o Sukue! (Japan)" - description "Fushigi na Blobby - Princess Blob o Sukue! (Japan)" - rom ( name "Fushigi na Blobby - Princess Blob o Sukue! (Japan).gb" size 65536 crc 3d0bac10 sha1 fcd6ac8a0ad6eb1f5d9e00c877747521541204de ) + name "Donkey Kong Land III (USA, Europe) (Beta) (SGB Enhanced)" + description "Donkey Kong Land III (USA, Europe) (Beta) (SGB Enhanced)" + rom ( name "Donkey Kong Land III (USA, Europe) (Beta) (SGB Enhanced).gb" size 524288 crc 872bbd5e sha1 9d17bc07bd3c48f8bb8a3315faf817d055417f53 ) ) game ( - name "Fushigi no Dungeon - Fuurai no Shiren GB - Tsukikage Mura no Kaibutsu (Japan) (SGB Enhanced)" - description "Fushigi no Dungeon - Fuurai no Shiren GB - Tsukikage Mura no Kaibutsu (Japan) (SGB Enhanced)" - rom ( name "Fushigi no Dungeon - Fuurai no Shiren GB - Tsukikage Mura no Kaibutsu (Japan) (SGB Enhanced).gb" size 524288 crc 2962afb4 sha1 920ef94c05ac741047a266cb1668c881eab2937c flags verified ) + name "Donkey Kong Land III (USA, Europe) (SGB Enhanced)" + description "Donkey Kong Land III (USA, Europe) (SGB Enhanced)" + rom ( name "Donkey Kong Land III (USA, Europe) (SGB Enhanced).gb" size 524288 crc b40c159c sha1 a33f10194b5b228863c04abd0e65c7cc5d73fc3e flags verified ) ) game ( - name "Fydo's Magic Tiles (World) (2022-09-01) (Aftermarket) (Unl)" - description "Fydo's Magic Tiles (World) (2022-09-01) (Aftermarket) (Unl)" - rom ( name "Fydo's Magic Tiles (World) (2022-09-01) (Aftermarket) (Unl).gb" size 32768 crc 36e2ca02 sha1 fd985703b296dd0bf74225c72155ea9e51dd6853 ) + name "Donkey Kong Land III (USA, Europe) (Rev 1) (SGB Enhanced)" + description "Donkey Kong Land III (USA, Europe) (Rev 1) (SGB Enhanced)" + rom ( name "Donkey Kong Land III (USA, Europe) (Rev 1) (SGB Enhanced).gb" size 524288 crc a19acdb6 sha1 a6ce883727212e1afb45b48431a46cfbc6f7f6ef flags verified ) ) game ( - name "G Arms - Operation Gundam (Japan)" - description "G Arms - Operation Gundam (Japan)" - rom ( name "G Arms - Operation Gundam (Japan).gb" size 131072 crc 39058153 sha1 7d8011636fe36266b5f716e78e3e29006f024992 ) + name "Doomsayer - A Hero's Crusade (USA) (Proto)" + description "Doomsayer - A Hero's Crusade (USA) (Proto)" + rom ( name "Doomsayer - A Hero's Crusade (USA) (Proto).gb" size 131072 crc e74cb320 sha1 565c719e0526330e6573c7ac61322f641ce9324b ) ) game ( - name "G-Man (World) (Aftermarket) (Unl)" - description "G-Man (World) (Aftermarket) (Unl)" - rom ( name "G-Man (World) (Aftermarket) (Unl).gb" size 524288 crc 7296da69 sha1 fdc9933d46a063575c175453b1da8042fd28b135 ) + name "Doraemon - Taiketsu HimitsuDougu!! (Japan)" + description "Doraemon - Taiketsu HimitsuDougu!! (Japan)" + rom ( name "Doraemon - Taiketsu HimitsuDougu!! (Japan).gb" size 131072 crc a42524a3 sha1 5e89e34a2cec89e0aba4e12d18d96671151730ec ) ) game ( - name "G-ZERO (World) (v2.6) (Aftermarket) (Unl)" - description "G-ZERO (World) (v2.6) (Aftermarket) (Unl)" - rom ( name "G-ZERO (World) (v2.6) (Aftermarket) (Unl).gb" size 65536 crc 7dd0c878 sha1 929d25a612308614ac3ac2ee5a19a9cd4a9968d6 ) + name "Doraemon 2 - Animal Planet Densetsu (Japan)" + description "Doraemon 2 - Animal Planet Densetsu (Japan)" + rom ( name "Doraemon 2 - Animal Planet Densetsu (Japan).gb" size 131072 crc 843bd5bc sha1 0d72e0310bbf0b23483f37688df61543048c4b31 ) ) game ( - name "Galaga & Galaxian (Japan) (SGB Enhanced)" - description "Galaga & Galaxian (Japan) (SGB Enhanced)" - rom ( name "Galaga & Galaxian (Japan) (SGB Enhanced).gb" size 131072 crc 532036d5 sha1 2d67a97b4737b24ea0eff7a7c798b7d77e6a0724 ) + name "Doraemon Kart (Japan) (SGB Enhanced)" + description "Doraemon Kart (Japan) (SGB Enhanced)" + rom ( name "Doraemon Kart (Japan) (SGB Enhanced).gb" size 262144 crc dd4e588f sha1 f19734b2cb19de0be2d9e80297f567806ce4cad5 ) ) game ( - name "Game & Watch Gallery (Europe) (SGB Enhanced)" - description "Game & Watch Gallery (Europe) (SGB Enhanced)" - rom ( name "Game & Watch Gallery (Europe) (SGB Enhanced).gb" size 262144 crc 96ecc1e0 sha1 31186cff6bb548ecd0c91c07f16dc98de9c19ea2 ) + name "Doraemon no Game Boy de Asobouyo Deluxe 10 (Japan) (SGB Enhanced)" + description "Doraemon no Game Boy de Asobouyo Deluxe 10 (Japan) (SGB Enhanced)" + rom ( name "Doraemon no Game Boy de Asobouyo Deluxe 10 (Japan) (SGB Enhanced).gb" size 262144 crc b368e717 sha1 7ad70061c8afbbe0890e3d50accd40b2a8cb9790 ) ) game ( - name "Game & Watch Gallery (USA) (SGB Enhanced)" - description "Game & Watch Gallery (USA) (SGB Enhanced)" - rom ( name "Game & Watch Gallery (USA) (SGB Enhanced).gb" size 262144 crc 99b2fe79 sha1 f8c5ad6d6bf1a5a90dffebada1dbd69a93720c83 ) + name "Doraemon no Study Boy 1 - Shou 1 Kokugo Kanji (Japan)" + description "Doraemon no Study Boy 1 - Shou 1 Kokugo Kanji (Japan)" + rom ( name "Doraemon no Study Boy 1 - Shou 1 Kokugo Kanji (Japan).gb" size 524288 crc 652b3ca4 sha1 7be5e001f60338fd605cb3cd918df66a9ebf2ad2 flags verified ) ) game ( - name "Game & Watch Gallery (USA) (Rev 1) (SGB Enhanced)" - description "Game & Watch Gallery (USA) (Rev 1) (SGB Enhanced)" - rom ( name "Game & Watch Gallery (USA) (Rev 1) (SGB Enhanced).gb" size 262144 crc 9e6cdc96 sha1 4e4da0ed89c2baaed64600f7eaca90aeeadc084e ) + name "Doraemon no Study Boy 2 - Shou 1 Sansuu Keisan (Japan)" + description "Doraemon no Study Boy 2 - Shou 1 Sansuu Keisan (Japan)" + rom ( name "Doraemon no Study Boy 2 - Shou 1 Sansuu Keisan (Japan).gb" size 524288 crc 5333d083 sha1 38b9fafd4604bd69a59f0445508f15bfbba459c6 flags verified ) ) game ( - name "Game Boy Aging Cartridge (World) (En,Ja) (v1.1)" - description "Game Boy Aging Cartridge (World) (En,Ja) (v1.1)" - rom ( name "Game Boy Aging Cartridge (World) (En,Ja) (v1.1).gb" size 32768 crc 4db33858 sha1 3f27a044131548d528783f0d43f918f04418519e ) + name "Doraemon no Study Boy 3 - Ku Ku Master (Japan)" + description "Doraemon no Study Boy 3 - Ku Ku Master (Japan)" + rom ( name "Doraemon no Study Boy 3 - Ku Ku Master (Japan).gb" size 524288 crc 0356a509 sha1 7fdd0855dce2c5bbd229c2ba8485a3a020b873a1 flags verified ) ) game ( - name "Game Boy Camera (USA, Europe) (SGB Enhanced)" - description "Game Boy Camera (USA, Europe) (SGB Enhanced)" - rom ( name "Game Boy Camera (USA, Europe) (SGB Enhanced).gb" size 1048576 crc 4640909f sha1 461c3c37ed270681e3e94053efb21504b600aef5 flags verified ) + name "Doraemon no Study Boy 4 - Shou ni Kokugo Kanji (Japan)" + description "Doraemon no Study Boy 4 - Shou ni Kokugo Kanji (Japan)" + rom ( name "Doraemon no Study Boy 4 - Shou ni Kokugo Kanji (Japan).gb" size 524288 crc 45e3e8f2 sha1 996a57958c9971070cf881f475cfa815361409c4 ) ) game ( - name "Game Boy Camera Gold (USA) (SGB Enhanced)" - description "Game Boy Camera Gold (USA) (SGB Enhanced)" - rom ( name "Game Boy Camera Gold (USA) (SGB Enhanced).gb" size 1048576 crc a1a3f786 sha1 53a0dd6de3ebd0d3495f8bdc377ab08e5074c0ef ) + name "Doraemon no Study Boy 5 - Shou 2 Sansuu Keisan (Japan)" + description "Doraemon no Study Boy 5 - Shou 2 Sansuu Keisan (Japan)" + rom ( name "Doraemon no Study Boy 5 - Shou 2 Sansuu Keisan (Japan).gb" size 524288 crc 6b39f607 sha1 8bc5692de1850b68767bee01fe4506455aac8cc6 ) ) game ( - name "Game Boy Controller Kensa Cartridge (Japan)" - description "Game Boy Controller Kensa Cartridge (Japan)" - rom ( name "Game Boy Controller Kensa Cartridge (Japan).gb" size 32768 crc f5657fce sha1 1bed2a9ac25ac2f88b4fc45e729122abcad962f3 ) + name "Doraemon no Study Boy 6 - Gakushuu Kanji Master 1006 (Japan)" + description "Doraemon no Study Boy 6 - Gakushuu Kanji Master 1006 (Japan)" + rom ( name "Doraemon no Study Boy 6 - Gakushuu Kanji Master 1006 (Japan).gb" size 1048576 crc 5a16c88d sha1 1bfbd1aa188cfa1a2168b5e245b87bd67090d810 flags verified ) ) game ( - name "Game Boy Datenlogger 1 (Germany) (Unl)" - description "Game Boy Datenlogger 1 (Germany) (Unl)" - rom ( name "Game Boy Datenlogger 1 (Germany) (Unl).gb" size 32768 crc 9ab28af0 sha1 bfeba84926a72498ea65fcae767df8ba13f28d49 ) + name "Double Dragon (Japan)" + description "Double Dragon (Japan)" + rom ( name "Double Dragon (Japan).gb" size 131072 crc a0645e8a sha1 7dccd7d3ca7223815e7b00a3b664f5e7d7d433b2 ) ) game ( - name "Game Boy Digital Sampling Oscilloscope (Europe) (Unl)" - description "Game Boy Digital Sampling Oscilloscope (Europe) (Unl)" - rom ( name "Game Boy Digital Sampling Oscilloscope (Europe) (Unl).gb" size 32768 crc 572ea59c sha1 68128bd8b01970054590a88b785d553456b68ec1 ) + name "Double Dragon (USA, Europe)" + description "Double Dragon (USA, Europe)" + rom ( name "Double Dragon (USA, Europe).gb" size 131072 crc 40a8bf12 sha1 6565a3d89827717d8e5d2e041c743266ba14b412 flags verified ) ) game ( - name "Game Boy Digital Sampling Oscilloscope (Europe) (Demo) (Unl)" - description "Game Boy Digital Sampling Oscilloscope (Europe) (Demo) (Unl)" - rom ( name "Game Boy Digital Sampling Oscilloscope (Europe) (Demo) (Unl).gb" size 32768 crc a800444b sha1 db3e76bced7bd9844aedf23345c4307403006600 ) + name "Double Dragon 3 - The Arcade Game (USA, Europe)" + description "Double Dragon 3 - The Arcade Game (USA, Europe)" + rom ( name "Double Dragon 3 - The Arcade Game (USA, Europe).gb" size 131072 crc fc970aef sha1 c596d069d9fbd6372757e5d669a5144e2eb9d8ff flags verified ) ) game ( - name "Game Boy Gallery (Japan) (SGB Enhanced)" - description "Game Boy Gallery (Japan) (SGB Enhanced)" - rom ( name "Game Boy Gallery (Japan) (SGB Enhanced).gb" size 262144 crc a93e125b sha1 9d9465486610ab470203236c614692bc7b86c328 flags verified ) + name "Double Dragon II (USA, Europe)" + description "Double Dragon II (USA, Europe)" + rom ( name "Double Dragon II (USA, Europe).gb" size 131072 crc 5b96e474 sha1 3532462be3ab1a569890261d20a1a37bfe79e1ea flags verified ) ) game ( - name "Game Boy Gallery - 5 Games in 1 (Europe) (SGB Enhanced)" - description "Game Boy Gallery - 5 Games in 1 (Europe) (SGB Enhanced)" - rom ( name "Game Boy Gallery - 5 Games in 1 (Europe) (SGB Enhanced).gb" size 131072 crc 263fd152 sha1 07b6174a413858f84bfc480169945c7fd1a372b9 flags verified ) + name "Double Dribble - 5 on 5 (USA)" + description "Double Dribble - 5 on 5 (USA)" + rom ( name "Double Dribble - 5 on 5 (USA).gb" size 131072 crc ee28749d sha1 d0f18c97b48dd8b355d195d2ddaeee910c5fc2b1 ) ) game ( - name "Game Boy Gallery 2 (Australia) (SGB Enhanced)" - description "Game Boy Gallery 2 (Australia) (SGB Enhanced)" - rom ( name "Game Boy Gallery 2 (Australia) (SGB Enhanced).gb" size 262144 crc 6b09508f sha1 f002564f9cd9edb704b9c64f889aea3e7836a712 flags verified ) + name "Double Yakuman (Japan)" + description "Double Yakuman (Japan)" + rom ( name "Double Yakuman (Japan).gb" size 131072 crc 252c32b5 sha1 24dd6ba6a82ca3e6aca44aa471cf03d08371dc80 ) ) game ( - name "Game Boy Gallery 2 (Japan) (SGB Enhanced)" - description "Game Boy Gallery 2 (Japan) (SGB Enhanced)" - rom ( name "Game Boy Gallery 2 (Japan) (SGB Enhanced).gb" size 524288 crc 9359a183 sha1 021c47f89fa975e4dc5cc32c61bf87b120a25c09 ) + name "Double Yakuman II (Japan)" + description "Double Yakuman II (Japan)" + rom ( name "Double Yakuman II (Japan).gb" size 131072 crc a3d77a55 sha1 7f6ed21bf0cce0d524dcbce56af5cab61c85d729 ) ) game ( - name "Game Boy Test Cartridge (USA, Europe) (Proto) (Test Program)" - description "Game Boy Test Cartridge (USA, Europe) (Proto) (Test Program)" - rom ( name "Game Boy Test Cartridge (USA, Europe) (Proto) (Test Program).gb" size 32768 crc ae13a5c3 sha1 ce9c211852b4357b1356bb015db6f675def69c9f flags verified ) + name "Double Yakuman Jr. (Japan)" + description "Double Yakuman Jr. (Japan)" + rom ( name "Double Yakuman Jr. (Japan).gb" size 131072 crc 34ac7268 sha1 7d72bc65297f21605521f7320a5b49193e584cd0 ) ) game ( - name "Game Boy Wars (Japan)" - description "Game Boy Wars (Japan)" - rom ( name "Game Boy Wars (Japan).gb" size 262144 crc f5d364db sha1 9f725d3cbbeb5e27b7ee36304f077f78d9ad074e flags verified ) + name "Downtown - Nekketsu Koushinkyoku - Dokodemo Daiundoukai (Japan)" + description "Downtown - Nekketsu Koushinkyoku - Dokodemo Daiundoukai (Japan)" + rom ( name "Downtown - Nekketsu Koushinkyoku - Dokodemo Daiundoukai (Japan).gb" size 262144 crc 82511a8f sha1 1b8f59467ddce14db359e22567e29f6955c7c92a ) ) game ( - name "Game Boy Wars Turbo (Japan) (SGB Enhanced)" - description "Game Boy Wars Turbo (Japan) (SGB Enhanced)" - rom ( name "Game Boy Wars Turbo (Japan) (SGB Enhanced).gb" size 524288 crc 94563424 sha1 27121450bee04790e7a0d8a08086ad42302f17e9 flags verified ) + name "Downtown Special - Kunio-kun no Jidaigeki Da yo Zenin Shuugou! (Japan)" + description "Downtown Special - Kunio-kun no Jidaigeki Da yo Zenin Shuugou! (Japan)" + rom ( name "Downtown Special - Kunio-kun no Jidaigeki Da yo Zenin Shuugou! (Japan).gb" size 262144 crc 229e9113 sha1 97ff2392f126b195ac8a1700a9a91aa364549dfd ) ) game ( - name "Game Boy Wars Turbo - Famitsu Version (Japan) (SGB Enhanced)" - description "Game Boy Wars Turbo - Famitsu Version (Japan) (SGB Enhanced)" - rom ( name "Game Boy Wars Turbo - Famitsu Version (Japan) (SGB Enhanced).gb" size 262144 crc 86d04bfb sha1 a0106f20aaf857a7ba033537821e31c6ec074dd6 ) + name "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv)" + description "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv)" + rom ( name "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv).gb" size 262144 crc f13a60b8 sha1 ba5aaac92c4a2ca2d6a752c521e4d95108444a4e ) ) game ( - name "Game de Hakken!! Tamagotchi (Japan) (SGB Enhanced)" - description "Game de Hakken!! Tamagotchi (Japan) (SGB Enhanced)" - rom ( name "Game de Hakken!! Tamagotchi (Japan) (SGB Enhanced).gb" size 524288 crc efc0f266 sha1 5aea023fd373643e55c7276b79a2d042302c3329 flags verified ) + name "Dr. Franken (Japan)" + description "Dr. Franken (Japan)" + rom ( name "Dr. Franken (Japan).gb" size 131072 crc 3d04b8e7 sha1 6350ec30e51f388e0e290f387989cb1c7a24a91c ) ) game ( - name "Game de Hakken!! Tamagotchi - Osutchi to Mesutchi (Japan) (SGB Enhanced)" - description "Game de Hakken!! Tamagotchi - Osutchi to Mesutchi (Japan) (SGB Enhanced)" - rom ( name "Game de Hakken!! Tamagotchi - Osutchi to Mesutchi (Japan) (SGB Enhanced).gb" size 524288 crc 9694d69d sha1 e61f7faad888e5a1c56ffe66fa3c0330b5ee459b flags verified ) + name "Dr. Franken (USA)" + description "Dr. Franken (USA)" + rom ( name "Dr. Franken (USA).gb" size 131072 crc d409375b sha1 2b136ef8e3dd082ccb4716035545fb2e03438c66 flags verified ) ) game ( - name "Game de Hakken!! Tamagotchi 2 (Japan) (SGB Enhanced)" - description "Game de Hakken!! Tamagotchi 2 (Japan) (SGB Enhanced)" - rom ( name "Game de Hakken!! Tamagotchi 2 (Japan) (SGB Enhanced).gb" size 524288 crc 19889c43 sha1 ade11f43f6957c75cde8575e7cba11de9e53e0ea flags verified ) + name "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta)" + description "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta)" + rom ( name "Dr. Franken (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta).gb" size 262144 crc a65adc31 sha1 440eb30e54bf257246923149d44bab3dfafed2aa ) ) game ( - name "Game Genie (USA) (v2.1) (Unl)" - description "Game Genie (USA) (v2.1) (Unl)" - rom ( name "Game Genie (USA) (v2.1) (Unl).gb" size 8192 crc bc491c4b sha1 50e2ceb9b83f953d304d5bc6a25065bafad89490 ) + name "Dr. Franken II (USA, Europe) (En,Fr,De,Es,It,Nl,Sv)" + description "Dr. Franken II (USA, Europe) (En,Fr,De,Es,It,Nl,Sv)" + rom ( name "Dr. Franken II (USA, Europe) (En,Fr,De,Es,It,Nl,Sv).gb" size 262144 crc 0d62473d sha1 8d578ce74907131114279854a0dc376f4426120c flags verified ) ) game ( - name "Game of Harmony, The (USA)" - description "Game of Harmony, The (USA)" - rom ( name "Game of Harmony, The (USA).gb" size 32768 crc b0074acb sha1 b0bc752e3ad25fcb83d8ca04a82a0f5e35381db2 ) + name "Dr. Mario (World)" + description "Dr. Mario (World)" + rom ( name "Dr. Mario (World).gb" size 32768 crc 10c98dd1 sha1 f1006d6cf77469092f3b9f266d0a65da9c91ac42 flags verified ) ) game ( - name "GameBoy WORDLE (World) (Aftermarket) (Unl)" - description "GameBoy WORDLE (World) (Aftermarket) (Unl)" - rom ( name "GameBoy WORDLE (World) (Aftermarket) (Unl).gb" size 32768 crc cc971c0f sha1 ba93939b93ab3f3aa5f7aa451d50d9b89220adbc ) + name "Dr. Mario (World) (Rev 1)" + description "Dr. Mario (World) (Rev 1)" + rom ( name "Dr. Mario (World) (Rev 1).gb" size 32768 crc f0225dd0 sha1 d31d67d0682515c7c85deaa1752b02231150e5bf flags verified ) ) game ( - name "Gamera - Daikaijuu Kuuchuu Kessen (Japan) (SGB Enhanced)" - description "Gamera - Daikaijuu Kuuchuu Kessen (Japan) (SGB Enhanced)" - rom ( name "Gamera - Daikaijuu Kuuchuu Kessen (Japan) (SGB Enhanced).gb" size 262144 crc 62769ec1 sha1 c6ec7aa3ad2b28ca43551cda3c0cfdbcb4377b45 ) + name "Dr. Mario (World) (Beta)" + description "Dr. Mario (World) (Beta)" + rom ( name "Dr. Mario (World) (Beta).gb" size 32768 crc 2b2f4f8f sha1 4b2343f40e7ca3c583108ed70a870c7bd906b108 ) ) game ( - name "GameShark (USA) (Unl) [b]" - description "GameShark (USA) (Unl) [b]" - rom ( name "GameShark (USA) (Unl) [b].gb" size 131072 crc d6909596 sha1 09a6dae5e5faae1c4b5cf20e1b913b1c5e72297e flags baddump ) + name "Dracula Densetsu (Japan) (Castlevania Anniversary Collection)" + description "Dracula Densetsu (Japan) (Castlevania Anniversary Collection)" + rom ( name "Dracula Densetsu (Japan) (Castlevania Anniversary Collection).gb" size 65536 crc 4d57af56 sha1 5a79f9d5d6b710216921a89450b727a9741e0d83 flags verified ) ) game ( - name "Ganbare Goemon - Kurofunetou no Nazo (Japan) (SGB Enhanced)" - description "Ganbare Goemon - Kurofunetou no Nazo (Japan) (SGB Enhanced)" - rom ( name "Ganbare Goemon - Kurofunetou no Nazo (Japan) (SGB Enhanced).gb" size 262144 crc 910afe24 sha1 bd336346982e33270128b74a7b356e9e6824e4a6 ) + name "Dracula Densetsu (Japan)" + description "Dracula Densetsu (Japan)" + rom ( name "Dracula Densetsu (Japan).gb" size 65536 crc a35b9ef5 sha1 bedeb390391779400de14196d24f07a451184ece flags verified ) ) game ( - name "Ganbare Goemon - Sarawareta Ebisumaru (Japan)" - description "Ganbare Goemon - Sarawareta Ebisumaru (Japan)" - rom ( name "Ganbare Goemon - Sarawareta Ebisumaru (Japan).gb" size 262144 crc 33261c11 sha1 dd38c2b305160b6bc7e1767a0e7de9850260779c ) + name "Dracula Densetsu II (Japan)" + description "Dracula Densetsu II (Japan)" + rom ( name "Dracula Densetsu II (Japan).gb" size 131072 crc 7582ae14 sha1 bca90edddbf50d0d05630852c092fc5d3e0df9d4 ) ) game ( - name "Ganso!! Yancha Maru (Japan)" - description "Ganso!! Yancha Maru (Japan)" - rom ( name "Ganso!! Yancha Maru (Japan).gb" size 65536 crc 004443e6 sha1 76be351eac00749553c942b6f8002e65d8a35986 flags verified ) + name "Dracula Densetsu II (Japan) (Castlevania Anniversary Collection)" + description "Dracula Densetsu II (Japan) (Castlevania Anniversary Collection)" + rom ( name "Dracula Densetsu II (Japan) (Castlevania Anniversary Collection).gb" size 131072 crc 8709434b sha1 3d0c52d7f566fd717e9117ca4b948174b7864769 flags verified ) ) game ( - name "Garfield Labyrinth (Europe)" - description "Garfield Labyrinth (Europe)" - rom ( name "Garfield Labyrinth (Europe).gb" size 131072 crc 51b8626d sha1 87913e557dfb98c5f2a0f42ea074c36eca57a4f7 flags verified ) + name "Dragon Ball Z - Gokuu Gekitouden (Japan) (SGB Enhanced)" + description "Dragon Ball Z - Gokuu Gekitouden (Japan) (SGB Enhanced)" + rom ( name "Dragon Ball Z - Gokuu Gekitouden (Japan) (SGB Enhanced).gb" size 524288 crc ff3c027d sha1 1f7a08d2e51e90d770d9dbf4092166b2bfa5697e ) ) game ( - name "Garfield Labyrinth (Europe) (Beta)" - description "Garfield Labyrinth (Europe) (Beta)" - rom ( name "Garfield Labyrinth (Europe) (Beta).gb" size 131072 crc 06884616 sha1 c9170113c3370523cf5d13132ed3e2253a3f9dde ) + name "Dragon Ball Z - Gokuu Hishouden (Japan) (SGB Enhanced)" + description "Dragon Ball Z - Gokuu Hishouden (Japan) (SGB Enhanced)" + rom ( name "Dragon Ball Z - Gokuu Hishouden (Japan) (SGB Enhanced).gb" size 262144 crc 38da46d7 sha1 6bf8f3400bf323edecc2152c4a86f6b0cae628fe ) ) game ( - name "Gargoyle's Quest (Europe) (Rev 1)" - description "Gargoyle's Quest (Europe) (Rev 1)" - rom ( name "Gargoyle's Quest (Europe) (Rev 1).gb" size 131072 crc b86ef7a5 sha1 21fbe39014ffed80d0de2092517522d3cb9b03f9 ) + name "Dragon Ball Z 3 (USA) (SGB Enhanced) (Unl)" + description "Dragon Ball Z 3 (USA) (SGB Enhanced) (Unl)" + rom ( name "Dragon Ball Z 3 (USA) (SGB Enhanced) (Unl).gb" size 1048576 crc 71b8ea17 sha1 c43eb3906f77dda5fee94a0fce0b6d783461238c ) ) game ( - name "Gargoyle's Quest (USA, Europe)" - description "Gargoyle's Quest (USA, Europe)" - rom ( name "Gargoyle's Quest (USA, Europe).gb" size 131072 crc 0030e61f sha1 1da5834cd7cea711195cd8581614c5022da768b7 flags verified ) + name "Dragon Slayer Gaiden - Nemuri no Oukan (Japan)" + description "Dragon Slayer Gaiden - Nemuri no Oukan (Japan)" + rom ( name "Dragon Slayer Gaiden - Nemuri no Oukan (Japan).gb" size 131072 crc 10dcbdc3 sha1 ef58063d896533398288a4f07245f23efa3aee4a ) ) game ( - name "Gargoyle's Quest II - The Demon Darkness (USA) (Proto)" - description "Gargoyle's Quest II - The Demon Darkness (USA) (Proto)" - rom ( name "Gargoyle's Quest II - The Demon Darkness (USA) (Proto).gb" size 262144 crc db6f5930 sha1 1534f0a1806a69d408e702eda5b2d67fef05b1ed ) + name "Dragon Slayer I (Japan)" + description "Dragon Slayer I (Japan)" + rom ( name "Dragon Slayer I (Japan).gb" size 32768 crc 308a2465 sha1 7d987446f67d8bee42482a4932d0fa60318238e4 ) ) game ( - name "Gargoyle's Quest II - The Demon Darkness (Europe) (Proto)" - description "Gargoyle's Quest II - The Demon Darkness (Europe) (Proto)" - rom ( name "Gargoyle's Quest II - The Demon Darkness (Europe) (Proto).gb" size 262144 crc a7447341 sha1 131b81e35e2d23b768949a23b5a9ba71b4f6177d ) + name "Dragon Tail (Japan)" + description "Dragon Tail (Japan)" + rom ( name "Dragon Tail (Japan).gb" size 131072 crc 1d1155af sha1 390addf6bb52452dc6370eb54c702972e51968a2 ) ) game ( - name "Gauntlet II (USA, Europe) (Beta)" - description "Gauntlet II (USA, Europe) (Beta)" - rom ( name "Gauntlet II (USA, Europe) (Beta).gb" size 262144 crc 965bbe1f sha1 53e6162e9276318f357a1e2e5bd706d4e4fd47d2 ) + name "Dragon's Lair (Japan)" + description "Dragon's Lair (Japan)" + rom ( name "Dragon's Lair (Japan).gb" size 131072 crc 73c994a0 sha1 e344b536e3edcf1628d09773f694e14ab2864b7a ) ) game ( - name "Gauntlet II (USA, Europe)" - description "Gauntlet II (USA, Europe)" - rom ( name "Gauntlet II (USA, Europe).gb" size 262144 crc 1907dac5 sha1 dc37df322b54a5df5d04bc637e26b011b84598bf flags verified ) + name "Dragon's Lair - The Legend (Europe)" + description "Dragon's Lair - The Legend (Europe)" + rom ( name "Dragon's Lair - The Legend (Europe).gb" size 131072 crc 00a14889 sha1 babc3c70d5b73df268cd5c9e5e841fe277b57003 flags verified ) ) game ( - name "GB Basketball (Japan)" - description "GB Basketball (Japan)" - rom ( name "GB Basketball (Japan).gb" size 131072 crc d9b24d21 sha1 65f73db2942d400a4c555fbcfd6313f07303d4e4 ) + name "Dragon's Lair - The Legend (USA)" + description "Dragon's Lair - The Legend (USA)" + rom ( name "Dragon's Lair - The Legend (USA).gb" size 131072 crc 7a38b5c3 sha1 4e947908fde7ef9892c59021c6eea0607771f6d2 ) ) game ( - name "GB Genjin (Japan)" - description "GB Genjin (Japan)" - rom ( name "GB Genjin (Japan).gb" size 262144 crc 690227f6 sha1 c2e98c76e49155e7b9815e0c33ae6cf71daaee2c ) + name "DragonHeart (France)" + description "DragonHeart (France)" + rom ( name "DragonHeart (France).gb" size 524288 crc 8d089356 sha1 6b01e78df8a7dc3fb171d488cae38501fce3b660 ) ) game ( - name "GB Genjin 2 (Japan) (SGB Enhanced)" - description "GB Genjin 2 (Japan) (SGB Enhanced)" - rom ( name "GB Genjin 2 (Japan) (SGB Enhanced).gb" size 262144 crc 6f7ad5d9 sha1 82c1e3dd8b425fb49a1d1c25813002b23963a84a ) + name "DragonHeart (USA, Europe)" + description "DragonHeart (USA, Europe)" + rom ( name "DragonHeart (USA, Europe).gb" size 524288 crc 5129a518 sha1 1800ceeba6ed491e5f85997c945ab52b09f6e4ba flags verified ) ) game ( - name "GB Genjin Land - Viva! Chikkun Oukoku (Japan)" - description "GB Genjin Land - Viva! Chikkun Oukoku (Japan)" - rom ( name "GB Genjin Land - Viva! Chikkun Oukoku (Japan).gb" size 262144 crc b08bb116 sha1 6c7b6268e28281ae06fb621bf3cbbcbadc8e30e8 ) + name "Dropzone (Europe)" + description "Dropzone (Europe)" + rom ( name "Dropzone (Europe).gb" size 32768 crc 351a7277 sha1 0bf73ffa90fdba5a4ee4e2338bb2f0d01af6fb88 ) ) game ( - name "GB Pachi-Slot Hisshouhou! Jr. (Japan)" - description "GB Pachi-Slot Hisshouhou! Jr. (Japan)" - rom ( name "GB Pachi-Slot Hisshouhou! Jr. (Japan).gb" size 131072 crc a2e210e9 sha1 7636799f5a57d22cf579bb687be5bb9fedddd0ca ) + name "Dropzone (Europe) (Beta)" + description "Dropzone (Europe) (Beta)" + rom ( name "Dropzone (Europe) (Beta).gb" size 131072 crc 374f80b0 sha1 ac64c854dfea6387f262a2870f85c369d2cd14f5 ) ) game ( - name "GBKiss Mini Games (Japan)" - description "GBKiss Mini Games (Japan)" - rom ( name "GBKiss Mini Games (Japan).gb" size 262144 crc 92a03fc3 sha1 3c6c78f0a936dbc3f366a82c1eca8be0597d4d5b ) + name "Druaga no Tou (Japan)" + description "Druaga no Tou (Japan)" + rom ( name "Druaga no Tou (Japan).gb" size 131072 crc f924bdb1 sha1 7701f8c535f612943d736fef342973e9c77011df flags verified ) ) game ( - name "Gear Works (USA, Europe)" - description "Gear Works (USA, Europe)" - rom ( name "Gear Works (USA, Europe).gb" size 131072 crc b2b72056 sha1 f064c897da11945287ed793fe041d75c1b536709 flags verified ) + name "DuckTales (Europe)" + description "DuckTales (Europe)" + rom ( name "DuckTales (Europe).gb" size 65536 crc ac6483dc sha1 04aa9c515c2ede8fdf37b29e69c44481f8a8630c flags verified ) ) game ( - name "Gegege no Kitarou - Youkai Souzoushu Arawaru! (Japan) (SGB Enhanced)" - description "Gegege no Kitarou - Youkai Souzoushu Arawaru! (Japan) (SGB Enhanced)" - rom ( name "Gegege no Kitarou - Youkai Souzoushu Arawaru! (Japan) (SGB Enhanced).gb" size 262144 crc 28e507b0 sha1 fa52c8f0bb31e25be829c7d4f52a7f4db1d5ef5b ) + name "DuckTales (Japan)" + description "DuckTales (Japan)" + rom ( name "DuckTales (Japan).gb" size 65536 crc 5b5410f5 sha1 ce734cc3548f1d5a0cb26017b29b714f23d80c0f ) ) game ( - name "Gekitou Power Modeller (Japan) (SGB Enhanced)" - description "Gekitou Power Modeller (Japan) (SGB Enhanced)" - rom ( name "Gekitou Power Modeller (Japan) (SGB Enhanced).gb" size 524288 crc 48c1ee22 sha1 22d6bf37eb3a29aeb1f9969ec51537eca8036a4c ) + name "DuckTales (USA)" + description "DuckTales (USA)" + rom ( name "DuckTales (USA).gb" size 65536 crc 2bbbb54d sha1 93460364e33e8fb09a0659738044d0297cd4df69 ) ) game ( - name "Gem Gem (Japan)" - description "Gem Gem (Japan)" - rom ( name "Gem Gem (Japan).gb" size 65536 crc a64a8710 sha1 90a29d7a56f64b596cda1c64c8998b63d12c321e ) + name "DuckTales 2 (Europe)" + description "DuckTales 2 (Europe)" + rom ( name "DuckTales 2 (Europe).gb" size 131072 crc 169b00c1 sha1 68113dcd6482a8a54e48c69223fcf2e2dedea844 flags verified ) ) game ( - name "Genesis (World) (Aftermarket) (Unl)" - description "Genesis (World) (Aftermarket) (Unl)" - rom ( name "Genesis (World) (Aftermarket) (Unl).gb" size 65536 crc 74b3ec78 sha1 ca43f82d73ba0b3e43ec17f6bc6761c09ca23626 ) + name "DuckTales 2 (Japan)" + description "DuckTales 2 (Japan)" + rom ( name "DuckTales 2 (Japan).gb" size 131072 crc 2b693cde sha1 d7c33c30e9921d119c4f4c9a77be9406207368eb ) ) game ( - name "Genesis II (World) (Demo) (Aftermarket) (Unl)" - description "Genesis II (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Genesis II (World) (Demo) (Aftermarket) (Unl).gb" size 262144 crc d7aec1cc sha1 9700ea1278850df004ded7553253cfdd354f4ada ) + name "DuckTales 2 (USA)" + description "DuckTales 2 (USA)" + rom ( name "DuckTales 2 (USA).gb" size 131072 crc b151509d sha1 c9d5b7a71badcc7b198897b4888482f663f03504 flags verified ) ) game ( - name "Genjin Collection (Japan) (SGB Enhanced)" - description "Genjin Collection (Japan) (SGB Enhanced)" - rom ( name "Genjin Collection (Japan) (SGB Enhanced).gb" size 1048576 crc b2eedd36 sha1 a9f953e2a3680078e51cb42fac44edf81991737b ) + name "Dungeon Land (Japan)" + description "Dungeon Land (Japan)" + rom ( name "Dungeon Land (Japan).gb" size 131072 crc 11be4b45 sha1 e354b0e78992f66bd598399998790231ff81b86f flags verified ) ) game ( - name "Genjin Cottsu (Japan) (SGB Enhanced)" - description "Genjin Cottsu (Japan) (SGB Enhanced)" - rom ( name "Genjin Cottsu (Japan) (SGB Enhanced).gb" size 262144 crc 95e8fcb1 sha1 70e3cd1df16fbff644c32f588bf80a116b043bb2 ) + name "Dungeon Warrior (Europe) (Proto)" + description "Dungeon Warrior (Europe) (Proto)" + rom ( name "Dungeon Warrior (Europe) (Proto).gb" size 65536 crc 2910429c sha1 21a6fba83faa7649fbb2e75176649bcd7d846d25 ) ) game ( - name "Genki Bakuhatsu Gambaruger (Japan)" - description "Genki Bakuhatsu Gambaruger (Japan)" - rom ( name "Genki Bakuhatsu Gambaruger (Japan).gb" size 131072 crc 6226d280 sha1 4ca8a77c95530879b175a2ec9a792485ae18e83c ) + name "DX Bakenou Z (Japan)" + description "DX Bakenou Z (Japan)" + rom ( name "DX Bakenou Z (Japan).gb" size 131072 crc 3ef2e823 sha1 346ed92c1f56221d1feda2a008ead2e3940bcbcb ) ) game ( - name "George Foreman's KO Boxing (USA, Europe)" - description "George Foreman's KO Boxing (USA, Europe)" - rom ( name "George Foreman's KO Boxing (USA, Europe).gb" size 131072 crc 7f62456b sha1 01e923706486c75b2d0a438d968c5d571b2fdf1c flags verified ) + name "DX Bakenou Z (Japan) (Rev 1)" + description "DX Bakenou Z (Japan) (Rev 1)" + rom ( name "DX Bakenou Z (Japan) (Rev 1).gb" size 131072 crc fadfd0f6 sha1 6e2b9b21ea7d8d482be1f17722a579f720f2029d flags verified ) ) game ( - name "Gerry Anderson's Thunderbirds (Japan)" - description "Gerry Anderson's Thunderbirds (Japan)" - rom ( name "Gerry Anderson's Thunderbirds (Japan).gb" size 131072 crc 149e9393 sha1 440169376982aa89cedde08edbc9efdfafc6c7f1 ) + name "Dynablaster (Europe)" + description "Dynablaster (Europe)" + rom ( name "Dynablaster (Europe).gb" size 131072 crc 9677d157 sha1 3c284831353be165e20b56f3728b0421eaea274a flags verified ) ) game ( - name "Getaway, The - High Speed II (USA)" - description "Getaway, The - High Speed II (USA)" - rom ( name "Getaway, The - High Speed II (USA).gb" size 262144 crc 8f2bf517 sha1 a0ca7187b55135150f348d44544d3a6e6d51394e ) + name "Earthworm Jim (Europe)" + description "Earthworm Jim (Europe)" + rom ( name "Earthworm Jim (Europe).gb" size 262144 crc b1a7a008 sha1 4249abe39285b02ccb0e739b5a2cf96ace1281ff flags verified ) ) game ( - name "Ghost Town (World) (Aftermarket) (Unl)" - description "Ghost Town (World) (Aftermarket) (Unl)" - rom ( name "Ghost Town (World) (Aftermarket) (Unl).gb" size 262144 crc 2d27cdf2 sha1 af526273cdaa6423b92d0484fb27af56fe355a5d ) + name "Earthworm Jim (USA)" + description "Earthworm Jim (USA)" + rom ( name "Earthworm Jim (USA).gb" size 262144 crc 259ff267 sha1 f5d3085de17a5181c07739e49be7637faa5ff932 ) ) game ( - name "Ghostbusters II (USA, Europe) (Beta)" - description "Ghostbusters II (USA, Europe) (Beta)" - rom ( name "Ghostbusters II (USA, Europe) (Beta).gb" size 131072 crc 41423376 sha1 c96b152f5351eeec19e1b020c9e0d51d582e2e8c ) + name "Eclipse (Europe) (Proto)" + description "Eclipse (Europe) (Proto)" + rom ( name "Eclipse (Europe) (Proto).gb" size 65536 crc 6b507efd sha1 de02a34675a57d450284103681951436a4c830cd ) ) game ( - name "Ghostbusters II (Japan)" - description "Ghostbusters II (Japan)" - rom ( name "Ghostbusters II (Japan).gb" size 131072 crc 69b161bc sha1 0ca645c40ca8dc6102b4f3cf56f0e9ae5d1ffc03 ) + name "Edd the Duck (Europe) (Proto)" + description "Edd the Duck (Europe) (Proto)" + rom ( name "Edd the Duck (Europe) (Proto).gb" size 131072 crc 486463a4 sha1 4ee8fa0c4f4c9268182945835f19c25eb055ceb3 ) ) game ( - name "Ghostbusters II (USA, Europe)" - description "Ghostbusters II (USA, Europe)" - rom ( name "Ghostbusters II (USA, Europe).gb" size 131072 crc 5821ecd4 sha1 1e2aa42b7e0f974f45fbca35160cda6d5964f0ad flags verified ) + name "Eddie's Puzzle Time (USA) (Proto)" + description "Eddie's Puzzle Time (USA) (Proto)" + rom ( name "Eddie's Puzzle Time (USA) (Proto).gb" size 65536 crc f2600f02 sha1 cd2695295831737d0f8a7eb825bbfe870b9c0bfd ) ) game ( - name "GI King! - Sanbiki no Yosouya (Japan)" - description "GI King! - Sanbiki no Yosouya (Japan)" - rom ( name "GI King! - Sanbiki no Yosouya (Japan).gb" size 65536 crc 150bc291 sha1 de6109b643a97e7a96e55a6becfd7e61dfdc915e ) + name "Elevator Action (Japan)" + description "Elevator Action (Japan)" + rom ( name "Elevator Action (Japan).gb" size 65536 crc bead8ae4 sha1 16dbf00df012c1216d9d4abec9abcd5512d053a3 ) ) game ( - name "Ginga - Card & Puzzle Collection (Japan) (En,Ja)" - description "Ginga - Card & Puzzle Collection (Japan) (En,Ja)" - rom ( name "Ginga - Card & Puzzle Collection (Japan) (En,Ja).gb" size 65536 crc 87d0637b sha1 14f4f14caee081dceadb9d31ae26fd8968c432ea ) + name "Elevator Action (USA, Europe)" + description "Elevator Action (USA, Europe)" + rom ( name "Elevator Action (USA, Europe).gb" size 65536 crc b749a927 sha1 c0c9de672a31f314e98392160fc343cf46ee98b9 flags verified ) ) game ( - name "Glory Hunters - Chapter 1 (World) (v0.1) (Demo) (Aftermarket) (Unl)" - description "Glory Hunters - Chapter 1 (World) (v0.1) (Demo) (Aftermarket) (Unl)" - rom ( name "Glory Hunters - Chapter 1 (World) (v0.1) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc 4b19366d sha1 77f3b561bf28a81f38dbedc351752e10ff4c23dc ) + name "Elite Soccer (USA) (SGB Enhanced)" + description "Elite Soccer (USA) (SGB Enhanced)" + rom ( name "Elite Soccer (USA) (SGB Enhanced).gb" size 131072 crc f54158a6 sha1 4576881ea25e29ebba91c49c89f8e70e105fbc60 ) ) game ( - name "Glory Hunters - Chapter 1 (World) (v0.2) (Demo) (Aftermarket) (Unl)" - description "Glory Hunters - Chapter 1 (World) (v0.2) (Demo) (Aftermarket) (Unl)" - rom ( name "Glory Hunters - Chapter 1 (World) (v0.2) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc 3f34ff66 sha1 a0bff49b6917186d27dc24773da0674a18a6212c ) + name "Exodus - Journey to the Promised Land (USA) (Unl)" + description "Exodus - Journey to the Promised Land (USA) (Unl)" + rom ( name "Exodus - Journey to the Promised Land (USA) (Unl).gb" size 131072 crc 2e5497ef sha1 685d5a47a1fc386d7b451c8b2733e654b7779b71 ) ) game ( - name "Gluecksrad (Germany)" - description "Gluecksrad (Germany)" - rom ( name "Gluecksrad (Germany).gb" size 131072 crc e8b26577 sha1 638cd5087b53b7fe7c6ece99fd973f98c0c09ebe flags verified ) + name "Extra Bases (USA)" + description "Extra Bases (USA)" + rom ( name "Extra Bases (USA).gb" size 131072 crc 19608641 sha1 bf44f14a948e8816fb9deea229512d979cb42aec ) ) game ( - name "Go Go Ackman (Japan) (SGB Enhanced)" - description "Go Go Ackman (Japan) (SGB Enhanced)" - rom ( name "Go Go Ackman (Japan) (SGB Enhanced).gb" size 262144 crc 61d80946 sha1 28ce08f67b4fb26e7a5a46f853b053d20ec9d7cd flags verified ) + name "F-1 Race (World)" + description "F-1 Race (World)" + rom ( name "F-1 Race (World).gb" size 131072 crc 7e4febdf sha1 96490be847aeeded0b635f45b05683a6defdf2e8 ) ) game ( - name "Go! Go! Hitchhike (Japan) (SGB Enhanced)" - description "Go! Go! Hitchhike (Japan) (SGB Enhanced)" - rom ( name "Go! Go! Hitchhike (Japan) (SGB Enhanced).gb" size 524288 crc 845735de sha1 6a35bc2967f25fda0626b7a00a2cacfec9c53278 ) + name "F-1 Race (World) (Rev 1)" + description "F-1 Race (World) (Rev 1)" + rom ( name "F-1 Race (World) (Rev 1).gb" size 131072 crc ab83bd70 sha1 0256082f482af57e0472f5713a432a22bfa4d2fc flags verified ) ) game ( - name "Go! Go! Tank (Japan)" - description "Go! Go! Tank (Japan)" - rom ( name "Go! Go! Tank (Japan).gb" size 65536 crc 30ae39b6 sha1 6a60d5b550355e634ba54d8bd83b51ca55d6874b ) + name "F-1 Spirit (Japan)" + description "F-1 Spirit (Japan)" + rom ( name "F-1 Spirit (Japan).gb" size 131072 crc f9e08783 sha1 4f950151001c2c7e157bc407601d9a8eb9d2523c ) ) game ( - name "Go! Go! Tank (USA)" - description "Go! Go! Tank (USA)" - rom ( name "Go! Go! Tank (USA).gb" size 65536 crc 65dfabcb sha1 7f3408c951a161f93394812d34f6d2534658b7d3 ) + name "F-15 Strike Eagle (USA, Europe)" + description "F-15 Strike Eagle (USA, Europe)" + rom ( name "F-15 Strike Eagle (USA, Europe).gb" size 131072 crc 045dee8c sha1 237a08abe860bce316f1ce337afb11ee0e566037 ) ) game ( - name "Go! Go! Tank (Japan) (Beta)" - description "Go! Go! Tank (Japan) (Beta)" - rom ( name "Go! Go! Tank (Japan) (Beta).gb" size 65536 crc 6dcf5e7f sha1 18bbee226858af45a81f7da1186938f53511ef73 ) + name "F-15 Strike Eagle II (USA, Europe) (Beta) (July, 1992)" + description "F-15 Strike Eagle II (USA, Europe) (Beta) (July, 1992)" + rom ( name "F-15 Strike Eagle II (USA, Europe) (Beta) (July, 1992).gb" size 131072 crc d80bdbba sha1 298c07ef596ab3a3c4a320b2f2d7e2c0dbaf764d ) ) game ( - name "Goal! (Europe)" - description "Goal! (Europe)" - rom ( name "Goal! (Europe).gb" size 131072 crc 533fa979 sha1 24fffa3db4153895546a346a38971b6946011679 ) + name "F1 Boy (Japan)" + description "F1 Boy (Japan)" + rom ( name "F1 Boy (Japan).gb" size 65536 crc fac1f53b sha1 632f0ccc2bcb1c33ad46724d7b1bc66b256303a2 ) ) game ( - name "Goal! (USA)" - description "Goal! (USA)" - rom ( name "Goal! (USA).gb" size 131072 crc 00d4caf2 sha1 9bb15769b2674d41075b45256dbfffc18483fd84 ) + name "F1 Challenge (Europe) (Beta)" + description "F1 Challenge (Europe) (Beta)" + rom ( name "F1 Challenge (Europe) (Beta).gb" size 262144 crc bc505a3b sha1 9849276839efdf7c2270a2fa7acd0d814cac026b ) ) game ( - name "God Medicine - Fantasy Sekai no Tanjou (Japan)" - description "God Medicine - Fantasy Sekai no Tanjou (Japan)" - rom ( name "God Medicine - Fantasy Sekai no Tanjou (Japan).gb" size 262144 crc a1b29ab8 sha1 b365cd58d133c2b441bbf53c2e5ff9486bbf0bde ) + name "F1 Pole Position (USA, Europe)" + description "F1 Pole Position (USA, Europe)" + rom ( name "F1 Pole Position (USA, Europe).gb" size 262144 crc aabe61bb sha1 a0087bd7421d73e1f8f339a266e62c2d03d081d6 ) ) game ( - name "God Medicine - Fukkokuban (Japan) (SGB Enhanced)" - description "God Medicine - Fukkokuban (Japan) (SGB Enhanced)" - rom ( name "God Medicine - Fukkokuban (Japan) (SGB Enhanced).gb" size 524288 crc 847e0772 sha1 61d3579293bf07166402d11d891e14bfd6fef6b4 flags verified ) + name "Faceball 2000 (USA)" + description "Faceball 2000 (USA)" + rom ( name "Faceball 2000 (USA).gb" size 131072 crc 7d890cd0 sha1 b0bd15bace04e0a3eb89773f231ac3a532181a0a flags verified ) ) game ( - name "Godzilla (USA, Europe)" - description "Godzilla (USA, Europe)" - rom ( name "Godzilla (USA, Europe).gb" size 131072 crc fe4f80b7 sha1 c0fa19386aa1e325af42e8dd2caf8e66112b9578 flags verified ) + name "Family Jockey (Japan)" + description "Family Jockey (Japan)" + rom ( name "Family Jockey (Japan).gb" size 131072 crc d6ef1450 sha1 e463999d178489e050504298f4a3ffe30b48494a flags verified ) ) game ( - name "Gojira-kun - Kaijuu Daikoushin (Japan)" - description "Gojira-kun - Kaijuu Daikoushin (Japan)" - rom ( name "Gojira-kun - Kaijuu Daikoushin (Japan).gb" size 131072 crc ed204600 sha1 4c03da759e5fb2ec06d286d5f0b52d64621fea41 ) + name "Family Jockey 2 - Meiba no Kettou (Japan)" + description "Family Jockey 2 - Meiba no Kettou (Japan)" + rom ( name "Family Jockey 2 - Meiba no Kettou (Japan).gb" size 131072 crc 0325e729 sha1 d858fcdfce099435fa632859a9f8e8c82823bbcb ) ) game ( - name "Golf (World)" - description "Golf (World)" - rom ( name "Golf (World).gb" size 131072 crc 6ed10383 sha1 2acee1a14ba611e73b0b7d6bce170107213fcc0c flags verified ) + name "Famista (Japan)" + description "Famista (Japan)" + rom ( name "Famista (Japan).gb" size 131072 crc 3d3c059e sha1 5cb8e63906d32c5408b7f959a75c41578a444c3b ) ) game ( - name "Golf Classic (Europe) (SGB Enhanced)" - description "Golf Classic (Europe) (SGB Enhanced)" - rom ( name "Golf Classic (Europe) (SGB Enhanced).gb" size 262144 crc a6dadb1e sha1 b7ffb77a5061c33b0bbe5b074c1526e46c5eb7c3 ) + name "Famista 2 (Japan)" + description "Famista 2 (Japan)" + rom ( name "Famista 2 (Japan).gb" size 131072 crc 241a6e4c sha1 e6f4ca432c36ec421935e6d4ecfc65c46764bc9c ) ) game ( - name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (Imagineer)" - description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (Imagineer)" - rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (Imagineer).gb" size 1048576 crc 5d43a385 sha1 d367f2dab5eacb10e785a13a2550ca7cc3e54177 ) + name "Famista 3 (Japan)" + description "Famista 3 (Japan)" + rom ( name "Famista 3 (Japan).gb" size 262144 crc bdc4ccc3 sha1 ac4b03e11e2ba135d0427c8b1da7de57c006b4a6 ) ) game ( - name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (IE Institute)" - description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (IE Institute)" - rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (IE Institute).gb" size 1048576 crc 26772e04 sha1 a6ab7420a2d69d62338bc03dc4e0e46b0dc8429b flags verified ) + name "Fastest Lap (USA)" + description "Fastest Lap (USA)" + rom ( name "Fastest Lap (USA).gb" size 131072 crc a9ba7875 sha1 25bf89b112c9b134b2e4d07354d1a762ab0d4e92 ) ) game ( - name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (IE Institute)" - description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (IE Institute)" - rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (IE Institute).gb" size 1048576 crc 180d54a7 sha1 7dce0adcbac61f0caae33646847fd06ced8c8b67 ) + name "Fastest Lap (Japan) (En)" + description "Fastest Lap (Japan) (En)" + rom ( name "Fastest Lap (Japan) (En).gb" size 131072 crc 59285f0a sha1 f1abe89a52e4f06e0479277d8681feaa09fcff2f ) ) game ( - name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (Imagineer)" - description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (Imagineer)" - rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (Imagineer).gb" size 1048576 crc 62b00f69 sha1 1d3e5ad888b8339e35c46455d84017d8a0d69c6d flags verified ) + name "Felix the Cat (USA, Europe)" + description "Felix the Cat (USA, Europe)" + rom ( name "Felix the Cat (USA, Europe).gb" size 131072 crc f53f7f00 sha1 c4a0d02d5964335a18839c7c30ac05b6f40c33b3 ) ) game ( - name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (Imagineer)" - description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (Imagineer)" - rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (Imagineer).gb" size 1048576 crc 71acbb67 sha1 e2ac91493248869aba6b7d26a36e5ff6bd6d6f5a flags verified ) + name "Felix the Cat (USA, Europe) (Beta)" + description "Felix the Cat (USA, Europe) (Beta)" + rom ( name "Felix the Cat (USA, Europe) (Beta).gb" size 131072 crc b1734088 sha1 66fe01233643fb63e758d1f2e9932f63d545e288 ) ) game ( - name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (IE Institute)" - description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (IE Institute)" - rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (IE Institute).gb" size 1048576 crc 04214f92 sha1 6b8726c69a31e674a4c5ab02631de073d42e7d52 ) + name "Ferrari (Japan)" + description "Ferrari (Japan)" + rom ( name "Ferrari (Japan).gb" size 131072 crc a7bdfec8 sha1 f9883af35e5f49736f9dc073ce00f3779e93cf3f ) ) game ( - name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Proto) (IE Institute)" - description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Proto) (IE Institute)" - rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Proto) (IE Institute).gb" size 1048576 crc 91ab959f sha1 2e1797646b2d3aa6fc9b2f5eaa248751133a0518 ) + name "Ferrari Grand Prix Challenge (USA, Europe)" + description "Ferrari Grand Prix Challenge (USA, Europe)" + rom ( name "Ferrari Grand Prix Challenge (USA, Europe).gb" size 131072 crc ed6771db sha1 ecdbe43db8714367bd606127e3276d8a3431841c flags verified ) ) game ( - name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Imagineer)" - description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Imagineer)" - rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Imagineer).gb" size 1048576 crc 3c907f2c sha1 fa7a40acd835676fbcae9507a8aaaf1191f9b1cd ) + name "Fidgetts, The (Japan)" + description "Fidgetts, The (Japan)" + rom ( name "Fidgetts, The (Japan).gb" size 262144 crc ffd4a9e3 sha1 c701ce4c62c414aada502f8c17aa9261dd635685 ) ) game ( - name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Zukei no Tatsujin (Japan)" - description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Zukei no Tatsujin (Japan)" - rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Zukei no Tatsujin (Japan).gb" size 1048576 crc 479e2c18 sha1 630a331a3c89823647fbda13235b6299d91a1b25 ) + name "Fidgetts, The (USA, Europe) (En,Fr,De,Es,It,Nl,Sv)" + description "Fidgetts, The (USA, Europe) (En,Fr,De,Es,It,Nl,Sv)" + rom ( name "Fidgetts, The (USA, Europe) (En,Fr,De,Es,It,Nl,Sv).gb" size 262144 crc b3fd3e36 sha1 1100f259fe30857d1103beb116b888497f6fbdaa flags verified ) ) game ( - name "Goukaku Boy Series - 99 Nendo Ban Eitango Center 1500 (Japan)" - description "Goukaku Boy Series - 99 Nendo Ban Eitango Center 1500 (Japan)" - rom ( name "Goukaku Boy Series - 99 Nendo Ban Eitango Center 1500 (Japan).gb" size 262144 crc 9c0d14c3 sha1 b9e79e032f4d65442daa37767be5238a84c103db ) + name "FIFA - Road to World Cup 98 (Europe) (SGB Enhanced)" + description "FIFA - Road to World Cup 98 (Europe) (SGB Enhanced)" + rom ( name "FIFA - Road to World Cup 98 (Europe) (SGB Enhanced).gb" size 524288 crc cdf6a5ac sha1 5ef615a919ea967e749febb046f9d097d91fab0d flags verified ) ) game ( - name "Goukaku Boy Series - Eijukugo Target 1000 (Japan)" - description "Goukaku Boy Series - Eijukugo Target 1000 (Japan)" - rom ( name "Goukaku Boy Series - Eijukugo Target 1000 (Japan).gb" size 262144 crc ca20c594 sha1 535fbf6988af70c4283d8101c72acb67d249bb96 ) + name "FIFA - Road to World Cup 98 (Europe) (Rev 1) (SGB Enhanced)" + description "FIFA - Road to World Cup 98 (Europe) (Rev 1) (SGB Enhanced)" + rom ( name "FIFA - Road to World Cup 98 (Europe) (Rev 1) (SGB Enhanced).gb" size 524288 crc 8dc0d46c sha1 8dc3ab8f020e4377af1e1f636396cc3881268a1f ) ) game ( - name "Goukaku Boy Series - Eiken 2kyuu Level no Kaiwa Hyougen 333 (Japan)" - description "Goukaku Boy Series - Eiken 2kyuu Level no Kaiwa Hyougen 333 (Japan)" - rom ( name "Goukaku Boy Series - Eiken 2kyuu Level no Kaiwa Hyougen 333 (Japan).gb" size 262144 crc 46af90da sha1 e58d4dc3e8b5f0407f156c5d252d34b40e7dfec0 ) + name "FIFA International Soccer (USA, Europe) (En,Fr,De,Es) (SGB Enhanced)" + description "FIFA International Soccer (USA, Europe) (En,Fr,De,Es) (SGB Enhanced)" + rom ( name "FIFA International Soccer (USA, Europe) (En,Fr,De,Es) (SGB Enhanced).gb" size 524288 crc e5989908 sha1 6f0affdec339d7beb9c565dc51abe59ee0398b7b ) ) game ( - name "Goukaku Boy Series - Eitango Target 1900 (Japan)" - description "Goukaku Boy Series - Eitango Target 1900 (Japan)" - rom ( name "Goukaku Boy Series - Eitango Target 1900 (Japan).gb" size 262144 crc f8406560 sha1 c5f885c9c6b7ab89646b4c17b6ff83b2dfe67a04 ) + name "FIFA Soccer 96 (USA, Europe) (En,Fr,De,Es) (SGB Enhanced)" + description "FIFA Soccer 96 (USA, Europe) (En,Fr,De,Es) (SGB Enhanced)" + rom ( name "FIFA Soccer 96 (USA, Europe) (En,Fr,De,Es) (SGB Enhanced).gb" size 524288 crc af4a5de1 sha1 a434f0f96d1aa3ec50d35f82eb5ef876bcd22115 ) ) game ( - name "Goukaku Boy Series - Gakken - Kanyouku Kotowaza 210 (Japan)" - description "Goukaku Boy Series - Gakken - Kanyouku Kotowaza 210 (Japan)" - rom ( name "Goukaku Boy Series - Gakken - Kanyouku Kotowaza 210 (Japan).gb" size 262144 crc 44f5a443 sha1 19a6f8c7a98b84b9b0bf53c25dbba02c438c1822 ) + name "FIFA Soccer 97 (USA, Europe) (SGB Enhanced)" + description "FIFA Soccer 97 (USA, Europe) (SGB Enhanced)" + rom ( name "FIFA Soccer 97 (USA, Europe) (SGB Enhanced).gb" size 524288 crc dcab906c sha1 dd9b9b99bd663cdf55187ff5867eccd52615f025 ) ) game ( - name "Goukaku Boy Series - Gakken - Rekishi 512 (Japan)" - description "Goukaku Boy Series - Gakken - Rekishi 512 (Japan)" - rom ( name "Goukaku Boy Series - Gakken - Rekishi 512 (Japan).gb" size 262144 crc 10bd83ba sha1 ab7733c04bc7975312b0cbe75d8d9b2519ac35ae ) + name "Fighting Simulator 2 in 1 - Flying Warriors (USA, Europe)" + description "Fighting Simulator 2 in 1 - Flying Warriors (USA, Europe)" + rom ( name "Fighting Simulator 2 in 1 - Flying Warriors (USA, Europe).gb" size 131072 crc 52678ae8 sha1 9073276d8adf1e59829ae48073b42ae19c9770ce flags verified ) ) game ( - name "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan)" - description "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan)" - rom ( name "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan).gb" size 262144 crc 631a752e sha1 df253afb9c01615ad8219730573321a40fb5e230 flags verified ) + name "Final Fantasy Adventure (USA)" + description "Final Fantasy Adventure (USA)" + rom ( name "Final Fantasy Adventure (USA).gb" size 262144 crc 18c78b3a sha1 8b93c55ee2660c60cf86dd70058f96ace98782c8 flags verified ) ) game ( - name "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan) (Rev 1)" - description "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan) (Rev 1)" - rom ( name "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan) (Rev 1).gb" size 262144 crc c8e01c7c sha1 7df1d7b389814c6de2a1b201a00c71316b0ac856 flags verified ) + name "Final Fantasy Adventure (World) (Collection of Mana)" + description "Final Fantasy Adventure (World) (Collection of Mana)" + rom ( name "Final Fantasy Adventure (World) (Collection of Mana).gb" size 262144 crc 8e5e5097 sha1 bd8369977cfbbaf3cc57f6268b564d6b11c27d45 flags verified ) ) game ( - name "Goukaku Boy Series - Kirihara Shoten Hinshutsu Eibunpou Gohou Mondai 1000 (Japan)" - description "Goukaku Boy Series - Kirihara Shoten Hinshutsu Eibunpou Gohou Mondai 1000 (Japan)" - rom ( name "Goukaku Boy Series - Kirihara Shoten Hinshutsu Eibunpou Gohou Mondai 1000 (Japan).gb" size 262144 crc 41c17421 sha1 134a9d7a276b8ef2ed698075e0990d0553ffbf73 ) + name "Final Fantasy Legend II (World) (Collection of SaGa)" + description "Final Fantasy Legend II (World) (Collection of SaGa)" + rom ( name "Final Fantasy Legend II (World) (Collection of SaGa).gb" size 262144 crc e84e051a sha1 eedf962d01b733b5eaf2413905e59e671e04a51c ) ) game ( - name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Imagineer)" - description "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Imagineer)" - rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Imagineer).gb" size 262144 crc e4271f4b sha1 02baaf987249f2daf9daa6d6000e61adc05b0ef6 flags verified ) + name "Final Fantasy Legend II (USA)" + description "Final Fantasy Legend II (USA)" + rom ( name "Final Fantasy Legend II (USA).gb" size 262144 crc 58314182 sha1 6ab6890e8f688bcd87e97886a1748a4d9d341909 flags verified ) ) game ( - name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Possible Proto) (IE Institute)" - description "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Possible Proto) (IE Institute)" - rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Possible Proto) (IE Institute).gb" size 262144 crc 5855b281 sha1 25f69cc4da819f7d5c449f6ad0cf4963011dc5a7 ) + name "Final Fantasy Legend III (USA)" + description "Final Fantasy Legend III (USA)" + rom ( name "Final Fantasy Legend III (USA).gb" size 262144 crc 3e454710 sha1 3864afa48a97db826ffda1d31a7ff9c6c315d5c9 ) ) game ( - name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Possible Proto) (IE Institute)" - description "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Possible Proto) (IE Institute)" - rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Possible Proto) (IE Institute).gb" size 262144 crc bc14fce6 sha1 48775723113ac0e3d1cbcf7381ba876d6dc30a7c ) + name "Final Fantasy Legend III (World) (Collection of SaGa)" + description "Final Fantasy Legend III (World) (Collection of SaGa)" + rom ( name "Final Fantasy Legend III (World) (Collection of SaGa).gb" size 262144 crc 0c5171ef sha1 5190b0ef6264e26af21dc0097fd5608cb619fb63 ) ) game ( - name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Imagineer)" - description "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Imagineer)" - rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Imagineer).gb" size 262144 crc d3168eca sha1 2e30d41e3783da4d3f6bb928c54c0e243f63e4ca ) + name "Final Fantasy Legend, The (World) (Collection of SaGa)" + description "Final Fantasy Legend, The (World) (Collection of SaGa)" + rom ( name "Final Fantasy Legend, The (World) (Collection of SaGa).gb" size 131072 crc 00388844 sha1 42450483c9894863c7543f9695c0cbaffdcb7e99 ) ) game ( - name "Goukaku Boy Series - Koukou Nyuushi Derujun - Kanji Mondai no Seifuku (Japan)" - description "Goukaku Boy Series - Koukou Nyuushi Derujun - Kanji Mondai no Seifuku (Japan)" - rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Kanji Mondai no Seifuku (Japan).gb" size 262144 crc 84e30e6c sha1 2185bbb4868058577fbe696b9a88fa7238ce7098 ) + name "Final Fantasy Legend, The (USA)" + description "Final Fantasy Legend, The (USA)" + rom ( name "Final Fantasy Legend, The (USA).gb" size 131072 crc 8046148f sha1 901dfc83c72e172d35a376835807fc788444a9bb flags verified ) ) game ( - name "Goukaku Boy Series - Koukou Nyuushi Derujun - Rekishi Nendai Anki Point 240 (Japan)" - description "Goukaku Boy Series - Koukou Nyuushi Derujun - Rekishi Nendai Anki Point 240 (Japan)" - rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Rekishi Nendai Anki Point 240 (Japan).gb" size 262144 crc 7e262a4d sha1 d969dbc0cf3e5d427726bf749d082b89e171354b ) + name "Final Reverse (Japan)" + description "Final Reverse (Japan)" + rom ( name "Final Reverse (Japan).gb" size 65536 crc e94a6942 sha1 e4b08e702f3b6c575b31dbd62615619126e03af5 ) ) game ( - name "Goukaku Boy Series - Koukou Nyuushi Derujun - Rika Anki Point 250 (Japan)" - description "Goukaku Boy Series - Koukou Nyuushi Derujun - Rika Anki Point 250 (Japan)" - rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Rika Anki Point 250 (Japan).gb" size 262144 crc 70468755 sha1 b96acb6454ba916ad5df2256f9a0a8022cdbff3b ) + name "Fire Fighter (Europe)" + description "Fire Fighter (Europe)" + rom ( name "Fire Fighter (Europe).gb" size 131072 crc c46bbd49 sha1 a26a4f0a51fb3aad3f138eedfe326a04af9a1b56 ) ) game ( - name "Goukaku Boy Series - Nihonshi Target 201 (Japan)" - description "Goukaku Boy Series - Nihonshi Target 201 (Japan)" - rom ( name "Goukaku Boy Series - Nihonshi Target 201 (Japan).gb" size 262144 crc cf133379 sha1 d6178851d778bf794a0fce14a831f6e2cd991f22 ) + name "Fish Dude (USA)" + description "Fish Dude (USA)" + rom ( name "Fish Dude (USA).gb" size 65536 crc 4b929719 sha1 72d11ae07b6701efe109d20dad6107ff6f603ea5 ) ) game ( - name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (Imagineer)" - description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (Imagineer)" - rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (Imagineer).gb" size 262144 crc 8bd567d1 sha1 75009ac4a2114b4ceac3e4bc7e6c3f3173292bf0 flags verified ) + name "Fist of the North Star (USA)" + description "Fist of the North Star (USA)" + rom ( name "Fist of the North Star (USA).gb" size 131072 crc 9a84b6cf sha1 0bf60583da14cd32947f8e8e6b995c2b176d95c5 ) ) game ( - name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (IE Institute)" - description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (IE Institute)" - rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (IE Institute).gb" size 262144 crc 7e6e16d5 sha1 3fc9c1bc1d3b8e7ee90c14d4ae4938726f61a2db flags verified ) + name "Flappy Special (Japan)" + description "Flappy Special (Japan)" + rom ( name "Flappy Special (Japan).gb" size 32768 crc 3b6cdda4 sha1 6517aee7caa2fa60750005ef1dacaeaecee7c2f6 ) ) game ( - name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (IE Institute)" - description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (IE Institute)" - rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (IE Institute).gb" size 262144 crc 62aa54a4 sha1 4569f5cc0f528fdf46cfd1b3a8ef8a6fd3953d7e flags verified ) + name "Flappy Special (USA) (Proto)" + description "Flappy Special (USA) (Proto)" + rom ( name "Flappy Special (USA) (Proto).gb" size 32768 crc 617d0d9f sha1 75347d9f708da85487b779ed79b9c1e84954020d ) ) game ( - name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (Imagineer)" - description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (Imagineer)" - rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (Imagineer).gb" size 262144 crc c34ae38f sha1 fa92ad7099a6c698088433d7721fd1e87b2b925d flags verified ) + name "Flash, The (USA, Europe)" + description "Flash, The (USA, Europe)" + rom ( name "Flash, The (USA, Europe).gb" size 131072 crc 6deb1f06 sha1 f7e5701e6fa8fe4440988d1207517668c35088c6 ) ) game ( - name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (Imagineer)" - description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (Imagineer)" - rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (Imagineer).gb" size 262144 crc 0dadb829 sha1 a10e78f3fe2c46e167d39ed713106937365a6d55 ) + name "Fleet Commander VS. (Japan)" + description "Fleet Commander VS. (Japan)" + rom ( name "Fleet Commander VS. (Japan).gb" size 262144 crc 71bf3256 sha1 b858d597e5eea575c5baa953785c96459d9be593 ) ) game ( - name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (IE Institute)" - description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (IE Institute)" - rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (IE Institute).gb" size 262144 crc de74fd69 sha1 1e0fe5a54b4eb03a1f108d8650ad5ef8814d7444 flags verified ) + name "Flintstones, The (USA, Europe)" + description "Flintstones, The (USA, Europe)" + rom ( name "Flintstones, The (USA, Europe).gb" size 262144 crc 503d3613 sha1 506a647137bcaad81589f1b3592884b3bbed8aa3 ) ) game ( - name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (IE Institute)" - description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (IE Institute)" - rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (IE Institute).gb" size 262144 crc 8ba62b3d sha1 dfdcabdc06b74f896b9ef47db2a9cc49ddb104c4 flags verified ) + name "Flintstones, The - King Rock Treasure Island (USA, Europe)" + description "Flintstones, The - King Rock Treasure Island (USA, Europe)" + rom ( name "Flintstones, The - King Rock Treasure Island (USA, Europe).gb" size 131072 crc 508282d0 sha1 4ea1609dc273623c677aaa0accd0cd8d4a03efca flags verified ) ) game ( - name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (Imagineer)" - description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (Imagineer)" - rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (Imagineer).gb" size 262144 crc 87f0cfad sha1 edfc194f9f58ef97dfe87092eebd4c73359925e1 flags verified ) + name "Flintstones, The - King Rock Treasure Island (Japan) (Proto)" + description "Flintstones, The - King Rock Treasure Island (Japan) (Proto)" + rom ( name "Flintstones, The - King Rock Treasure Island (Japan) (Proto).gb" size 131072 crc 437600bb sha1 bf6ba87bbc9ce4252c91f0e72121ab7c496a7dec ) ) game ( - name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan)" - description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan)" - rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan).gb" size 262144 crc f141b2dc sha1 02ddcaef0008871786797fc76c649d74f010718d ) + name "Flipull (USA)" + description "Flipull (USA)" + rom ( name "Flipull (USA).gb" size 32768 crc a2f30b4b sha1 54cf45a997d390729dd23b9ed46a967b77cb7664 ) ) game ( - name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan) (Rev 1)" - description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan) (Rev 1)" - rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan) (Rev 1).gb" size 262144 crc 74821248 sha1 b1626c1fe162a7b0292d292e8ba60a1c6823fc8d ) + name "Flipull - An Exciting Cube Game (Japan)" + description "Flipull - An Exciting Cube Game (Japan)" + rom ( name "Flipull - An Exciting Cube Game (Japan).gb" size 32768 crc 198f147d sha1 090c88ae19892c35608f4fa844a6e9efcbe23893 ) ) game ( - name "Goukaku Boy Series - Yamakawa Ichimonittou - Nihonshi B Yougo Mondaishuu (Japan)" - description "Goukaku Boy Series - Yamakawa Ichimonittou - Nihonshi B Yougo Mondaishuu (Japan)" - rom ( name "Goukaku Boy Series - Yamakawa Ichimonittou - Nihonshi B Yougo Mondaishuu (Japan).gb" size 524288 crc a09c1790 sha1 6611adc52faa628bbc36cdc759d7c18b00316ba4 ) + name "Football International (Europe)" + description "Football International (Europe)" + rom ( name "Football International (Europe).gb" size 131072 crc 6e659690 sha1 30be5422b15e1960d22dc77d646642d7365b243c ) ) game ( - name "Goukaku Boy Series - Yamakawa Ichimonittou - Sekaishi B Yougo Mondaishuu (Japan)" - description "Goukaku Boy Series - Yamakawa Ichimonittou - Sekaishi B Yougo Mondaishuu (Japan)" - rom ( name "Goukaku Boy Series - Yamakawa Ichimonittou - Sekaishi B Yougo Mondaishuu (Japan).gb" size 524288 crc d185b939 sha1 33e651bbccda46ab395b6609810ee175b5cfacea ) + name "Foreman for Real (Japan)" + description "Foreman for Real (Japan)" + rom ( name "Foreman for Real (Japan).gb" size 262144 crc 860ea816 sha1 835b3208458e8ca1956e27a693fab036d4b25974 ) ) game ( - name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eigo Koubun 285 (Japan)" - description "Goukaku Boy Series - Z-Kai Kyuukyoku no Eigo Koubun 285 (Japan)" - rom ( name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eigo Koubun 285 (Japan).gb" size 262144 crc d792f747 sha1 4d0d8bf6cbaef902c5855513531203b756deb93f ) + name "Foreman for Real (USA, Europe)" + description "Foreman for Real (USA, Europe)" + rom ( name "Foreman for Real (USA, Europe).gb" size 262144 crc 77083ae0 sha1 7b088c7b3a0ad275d340ca27f64a99c1bd6c34e6 ) ) game ( - name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eijukugo 1017 (Japan)" - description "Goukaku Boy Series - Z-Kai Kyuukyoku no Eijukugo 1017 (Japan)" - rom ( name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eijukugo 1017 (Japan).gb" size 262144 crc 12e738ea sha1 ba02b31919422226d22f89e59df90ab060b046c9 ) + name "Fortified Zone (USA, Europe)" + description "Fortified Zone (USA, Europe)" + rom ( name "Fortified Zone (USA, Europe).gb" size 131072 crc e3b59b7e sha1 232d2f57ab4bef748eb832dfb4085cc3df1fd532 flags verified ) ) game ( - name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eitango 1500 (Japan)" - description "Goukaku Boy Series - Z-Kai Kyuukyoku no Eitango 1500 (Japan)" - rom ( name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eitango 1500 (Japan).gb" size 262144 crc 3fac5c42 sha1 f439497b513262d2c98b622af1a00f4efd8650a6 ) + name "Frank Thomas Big Hurt Baseball (USA, Europe)" + description "Frank Thomas Big Hurt Baseball (USA, Europe)" + rom ( name "Frank Thomas Big Hurt Baseball (USA, Europe).gb" size 524288 crc 9a494ae6 sha1 ccea5b85ed334a2bf7bd4449f07bbf3a86841dfd flags verified ) ) game ( - name "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Chuugaku Eitango 1132 (Japan)" - description "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Chuugaku Eitango 1132 (Japan)" - rom ( name "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Chuugaku Eitango 1132 (Japan).gb" size 262144 crc dc010f04 sha1 a5f3e531b8becf0fa218d73d21c3775265df607e flags verified ) + name "Franky, Joe & Dirk - On the Tiles (Europe) (En,Fr,De,Es,It,Nl)" + description "Franky, Joe & Dirk - On the Tiles (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Franky, Joe & Dirk - On the Tiles (Europe) (En,Fr,De,Es,It,Nl).gb" size 131072 crc caf5b372 sha1 b7e292cfd34d64546f158e548afa92efaf8c2acd ) ) game ( - name "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Kyuukyoku no Kobun Tango (Japan)" - description "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Kyuukyoku no Kobun Tango (Japan)" - rom ( name "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Kyuukyoku no Kobun Tango (Japan).gb" size 262144 crc 99062c13 sha1 e105f4d680fbf0621997aa2f9ce05cb0651a9ee9 ) + name "Frisky Tom (Japan) (SGB Enhanced)" + description "Frisky Tom (Japan) (SGB Enhanced)" + rom ( name "Frisky Tom (Japan) (SGB Enhanced).gb" size 131072 crc 0bef84a1 sha1 4162ca88c94c40e3fa6e09067b956cf4953ccf89 ) ) game ( - name "Gradius - The Interstellar Assault (USA)" - description "Gradius - The Interstellar Assault (USA)" - rom ( name "Gradius - The Interstellar Assault (USA).gb" size 262144 crc 90f87d57 sha1 7a50fdf0b8ad15556c933df0657fae0a2cd8bc92 ) + name "Frogger (USA)" + description "Frogger (USA)" + rom ( name "Frogger (USA).gb" size 131072 crc 4d933c08 sha1 1dbb26dd94c9710b029f2f88473aed0267db491c flags verified ) ) game ( - name "Grander Musashi RV (Japan) (SGB Enhanced)" - description "Grander Musashi RV (Japan) (SGB Enhanced)" - rom ( name "Grander Musashi RV (Japan) (SGB Enhanced).gb" size 524288 crc e97f2e9a sha1 d6fc45fd02e3d7c885c0e0244dc3c8073fb64ff4 ) + name "From TV Animation Slam Dunk - Gakeppuchi no Kesshou League (Japan) (SGB Enhanced)" + description "From TV Animation Slam Dunk - Gakeppuchi no Kesshou League (Japan) (SGB Enhanced)" + rom ( name "From TV Animation Slam Dunk - Gakeppuchi no Kesshou League (Japan) (SGB Enhanced).gb" size 262144 crc ae478a6f sha1 0faf2c66a916c979450810ec16029c2258f90f83 ) ) game ( - name "Great Greed (USA)" - description "Great Greed (USA)" - rom ( name "Great Greed (USA).gb" size 262144 crc c4cbf6b1 sha1 9d7de25431f3e31f244925e317e3d0933f5efa2e flags verified ) + name "From TV Animation Slam Dunk 2 - Zenkoku e no Tip Off (Japan) (SGB Enhanced)" + description "From TV Animation Slam Dunk 2 - Zenkoku e no Tip Off (Japan) (SGB Enhanced)" + rom ( name "From TV Animation Slam Dunk 2 - Zenkoku e no Tip Off (Japan) (SGB Enhanced).gb" size 524288 crc cb35900a sha1 b8223ce166121ae7224d4431fdf27750c737b3f2 ) ) game ( - name "Gremlins 2 - The New Batch (World)" - description "Gremlins 2 - The New Batch (World)" - rom ( name "Gremlins 2 - The New Batch (World).gb" size 131072 crc 3579e297 sha1 0cb722d9d4e349bea1b1afa85d8d3b93f2dc2aad flags verified ) + name "From TV Animation Slam Dunk Limited Edition (Japan) (SGB Enhanced)" + description "From TV Animation Slam Dunk Limited Edition (Japan) (SGB Enhanced)" + rom ( name "From TV Animation Slam Dunk Limited Edition (Japan) (SGB Enhanced).gb" size 262144 crc ad55dbf0 sha1 ac878552813e3715b7de992f3dc6362c2150cce9 ) ) game ( - name "Gun Law (World) (Aftermarket) (Unl)" - description "Gun Law (World) (Aftermarket) (Unl)" - rom ( name "Gun Law (World) (Aftermarket) (Unl).gb" size 262144 crc b0d53211 sha1 ef6e3d287e99bd61861a333165c92b306238a45f ) + name "Funny Field (Japan)" + description "Funny Field (Japan)" + rom ( name "Funny Field (Japan).gb" size 65536 crc bfd87aa4 sha1 0b74e84ce50454057f78e4178be2599e57c91855 ) ) game ( - name "Gunman Clive (World) (Demo) (Aftermarket) (Unl)" - description "Gunman Clive (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Gunman Clive (World) (Demo) (Aftermarket) (Unl).gb" size 65536 crc 11f5fded sha1 ec03763db2c0d754e2eb7e98384ed92fc8aeeb1d ) + name "Fushigi na Blobby - Princess Blob o Sukue! (Japan)" + description "Fushigi na Blobby - Princess Blob o Sukue! (Japan)" + rom ( name "Fushigi na Blobby - Princess Blob o Sukue! (Japan).gb" size 65536 crc 3d0bac10 sha1 fcd6ac8a0ad6eb1f5d9e00c877747521541204de ) ) game ( - name "Gunship (World) (Aftermarket) (Unl)" - description "Gunship (World) (Aftermarket) (Unl)" - rom ( name "Gunship (World) (Aftermarket) (Unl).gb" size 131072 crc bd31eef8 sha1 a801977c3746799cfb4d8bdfd679e45cccd3b719 ) + name "Fushigi no Dungeon - Fuurai no Shiren GB - Tsukikage Mura no Kaibutsu (Japan) (SGB Enhanced)" + description "Fushigi no Dungeon - Fuurai no Shiren GB - Tsukikage Mura no Kaibutsu (Japan) (SGB Enhanced)" + rom ( name "Fushigi no Dungeon - Fuurai no Shiren GB - Tsukikage Mura no Kaibutsu (Japan) (SGB Enhanced).gb" size 524288 crc 2962afb4 sha1 920ef94c05ac741047a266cb1668c881eab2937c flags verified ) ) game ( - name "HAL Wrestling (USA)" - description "HAL Wrestling (USA)" - rom ( name "HAL Wrestling (USA).gb" size 131072 crc 5e4a61d3 sha1 861f1cd6ea513a003ab8364b37fa73c63b555e38 ) + name "G Arms - Operation Gundam (Japan)" + description "G Arms - Operation Gundam (Japan)" + rom ( name "G Arms - Operation Gundam (Japan).gb" size 131072 crc 39058153 sha1 7d8011636fe36266b5f716e78e3e29006f024992 ) ) game ( - name "HAL Wrestling (USA) (Beta)" - description "HAL Wrestling (USA) (Beta)" - rom ( name "HAL Wrestling (USA) (Beta).gb" size 131072 crc b02faa0b sha1 6ac35a017fd1f61c19086765107e3940426a2a66 ) + name "Galaga & Galaxian (Japan) (SGB Enhanced)" + description "Galaga & Galaxian (Japan) (SGB Enhanced)" + rom ( name "Galaga & Galaxian (Japan) (SGB Enhanced).gb" size 131072 crc 532036d5 sha1 2d67a97b4737b24ea0eff7a7c798b7d77e6a0724 ) ) game ( - name "Hammerin' Harry (Europe)" - description "Hammerin' Harry (Europe)" - rom ( name "Hammerin' Harry (Europe).gb" size 262144 crc 9f09afe8 sha1 05490ab94ae5e01dd02b4a578bfccc5647816408 ) + name "Game & Watch Gallery (Europe) (SGB Enhanced)" + description "Game & Watch Gallery (Europe) (SGB Enhanced)" + rom ( name "Game & Watch Gallery (Europe) (SGB Enhanced).gb" size 262144 crc 96ecc1e0 sha1 31186cff6bb548ecd0c91c07f16dc98de9c19ea2 ) ) game ( - name "Hammerin' Harry - Ghost Building Company (USA) (Proto)" - description "Hammerin' Harry - Ghost Building Company (USA) (Proto)" - rom ( name "Hammerin' Harry - Ghost Building Company (USA) (Proto).gb" size 262144 crc 6c4d0377 sha1 c5f73b09f001fc4d7eaa40ffee00234ca6a41a41 ) + name "Game & Watch Gallery (USA) (SGB Enhanced)" + description "Game & Watch Gallery (USA) (SGB Enhanced)" + rom ( name "Game & Watch Gallery (USA) (SGB Enhanced).gb" size 262144 crc 99b2fe79 sha1 f8c5ad6d6bf1a5a90dffebada1dbd69a93720c83 ) ) game ( - name "Harbour Attack (World) (Aftermarket) (Unl)" - description "Harbour Attack (World) (Aftermarket) (Unl)" - rom ( name "Harbour Attack (World) (Aftermarket) (Unl).gb" size 262144 crc 4018ebf7 sha1 5bbbe727ebc6a489f1a498d067e4f05d0d69b60f ) + name "Game & Watch Gallery (USA) (Rev 1) (SGB Enhanced)" + description "Game & Watch Gallery (USA) (Rev 1) (SGB Enhanced)" + rom ( name "Game & Watch Gallery (USA) (Rev 1) (SGB Enhanced).gb" size 262144 crc 9e6cdc96 sha1 4e4da0ed89c2baaed64600f7eaca90aeeadc084e flags verified ) ) game ( - name "Harvest Moon GB (USA) (SGB Enhanced)" - description "Harvest Moon GB (USA) (SGB Enhanced)" - rom ( name "Harvest Moon GB (USA) (SGB Enhanced).gb" size 524288 crc 1eae0e10 sha1 5b85d2accd3877e80d73a7ad19d9f55c288f43cc ) + name "Game Boy Aging Cartridge (World) (En,Ja) (v1.1)" + description "Game Boy Aging Cartridge (World) (En,Ja) (v1.1)" + rom ( name "Game Boy Aging Cartridge (World) (En,Ja) (v1.1).gb" size 32768 crc 4db33858 sha1 3f27a044131548d528783f0d43f918f04418519e ) ) game ( - name "Hatris (Japan, USA) (En)" - description "Hatris (Japan, USA) (En)" - rom ( name "Hatris (Japan, USA) (En).gb" size 65536 crc 7635f28b sha1 e8002f226e90ed52e1675c003d3c8ce804b56b0e ) + name "Game Boy Camera (USA, Europe) (SGB Enhanced)" + description "Game Boy Camera (USA, Europe) (SGB Enhanced)" + rom ( name "Game Boy Camera (USA, Europe) (SGB Enhanced).gb" size 1048576 crc 4640909f sha1 461c3c37ed270681e3e94053efb21504b600aef5 flags verified ) ) game ( - name "Hayaoshi Quiz - Ouza Ketteisen (Japan) (SGB Enhanced)" - description "Hayaoshi Quiz - Ouza Ketteisen (Japan) (SGB Enhanced)" - rom ( name "Hayaoshi Quiz - Ouza Ketteisen (Japan) (SGB Enhanced).gb" size 524288 crc 60727bf9 sha1 7f0010677e3052c6b9caf41714e87d285ad45a91 ) + name "Game Boy Camera Gold (USA) (SGB Enhanced)" + description "Game Boy Camera Gold (USA) (SGB Enhanced)" + rom ( name "Game Boy Camera Gold (USA) (SGB Enhanced).gb" size 1048576 crc a1a3f786 sha1 53a0dd6de3ebd0d3495f8bdc377ab08e5074c0ef ) ) game ( - name "Head On (Japan)" - description "Head On (Japan)" - rom ( name "Head On (Japan).gb" size 65536 crc 78830daf sha1 76261091adb7def20a4f76aa6c062c60c6d9761c ) + name "Game Boy Controller Kensa Cartridge (Japan)" + description "Game Boy Controller Kensa Cartridge (Japan)" + rom ( name "Game Boy Controller Kensa Cartridge (Japan).gb" size 32768 crc f5657fce sha1 1bed2a9ac25ac2f88b4fc45e729122abcad962f3 ) ) game ( - name "Heart Knight (World) (Aftermarket) (Unl)" - description "Heart Knight (World) (Aftermarket) (Unl)" - rom ( name "Heart Knight (World) (Aftermarket) (Unl).gb" size 32768 crc c7ecac73 sha1 dedcab41f58c58834e3534e877c494669a0d8952 ) + name "Game Boy Datenlogger 1 (Germany) (Unl)" + description "Game Boy Datenlogger 1 (Germany) (Unl)" + rom ( name "Game Boy Datenlogger 1 (Germany) (Unl).gb" size 32768 crc 9ab28af0 sha1 bfeba84926a72498ea65fcae767df8ba13f28d49 ) ) game ( - name "Heavyweight Championship Boxing (USA)" - description "Heavyweight Championship Boxing (USA)" - rom ( name "Heavyweight Championship Boxing (USA).gb" size 65536 crc 1526a96b sha1 1d6f1afed7ce7a90a07219449d4d3b679afeda6b ) + name "Game Boy Digital Sampling Oscilloscope (Europe) (Unl)" + description "Game Boy Digital Sampling Oscilloscope (Europe) (Unl)" + rom ( name "Game Boy Digital Sampling Oscilloscope (Europe) (Unl).gb" size 32768 crc 572ea59c sha1 68128bd8b01970054590a88b785d553456b68ec1 ) ) game ( - name "Heiankyo Alien (USA)" - description "Heiankyo Alien (USA)" - rom ( name "Heiankyo Alien (USA).gb" size 32768 crc 1495bbe5 sha1 7372e49dbe5cbb25b8201f52ca544737d06e0fb6 flags verified ) + name "Game Boy Digital Sampling Oscilloscope (Europe) (Demo) (Unl)" + description "Game Boy Digital Sampling Oscilloscope (Europe) (Demo) (Unl)" + rom ( name "Game Boy Digital Sampling Oscilloscope (Europe) (Demo) (Unl).gb" size 32768 crc a800444b sha1 db3e76bced7bd9844aedf23345c4307403006600 ) ) game ( - name "Heiankyou Alien (Japan)" - description "Heiankyou Alien (Japan)" - rom ( name "Heiankyou Alien (Japan).gb" size 32768 crc 08bf29c9 sha1 602561d82cec7484e9509b5739be021f8a3f3449 ) + name "Game Boy Gallery (Japan) (SGB Enhanced)" + description "Game Boy Gallery (Japan) (SGB Enhanced)" + rom ( name "Game Boy Gallery (Japan) (SGB Enhanced).gb" size 262144 crc a93e125b sha1 9d9465486610ab470203236c614692bc7b86c328 flags verified ) ) game ( - name "Heisei Tensai Bakabon (Japan)" - description "Heisei Tensai Bakabon (Japan)" - rom ( name "Heisei Tensai Bakabon (Japan).gb" size 131072 crc ac044e9a sha1 aaccd5b75894916ef655082a4ab4e05cb3f6fee8 ) + name "Game Boy Gallery - 5 Games in 1 (Europe) (SGB Enhanced)" + description "Game Boy Gallery - 5 Games in 1 (Europe) (SGB Enhanced)" + rom ( name "Game Boy Gallery - 5 Games in 1 (Europe) (SGB Enhanced).gb" size 131072 crc 263fd152 sha1 07b6174a413858f84bfc480169945c7fd1a372b9 flags verified ) ) game ( - name "Hello Kitty - Pocket Camera (Japan) (Proto) (SGB Enhanced)" - description "Hello Kitty - Pocket Camera (Japan) (Proto) (SGB Enhanced)" - rom ( name "Hello Kitty - Pocket Camera (Japan) (Proto) (SGB Enhanced).gb" size 1048576 crc 257ad445 sha1 3c416b44c7dc05701e0f1e1b29e87a505dcde442 ) + name "Game Boy Gallery 2 (Australia) (SGB Enhanced)" + description "Game Boy Gallery 2 (Australia) (SGB Enhanced)" + rom ( name "Game Boy Gallery 2 (Australia) (SGB Enhanced).gb" size 262144 crc 6b09508f sha1 f002564f9cd9edb704b9c64f889aea3e7836a712 flags verified ) ) game ( - name "Heracles no Eikou - Ugokidashita Kamigami (Japan)" - description "Heracles no Eikou - Ugokidashita Kamigami (Japan)" - rom ( name "Heracles no Eikou - Ugokidashita Kamigami (Japan).gb" size 262144 crc 4f8a61bf sha1 c12c60b0c0a2ee1aaded61020fa72b5b467459e1 ) + name "Game Boy Gallery 2 (Japan) (SGB Enhanced)" + description "Game Boy Gallery 2 (Japan) (SGB Enhanced)" + rom ( name "Game Boy Gallery 2 (Japan) (SGB Enhanced).gb" size 524288 crc 9359a183 sha1 021c47f89fa975e4dc5cc32c61bf87b120a25c09 ) ) game ( - name "Hercules (USA, Europe) (SGB Enhanced)" - description "Hercules (USA, Europe) (SGB Enhanced)" - rom ( name "Hercules (USA, Europe) (SGB Enhanced).gb" size 524288 crc 00a9001e sha1 215cceaccd4a33a2da6205f33a2803ff4004e2b1 flags verified ) + name "Game Boy Test Cartridge (USA, Europe) (Proto) (Test Program)" + description "Game Boy Test Cartridge (USA, Europe) (Proto) (Test Program)" + rom ( name "Game Boy Test Cartridge (USA, Europe) (Proto) (Test Program).gb" size 32768 crc ae13a5c3 sha1 ce9c211852b4357b1356bb015db6f675def69c9f flags verified ) ) game ( - name "Hermano (World) (v1.1) (Aftermarket) (Unl)" - description "Hermano (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Hermano (World) (v1.1) (Aftermarket) (Unl).gb" size 262144 crc 74a0419b sha1 c42cfe91a1ec593a76291e031c47137bd794ffda ) + name "Game Boy Wars (Japan)" + description "Game Boy Wars (Japan)" + rom ( name "Game Boy Wars (Japan).gb" size 262144 crc f5d364db sha1 9f725d3cbbeb5e27b7ee36304f077f78d9ad074e flags verified ) ) game ( - name "Hero Shuugou!! Pinball Party (Japan)" - description "Hero Shuugou!! Pinball Party (Japan)" - rom ( name "Hero Shuugou!! Pinball Party (Japan).gb" size 65536 crc 740552ed sha1 c4f0428455c6a4772c2db7bab0132dca169e22c7 ) + name "Game Boy Wars Turbo (Japan) (SGB Enhanced)" + description "Game Boy Wars Turbo (Japan) (SGB Enhanced)" + rom ( name "Game Boy Wars Turbo (Japan) (SGB Enhanced).gb" size 524288 crc 94563424 sha1 27121450bee04790e7a0d8a08086ad42302f17e9 flags verified ) ) game ( - name "Hiden Inyou Kikouhou - Ca Da (Japan)" - description "Hiden Inyou Kikouhou - Ca Da (Japan)" - rom ( name "Hiden Inyou Kikouhou - Ca Da (Japan).gb" size 65536 crc 9234eeab sha1 0ba32a4383f1ff89c8838d155cb672ff799f0687 ) + name "Game Boy Wars Turbo - Famitsu Version (Japan) (SGB Enhanced)" + description "Game Boy Wars Turbo - Famitsu Version (Japan) (SGB Enhanced)" + rom ( name "Game Boy Wars Turbo - Famitsu Version (Japan) (SGB Enhanced).gb" size 262144 crc 86d04bfb sha1 a0106f20aaf857a7ba033537821e31c6ec074dd6 ) ) game ( - name "Higashio Osamu Kanshuu Pro Yakyuu Stadium '91 (Japan)" - description "Higashio Osamu Kanshuu Pro Yakyuu Stadium '91 (Japan)" - rom ( name "Higashio Osamu Kanshuu Pro Yakyuu Stadium '91 (Japan).gb" size 131072 crc 420881ae sha1 cc6cbbcaabce4a63106da3c9b5e4a761511cae38 ) + name "Game de Hakken!! Tamagotchi (Japan) (SGB Enhanced)" + description "Game de Hakken!! Tamagotchi (Japan) (SGB Enhanced)" + rom ( name "Game de Hakken!! Tamagotchi (Japan) (SGB Enhanced).gb" size 524288 crc efc0f266 sha1 5aea023fd373643e55c7276b79a2d042302c3329 flags verified ) ) game ( - name "Higashio Osamu Kanshuu Pro Yakyuu Stadium '92 (Japan)" - description "Higashio Osamu Kanshuu Pro Yakyuu Stadium '92 (Japan)" - rom ( name "Higashio Osamu Kanshuu Pro Yakyuu Stadium '92 (Japan).gb" size 262144 crc 71559ba0 sha1 7c89b508b71569776c50256da350652657027cf2 ) + name "Game de Hakken!! Tamagotchi - Osutchi to Mesutchi (Japan) (SGB Enhanced)" + description "Game de Hakken!! Tamagotchi - Osutchi to Mesutchi (Japan) (SGB Enhanced)" + rom ( name "Game de Hakken!! Tamagotchi - Osutchi to Mesutchi (Japan) (SGB Enhanced).gb" size 524288 crc 9694d69d sha1 e61f7faad888e5a1c56ffe66fa3c0330b5ee459b flags verified ) ) game ( - name "High Stakes Gambling (USA)" - description "High Stakes Gambling (USA)" - rom ( name "High Stakes Gambling (USA).gb" size 131072 crc 6b17abe5 sha1 4235ecc5416a3fb0a455bec19bf26ecc9a12197b ) + name "Game de Hakken!! Tamagotchi 2 (Japan) (SGB Enhanced)" + description "Game de Hakken!! Tamagotchi 2 (Japan) (SGB Enhanced)" + rom ( name "Game de Hakken!! Tamagotchi 2 (Japan) (SGB Enhanced).gb" size 524288 crc 19889c43 sha1 ade11f43f6957c75cde8575e7cba11de9e53e0ea flags verified ) ) game ( - name "Hiryuu no Ken Gaiden (Japan)" - description "Hiryuu no Ken Gaiden (Japan)" - rom ( name "Hiryuu no Ken Gaiden (Japan).gb" size 131072 crc 8ee95e0b sha1 fb4133f25fa0b9eea75f2ec69b786fe2d20d537e ) + name "Game Genie (USA) (v2.1) (Unl)" + description "Game Genie (USA) (v2.1) (Unl)" + rom ( name "Game Genie (USA) (v2.1) (Unl).gb" size 8192 crc bc491c4b sha1 50e2ceb9b83f953d304d5bc6a25065bafad89490 ) ) game ( - name "Hit the Ice - VHL - The Official Video Hockey League (USA, Europe)" - description "Hit the Ice - VHL - The Official Video Hockey League (USA, Europe)" - rom ( name "Hit the Ice - VHL - The Official Video Hockey League (USA, Europe).gb" size 131072 crc 2c77f399 sha1 f1631e0a97fd60a285feba1b2fc9082bca3be829 ) + name "Game of Harmony, The (USA)" + description "Game of Harmony, The (USA)" + rom ( name "Game of Harmony, The (USA).gb" size 32768 crc b0074acb sha1 b0bc752e3ad25fcb83d8ca04a82a0f5e35381db2 ) ) game ( - name "Hitori de Dekirumon! - Cooking Densetsu (Japan)" - description "Hitori de Dekirumon! - Cooking Densetsu (Japan)" - rom ( name "Hitori de Dekirumon! - Cooking Densetsu (Japan).gb" size 131072 crc 59db5e75 sha1 d7b744b84de2097fe77e55c76676256a14b20d74 ) + name "Gamera - Daikaijuu Kuuchuu Kessen (Japan) (SGB Enhanced)" + description "Gamera - Daikaijuu Kuuchuu Kessen (Japan) (SGB Enhanced)" + rom ( name "Gamera - Daikaijuu Kuuchuu Kessen (Japan) (SGB Enhanced).gb" size 262144 crc 62769ec1 sha1 c6ec7aa3ad2b28ca43551cda3c0cfdbcb4377b45 ) ) game ( - name "Hoi Hoi - Game Boy Ban (Japan)" - description "Hoi Hoi - Game Boy Ban (Japan)" - rom ( name "Hoi Hoi - Game Boy Ban (Japan).gb" size 131072 crc c2c2ad19 sha1 d8962cc3a8c4d11af236b2612db7ab3f29615435 ) + name "GameShark (USA) (Unl) [b]" + description "GameShark (USA) (Unl) [b]" + rom ( name "GameShark (USA) (Unl) [b].gb" size 131072 crc d6909596 sha1 09a6dae5e5faae1c4b5cf20e1b913b1c5e72297e flags baddump ) ) game ( - name "Hokuto no Ken - Seizetsu Juuban Shoubu (Japan)" - description "Hokuto no Ken - Seizetsu Juuban Shoubu (Japan)" - rom ( name "Hokuto no Ken - Seizetsu Juuban Shoubu (Japan).gb" size 131072 crc e4b4febc sha1 4f8e8d2d079a0e3b76a67411d919297808f3849b ) + name "Ganbare Goemon - Kurofunetou no Nazo (Japan) (SGB Enhanced)" + description "Ganbare Goemon - Kurofunetou no Nazo (Japan) (SGB Enhanced)" + rom ( name "Ganbare Goemon - Kurofunetou no Nazo (Japan) (SGB Enhanced).gb" size 262144 crc 910afe24 sha1 bd336346982e33270128b74a7b356e9e6824e4a6 ) ) game ( - name "Home Alone (Japan)" - description "Home Alone (Japan)" - rom ( name "Home Alone (Japan).gb" size 131072 crc 7c3f3107 sha1 24c58e7b4bcce704ab0976c18919066582e6daf2 ) + name "Ganbare Goemon - Sarawareta Ebisumaru (Japan)" + description "Ganbare Goemon - Sarawareta Ebisumaru (Japan)" + rom ( name "Ganbare Goemon - Sarawareta Ebisumaru (Japan).gb" size 262144 crc 33261c11 sha1 dd38c2b305160b6bc7e1767a0e7de9850260779c ) ) game ( - name "Home Alone (USA, Europe)" - description "Home Alone (USA, Europe)" - rom ( name "Home Alone (USA, Europe).gb" size 131072 crc 8efc8434 sha1 a3142c83f391eda6f445226f2d49bd8a384be411 flags verified ) + name "Ganso!! Yancha Maru (Japan)" + description "Ganso!! Yancha Maru (Japan)" + rom ( name "Ganso!! Yancha Maru (Japan).gb" size 65536 crc 004443e6 sha1 76be351eac00749553c942b6f8002e65d8a35986 flags verified ) ) game ( - name "Home Alone 2 - Kevin's Dream (USA) (Proto)" - description "Home Alone 2 - Kevin's Dream (USA) (Proto)" - rom ( name "Home Alone 2 - Kevin's Dream (USA) (Proto).gb" size 131072 crc f8087e88 sha1 7fa6b52a9380c5b6091ebdabbabcc816399193d3 ) + name "Garfield Labyrinth (Europe)" + description "Garfield Labyrinth (Europe)" + rom ( name "Garfield Labyrinth (Europe).gb" size 131072 crc 51b8626d sha1 87913e557dfb98c5f2a0f42ea074c36eca57a4f7 flags verified ) ) game ( - name "Home Alone 2 - Lost in New York (USA, Europe)" - description "Home Alone 2 - Lost in New York (USA, Europe)" - rom ( name "Home Alone 2 - Lost in New York (USA, Europe).gb" size 131072 crc e8e430f1 sha1 853e6f96bcba40bc4cfa72898b02aebc3f9d9498 flags verified ) + name "Garfield Labyrinth (Europe) (Beta)" + description "Garfield Labyrinth (Europe) (Beta)" + rom ( name "Garfield Labyrinth (Europe) (Beta).gb" size 131072 crc 06884616 sha1 c9170113c3370523cf5d13132ed3e2253a3f9dde ) ) game ( - name "Hon Shougi (Japan) (SGB Enhanced)" - description "Hon Shougi (Japan) (SGB Enhanced)" - rom ( name "Hon Shougi (Japan) (SGB Enhanced).gb" size 65536 crc 6c407eed sha1 3f49109296b4dc0006b4e8e68133992f5ca2b843 ) + name "Gargoyle's Quest (Europe) (Rev 1)" + description "Gargoyle's Quest (Europe) (Rev 1)" + rom ( name "Gargoyle's Quest (Europe) (Rev 1).gb" size 131072 crc b86ef7a5 sha1 21fbe39014ffed80d0de2092517522d3cb9b03f9 ) ) game ( - name "Hong Kong (Japan)" - description "Hong Kong (Japan)" - rom ( name "Hong Kong (Japan).gb" size 32768 crc 5ad83d68 sha1 d8dd3e1baa95d8bb0a4e6b4e97ea64b8ec34331a ) + name "Gargoyle's Quest (USA, Europe)" + description "Gargoyle's Quest (USA, Europe)" + rom ( name "Gargoyle's Quest (USA, Europe).gb" size 131072 crc 0030e61f sha1 1da5834cd7cea711195cd8581614c5022da768b7 flags verified ) ) game ( - name "Honmei Boy (Japan)" - description "Honmei Boy (Japan)" - rom ( name "Honmei Boy (Japan).gb" size 262144 crc 0d255d59 sha1 2d6c460123886502e1590268ec5d8422c5375f7b ) + name "Gargoyle's Quest II - The Demon Darkness (USA) (Proto)" + description "Gargoyle's Quest II - The Demon Darkness (USA) (Proto)" + rom ( name "Gargoyle's Quest II - The Demon Darkness (USA) (Proto).gb" size 262144 crc db6f5930 sha1 1534f0a1806a69d408e702eda5b2d67fef05b1ed ) ) game ( - name "Honoo no Toukyuuji - Dodge Danpei (Japan)" - description "Honoo no Toukyuuji - Dodge Danpei (Japan)" - rom ( name "Honoo no Toukyuuji - Dodge Danpei (Japan).gb" size 262144 crc ba595897 sha1 417c22bfd8dba5da00c207da7866d8d8e8b292d1 ) + name "Gargoyle's Quest II - The Demon Darkness (Europe) (Proto)" + description "Gargoyle's Quest II - The Demon Darkness (Europe) (Proto)" + rom ( name "Gargoyle's Quest II - The Demon Darkness (Europe) (Proto).gb" size 262144 crc a7447341 sha1 131b81e35e2d23b768949a23b5a9ba71b4f6177d ) ) game ( - name "Hook (Europe)" - description "Hook (Europe)" - rom ( name "Hook (Europe).gb" size 131072 crc 370a2c2f sha1 0e0784c238b8a16666157e1ac99cee17feb52c63 ) + name "Gauntlet II (USA, Europe) (Beta)" + description "Gauntlet II (USA, Europe) (Beta)" + rom ( name "Gauntlet II (USA, Europe) (Beta).gb" size 262144 crc 965bbe1f sha1 53e6162e9276318f357a1e2e5bd706d4e4fd47d2 ) ) game ( - name "Hook (Japan)" - description "Hook (Japan)" - rom ( name "Hook (Japan).gb" size 131072 crc 62d8173c sha1 90eee3e0434bdf63d00b0e9c5cf6f62626974ca4 ) + name "Gauntlet II (USA, Europe)" + description "Gauntlet II (USA, Europe)" + rom ( name "Gauntlet II (USA, Europe).gb" size 262144 crc 1907dac5 sha1 dc37df322b54a5df5d04bc637e26b011b84598bf flags verified ) ) game ( - name "Hook (USA)" - description "Hook (USA)" - rom ( name "Hook (USA).gb" size 131072 crc 6765b61b sha1 570d7cc03e80e199e856160912431c21a6ca0f6c ) + name "GB Basketball (Japan)" + description "GB Basketball (Japan)" + rom ( name "GB Basketball (Japan).gb" size 131072 crc d9b24d21 sha1 65f73db2942d400a4c555fbcfd6313f07303d4e4 ) ) game ( - name "Hook (USA) (Sample)" - description "Hook (USA) (Sample)" - rom ( name "Hook (USA) (Sample).gb" size 131072 crc c091abc8 sha1 0299d84e5f722e9298c1ce190b8e4a785849b868 ) + name "GB Genjin (Japan)" + description "GB Genjin (Japan)" + rom ( name "GB Genjin (Japan).gb" size 262144 crc 690227f6 sha1 c2e98c76e49155e7b9815e0c33ae6cf71daaee2c ) ) game ( - name "Hoshi no Kirby (Japan)" - description "Hoshi no Kirby (Japan)" - rom ( name "Hoshi no Kirby (Japan).gb" size 262144 crc 21035f95 sha1 1e34b7beee30e350087771b3a3e05a40e4a1ea84 ) + name "GB Genjin 2 (Japan) (SGB Enhanced)" + description "GB Genjin 2 (Japan) (SGB Enhanced)" + rom ( name "GB Genjin 2 (Japan) (SGB Enhanced).gb" size 262144 crc 6f7ad5d9 sha1 82c1e3dd8b425fb49a1d1c25813002b23963a84a ) ) game ( - name "Hoshi no Kirby (Japan) (Rev 1)" - description "Hoshi no Kirby (Japan) (Rev 1)" - rom ( name "Hoshi no Kirby (Japan) (Rev 1).gb" size 262144 crc 04342c83 sha1 5fe35fab25299b6c53b40decfe2b1827b4a64d2a flags verified ) + name "GB Genjin Land - Viva! Chikkun Oukoku (Japan)" + description "GB Genjin Land - Viva! Chikkun Oukoku (Japan)" + rom ( name "GB Genjin Land - Viva! Chikkun Oukoku (Japan).gb" size 262144 crc b08bb116 sha1 6c7b6268e28281ae06fb621bf3cbbcbadc8e30e8 ) ) game ( - name "Hoshi no Kirby 2 (Japan) (SGB Enhanced)" - description "Hoshi no Kirby 2 (Japan) (SGB Enhanced)" - rom ( name "Hoshi no Kirby 2 (Japan) (SGB Enhanced).gb" size 524288 crc 4bedf22c sha1 8487fcc3f9005f6c6819c3d5810f54e78b510d47 flags verified ) + name "GB Pachi-Slot Hisshouhou! Jr. (Japan)" + description "GB Pachi-Slot Hisshouhou! Jr. (Japan)" + rom ( name "GB Pachi-Slot Hisshouhou! Jr. (Japan).gb" size 131072 crc a2e210e9 sha1 7636799f5a57d22cf579bb687be5bb9fedddd0ca ) ) game ( - name "Hudson Hawk (Japan)" - description "Hudson Hawk (Japan)" - rom ( name "Hudson Hawk (Japan).gb" size 131072 crc 1cb6158c sha1 6dfc4f8269dccec1653854b98fa5c8627cd50ce0 ) + name "GBKiss Mini Games (Japan)" + description "GBKiss Mini Games (Japan)" + rom ( name "GBKiss Mini Games (Japan).gb" size 262144 crc 92a03fc3 sha1 3c6c78f0a936dbc3f366a82c1eca8be0597d4d5b ) ) game ( - name "Hudson Hawk (USA)" - description "Hudson Hawk (USA)" - rom ( name "Hudson Hawk (USA).gb" size 131072 crc adff7bbd sha1 efdbb5f86d6ff3b3f248b0360ab548ac1ceb1e0e flags verified ) + name "Gear Works (USA, Europe)" + description "Gear Works (USA, Europe)" + rom ( name "Gear Works (USA, Europe).gb" size 131072 crc b2b72056 sha1 f064c897da11945287ed793fe041d75c1b536709 flags verified ) ) game ( - name "Hudson Hawk (Europe) (Proto)" - description "Hudson Hawk (Europe) (Proto)" - rom ( name "Hudson Hawk (Europe) (Proto).gb" size 131072 crc d4cd525d sha1 07c6a49f7c340d3cc78ca688eb1591853255a6c6 ) + name "Gegege no Kitarou - Youkai Souzoushu Arawaru! (Japan) (SGB Enhanced)" + description "Gegege no Kitarou - Youkai Souzoushu Arawaru! (Japan) (SGB Enhanced)" + rom ( name "Gegege no Kitarou - Youkai Souzoushu Arawaru! (Japan) (SGB Enhanced).gb" size 262144 crc 28e507b0 sha1 fa52c8f0bb31e25be829c7d4f52a7f4db1d5ef5b ) ) game ( - name "Hugo (World) (Aftermarket) (Unl)" - description "Hugo (World) (Aftermarket) (Unl)" - rom ( name "Hugo (World) (Aftermarket) (Unl).gb" size 262144 crc 8cc87f60 sha1 53fac2774b29a32501788e1eac65db23bf5c7b8f ) + name "Gekitou Power Modeller (Japan) (SGB Enhanced)" + description "Gekitou Power Modeller (Japan) (SGB Enhanced)" + rom ( name "Gekitou Power Modeller (Japan) (SGB Enhanced).gb" size 524288 crc 48c1ee22 sha1 22d6bf37eb3a29aeb1f9969ec51537eca8036a4c ) ) game ( - name "Hugo (Europe) (SGB Enhanced)" - description "Hugo (Europe) (SGB Enhanced)" - rom ( name "Hugo (Europe) (SGB Enhanced).gb" size 131072 crc 74aa5e0f sha1 d314dffcf5fb441d5d6d6419e01dc825e90cf0fc flags verified ) + name "Gem Gem (Japan)" + description "Gem Gem (Japan)" + rom ( name "Gem Gem (Japan).gb" size 65536 crc a64a8710 sha1 90a29d7a56f64b596cda1c64c8998b63d12c321e ) ) game ( - name "Hugo 2 (Germany)" - description "Hugo 2 (Germany)" - rom ( name "Hugo 2 (Germany).gb" size 131072 crc 67998fa4 sha1 66324a9b4d6f8782b706e0d3942d7efdb2b1f141 flags verified ) + name "Genjin Collection (Japan) (SGB Enhanced)" + description "Genjin Collection (Japan) (SGB Enhanced)" + rom ( name "Genjin Collection (Japan) (SGB Enhanced).gb" size 1048576 crc b2eedd36 sha1 a9f953e2a3680078e51cb42fac44edf81991737b ) ) game ( - name "Humans, The (Europe) (En,Fr,De,Es,It)" - description "Humans, The (Europe) (En,Fr,De,Es,It)" - rom ( name "Humans, The (Europe) (En,Fr,De,Es,It).gb" size 262144 crc 999c67d6 sha1 daa810cf09eae39867339b7615c6ffcf4bfd701a ) + name "Genjin Cottsu (Japan) (SGB Enhanced)" + description "Genjin Cottsu (Japan) (SGB Enhanced)" + rom ( name "Genjin Cottsu (Japan) (SGB Enhanced).gb" size 262144 crc 95e8fcb1 sha1 70e3cd1df16fbff644c32f588bf80a116b043bb2 ) ) game ( - name "Humans, The (USA)" - description "Humans, The (USA)" - rom ( name "Humans, The (USA).gb" size 262144 crc 1df2e81d sha1 39b7f8f6abb213bb5727379b864106ca2947fe6f ) + name "Genki Bakuhatsu Gambaruger (Japan)" + description "Genki Bakuhatsu Gambaruger (Japan)" + rom ( name "Genki Bakuhatsu Gambaruger (Japan).gb" size 131072 crc 6226d280 sha1 4ca8a77c95530879b175a2ec9a792485ae18e83c ) ) game ( - name "Humans, The (USA) (QUByte Classics)" - description "Humans, The (USA) (QUByte Classics)" - rom ( name "Humans, The (USA) (QUByte Classics).gb" size 262144 crc 4580ec88 sha1 669f4645b426400a4853793c7070c53642f71556 ) + name "George Foreman's KO Boxing (USA, Europe)" + description "George Foreman's KO Boxing (USA, Europe)" + rom ( name "George Foreman's KO Boxing (USA, Europe).gb" size 131072 crc 7f62456b sha1 01e923706486c75b2d0a438d968c5d571b2fdf1c flags verified ) ) game ( - name "Hunchback of Notre Dame, The - 5 Foolishly Fun Topsy Turvy Games (USA, Europe) (SGB Enhanced)" - description "Hunchback of Notre Dame, The - 5 Foolishly Fun Topsy Turvy Games (USA, Europe) (SGB Enhanced)" - rom ( name "Hunchback of Notre Dame, The - 5 Foolishly Fun Topsy Turvy Games (USA, Europe) (SGB Enhanced).gb" size 524288 crc 3a4636ff sha1 de0310602e675924f393140b3fa66284870661dd ) + name "Gerry Anderson's Thunderbirds (Japan)" + description "Gerry Anderson's Thunderbirds (Japan)" + rom ( name "Gerry Anderson's Thunderbirds (Japan).gb" size 131072 crc 149e9393 sha1 440169376982aa89cedde08edbc9efdfafc6c7f1 ) ) game ( - name "Hunt for Red October, The (USA, Europe)" - description "Hunt for Red October, The (USA, Europe)" - rom ( name "Hunt for Red October, The (USA, Europe).gb" size 131072 crc 5a61ee00 sha1 7c9ccfd9e98b30c33ff71b3ab3098c2afeb9037c flags verified ) + name "Getaway, The - High Speed II (USA)" + description "Getaway, The - High Speed II (USA)" + rom ( name "Getaway, The - High Speed II (USA).gb" size 262144 crc 8f2bf517 sha1 a0ca7187b55135150f348d44544d3a6e6d51394e ) ) game ( - name "Hyper Black Bass (Japan) (En,Ja)" - description "Hyper Black Bass (Japan) (En,Ja)" - rom ( name "Hyper Black Bass (Japan) (En,Ja).gb" size 262144 crc c364d55f sha1 fc8ad749979702c3d52954ed5808065cde77fe38 ) + name "Ghostbusters II (USA, Europe) (Beta)" + description "Ghostbusters II (USA, Europe) (Beta)" + rom ( name "Ghostbusters II (USA, Europe) (Beta).gb" size 131072 crc 41423376 sha1 c96b152f5351eeec19e1b020c9e0d51d582e2e8c ) ) game ( - name "Hyper Black Bass '95 (Japan) (En,Ja)" - description "Hyper Black Bass '95 (Japan) (En,Ja)" - rom ( name "Hyper Black Bass '95 (Japan) (En,Ja).gb" size 262144 crc 32a81a49 sha1 bea9133cdbe8d96ee753a4f55cf5fa7bb80ff490 ) + name "Ghostbusters II (Japan)" + description "Ghostbusters II (Japan)" + rom ( name "Ghostbusters II (Japan).gb" size 131072 crc 69b161bc sha1 0ca645c40ca8dc6102b4f3cf56f0e9ae5d1ffc03 ) ) game ( - name "Hyper Dunk (Europe)" - description "Hyper Dunk (Europe)" - rom ( name "Hyper Dunk (Europe).gb" size 131072 crc 02d09ce3 sha1 6aca47dd2d9c57999a566903292af2601c832c9c flags verified ) + name "Ghostbusters II (USA, Europe)" + description "Ghostbusters II (USA, Europe)" + rom ( name "Ghostbusters II (USA, Europe).gb" size 131072 crc 5821ecd4 sha1 1e2aa42b7e0f974f45fbca35160cda6d5964f0ad flags verified ) ) game ( - name "Hyper Lode Runner (World) (Rev 1)" - description "Hyper Lode Runner (World) (Rev 1)" - rom ( name "Hyper Lode Runner (World) (Rev 1).gb" size 32768 crc b3a86164 sha1 261da795c7b4155f1b8083acc55da78699c8a0de flags verified ) + name "GI King! - Sanbiki no Yosouya (Japan)" + description "GI King! - Sanbiki no Yosouya (Japan)" + rom ( name "GI King! - Sanbiki no Yosouya (Japan).gb" size 65536 crc 150bc291 sha1 de6109b643a97e7a96e55a6becfd7e61dfdc915e ) ) game ( - name "Hyper Lode Runner (Japan) (En) (Possible Proto)" - description "Hyper Lode Runner (Japan) (En) (Possible Proto)" - rom ( name "Hyper Lode Runner (Japan) (En) (Possible Proto).gb" size 32768 crc 3fc21b74 sha1 37d0f2cbac0f95af8b22dea0c882612681ec5cc8 ) + name "Ginga - Card & Puzzle Collection (Japan) (En,Ja)" + description "Ginga - Card & Puzzle Collection (Japan) (En,Ja)" + rom ( name "Ginga - Card & Puzzle Collection (Japan) (En,Ja).gb" size 65536 crc 87d0637b sha1 14f4f14caee081dceadb9d31ae26fd8968c432ea ) ) game ( - name "If (World) (Aftermarket) (Unl)" - description "If (World) (Aftermarket) (Unl)" - rom ( name "If (World) (Aftermarket) (Unl).gb" size 1048576 crc be7e4454 sha1 c11d8dc9ce96133f679678b07822a82f985e16f9 ) + name "Gluecksrad (Germany)" + description "Gluecksrad (Germany)" + rom ( name "Gluecksrad (Germany).gb" size 131072 crc e8b26577 sha1 638cd5087b53b7fe7c6ece99fd973f98c0c09ebe flags verified ) ) game ( - name "Ikari no Yousai (Japan)" - description "Ikari no Yousai (Japan)" - rom ( name "Ikari no Yousai (Japan).gb" size 131072 crc 1c2ba2a1 sha1 039da1616e1a179aeda7186d6cc1955149f49581 ) + name "Go Go Ackman (Japan) (SGB Enhanced)" + description "Go Go Ackman (Japan) (SGB Enhanced)" + rom ( name "Go Go Ackman (Japan) (SGB Enhanced).gb" size 262144 crc 61d80946 sha1 28ce08f67b4fb26e7a5a46f853b053d20ec9d7cd flags verified ) ) game ( - name "Ikari no Yousai 2 (Japan)" - description "Ikari no Yousai 2 (Japan)" - rom ( name "Ikari no Yousai 2 (Japan).gb" size 131072 crc 6d4fd9aa sha1 ae437d4fb39d7438fc9eb98c91820aa2b5161b4f ) + name "Go! Go! Hitchhike (Japan) (SGB Enhanced)" + description "Go! Go! Hitchhike (Japan) (SGB Enhanced)" + rom ( name "Go! Go! Hitchhike (Japan) (SGB Enhanced).gb" size 524288 crc 845735de sha1 6a35bc2967f25fda0626b7a00a2cacfec9c53278 ) ) game ( - name "Impossible Gameboy (World) (Aftermarket) (Unl)" - description "Impossible Gameboy (World) (Aftermarket) (Unl)" - rom ( name "Impossible Gameboy (World) (Aftermarket) (Unl).gb" size 131072 crc ab65b738 sha1 d31cedd6227b23cf3d8ef81c73f133ab0b57e4f4 ) + name "Go! Go! Tank (Japan)" + description "Go! Go! Tank (Japan)" + rom ( name "Go! Go! Tank (Japan).gb" size 65536 crc 30ae39b6 sha1 6a60d5b550355e634ba54d8bd83b51ca55d6874b ) ) game ( - name "In Your Face (USA)" - description "In Your Face (USA)" - rom ( name "In Your Face (USA).gb" size 131072 crc 80ac487e sha1 0be0f2a952497b321655dbee5c89678f40bf0b5a flags verified ) + name "Go! Go! Tank (USA)" + description "Go! Go! Tank (USA)" + rom ( name "Go! Go! Tank (USA).gb" size 65536 crc 65dfabcb sha1 7f3408c951a161f93394812d34f6d2534658b7d3 ) ) game ( - name "Incredible Crash Dummies, The (USA, Europe)" - description "Incredible Crash Dummies, The (USA, Europe)" - rom ( name "Incredible Crash Dummies, The (USA, Europe).gb" size 131072 crc d81c08fa sha1 f62d369b576cfd2882f8e03a5a32238eb1599477 ) + name "Go! Go! Tank (Japan) (Beta)" + description "Go! Go! Tank (Japan) (Beta)" + rom ( name "Go! Go! Tank (Japan) (Beta).gb" size 65536 crc 6dcf5e7f sha1 18bbee226858af45a81f7da1186938f53511ef73 ) ) game ( - name "Indiana Jones - Saigo no Seisen (Japan)" - description "Indiana Jones - Saigo no Seisen (Japan)" - rom ( name "Indiana Jones - Saigo no Seisen (Japan).gb" size 131072 crc 8f234f49 sha1 238499f9fc98183e57222e8f1271b9bbad2af3ec ) + name "Goal! (Europe)" + description "Goal! (Europe)" + rom ( name "Goal! (Europe).gb" size 131072 crc 533fa979 sha1 24fffa3db4153895546a346a38971b6946011679 ) ) game ( - name "Indiana Jones and the Last Crusade (USA, Europe)" - description "Indiana Jones and the Last Crusade (USA, Europe)" - rom ( name "Indiana Jones and the Last Crusade (USA, Europe).gb" size 131072 crc 9189921a sha1 b656ba6c03d0cb5c81c2ed8c5c64ea8e36660aaa flags verified ) + name "Goal! (USA)" + description "Goal! (USA)" + rom ( name "Goal! (USA).gb" size 131072 crc 00d4caf2 sha1 9bb15769b2674d41075b45256dbfffc18483fd84 ) ) game ( - name "Indien dans la Ville, Un (Europe) (SGB Enhanced)" - description "Indien dans la Ville, Un (Europe) (SGB Enhanced)" - rom ( name "Indien dans la Ville, Un (Europe) (SGB Enhanced).gb" size 131072 crc e37e1832 sha1 168337cdd8e4d919ce3b62ea4802ec6b959c6893 ) + name "God Medicine - Fantasy Sekai no Tanjou (Japan)" + description "God Medicine - Fantasy Sekai no Tanjou (Japan)" + rom ( name "God Medicine - Fantasy Sekai no Tanjou (Japan).gb" size 262144 crc a1b29ab8 sha1 b365cd58d133c2b441bbf53c2e5ff9486bbf0bde ) ) game ( - name "InfoGenius Productivity Pak - Berlitz French Translator (USA, Europe)" - description "InfoGenius Productivity Pak - Berlitz French Translator (USA, Europe)" - rom ( name "InfoGenius Productivity Pak - Berlitz French Translator (USA, Europe).gb" size 131072 crc 80485fda sha1 ea77a00e9982ffa710ce9e179d4614419f9e1a35 flags verified ) + name "God Medicine - Fukkokuban (Japan) (SGB Enhanced)" + description "God Medicine - Fukkokuban (Japan) (SGB Enhanced)" + rom ( name "God Medicine - Fukkokuban (Japan) (SGB Enhanced).gb" size 524288 crc 847e0772 sha1 61d3579293bf07166402d11d891e14bfd6fef6b4 flags verified ) ) game ( - name "InfoGenius Productivity Pak - Berlitz German Translator (USA, Europe) (Proto)" - description "InfoGenius Productivity Pak - Berlitz German Translator (USA, Europe) (Proto)" - rom ( name "InfoGenius Productivity Pak - Berlitz German Translator (USA, Europe) (Proto).gb" size 131072 crc d600edc6 sha1 ecf723d2da9be058396568b3ee91b715ea9d89e3 ) + name "Godzilla (USA, Europe)" + description "Godzilla (USA, Europe)" + rom ( name "Godzilla (USA, Europe).gb" size 131072 crc fe4f80b7 sha1 c0fa19386aa1e325af42e8dd2caf8e66112b9578 flags verified ) ) game ( - name "InfoGenius Productivity Pak - Berlitz Japanese Translator (USA, Europe) (Proto)" - description "InfoGenius Productivity Pak - Berlitz Japanese Translator (USA, Europe) (Proto)" - rom ( name "InfoGenius Productivity Pak - Berlitz Japanese Translator (USA, Europe) (Proto).gb" size 131072 crc ea539f03 sha1 9a02b19b83448e94c4877c36dd3d2e6891f8e48f ) + name "Gojira-kun - Kaijuu Daikoushin (Japan)" + description "Gojira-kun - Kaijuu Daikoushin (Japan)" + rom ( name "Gojira-kun - Kaijuu Daikoushin (Japan).gb" size 131072 crc ed204600 sha1 4c03da759e5fb2ec06d286d5f0b52d64621fea41 ) ) game ( - name "InfoGenius Productivity Pak - Berlitz Spanish Translator (USA, Europe)" - description "InfoGenius Productivity Pak - Berlitz Spanish Translator (USA, Europe)" - rom ( name "InfoGenius Productivity Pak - Berlitz Spanish Translator (USA, Europe).gb" size 131072 crc 058eeedb sha1 ff229bc70ef30154ef4b4d4f9a4f0eb86015682e flags verified ) + name "Golf (World)" + description "Golf (World)" + rom ( name "Golf (World).gb" size 131072 crc 6ed10383 sha1 2acee1a14ba611e73b0b7d6bce170107213fcc0c flags verified ) ) game ( - name "InfoGenius Productivity Pak - Frommer's Travel Guide (USA)" - description "InfoGenius Productivity Pak - Frommer's Travel Guide (USA)" - rom ( name "InfoGenius Productivity Pak - Frommer's Travel Guide (USA).gb" size 262144 crc 40242e35 sha1 e4155270a59b0998b3eeffea779c33713eddf2e6 ) + name "Golf Classic (Europe) (SGB Enhanced)" + description "Golf Classic (Europe) (SGB Enhanced)" + rom ( name "Golf Classic (Europe) (SGB Enhanced).gb" size 262144 crc a6dadb1e sha1 b7ffb77a5061c33b0bbe5b074c1526e46c5eb7c3 ) ) game ( - name "InfoGenius Productivity Pak - Personal Organizer and Phone Book (USA)" - description "InfoGenius Productivity Pak - Personal Organizer and Phone Book (USA)" - rom ( name "InfoGenius Productivity Pak - Personal Organizer and Phone Book (USA).gb" size 65536 crc ca436939 sha1 9f65e16785e82fbddc27d811f051f60f4812fcb4 ) + name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (Imagineer)" + description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (Imagineer)" + rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (Imagineer).gb" size 1048576 crc 5d43a385 sha1 d367f2dab5eacb10e785a13a2550ca7cc3e54177 ) ) game ( - name "InfoGenius Productivity Pak - Spell Checker and Calculator (USA)" - description "InfoGenius Productivity Pak - Spell Checker and Calculator (USA)" - rom ( name "InfoGenius Productivity Pak - Spell Checker and Calculator (USA).gb" size 131072 crc 754496bb sha1 654e6f36c1260afba14640cf25c05c31a4075eb6 flags verified ) + name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (IE Institute)" + description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (IE Institute)" + rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Joushiki no Sho (Japan) (IE Institute).gb" size 1048576 crc 26772e04 sha1 a6ab7420a2d69d62338bc03dc4e0e46b0dc8429b flags verified ) ) game ( - name "InfoGenius Systems - Personal Organizer with Phone Book (Europe)" - description "InfoGenius Systems - Personal Organizer with Phone Book (Europe)" - rom ( name "InfoGenius Systems - Personal Organizer with Phone Book (Europe).gb" size 65536 crc bfd65534 sha1 434d2acb7c2c23ae58222254f2e2ca2f4ceddc61 flags verified ) + name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (IE Institute)" + description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (IE Institute)" + rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (IE Institute).gb" size 1048576 crc 180d54a7 sha1 7dce0adcbac61f0caae33646847fd06ced8c8b67 ) ) game ( - name "Initial D Gaiden (Japan) (SGB Enhanced)" - description "Initial D Gaiden (Japan) (SGB Enhanced)" - rom ( name "Initial D Gaiden (Japan) (SGB Enhanced).gb" size 262144 crc 6cc56612 sha1 1b3c4c1c4dfca46a009eb2e5cd45b343d7ee6681 ) + name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (Imagineer)" + description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (Imagineer)" + rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Kanji no Tatsujin (Japan) (Imagineer).gb" size 1048576 crc 62b00f69 sha1 1d3e5ad888b8339e35c46455d84017d8a0d69c6d flags verified ) ) game ( - name "Interblocked (World) (Aftermarket) (Unl)" - description "Interblocked (World) (Aftermarket) (Unl)" - rom ( name "Interblocked (World) (Aftermarket) (Unl).gb" size 262144 crc 5c208855 sha1 8e46486533a3de9ee87cc07bf8efaf818752a61a ) + name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (Imagineer)" + description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (Imagineer)" + rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (Imagineer).gb" size 1048576 crc 71acbb67 sha1 e2ac91493248869aba6b7d26a36e5ff6bd6d6f5a flags verified ) ) game ( - name "International Superstar Soccer (USA, Europe) (SGB Enhanced)" - description "International Superstar Soccer (USA, Europe) (SGB Enhanced)" - rom ( name "International Superstar Soccer (USA, Europe) (SGB Enhanced).gb" size 262144 crc 94757be8 sha1 13f2fc0945fb7a90f4d87d8c4e310dec9af6b792 ) + name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (IE Institute)" + description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (IE Institute)" + rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Keisan no Tatsujin (Japan) (IE Institute).gb" size 1048576 crc 04214f92 sha1 6b8726c69a31e674a4c5ab02631de073d42e7d52 ) ) game ( - name "Into the Blue (World) (Aftermarket) (Unl)" - description "Into the Blue (World) (Aftermarket) (Unl)" - rom ( name "Into the Blue (World) (Aftermarket) (Unl).gb" size 131072 crc 7714e96e sha1 5ac7a349bb37c8767c9db264ed8ae7b7647fa8ea ) + name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Proto) (IE Institute)" + description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Proto) (IE Institute)" + rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Proto) (IE Institute).gb" size 1048576 crc 91ab959f sha1 2e1797646b2d3aa6fc9b2f5eaa248751133a0518 ) ) game ( - name "Ippatsu Gyakuten! DX Bakenou (Japan)" - description "Ippatsu Gyakuten! DX Bakenou (Japan)" - rom ( name "Ippatsu Gyakuten! DX Bakenou (Japan).gb" size 65536 crc 8f3e7f95 sha1 991efd117dcb30ddf111bb4f6e46bdda1c811417 ) + name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Imagineer)" + description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Imagineer)" + rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Nanmon no Sho (Japan) (Imagineer).gb" size 1048576 crc 3c907f2c sha1 fa7a40acd835676fbcae9507a8aaaf1191f9b1cd ) ) game ( - name "Iron Man X-O Manowar in Heavy Metal (USA, Europe) (SGB Enhanced)" - description "Iron Man X-O Manowar in Heavy Metal (USA, Europe) (SGB Enhanced)" - rom ( name "Iron Man X-O Manowar in Heavy Metal (USA, Europe) (SGB Enhanced).gb" size 524288 crc 173232e5 sha1 4ee9ba152e2339497d6ad49aca6f2c78a8431480 ) + name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Zukei no Tatsujin (Japan)" + description "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Zukei no Tatsujin (Japan)" + rom ( name "Goukaku Boy GOLD - Shikakui Atama o Maruku Suru - Zukei no Tatsujin (Japan).gb" size 1048576 crc 479e2c18 sha1 630a331a3c89823647fbda13235b6299d91a1b25 ) ) game ( - name "Ishida Yoshio Tsumego Paradise (Japan)" - description "Ishida Yoshio Tsumego Paradise (Japan)" - rom ( name "Ishida Yoshio Tsumego Paradise (Japan).gb" size 65536 crc c97daaca sha1 dd9fd57dfa72e8818c553db553d9e598edb9d956 ) + name "Goukaku Boy Series - 99 Nendo Ban Eitango Center 1500 (Japan)" + description "Goukaku Boy Series - 99 Nendo Ban Eitango Center 1500 (Japan)" + rom ( name "Goukaku Boy Series - 99 Nendo Ban Eitango Center 1500 (Japan).gb" size 262144 crc 9c0d14c3 sha1 b9e79e032f4d65442daa37767be5238a84c103db ) ) game ( - name "Ishido - The Way of Stones (Japan)" - description "Ishido - The Way of Stones (Japan)" - rom ( name "Ishido - The Way of Stones (Japan).gb" size 32768 crc ab367915 sha1 75768fa6c719b96e6642bca5439a78cd3696761f flags verified ) + name "Goukaku Boy Series - Eijukugo Target 1000 (Japan)" + description "Goukaku Boy Series - Eijukugo Target 1000 (Japan)" + rom ( name "Goukaku Boy Series - Eijukugo Target 1000 (Japan).gb" size 262144 crc ca20c594 sha1 535fbf6988af70c4283d8101c72acb67d249bb96 ) ) game ( - name "Ishido - The Way of Stones (USA)" - description "Ishido - The Way of Stones (USA)" - rom ( name "Ishido - The Way of Stones (USA).gb" size 65536 crc 85b98a77 sha1 41a00b379864cc0be08de75ae0de5bb2c6fbb045 ) + name "Goukaku Boy Series - Eiken 2kyuu Level no Kaiwa Hyougen 333 (Japan)" + description "Goukaku Boy Series - Eiken 2kyuu Level no Kaiwa Hyougen 333 (Japan)" + rom ( name "Goukaku Boy Series - Eiken 2kyuu Level no Kaiwa Hyougen 333 (Japan).gb" size 262144 crc 46af90da sha1 e58d4dc3e8b5f0407f156c5d252d34b40e7dfec0 ) ) game ( - name "Itsudemo! Nyan to Wonderful (Japan) (SGB Enhanced)" - description "Itsudemo! Nyan to Wonderful (Japan) (SGB Enhanced)" - rom ( name "Itsudemo! Nyan to Wonderful (Japan) (SGB Enhanced).gb" size 262144 crc 1c4d3665 sha1 a48d6b68d82b98e775c00366da544402d7c7ac0e flags verified ) + name "Goukaku Boy Series - Eitango Target 1900 (Japan)" + description "Goukaku Boy Series - Eitango Target 1900 (Japan)" + rom ( name "Goukaku Boy Series - Eitango Target 1900 (Japan).gb" size 262144 crc f8406560 sha1 c5f885c9c6b7ab89646b4c17b6ff83b2dfe67a04 ) ) game ( - name "J.League Big Wave Soccer (Japan) (SGB Enhanced)" - description "J.League Big Wave Soccer (Japan) (SGB Enhanced)" - rom ( name "J.League Big Wave Soccer (Japan) (SGB Enhanced).gb" size 262144 crc cdd02f22 sha1 00369c42d2c4be0506901b64f7d5424538574ce0 ) + name "Goukaku Boy Series - Gakken - Kanyouku Kotowaza 210 (Japan)" + description "Goukaku Boy Series - Gakken - Kanyouku Kotowaza 210 (Japan)" + rom ( name "Goukaku Boy Series - Gakken - Kanyouku Kotowaza 210 (Japan).gb" size 262144 crc 44f5a443 sha1 19a6f8c7a98b84b9b0bf53c25dbba02c438c1822 ) ) game ( - name "J.League Fighting Soccer - The King of Ace Strikers (Japan)" - description "J.League Fighting Soccer - The King of Ace Strikers (Japan)" - rom ( name "J.League Fighting Soccer - The King of Ace Strikers (Japan).gb" size 131072 crc 17608642 sha1 fbe94c42a9bd7d5ebddb28382caf03ab2f9902d6 ) + name "Goukaku Boy Series - Gakken - Rekishi 512 (Japan)" + description "Goukaku Boy Series - Gakken - Rekishi 512 (Japan)" + rom ( name "Goukaku Boy Series - Gakken - Rekishi 512 (Japan).gb" size 262144 crc 10bd83ba sha1 ab7733c04bc7975312b0cbe75d8d9b2519ac35ae ) ) game ( - name "J.League Live 95 (Japan) (SGB Enhanced)" - description "J.League Live 95 (Japan) (SGB Enhanced)" - rom ( name "J.League Live 95 (Japan) (SGB Enhanced).gb" size 262144 crc f0321342 sha1 3b4922f8034877d1a5aca380f846a7cb6841f6ee ) + name "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan)" + description "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan)" + rom ( name "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan).gb" size 262144 crc 631a752e sha1 df253afb9c01615ad8219730573321a40fb5e230 flags verified ) ) game ( - name "J.League Winning Goal (Japan)" - description "J.League Winning Goal (Japan)" - rom ( name "J.League Winning Goal (Japan).gb" size 131072 crc adb46f9c sha1 b8630f06e8b9682e667b7b1f2139162e2f022561 ) + name "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan) (Rev 1)" + description "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan) (Rev 1)" + rom ( name "Goukaku Boy Series - Gakken - Yojijukugo 288 (Japan) (Rev 1).gb" size 262144 crc c8e01c7c sha1 7df1d7b389814c6de2a1b201a00c71316b0ac856 flags verified ) ) game ( - name "Jabberwocky (World) (Aftermarket) (Unl)" - description "Jabberwocky (World) (Aftermarket) (Unl)" - rom ( name "Jabberwocky (World) (Aftermarket) (Unl).gb" size 1048576 crc cfc51717 sha1 b4e447f2197688c740a45dce27879a62c742fb96 ) + name "Goukaku Boy Series - Kirihara Shoten Hinshutsu Eibunpou Gohou Mondai 1000 (Japan)" + description "Goukaku Boy Series - Kirihara Shoten Hinshutsu Eibunpou Gohou Mondai 1000 (Japan)" + rom ( name "Goukaku Boy Series - Kirihara Shoten Hinshutsu Eibunpou Gohou Mondai 1000 (Japan).gb" size 262144 crc 41c17421 sha1 134a9d7a276b8ef2ed698075e0990d0553ffbf73 ) ) game ( - name "Jack Nicklaus Golf (France)" - description "Jack Nicklaus Golf (France)" - rom ( name "Jack Nicklaus Golf (France).gb" size 131072 crc 374893d7 sha1 2bc2c3a95a49498347c49d5dd7182a1387ab531e ) + name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Imagineer)" + description "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Imagineer)" + rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Imagineer).gb" size 262144 crc e4271f4b sha1 02baaf987249f2daf9daa6d6000e61adc05b0ef6 flags verified ) ) game ( - name "Jack Nicklaus Golf (USA, Europe)" - description "Jack Nicklaus Golf (USA, Europe)" - rom ( name "Jack Nicklaus Golf (USA, Europe).gb" size 131072 crc 654988b2 sha1 bac74527dbd276f395d5c89f14450bb5bc2baab1 ) + name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Possible Proto) (IE Institute)" + description "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Possible Proto) (IE Institute)" + rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eijukugo 350 (Japan) (Possible Proto) (IE Institute).gb" size 262144 crc 5855b281 sha1 25f69cc4da819f7d5c449f6ad0cf4963011dc5a7 ) ) game ( - name "Jaleco J.Cup Soccer (Japan)" - description "Jaleco J.Cup Soccer (Japan)" - rom ( name "Jaleco J.Cup Soccer (Japan).gb" size 131072 crc 98259257 sha1 984f4fd0127325311cad9fbceb5c71f305cb2b23 ) + name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Possible Proto) (IE Institute)" + description "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Possible Proto) (IE Institute)" + rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Possible Proto) (IE Institute).gb" size 262144 crc bc14fce6 sha1 48775723113ac0e3d1cbcf7381ba876d6dc30a7c ) ) game ( - name "James Bond 007 (USA, Europe) (SGB Enhanced)" - description "James Bond 007 (USA, Europe) (SGB Enhanced)" - rom ( name "James Bond 007 (USA, Europe) (SGB Enhanced).gb" size 524288 crc ca3bc3ce sha1 e03754173a5d62cb9da7d2306bc41b0e23e3d519 flags verified ) + name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Imagineer)" + description "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Imagineer)" + rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Chuugaku Eitango 1700 (Japan) (Imagineer).gb" size 262144 crc d3168eca sha1 2e30d41e3783da4d3f6bb928c54c0e243f63e4ca ) ) game ( - name "Jane in the Jungle (World) (Aftermarket) (Unl)" - description "Jane in the Jungle (World) (Aftermarket) (Unl)" - rom ( name "Jane in the Jungle (World) (Aftermarket) (Unl).gb" size 262144 crc c68e751a sha1 dfc65dcf700a26b273d705b7cfececbc44b80587 ) + name "Goukaku Boy Series - Koukou Nyuushi Derujun - Kanji Mondai no Seifuku (Japan)" + description "Goukaku Boy Series - Koukou Nyuushi Derujun - Kanji Mondai no Seifuku (Japan)" + rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Kanji Mondai no Seifuku (Japan).gb" size 262144 crc 84e30e6c sha1 2185bbb4868058577fbe696b9a88fa7238ce7098 ) ) game ( - name "Jankenman (Japan)" - description "Jankenman (Japan)" - rom ( name "Jankenman (Japan).gb" size 65536 crc 37b3d081 sha1 723f34875166b73c95610a6c146eeac34dd90868 ) + name "Goukaku Boy Series - Koukou Nyuushi Derujun - Rekishi Nendai Anki Point 240 (Japan)" + description "Goukaku Boy Series - Koukou Nyuushi Derujun - Rekishi Nendai Anki Point 240 (Japan)" + rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Rekishi Nendai Anki Point 240 (Japan).gb" size 262144 crc 7e262a4d sha1 d969dbc0cf3e5d427726bf749d082b89e171354b ) ) game ( - name "Janshirou (Japan)" - description "Janshirou (Japan)" - rom ( name "Janshirou (Japan).gb" size 65536 crc 0530e1cc sha1 658120ff41a0fd4c2198f5618dd43a799958aa55 ) + name "Goukaku Boy Series - Koukou Nyuushi Derujun - Rika Anki Point 250 (Japan)" + description "Goukaku Boy Series - Koukou Nyuushi Derujun - Rika Anki Point 250 (Japan)" + rom ( name "Goukaku Boy Series - Koukou Nyuushi Derujun - Rika Anki Point 250 (Japan).gb" size 262144 crc 70468755 sha1 b96acb6454ba916ad5df2256f9a0a8022cdbff3b ) ) game ( - name "Janshirou II - Sekai Saikyou no Janshi (Japan)" - description "Janshirou II - Sekai Saikyou no Janshi (Japan)" - rom ( name "Janshirou II - Sekai Saikyou no Janshi (Japan).gb" size 131072 crc 2812036b sha1 f85022f21549349f95b58db57ab71998ab24c012 ) + name "Goukaku Boy Series - Nihonshi Target 201 (Japan)" + description "Goukaku Boy Series - Nihonshi Target 201 (Japan)" + rom ( name "Goukaku Boy Series - Nihonshi Target 201 (Japan).gb" size 262144 crc cf133379 sha1 d6178851d778bf794a0fce14a831f6e2cd991f22 ) ) game ( - name "Jantaku Boy (Japan)" - description "Jantaku Boy (Japan)" - rom ( name "Jantaku Boy (Japan).gb" size 131072 crc 04daa03b sha1 34f0a33f329915800ba681728c43d7451ff1f162 ) + name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (Imagineer)" + description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (Imagineer)" + rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (Imagineer).gb" size 262144 crc 8bd567d1 sha1 75009ac4a2114b4ceac3e4bc7e6c3f3173292bf0 flags verified ) ) game ( - name "Jeep Jamboree - Off-Road Adventure (USA)" - description "Jeep Jamboree - Off-Road Adventure (USA)" - rom ( name "Jeep Jamboree - Off-Road Adventure (USA).gb" size 131072 crc a1e76a33 sha1 988a40823f7db661bc91ffff8fc1bcd80e64f18d flags verified ) + name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (IE Institute)" + description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (IE Institute)" + rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Kokugo Battle Hen (Japan) (IE Institute).gb" size 262144 crc 7e6e16d5 sha1 3fc9c1bc1d3b8e7ee90c14d4ae4938726f61a2db flags verified ) ) game ( - name "Jeep Jamboree - Off-Road Adventure (Europe) (Proto)" - description "Jeep Jamboree - Off-Road Adventure (Europe) (Proto)" - rom ( name "Jeep Jamboree - Off-Road Adventure (Europe) (Proto).gb" size 131072 crc 96633953 sha1 5a116101a1db86de71b6c622f5a6e60373ecdade ) + name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (IE Institute)" + description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (IE Institute)" + rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (IE Institute).gb" size 262144 crc 62aa54a4 sha1 4569f5cc0f528fdf46cfd1b3a8ef8a6fd3953d7e flags verified ) ) game ( - name "Jelly Boy (Europe)" - description "Jelly Boy (Europe)" - rom ( name "Jelly Boy (Europe).gb" size 262144 crc 7e6598bb sha1 579579d660cdc84af2428ccd1b30b40a2fb592fa ) + name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (Imagineer)" + description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (Imagineer)" + rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Rika Battle Hen (Japan) (Imagineer).gb" size 262144 crc c34ae38f sha1 fa92ad7099a6c698088433d7721fd1e87b2b925d flags verified ) ) game ( - name "Jeopardy! (USA)" - description "Jeopardy! (USA)" - rom ( name "Jeopardy! (USA).gb" size 131072 crc 08725c79 sha1 d0bf6e71ddae1faff179309eaab554c2ae994de0 ) + name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (Imagineer)" + description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (Imagineer)" + rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (Imagineer).gb" size 262144 crc 0dadb829 sha1 a10e78f3fe2c46e167d39ed713106937365a6d55 ) ) game ( - name "Jeopardy! - Platinum Edition (USA) (SGB Enhanced)" - description "Jeopardy! - Platinum Edition (USA) (SGB Enhanced)" - rom ( name "Jeopardy! - Platinum Edition (USA) (SGB Enhanced).gb" size 131072 crc 5206fd09 sha1 35934633a9b301d734a6fced7c56d55eba0385aa ) + name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (IE Institute)" + description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (IE Institute)" + rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Sansuu Battle Hen (Japan) (IE Institute).gb" size 262144 crc de74fd69 sha1 1e0fe5a54b4eb03a1f108d8650ad5ef8814d7444 flags verified ) ) game ( - name "Jeopardy! - Sports Edition (USA)" - description "Jeopardy! - Sports Edition (USA)" - rom ( name "Jeopardy! - Sports Edition (USA).gb" size 131072 crc 3b523216 sha1 ae534dcdeaa7138e1a0c775e0574c423a8c76dfb ) + name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (IE Institute)" + description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (IE Institute)" + rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (IE Institute).gb" size 262144 crc 8ba62b3d sha1 dfdcabdc06b74f896b9ef47db2a9cc49ddb104c4 flags verified ) ) game ( - name "Jeopardy! - Teen Tournament (USA) (SGB Enhanced)" - description "Jeopardy! - Teen Tournament (USA) (SGB Enhanced)" - rom ( name "Jeopardy! - Teen Tournament (USA) (SGB Enhanced).gb" size 131072 crc cd3df0c1 sha1 20c71f434ef093fac9361fa1db9c2282c938dd71 ) + name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (Imagineer)" + description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (Imagineer)" + rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Shakai Battle Hen (Japan) (Imagineer).gb" size 262144 crc 87f0cfad sha1 edfc194f9f58ef97dfe87092eebd4c73359925e1 flags verified ) ) game ( - name "Jet Pack (USA, Europe) (Beta)" - description "Jet Pack (USA, Europe) (Beta)" - rom ( name "Jet Pack (USA, Europe) (Beta).gb" size 131072 crc 1c223204 sha1 df7abbcaaccd5cff4c55bb331fa5d3049fb92896 ) + name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan)" + description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan)" + rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan).gb" size 262144 crc f141b2dc sha1 02ddcaef0008871786797fc76c649d74f010718d ) ) game ( - name "Jet Pak Jak (Europe) (Proto)" - description "Jet Pak Jak (Europe) (Proto)" - rom ( name "Jet Pak Jak (Europe) (Proto).gb" size 131072 crc 2040e99b sha1 da739097364e31f3be5851461170eaccbcd2aeb3 ) + name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan) (Rev 1)" + description "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan) (Rev 1)" + rom ( name "Goukaku Boy Series - Shikakui Atama o Maruku Suru - Suuji de Asobou Sansuu Hen (Japan) (Rev 1).gb" size 262144 crc 74821248 sha1 b1626c1fe162a7b0292d292e8ba60a1c6823fc8d ) ) game ( - name "Jet Pak Man (Europe) (Proto)" - description "Jet Pak Man (Europe) (Proto)" - rom ( name "Jet Pak Man (Europe) (Proto).gb" size 32768 crc e40dfc1b sha1 0080f76961164810d6c0543d951a465cfa1cab54 ) + name "Goukaku Boy Series - Yamakawa Ichimonittou - Nihonshi B Yougo Mondaishuu (Japan)" + description "Goukaku Boy Series - Yamakawa Ichimonittou - Nihonshi B Yougo Mondaishuu (Japan)" + rom ( name "Goukaku Boy Series - Yamakawa Ichimonittou - Nihonshi B Yougo Mondaishuu (Japan).gb" size 524288 crc a09c1790 sha1 6611adc52faa628bbc36cdc759d7c18b00316ba4 ) ) game ( - name "Jet Set Willy (World) (Aftermarket) (Unl)" - description "Jet Set Willy (World) (Aftermarket) (Unl)" - rom ( name "Jet Set Willy (World) (Aftermarket) (Unl).gb" size 262144 crc 1686d7ed sha1 0e594224506fd087e36c66bb66905d4c91b02461 ) + name "Goukaku Boy Series - Yamakawa Ichimonittou - Sekaishi B Yougo Mondaishuu (Japan)" + description "Goukaku Boy Series - Yamakawa Ichimonittou - Sekaishi B Yougo Mondaishuu (Japan)" + rom ( name "Goukaku Boy Series - Yamakawa Ichimonittou - Sekaishi B Yougo Mondaishuu (Japan).gb" size 524288 crc d185b939 sha1 33e651bbccda46ab395b6609810ee175b5cfacea ) ) game ( - name "Jetsons, The - Robot Panic (USA, Europe)" - description "Jetsons, The - Robot Panic (USA, Europe)" - rom ( name "Jetsons, The - Robot Panic (USA, Europe).gb" size 131072 crc 6386c870 sha1 1790c7462907f803e9641a330df6f06aa5e4e985 flags verified ) + name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eigo Koubun 285 (Japan)" + description "Goukaku Boy Series - Z-Kai Kyuukyoku no Eigo Koubun 285 (Japan)" + rom ( name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eigo Koubun 285 (Japan).gb" size 262144 crc d792f747 sha1 4d0d8bf6cbaef902c5855513531203b756deb93f ) ) game ( - name "Jetsons, The - Robot Panic (USA, Europe) (Rev 1)" - description "Jetsons, The - Robot Panic (USA, Europe) (Rev 1)" - rom ( name "Jetsons, The - Robot Panic (USA, Europe) (Rev 1).gb" size 131072 crc cc38cf0d sha1 38b5ec2c74316696b7731cd88e56be4519084168 ) + name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eijukugo 1017 (Japan)" + description "Goukaku Boy Series - Z-Kai Kyuukyoku no Eijukugo 1017 (Japan)" + rom ( name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eijukugo 1017 (Japan).gb" size 262144 crc 12e738ea sha1 ba02b31919422226d22f89e59df90ab060b046c9 ) ) game ( - name "Jetsons, The - Robot Panic (Japan) (Proto)" - description "Jetsons, The - Robot Panic (Japan) (Proto)" - rom ( name "Jetsons, The - Robot Panic (Japan) (Proto).gb" size 131072 crc d016d141 sha1 6035ee9364413b9eac7eb2290a806ffb57dc25cc ) + name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eitango 1500 (Japan)" + description "Goukaku Boy Series - Z-Kai Kyuukyoku no Eitango 1500 (Japan)" + rom ( name "Goukaku Boy Series - Z-Kai Kyuukyoku no Eitango 1500 (Japan).gb" size 262144 crc 3fac5c42 sha1 f439497b513262d2c98b622af1a00f4efd8650a6 ) ) game ( - name "Jikuu Senki Mu (Japan)" - description "Jikuu Senki Mu (Japan)" - rom ( name "Jikuu Senki Mu (Japan).gb" size 262144 crc 435c4697 sha1 799790fdf14c6202a44e5c9a18023fa4245243b8 ) + name "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Chuugaku Eitango 1132 (Japan)" + description "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Chuugaku Eitango 1132 (Japan)" + rom ( name "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Chuugaku Eitango 1132 (Japan).gb" size 262144 crc dc010f04 sha1 a5f3e531b8becf0fa218d73d21c3775265df607e flags verified ) ) game ( - name "Jimmy Connors no Pro Tennis Tour (Japan)" - description "Jimmy Connors no Pro Tennis Tour (Japan)" - rom ( name "Jimmy Connors no Pro Tennis Tour (Japan).gb" size 65536 crc 18671602 sha1 43ae08919dccb5129e17a3fdac553901fb6e3918 ) + name "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Kyuukyoku no Kobun Tango (Japan)" + description "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Kyuukyoku no Kobun Tango (Japan)" + rom ( name "Goukaku Boy Series - Z-Kai Reibun de Oboeru - Kyuukyoku no Kobun Tango (Japan).gb" size 262144 crc 99062c13 sha1 e105f4d680fbf0621997aa2f9ce05cb0651a9ee9 ) ) game ( - name "Jimmy Connors Tennis (USA, Europe)" - description "Jimmy Connors Tennis (USA, Europe)" - rom ( name "Jimmy Connors Tennis (USA, Europe).gb" size 65536 crc 9b7ebf91 sha1 d1f93db9a95c9023241e72fe0d7f9848322b53aa flags verified ) + name "Gradius - The Interstellar Assault (USA)" + description "Gradius - The Interstellar Assault (USA)" + rom ( name "Gradius - The Interstellar Assault (USA).gb" size 262144 crc 90f87d57 sha1 7a50fdf0b8ad15556c933df0657fae0a2cd8bc92 ) ) game ( - name "Jimmy Connors Tennis (USA, Europe) (Beta)" - description "Jimmy Connors Tennis (USA, Europe) (Beta)" - rom ( name "Jimmy Connors Tennis (USA, Europe) (Beta).gb" size 131072 crc eb50caf2 sha1 4ca04a3270e217d54d8c5fa7a254fdbcb48c5b87 ) + name "Grander Musashi RV (Japan) (SGB Enhanced)" + description "Grander Musashi RV (Japan) (SGB Enhanced)" + rom ( name "Grander Musashi RV (Japan) (SGB Enhanced).gb" size 524288 crc e97f2e9a sha1 d6fc45fd02e3d7c885c0e0244dc3c8073fb64ff4 ) ) game ( - name "Jimmy Connors Tennis (USA, Europe) (1993-03-19) (Beta)" - description "Jimmy Connors Tennis (USA, Europe) (1993-03-19) (Beta)" - rom ( name "Jimmy Connors Tennis (USA, Europe) (1993-03-19) (Beta).gb" size 65536 crc 4ee3e02e sha1 06c9018f7943362f8b9571486b6412de11672718 ) + name "Great Greed (USA)" + description "Great Greed (USA)" + rom ( name "Great Greed (USA).gb" size 262144 crc c4cbf6b1 sha1 9d7de25431f3e31f244925e317e3d0933f5efa2e flags verified ) ) game ( - name "Jinsei Game (Japan) (SGB Enhanced)" - description "Jinsei Game (Japan) (SGB Enhanced)" - rom ( name "Jinsei Game (Japan) (SGB Enhanced).gb" size 262144 crc 09f53d55 sha1 11f883c0f5f4b62d614fd8662ae56e62ab00450b ) + name "Gremlins 2 - The New Batch (World)" + description "Gremlins 2 - The New Batch (World)" + rom ( name "Gremlins 2 - The New Batch (World).gb" size 131072 crc 3579e297 sha1 0cb722d9d4e349bea1b1afa85d8d3b93f2dc2aad flags verified ) ) game ( - name "Jinsei Game Densetsu (Japan)" - description "Jinsei Game Densetsu (Japan)" - rom ( name "Jinsei Game Densetsu (Japan).gb" size 131072 crc 590f4afc sha1 106f9671e52d15dd06d614d87b4d690ab95d4131 ) + name "HAL Wrestling (USA)" + description "HAL Wrestling (USA)" + rom ( name "HAL Wrestling (USA).gb" size 131072 crc 5e4a61d3 sha1 861f1cd6ea513a003ab8364b37fa73c63b555e38 ) ) game ( - name "Joe & Mac (USA)" - description "Joe & Mac (USA)" - rom ( name "Joe & Mac (USA).gb" size 262144 crc 5da86ed4 sha1 dc4dc933c3138a05ab1d11bf77b4c7405cdd524b ) + name "HAL Wrestling (USA) (Beta)" + description "HAL Wrestling (USA) (Beta)" + rom ( name "HAL Wrestling (USA) (Beta).gb" size 131072 crc b02faa0b sha1 6ac35a017fd1f61c19086765107e3940426a2a66 ) ) game ( - name "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv)" - description "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv)" - rom ( name "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv).gb" size 262144 crc 9bd7f196 sha1 88ae07382560825b7cf9307d224938d3a0a89f8d ) + name "Hammerin' Harry (Europe)" + description "Hammerin' Harry (Europe)" + rom ( name "Hammerin' Harry (Europe).gb" size 262144 crc 9f09afe8 sha1 05490ab94ae5e01dd02b4a578bfccc5647816408 ) ) game ( - name "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta)" - description "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta)" - rom ( name "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta).gb" size 262144 crc 381c62ee sha1 979e36765291153b82025b1f036c08fe9c23cfa5 ) + name "Hammerin' Harry - Ghost Building Company (USA) (Proto)" + description "Hammerin' Harry - Ghost Building Company (USA) (Proto)" + rom ( name "Hammerin' Harry - Ghost Building Company (USA) (Proto).gb" size 262144 crc 6c4d0377 sha1 c5f73b09f001fc4d7eaa40ffee00234ca6a41a41 ) ) game ( - name "Joe Blade 2 (World) (Aftermarket) (Unl)" - description "Joe Blade 2 (World) (Aftermarket) (Unl)" - rom ( name "Joe Blade 2 (World) (Aftermarket) (Unl).gb" size 524288 crc 09f75c70 sha1 f001dffcd16be670c36a98dd9136f6f9fbf5b85d ) + name "Harvest Moon GB (USA) (SGB Enhanced)" + description "Harvest Moon GB (USA) (SGB Enhanced)" + rom ( name "Harvest Moon GB (USA) (SGB Enhanced).gb" size 524288 crc 1eae0e10 sha1 5b85d2accd3877e80d73a7ad19d9f55c288f43cc ) ) game ( - name "John Madden Football (USA) (Proto 2) (SGB Enhanced)" - description "John Madden Football (USA) (Proto 2) (SGB Enhanced)" - rom ( name "John Madden Football (USA) (Proto 2) (SGB Enhanced).gb" size 131072 crc 22f01823 sha1 8d9e6cb3c3fc60e3746355ac7a4e8b825aab57ea ) + name "Hatris (Japan, USA) (En)" + description "Hatris (Japan, USA) (En)" + rom ( name "Hatris (Japan, USA) (En).gb" size 65536 crc 7635f28b sha1 e8002f226e90ed52e1675c003d3c8ce804b56b0e ) ) game ( - name "John Madden Football (USA) (Proto 1) (SGB Enhanced)" - description "John Madden Football (USA) (Proto 1) (SGB Enhanced)" - rom ( name "John Madden Football (USA) (Proto 1) (SGB Enhanced).gb" size 131072 crc 4f03ee8c sha1 c79ecb697723f98448423d311c3d7c76328a46a8 ) + name "Hayaoshi Quiz - Ouza Ketteisen (Japan) (SGB Enhanced)" + description "Hayaoshi Quiz - Ouza Ketteisen (Japan) (SGB Enhanced)" + rom ( name "Hayaoshi Quiz - Ouza Ketteisen (Japan) (SGB Enhanced).gb" size 524288 crc 60727bf9 sha1 7f0010677e3052c6b9caf41714e87d285ad45a91 ) ) game ( - name "Jordan vs Bird - One on One (Japan)" - description "Jordan vs Bird - One on One (Japan)" - rom ( name "Jordan vs Bird - One on One (Japan).gb" size 65536 crc 3fcb174d sha1 e498c76c6367daed183cc3b185557078832aa5d9 ) + name "Head On (Japan)" + description "Head On (Japan)" + rom ( name "Head On (Japan).gb" size 65536 crc 78830daf sha1 76261091adb7def20a4f76aa6c062c60c6d9761c ) ) game ( - name "Jordan vs Bird - One on One (USA, Europe)" - description "Jordan vs Bird - One on One (USA, Europe)" - rom ( name "Jordan vs Bird - One on One (USA, Europe).gb" size 65536 crc c90c5456 sha1 c07fac4e1f29c4216ed94a2cdc7659dc3121b76e flags verified ) + name "Heavyweight Championship Boxing (USA)" + description "Heavyweight Championship Boxing (USA)" + rom ( name "Heavyweight Championship Boxing (USA).gb" size 65536 crc 1526a96b sha1 1d6f1afed7ce7a90a07219449d4d3b679afeda6b ) ) game ( - name "Joshua & the Battle of Jericho (USA) (Unl)" - description "Joshua & the Battle of Jericho (USA) (Unl)" - rom ( name "Joshua & the Battle of Jericho (USA) (Unl).gb" size 131072 crc e0cf879b sha1 019b4b0e76336e2613ae6e8b415b5c65f6d465a5 ) + name "Heiankyo Alien (USA)" + description "Heiankyo Alien (USA)" + rom ( name "Heiankyo Alien (USA).gb" size 32768 crc 1495bbe5 sha1 7372e49dbe5cbb25b8201f52ca544737d06e0fb6 flags verified ) ) game ( - name "Judge Dredd (Japan)" - description "Judge Dredd (Japan)" - rom ( name "Judge Dredd (Japan).gb" size 262144 crc 951b9907 sha1 cb5d6f34f5289c16782edee0257649bfcb82c096 ) + name "Heiankyou Alien (Japan)" + description "Heiankyou Alien (Japan)" + rom ( name "Heiankyou Alien (Japan).gb" size 32768 crc 08bf29c9 sha1 602561d82cec7484e9509b5739be021f8a3f3449 ) ) game ( - name "Judge Dredd (USA, Europe)" - description "Judge Dredd (USA, Europe)" - rom ( name "Judge Dredd (USA, Europe).gb" size 262144 crc b9d11656 sha1 36266c67c4fb095566401c25b11981785ac20a7d flags verified ) + name "Heisei Tensai Bakabon (Japan)" + description "Heisei Tensai Bakabon (Japan)" + rom ( name "Heisei Tensai Bakabon (Japan).gb" size 131072 crc ac044e9a sha1 aaccd5b75894916ef655082a4ab4e05cb3f6fee8 ) ) game ( - name "Jungle Book, The (USA, Europe)" - description "Jungle Book, The (USA, Europe)" - rom ( name "Jungle Book, The (USA, Europe).gb" size 131072 crc b64d27ee sha1 ca69dde7b176d4bec9c51f92c37a5d68402af616 flags verified ) + name "Hello Kitty - Pocket Camera (Japan) (Proto) (SGB Enhanced)" + description "Hello Kitty - Pocket Camera (Japan) (Proto) (SGB Enhanced)" + rom ( name "Hello Kitty - Pocket Camera (Japan) (Proto) (SGB Enhanced).gb" size 1048576 crc 257ad445 sha1 3c416b44c7dc05701e0f1e1b29e87a505dcde442 ) ) game ( - name "Jungle Book, The (World) (Disney Classic Games)" - description "Jungle Book, The (World) (Disney Classic Games)" - rom ( name "Jungle Book, The (World) (Disney Classic Games).gb" size 131072 crc 4a2c16ff sha1 1f332d2494f831950b88ece02d296a4708e82807 ) + name "Heracles no Eikou - Ugokidashita Kamigami (Japan)" + description "Heracles no Eikou - Ugokidashita Kamigami (Japan)" + rom ( name "Heracles no Eikou - Ugokidashita Kamigami (Japan).gb" size 262144 crc 4f8a61bf sha1 c12c60b0c0a2ee1aaded61020fa72b5b467459e1 ) ) game ( - name "Jungle no Ouja Tar-chan (Japan) (SGB Enhanced)" - description "Jungle no Ouja Tar-chan (Japan) (SGB Enhanced)" - rom ( name "Jungle no Ouja Tar-chan (Japan) (SGB Enhanced).gb" size 262144 crc 96555e9a sha1 5312e1804848603c41ac804243e5b2b758c75d0d ) + name "Hercules (USA, Europe) (SGB Enhanced)" + description "Hercules (USA, Europe) (SGB Enhanced)" + rom ( name "Hercules (USA, Europe) (SGB Enhanced).gb" size 524288 crc 00a9001e sha1 215cceaccd4a33a2da6205f33a2803ff4004e2b1 flags verified ) ) game ( - name "Jungle Strike (Europe)" - description "Jungle Strike (Europe)" - rom ( name "Jungle Strike (Europe).gb" size 262144 crc 763ababb sha1 b4c53804f6d7ed230c092232148e69b53f9eb597 ) + name "Hero Shuugou!! Pinball Party (Japan)" + description "Hero Shuugou!! Pinball Party (Japan)" + rom ( name "Hero Shuugou!! Pinball Party (Japan).gb" size 65536 crc 740552ed sha1 c4f0428455c6a4772c2db7bab0132dca169e22c7 ) ) game ( - name "Jungle Strike (USA)" - description "Jungle Strike (USA)" - rom ( name "Jungle Strike (USA).gb" size 262144 crc 7a8cdbe8 sha1 ea8b7a5d8d16b4448a3d758fff1f91f27db60292 flags verified ) + name "Hiden Inyou Kikouhou - Ca Da (Japan)" + description "Hiden Inyou Kikouhou - Ca Da (Japan)" + rom ( name "Hiden Inyou Kikouhou - Ca Da (Japan).gb" size 65536 crc 9234eeab sha1 0ba32a4383f1ff89c8838d155cb672ff799f0687 ) ) game ( - name "Jungle Wars (Japan)" - description "Jungle Wars (Japan)" - rom ( name "Jungle Wars (Japan).gb" size 262144 crc 2ad46ac7 sha1 3835a7821c11197fca87564b8d51a82c81fa7286 flags verified ) + name "Higashio Osamu Kanshuu Pro Yakyuu Stadium '91 (Japan)" + description "Higashio Osamu Kanshuu Pro Yakyuu Stadium '91 (Japan)" + rom ( name "Higashio Osamu Kanshuu Pro Yakyuu Stadium '91 (Japan).gb" size 131072 crc 420881ae sha1 cc6cbbcaabce4a63106da3c9b5e4a761511cae38 ) ) game ( - name "Jurassic Park (Europe) (En,Fr,De,Es,It)" - description "Jurassic Park (Europe) (En,Fr,De,Es,It)" - rom ( name "Jurassic Park (Europe) (En,Fr,De,Es,It).gb" size 262144 crc 2c8ad255 sha1 efbc825bae50c0498e56b53e9d02f00c400ff6d9 flags verified ) + name "Higashio Osamu Kanshuu Pro Yakyuu Stadium '92 (Japan)" + description "Higashio Osamu Kanshuu Pro Yakyuu Stadium '92 (Japan)" + rom ( name "Higashio Osamu Kanshuu Pro Yakyuu Stadium '92 (Japan).gb" size 262144 crc 71559ba0 sha1 7c89b508b71569776c50256da350652657027cf2 ) ) game ( - name "Jurassic Park (USA)" - description "Jurassic Park (USA)" - rom ( name "Jurassic Park (USA).gb" size 262144 crc b350bedf sha1 66273f0b52f9ff2be875b1428add267a5f01adb0 flags verified ) + name "High Stakes Gambling (USA)" + description "High Stakes Gambling (USA)" + rom ( name "High Stakes Gambling (USA).gb" size 131072 crc 6b17abe5 sha1 4235ecc5416a3fb0a455bec19bf26ecc9a12197b ) ) game ( - name "Jurassic Park Part 2 - The Chaos Continues (USA, Europe) (En,Fr,De,It)" - description "Jurassic Park Part 2 - The Chaos Continues (USA, Europe) (En,Fr,De,It)" - rom ( name "Jurassic Park Part 2 - The Chaos Continues (USA, Europe) (En,Fr,De,It).gb" size 262144 crc af3d2e95 sha1 b3df5f3bf73b42696261247c4c9c425a81322bb0 flags verified ) + name "Hiryuu no Ken Gaiden (Japan)" + description "Hiryuu no Ken Gaiden (Japan)" + rom ( name "Hiryuu no Ken Gaiden (Japan).gb" size 131072 crc 8ee95e0b sha1 fb4133f25fa0b9eea75f2ec69b786fe2d20d537e ) ) game ( - name "Kachiuma Yosou Keiba Kizoku (Japan)" - description "Kachiuma Yosou Keiba Kizoku (Japan)" - rom ( name "Kachiuma Yosou Keiba Kizoku (Japan).gb" size 131072 crc a57e1ac1 sha1 de965fae7d1e744302e6a12656ebb8867ba9cfff ) + name "Hit the Ice - VHL - The Official Video Hockey League (USA, Europe)" + description "Hit the Ice - VHL - The Official Video Hockey League (USA, Europe)" + rom ( name "Hit the Ice - VHL - The Official Video Hockey League (USA, Europe).gb" size 131072 crc 2c77f399 sha1 f1631e0a97fd60a285feba1b2fc9082bca3be829 ) ) game ( - name "Kachiuma Yosou Keiba Kizoku EX '94 (Japan)" - description "Kachiuma Yosou Keiba Kizoku EX '94 (Japan)" - rom ( name "Kachiuma Yosou Keiba Kizoku EX '94 (Japan).gb" size 131072 crc d4319169 sha1 30aab6efed1cc00295d7a35ea8e9f3d809f96334 ) + name "Hitori de Dekirumon! - Cooking Densetsu (Japan)" + description "Hitori de Dekirumon! - Cooking Densetsu (Japan)" + rom ( name "Hitori de Dekirumon! - Cooking Densetsu (Japan).gb" size 131072 crc 59db5e75 sha1 d7b744b84de2097fe77e55c76676256a14b20d74 ) ) game ( - name "Kachiuma Yosou Keiba Kizoku EX '95 (Japan)" - description "Kachiuma Yosou Keiba Kizoku EX '95 (Japan)" - rom ( name "Kachiuma Yosou Keiba Kizoku EX '95 (Japan).gb" size 131072 crc 9c6a4918 sha1 a368d20e2edcb8bc2745ae2c875505f45e40f4fb ) + name "Hoi Hoi - Game Boy Ban (Japan)" + description "Hoi Hoi - Game Boy Ban (Japan)" + rom ( name "Hoi Hoi - Game Boy Ban (Japan).gb" size 131072 crc c2c2ad19 sha1 d8962cc3a8c4d11af236b2612db7ab3f29615435 ) ) game ( - name "Kaeru no Tame ni Kane wa Naru (Japan)" - description "Kaeru no Tame ni Kane wa Naru (Japan)" - rom ( name "Kaeru no Tame ni Kane wa Naru (Japan).gb" size 524288 crc c18cd57a sha1 ce1e4a788327f3099877c88cc848e48c1fd055ab flags verified ) + name "Hokuto no Ken - Seizetsu Juuban Shoubu (Japan)" + description "Hokuto no Ken - Seizetsu Juuban Shoubu (Japan)" + rom ( name "Hokuto no Ken - Seizetsu Juuban Shoubu (Japan).gb" size 131072 crc e4b4febc sha1 4f8e8d2d079a0e3b76a67411d919297808f3849b ) ) game ( - name "Kaijuu Ou Gojira (Japan)" - description "Kaijuu Ou Gojira (Japan)" - rom ( name "Kaijuu Ou Gojira (Japan).gb" size 262144 crc c529a96a sha1 56271383f34a7709668a982df95ebd083831e30f ) + name "Home Alone (Japan)" + description "Home Alone (Japan)" + rom ( name "Home Alone (Japan).gb" size 131072 crc 7c3f3107 sha1 24c58e7b4bcce704ab0976c18919066582e6daf2 ) ) game ( - name "Kaisen Game - Navyblue (Japan)" - description "Kaisen Game - Navyblue (Japan)" - rom ( name "Kaisen Game - Navyblue (Japan).gb" size 65536 crc afd8c47c sha1 7fbf13dd0b5a4e7798724270a81006be9950f81a flags verified ) + name "Home Alone (USA, Europe)" + description "Home Alone (USA, Europe)" + rom ( name "Home Alone (USA, Europe).gb" size 131072 crc 8efc8434 sha1 a3142c83f391eda6f445226f2d49bd8a384be411 flags verified ) ) game ( - name "Kaisen Game - Navyblue 90 (Japan)" - description "Kaisen Game - Navyblue 90 (Japan)" - rom ( name "Kaisen Game - Navyblue 90 (Japan).gb" size 131072 crc 8cfeb2e2 sha1 60fa3fb83910f548047bbac02627c914a9057372 ) + name "Home Alone 2 - Kevin's Dream (USA) (Proto)" + description "Home Alone 2 - Kevin's Dream (USA) (Proto)" + rom ( name "Home Alone 2 - Kevin's Dream (USA) (Proto).gb" size 131072 crc f8087e88 sha1 7fa6b52a9380c5b6091ebdabbabcc816399193d3 ) ) game ( - name "Kaisen Game - Radarmission (Japan)" - description "Kaisen Game - Radarmission (Japan)" - rom ( name "Kaisen Game - Radarmission (Japan).gb" size 131072 crc 892fc0af sha1 64a808f582afcbed6a3ce0263f1dae6fde57f30b flags verified ) + name "Home Alone 2 - Lost in New York (USA, Europe)" + description "Home Alone 2 - Lost in New York (USA, Europe)" + rom ( name "Home Alone 2 - Lost in New York (USA, Europe).gb" size 131072 crc e8e430f1 sha1 853e6f96bcba40bc4cfa72898b02aebc3f9d9498 flags verified ) ) game ( - name "Kakomunja (Japan)" - description "Kakomunja (Japan)" - rom ( name "Kakomunja (Japan).gb" size 32768 crc bef1fe2b sha1 560d174d34b32a35e302297d1667cf67c3d4e8b8 ) + name "Hon Shougi (Japan) (SGB Enhanced)" + description "Hon Shougi (Japan) (SGB Enhanced)" + rom ( name "Hon Shougi (Japan) (SGB Enhanced).gb" size 65536 crc 6c407eed sha1 3f49109296b4dc0006b4e8e68133992f5ca2b843 ) ) game ( - name "Kamen Rider SD - Hashire! Mighty Riders (Japan)" - description "Kamen Rider SD - Hashire! Mighty Riders (Japan)" - rom ( name "Kamen Rider SD - Hashire! Mighty Riders (Japan).gb" size 131072 crc 71c804b3 sha1 03269715c9398659fa685830a6359caa3ffa3bbf ) + name "Hong Kong (Japan)" + description "Hong Kong (Japan)" + rom ( name "Hong Kong (Japan).gb" size 32768 crc 5ad83d68 sha1 d8dd3e1baa95d8bb0a4e6b4e97ea64b8ec34331a ) ) game ( - name "Kandume Monsters (Japan) (SGB Enhanced)" - description "Kandume Monsters (Japan) (SGB Enhanced)" - rom ( name "Kandume Monsters (Japan) (SGB Enhanced).gb" size 524288 crc 82e03e10 sha1 9444196c413a13cf326c18c5aa457bcac92114a5 flags verified ) + name "Honmei Boy (Japan)" + description "Honmei Boy (Japan)" + rom ( name "Honmei Boy (Japan).gb" size 262144 crc 0d255d59 sha1 2d6c460123886502e1590268ec5d8422c5375f7b ) ) game ( - name "Karakuri Kengou Den Musashi Lord (Japan)" - description "Karakuri Kengou Den Musashi Lord (Japan)" - rom ( name "Karakuri Kengou Den Musashi Lord (Japan).gb" size 131072 crc 01aee24b sha1 abef454ba28d9a89cdeef53dc32549d7bd7d95bb flags verified ) + name "Honoo no Toukyuuji - Dodge Danpei (Japan)" + description "Honoo no Toukyuuji - Dodge Danpei (Japan)" + rom ( name "Honoo no Toukyuuji - Dodge Danpei (Japan).gb" size 262144 crc ba595897 sha1 417c22bfd8dba5da00c207da7866d8d8e8b292d1 ) ) game ( - name "Karamuchou no Daijiken (Japan) (SGB Enhanced)" - description "Karamuchou no Daijiken (Japan) (SGB Enhanced)" - rom ( name "Karamuchou no Daijiken (Japan) (SGB Enhanced).gb" size 262144 crc fa7ea8a0 sha1 d831320bcec612c283afc2b6f194062cf98243dc ) + name "Hook (Europe)" + description "Hook (Europe)" + rom ( name "Hook (Europe).gb" size 131072 crc 370a2c2f sha1 0e0784c238b8a16666157e1ac99cee17feb52c63 ) ) game ( - name "Kaseki Sousei Reborn (Japan) (SGB Enhanced)" - description "Kaseki Sousei Reborn (Japan) (SGB Enhanced)" - rom ( name "Kaseki Sousei Reborn (Japan) (SGB Enhanced).gb" size 524288 crc 42e8ba89 sha1 c61050451f8731e35b1b983c610041cb59509ed2 flags verified ) + name "Hook (Japan)" + description "Hook (Japan)" + rom ( name "Hook (Japan).gb" size 131072 crc 62d8173c sha1 90eee3e0434bdf63d00b0e9c5cf6f62626974ca4 ) ) game ( - name "Kaseki Sousei Reborn (Japan) (Rev 1) (SGB Enhanced)" - description "Kaseki Sousei Reborn (Japan) (Rev 1) (SGB Enhanced)" - rom ( name "Kaseki Sousei Reborn (Japan) (Rev 1) (SGB Enhanced).gb" size 524288 crc 7c94197c sha1 5759394e2e8bfd68ccf5519362572daaba003573 ) + name "Hook (USA)" + description "Hook (USA)" + rom ( name "Hook (USA).gb" size 131072 crc 6765b61b sha1 570d7cc03e80e199e856160912431c21a6ca0f6c ) ) game ( - name "Kattobi Road (Japan)" - description "Kattobi Road (Japan)" - rom ( name "Kattobi Road (Japan).gb" size 131072 crc efbc23fc sha1 7ac064a877ecc8247dfb7213722dbd0f4be665f0 ) + name "Hook (USA) (Sample)" + description "Hook (USA) (Sample)" + rom ( name "Hook (USA) (Sample).gb" size 131072 crc c091abc8 sha1 0299d84e5f722e9298c1ce190b8e4a785849b868 ) ) game ( - name "Kawa no Nushi Tsuri 3 (Japan) (SGB Enhanced)" - description "Kawa no Nushi Tsuri 3 (Japan) (SGB Enhanced)" - rom ( name "Kawa no Nushi Tsuri 3 (Japan) (SGB Enhanced).gb" size 524288 crc 147e82ae sha1 5dc0c9b3fbaf75b44f368b8074c92a294e7382c4 flags verified ) + name "Hoshi no Kirby (Japan)" + description "Hoshi no Kirby (Japan)" + rom ( name "Hoshi no Kirby (Japan).gb" size 262144 crc 21035f95 sha1 1e34b7beee30e350087771b3a3e05a40e4a1ea84 ) ) game ( - name "Keitai Keiba Eight Special (Japan)" - description "Keitai Keiba Eight Special (Japan)" - rom ( name "Keitai Keiba Eight Special (Japan).gb" size 131072 crc 326273b7 sha1 1bbc35ddf540f2ad9937f57184add528c2811a5d ) + name "Hoshi no Kirby (Japan) (Rev 1)" + description "Hoshi no Kirby (Japan) (Rev 1)" + rom ( name "Hoshi no Kirby (Japan) (Rev 1).gb" size 262144 crc 04342c83 sha1 5fe35fab25299b6c53b40decfe2b1827b4a64d2a flags verified ) ) game ( - name "Ken Griffey Jr. Presents Major League Baseball (USA, Europe) (SGB Enhanced)" - description "Ken Griffey Jr. Presents Major League Baseball (USA, Europe) (SGB Enhanced)" - rom ( name "Ken Griffey Jr. Presents Major League Baseball (USA, Europe) (SGB Enhanced).gb" size 524288 crc 0a9859c1 sha1 7092afa1c1ea592bcd3afd185ae17a7b1cdf6800 ) + name "Hoshi no Kirby 2 (Japan) (SGB Enhanced)" + description "Hoshi no Kirby 2 (Japan) (SGB Enhanced)" + rom ( name "Hoshi no Kirby 2 (Japan) (SGB Enhanced).gb" size 524288 crc 4bedf22c sha1 8487fcc3f9005f6c6819c3d5810f54e78b510d47 flags verified ) ) game ( - name "Kenyuu Densetsu Yaiba (Japan)" - description "Kenyuu Densetsu Yaiba (Japan)" - rom ( name "Kenyuu Densetsu Yaiba (Japan).gb" size 262144 crc cc19768e sha1 c2b71ceee21f66f462df18233f7622d8ec95fcca ) + name "Hudson Hawk (Japan)" + description "Hudson Hawk (Japan)" + rom ( name "Hudson Hawk (Japan).gb" size 131072 crc 1cb6158c sha1 6dfc4f8269dccec1653854b98fa5c8627cd50ce0 ) ) game ( - name "Kenzie's Birthday Dash (World) (Aftermarket) (Unl)" - description "Kenzie's Birthday Dash (World) (Aftermarket) (Unl)" - rom ( name "Kenzie's Birthday Dash (World) (Aftermarket) (Unl).gb" size 1048576 crc 986bfd75 sha1 6d15b5bc33d7c7771ba62d56ae7f25fa081bc564 ) + name "Hudson Hawk (USA)" + description "Hudson Hawk (USA)" + rom ( name "Hudson Hawk (USA).gb" size 131072 crc adff7bbd sha1 efdbb5f86d6ff3b3f248b0360ab548ac1ceb1e0e flags verified ) ) game ( - name "Kick Attack (Japan) (Proto)" - description "Kick Attack (Japan) (Proto)" - rom ( name "Kick Attack (Japan) (Proto).gb" size 131072 crc 8cb898b2 sha1 ead2e41df9847e021f4638b269f85aed490aad31 ) + name "Hudson Hawk (Europe) (Proto)" + description "Hudson Hawk (Europe) (Proto)" + rom ( name "Hudson Hawk (Europe) (Proto).gb" size 131072 crc d4cd525d sha1 07c6a49f7c340d3cc78ca688eb1591853255a6c6 ) ) game ( - name "Kick Boxing, The (Japan)" - description "Kick Boxing, The (Japan)" - rom ( name "Kick Boxing, The (Japan).gb" size 262144 crc 8056344c sha1 6fb48835e5401d7b559b7e97c020bc8c356dfa1f ) + name "Hugo (Europe) (SGB Enhanced)" + description "Hugo (Europe) (SGB Enhanced)" + rom ( name "Hugo (Europe) (SGB Enhanced).gb" size 131072 crc 74aa5e0f sha1 d314dffcf5fb441d5d6d6419e01dc825e90cf0fc flags verified ) ) game ( - name "Kid Dracula (USA, Europe)" - description "Kid Dracula (USA, Europe)" - rom ( name "Kid Dracula (USA, Europe).gb" size 262144 crc f27294b7 sha1 f186833a2ccec808210eb4ba669f08401f950e23 flags verified ) + name "Hugo 2 (Germany)" + description "Hugo 2 (Germany)" + rom ( name "Hugo 2 (Germany).gb" size 131072 crc 67998fa4 sha1 66324a9b4d6f8782b706e0d3942d7efdb2b1f141 flags verified ) ) game ( - name "Kid Icarus - Of Myths and Monsters (USA, Europe)" - description "Kid Icarus - Of Myths and Monsters (USA, Europe)" - rom ( name "Kid Icarus - Of Myths and Monsters (USA, Europe).gb" size 131072 crc 0c042862 sha1 465614bb236c507a5709ecab95827a8be4e2e6b8 flags verified ) + name "Humans, The (Europe) (En,Fr,De,Es,It)" + description "Humans, The (Europe) (En,Fr,De,Es,It)" + rom ( name "Humans, The (Europe) (En,Fr,De,Es,It).gb" size 262144 crc 999c67d6 sha1 daa810cf09eae39867339b7615c6ffcf4bfd701a ) ) game ( - name "Kidou Keisatsu Patlabor - Nerawareta Machi 1990 (Japan)" - description "Kidou Keisatsu Patlabor - Nerawareta Machi 1990 (Japan)" - rom ( name "Kidou Keisatsu Patlabor - Nerawareta Machi 1990 (Japan).gb" size 131072 crc c7f7f0ac sha1 63508a4cc76bf1de2125b1055c631d9edfc6e11b ) + name "Humans, The (USA)" + description "Humans, The (USA)" + rom ( name "Humans, The (USA).gb" size 262144 crc 1df2e81d sha1 39b7f8f6abb213bb5727379b864106ca2947fe6f ) ) game ( - name "Kikou Keisatsu Metal Jack (Japan)" - description "Kikou Keisatsu Metal Jack (Japan)" - rom ( name "Kikou Keisatsu Metal Jack (Japan).gb" size 131072 crc f3cc5e62 sha1 8245f9f91126faad1f30502e1fc8012cc26c43c1 ) + name "Humans, The (USA) (QUByte Classics)" + description "Humans, The (USA) (QUByte Classics)" + rom ( name "Humans, The (USA) (QUByte Classics).gb" size 262144 crc 4580ec88 sha1 669f4645b426400a4853793c7070c53642f71556 ) ) game ( - name "Killer Instinct (USA, Europe) (SGB Enhanced)" - description "Killer Instinct (USA, Europe) (SGB Enhanced)" - rom ( name "Killer Instinct (USA, Europe) (SGB Enhanced).gb" size 524288 crc ac793b54 sha1 65ae38588abc0e699b244b0854f698ddf72c7b46 flags verified ) + name "Hunchback of Notre Dame, The - 5 Foolishly Fun Topsy Turvy Games (USA, Europe) (SGB Enhanced)" + description "Hunchback of Notre Dame, The - 5 Foolishly Fun Topsy Turvy Games (USA, Europe) (SGB Enhanced)" + rom ( name "Hunchback of Notre Dame, The - 5 Foolishly Fun Topsy Turvy Games (USA, Europe) (SGB Enhanced).gb" size 524288 crc 3a4636ff sha1 de0310602e675924f393140b3fa66284870661dd ) ) game ( - name "King James Bible (USA) (Unl)" - description "King James Bible (USA) (Unl)" - rom ( name "King James Bible (USA) (Unl).gb" size 1048576 crc 23679231 sha1 6362fde9dcb08242a64f2fbea33de93d1776a6e0 ) + name "Hunt for Red October, The (USA, Europe)" + description "Hunt for Red October, The (USA, Europe)" + rom ( name "Hunt for Red October, The (USA, Europe).gb" size 131072 crc 5a61ee00 sha1 7c9ccfd9e98b30c33ff71b3ab3098c2afeb9037c flags verified ) ) game ( - name "King of Fighters '95, The (Europe) (SGB Enhanced)" - description "King of Fighters '95, The (Europe) (SGB Enhanced)" - rom ( name "King of Fighters '95, The (Europe) (SGB Enhanced).gb" size 524288 crc a3e9b148 sha1 27eeb37f7be07381b6e4e01b5ae0d32f2ec209c0 flags verified ) + name "Hyper Black Bass (Japan) (En,Ja)" + description "Hyper Black Bass (Japan) (En,Ja)" + rom ( name "Hyper Black Bass (Japan) (En,Ja).gb" size 262144 crc c364d55f sha1 fc8ad749979702c3d52954ed5808065cde77fe38 ) ) game ( - name "King of Fighters '95, The (USA) (SGB Enhanced)" - description "King of Fighters '95, The (USA) (SGB Enhanced)" - rom ( name "King of Fighters '95, The (USA) (SGB Enhanced).gb" size 524288 crc 1ff84e8c sha1 59c11dd527d47b24323f84fb8a1bb3d06a531f32 ) + name "Hyper Black Bass '95 (Japan) (En,Ja)" + description "Hyper Black Bass '95 (Japan) (En,Ja)" + rom ( name "Hyper Black Bass '95 (Japan) (En,Ja).gb" size 262144 crc 32a81a49 sha1 bea9133cdbe8d96ee753a4f55cf5fa7bb80ff490 ) ) game ( - name "King of Fighters, The - Heat of Battle (Europe) (SGB Enhanced)" - description "King of Fighters, The - Heat of Battle (Europe) (SGB Enhanced)" - rom ( name "King of Fighters, The - Heat of Battle (Europe) (SGB Enhanced).gb" size 524288 crc 4d2d8bc3 sha1 1b5ac034b1333b3340fbdc5c128bc12abd310043 ) + name "Hyper Dunk (Europe)" + description "Hyper Dunk (Europe)" + rom ( name "Hyper Dunk (Europe).gb" size 131072 crc 02d09ce3 sha1 6aca47dd2d9c57999a566903292af2601c832c9c flags verified ) ) game ( - name "King of the Zoo (Europe)" - description "King of the Zoo (Europe)" - rom ( name "King of the Zoo (Europe).gb" size 65536 crc d2d648c4 sha1 683fcb45cf98f8d84c221ffb180b06bf81c1cf74 flags verified ) + name "Hyper Lode Runner (World) (Rev 1)" + description "Hyper Lode Runner (World) (Rev 1)" + rom ( name "Hyper Lode Runner (World) (Rev 1).gb" size 32768 crc b3a86164 sha1 261da795c7b4155f1b8083acc55da78699c8a0de flags verified ) ) game ( - name "Kingdom Crusade (USA)" - description "Kingdom Crusade (USA)" - rom ( name "Kingdom Crusade (USA).gb" size 131072 crc 920202dc sha1 ceca61f9ee1e549ca5b70bf620159cf2c2290423 ) + name "Hyper Lode Runner (Japan) (En) (Possible Proto)" + description "Hyper Lode Runner (Japan) (En) (Possible Proto)" + rom ( name "Hyper Lode Runner (Japan) (En) (Possible Proto).gb" size 32768 crc 3fc21b74 sha1 37d0f2cbac0f95af8b22dea0c882612681ec5cc8 ) ) game ( - name "Kingyo Chuuihou! - Wapiko no Wakuwaku Stamp Rally! (Japan)" - description "Kingyo Chuuihou! - Wapiko no Wakuwaku Stamp Rally! (Japan)" - rom ( name "Kingyo Chuuihou! - Wapiko no Wakuwaku Stamp Rally! (Japan).gb" size 131072 crc e69a6f0a sha1 baf5c1019c9a3752543036dca0925d370aa20d45 ) + name "Ikari no Yousai (Japan)" + description "Ikari no Yousai (Japan)" + rom ( name "Ikari no Yousai (Japan).gb" size 131072 crc 1c2ba2a1 sha1 039da1616e1a179aeda7186d6cc1955149f49581 ) ) game ( - name "Kingyo Chuuihou! 2 - Gyopi-chan o Sagase! (Japan)" - description "Kingyo Chuuihou! 2 - Gyopi-chan o Sagase! (Japan)" - rom ( name "Kingyo Chuuihou! 2 - Gyopi-chan o Sagase! (Japan).gb" size 131072 crc f3ccadc3 sha1 0674abafb9de841d658d249d06a499c14484f72c ) + name "Ikari no Yousai 2 (Japan)" + description "Ikari no Yousai 2 (Japan)" + rom ( name "Ikari no Yousai 2 (Japan).gb" size 131072 crc 6d4fd9aa sha1 ae437d4fb39d7438fc9eb98c91820aa2b5161b4f ) ) game ( - name "Kinin Koumaroku Oni (Japan)" - description "Kinin Koumaroku Oni (Japan)" - rom ( name "Kinin Koumaroku Oni (Japan).gb" size 131072 crc b7f48649 sha1 7c6c71b52c62b814945ee102054a7a3210b1ecf3 flags verified ) -) + name "In Your Face (USA)" + description "In Your Face (USA)" + rom ( name "In Your Face (USA).gb" size 131072 crc 80ac487e sha1 0be0f2a952497b321655dbee5c89678f40bf0b5a flags verified ) +) game ( - name "Kinin Koumaroku Oni (Japan) (Rev 1)" - description "Kinin Koumaroku Oni (Japan) (Rev 1)" - rom ( name "Kinin Koumaroku Oni (Japan) (Rev 1).gb" size 131072 crc aaf6366c sha1 298965bc2b99e49339618914114abfd0962560c1 flags verified ) + name "Incredible Crash Dummies, The (USA, Europe)" + description "Incredible Crash Dummies, The (USA, Europe)" + rom ( name "Incredible Crash Dummies, The (USA, Europe).gb" size 131072 crc d81c08fa sha1 f62d369b576cfd2882f8e03a5a32238eb1599477 ) ) game ( - name "Kinnikuman - The Dream Match (Japan)" - description "Kinnikuman - The Dream Match (Japan)" - rom ( name "Kinnikuman - The Dream Match (Japan).gb" size 131072 crc 48c2cd38 sha1 cc55e811024f60c0097efdff5962d85830626ab0 ) + name "Indiana Jones - Saigo no Seisen (Japan)" + description "Indiana Jones - Saigo no Seisen (Japan)" + rom ( name "Indiana Jones - Saigo no Seisen (Japan).gb" size 131072 crc 8f234f49 sha1 238499f9fc98183e57222e8f1271b9bbad2af3ec ) ) game ( - name "Kirby no Block Ball (Japan) (SGB Enhanced)" - description "Kirby no Block Ball (Japan) (SGB Enhanced)" - rom ( name "Kirby no Block Ball (Japan) (SGB Enhanced).gb" size 524288 crc df3bbcd7 sha1 3fecc964d2c13ad98abac1df49f05c488833ef5a flags verified ) + name "Indiana Jones and the Last Crusade (USA, Europe)" + description "Indiana Jones and the Last Crusade (USA, Europe)" + rom ( name "Indiana Jones and the Last Crusade (USA, Europe).gb" size 131072 crc 9189921a sha1 b656ba6c03d0cb5c81c2ed8c5c64ea8e36660aaa flags verified ) ) game ( - name "Kirby no Kirakira Kids (Japan) (SGB Enhanced)" - description "Kirby no Kirakira Kids (Japan) (SGB Enhanced)" - rom ( name "Kirby no Kirakira Kids (Japan) (SGB Enhanced).gb" size 262144 crc 47f42f42 sha1 2c46c42be76eca134e188814345afa390e298811 flags verified ) + name "Indien dans la Ville, Un (Europe) (SGB Enhanced)" + description "Indien dans la Ville, Un (Europe) (SGB Enhanced)" + rom ( name "Indien dans la Ville, Un (Europe) (SGB Enhanced).gb" size 131072 crc e37e1832 sha1 168337cdd8e4d919ce3b62ea4802ec6b959c6893 ) ) game ( - name "Kirby no Pinball (Japan)" - description "Kirby no Pinball (Japan)" - rom ( name "Kirby no Pinball (Japan).gb" size 262144 crc 8b44fb7d sha1 678ca586f5a2e2fc894fb8e9f7b9efa54fabba44 flags verified ) + name "InfoGenius Productivity Pak - Berlitz French Translator (USA, Europe)" + description "InfoGenius Productivity Pak - Berlitz French Translator (USA, Europe)" + rom ( name "InfoGenius Productivity Pak - Berlitz French Translator (USA, Europe).gb" size 131072 crc 80485fda sha1 ea77a00e9982ffa710ce9e179d4614419f9e1a35 flags verified ) ) game ( - name "Kirby's Block Ball (USA, Europe) (SGB Enhanced)" - description "Kirby's Block Ball (USA, Europe) (SGB Enhanced)" - rom ( name "Kirby's Block Ball (USA, Europe) (SGB Enhanced).gb" size 524288 crc 7ad90b4b sha1 a790d96526972d7ceb026ca27ae41ff475ccb2c5 flags verified ) + name "InfoGenius Productivity Pak - Berlitz German Translator (USA, Europe) (Proto)" + description "InfoGenius Productivity Pak - Berlitz German Translator (USA, Europe) (Proto)" + rom ( name "InfoGenius Productivity Pak - Berlitz German Translator (USA, Europe) (Proto).gb" size 131072 crc d600edc6 sha1 ecf723d2da9be058396568b3ee91b715ea9d89e3 ) ) game ( - name "Kirby's Dream Land (USA, Europe)" - description "Kirby's Dream Land (USA, Europe)" - rom ( name "Kirby's Dream Land (USA, Europe).gb" size 262144 crc 40f25740 sha1 90979baa1d0e24b41b5c304c5ddaf77450692d5a flags verified ) + name "InfoGenius Productivity Pak - Berlitz Japanese Translator (USA, Europe) (Proto)" + description "InfoGenius Productivity Pak - Berlitz Japanese Translator (USA, Europe) (Proto)" + rom ( name "InfoGenius Productivity Pak - Berlitz Japanese Translator (USA, Europe) (Proto).gb" size 131072 crc ea539f03 sha1 9a02b19b83448e94c4877c36dd3d2e6891f8e48f ) ) game ( - name "Kirby's Dream Land 2 (USA, Europe) (SGB Enhanced)" - description "Kirby's Dream Land 2 (USA, Europe) (SGB Enhanced)" - rom ( name "Kirby's Dream Land 2 (USA, Europe) (SGB Enhanced).gb" size 524288 crc 8dc07c35 sha1 8a2898ffa17e25f43793f40c88421d840d372d3c flags verified ) + name "InfoGenius Productivity Pak - Berlitz Spanish Translator (USA, Europe)" + description "InfoGenius Productivity Pak - Berlitz Spanish Translator (USA, Europe)" + rom ( name "InfoGenius Productivity Pak - Berlitz Spanish Translator (USA, Europe).gb" size 131072 crc 058eeedb sha1 ff229bc70ef30154ef4b4d4f9a4f0eb86015682e flags verified ) ) game ( - name "Kirby's Pinball Land (USA, Europe)" - description "Kirby's Pinball Land (USA, Europe)" - rom ( name "Kirby's Pinball Land (USA, Europe).gb" size 262144 crc 31cb6526 sha1 06efdb138ff56cd9522dece44adadd3fae169c76 flags verified ) + name "InfoGenius Productivity Pak - Frommer's Travel Guide (USA)" + description "InfoGenius Productivity Pak - Frommer's Travel Guide (USA)" + rom ( name "InfoGenius Productivity Pak - Frommer's Travel Guide (USA).gb" size 262144 crc 40242e35 sha1 e4155270a59b0998b3eeffea779c33713eddf2e6 ) ) game ( - name "Kirby's Star Stacker (USA, Europe) (SGB Enhanced)" - description "Kirby's Star Stacker (USA, Europe) (SGB Enhanced)" - rom ( name "Kirby's Star Stacker (USA, Europe) (SGB Enhanced).gb" size 262144 crc 91300898 sha1 3999993d31e457bb279efac3e4a65fe4967ba861 flags verified ) + name "InfoGenius Productivity Pak - Personal Organizer and Phone Book (USA)" + description "InfoGenius Productivity Pak - Personal Organizer and Phone Book (USA)" + rom ( name "InfoGenius Productivity Pak - Personal Organizer and Phone Book (USA).gb" size 65536 crc ca436939 sha1 9f65e16785e82fbddc27d811f051f60f4812fcb4 ) ) game ( - name "Kitchen Panic (Japan)" - description "Kitchen Panic (Japan)" - rom ( name "Kitchen Panic (Japan).gb" size 131072 crc 909937cb sha1 0e1b2f25c29ebabb1bc67737f3e47b263579423b ) + name "InfoGenius Productivity Pak - Spell Checker and Calculator (USA)" + description "InfoGenius Productivity Pak - Spell Checker and Calculator (USA)" + rom ( name "InfoGenius Productivity Pak - Spell Checker and Calculator (USA).gb" size 131072 crc 754496bb sha1 654e6f36c1260afba14640cf25c05c31a4075eb6 flags verified ) ) game ( - name "Kiteretsu Daihyakka - Bouken Ooedo Juraki (Japan)" - description "Kiteretsu Daihyakka - Bouken Ooedo Juraki (Japan)" - rom ( name "Kiteretsu Daihyakka - Bouken Ooedo Juraki (Japan).gb" size 262144 crc d53548b0 sha1 58d54cdc21c73661ccc0be22e8a40cef84861680 ) + name "InfoGenius Systems - Personal Organizer with Phone Book (Europe)" + description "InfoGenius Systems - Personal Organizer with Phone Book (Europe)" + rom ( name "InfoGenius Systems - Personal Organizer with Phone Book (Europe).gb" size 65536 crc bfd65534 sha1 434d2acb7c2c23ae58222254f2e2ca2f4ceddc61 flags verified ) ) game ( - name "Kizuchi da Quiz da Gen-san da! (Japan)" - description "Kizuchi da Quiz da Gen-san da! (Japan)" - rom ( name "Kizuchi da Quiz da Gen-san da! (Japan).gb" size 262144 crc 74a52399 sha1 0729da81a62a1c30e34f5c3157de16fc014c52fe ) + name "Initial D Gaiden (Japan) (SGB Enhanced)" + description "Initial D Gaiden (Japan) (SGB Enhanced)" + rom ( name "Initial D Gaiden (Japan) (SGB Enhanced).gb" size 262144 crc 6cc56612 sha1 1b3c4c1c4dfca46a009eb2e5cd45b343d7ee6681 ) ) game ( - name "Klax (Japan) (Hudson Soft)" - description "Klax (Japan) (Hudson Soft)" - rom ( name "Klax (Japan) (Hudson Soft).gb" size 32768 crc b4955889 sha1 0bc9af06d21b01bbecbe616c57e9a22f51da3eff ) + name "International Superstar Soccer (USA, Europe) (SGB Enhanced)" + description "International Superstar Soccer (USA, Europe) (SGB Enhanced)" + rom ( name "International Superstar Soccer (USA, Europe) (SGB Enhanced).gb" size 262144 crc 94757be8 sha1 13f2fc0945fb7a90f4d87d8c4e310dec9af6b792 ) ) game ( - name "Klax (USA) (Mindscape)" - description "Klax (USA) (Mindscape)" - rom ( name "Klax (USA) (Mindscape).gb" size 65536 crc 72660774 sha1 85f6b02815e7131fdd96f3802eb0a17d93277e75 ) + name "Ippatsu Gyakuten! DX Bakenou (Japan)" + description "Ippatsu Gyakuten! DX Bakenou (Japan)" + rom ( name "Ippatsu Gyakuten! DX Bakenou (Japan).gb" size 65536 crc 8f3e7f95 sha1 991efd117dcb30ddf111bb4f6e46bdda1c811417 ) ) game ( - name "Klustar (Europe) (Proto)" - description "Klustar (Europe) (Proto)" - rom ( name "Klustar (Europe) (Proto).gb" size 32768 crc 279dd6cc sha1 6a5e51bfb4d989fb31f5ed6572d08e5a8b703a8d ) + name "Iron Man X-O Manowar in Heavy Metal (USA, Europe) (SGB Enhanced)" + description "Iron Man X-O Manowar in Heavy Metal (USA, Europe) (SGB Enhanced)" + rom ( name "Iron Man X-O Manowar in Heavy Metal (USA, Europe) (SGB Enhanced).gb" size 524288 crc 173232e5 sha1 4ee9ba152e2339497d6ad49aca6f2c78a8431480 ) ) game ( - name "Knight Quest (Japan)" - description "Knight Quest (Japan)" - rom ( name "Knight Quest (Japan).gb" size 131072 crc c6f24d2f sha1 717c65392a5ed9f19fce995be08685df5fa0978b ) + name "Ishida Yoshio Tsumego Paradise (Japan)" + description "Ishida Yoshio Tsumego Paradise (Japan)" + rom ( name "Ishida Yoshio Tsumego Paradise (Japan).gb" size 65536 crc c97daaca sha1 dd9fd57dfa72e8818c553db553d9e598edb9d956 ) ) game ( - name "Knight Quest (USA)" - description "Knight Quest (USA)" - rom ( name "Knight Quest (USA).gb" size 131072 crc df50f477 sha1 99eb275df25baa6d1b53f5518e93c5f5913a2b6a flags verified ) + name "Ishido - The Way of Stones (Japan)" + description "Ishido - The Way of Stones (Japan)" + rom ( name "Ishido - The Way of Stones (Japan).gb" size 32768 crc ab367915 sha1 75768fa6c719b96e6642bca5439a78cd3696761f flags verified ) ) game ( - name "Koi wa Kakehiki (Japan)" - description "Koi wa Kakehiki (Japan)" - rom ( name "Koi wa Kakehiki (Japan).gb" size 32768 crc f3e1e652 sha1 d6a59fc334f93ba0d17faa66542eb74dcc3e536b ) + name "Ishido - The Way of Stones (USA)" + description "Ishido - The Way of Stones (USA)" + rom ( name "Ishido - The Way of Stones (USA).gb" size 65536 crc 85b98a77 sha1 41a00b379864cc0be08de75ae0de5bb2c6fbb045 ) ) game ( - name "Konami GB Collection Vol.1 (Japan) (SGB Enhanced)" - description "Konami GB Collection Vol.1 (Japan) (SGB Enhanced)" - rom ( name "Konami GB Collection Vol.1 (Japan) (SGB Enhanced).gb" size 524288 crc 992cd78f sha1 dfb86b1b2db29a7086d60dc143374ef27b130580 ) + name "Itsudemo! Nyan to Wonderful (Japan) (SGB Enhanced)" + description "Itsudemo! Nyan to Wonderful (Japan) (SGB Enhanced)" + rom ( name "Itsudemo! Nyan to Wonderful (Japan) (SGB Enhanced).gb" size 262144 crc 1c4d3665 sha1 a48d6b68d82b98e775c00366da544402d7c7ac0e flags verified ) ) game ( - name "Konami GB Collection Vol.2 (Japan) (SGB Enhanced)" - description "Konami GB Collection Vol.2 (Japan) (SGB Enhanced)" - rom ( name "Konami GB Collection Vol.2 (Japan) (SGB Enhanced).gb" size 524288 crc c3b318cd sha1 5753310cb9fbe44efc2b27ce488cd069ef243199 ) + name "J.League Big Wave Soccer (Japan) (SGB Enhanced)" + description "J.League Big Wave Soccer (Japan) (SGB Enhanced)" + rom ( name "J.League Big Wave Soccer (Japan) (SGB Enhanced).gb" size 262144 crc cdd02f22 sha1 00369c42d2c4be0506901b64f7d5424538574ce0 ) ) game ( - name "Konami GB Collection Vol.3 (Japan) (SGB Enhanced)" - description "Konami GB Collection Vol.3 (Japan) (SGB Enhanced)" - rom ( name "Konami GB Collection Vol.3 (Japan) (SGB Enhanced).gb" size 524288 crc 1de9caf9 sha1 db9f1192df7e186ea498c4f576fc016fdc339539 ) + name "J.League Fighting Soccer - The King of Ace Strikers (Japan)" + description "J.League Fighting Soccer - The King of Ace Strikers (Japan)" + rom ( name "J.League Fighting Soccer - The King of Ace Strikers (Japan).gb" size 131072 crc 17608642 sha1 fbe94c42a9bd7d5ebddb28382caf03ab2f9902d6 ) ) game ( - name "Konami GB Collection Vol.4 (Japan) (SGB Enhanced)" - description "Konami GB Collection Vol.4 (Japan) (SGB Enhanced)" - rom ( name "Konami GB Collection Vol.4 (Japan) (SGB Enhanced).gb" size 524288 crc 3a43ea33 sha1 c33ba418386b34b466b5dd28159ea76ca2db12f8 ) + name "J.League Live 95 (Japan) (SGB Enhanced)" + description "J.League Live 95 (Japan) (SGB Enhanced)" + rom ( name "J.League Live 95 (Japan) (SGB Enhanced).gb" size 262144 crc f0321342 sha1 3b4922f8034877d1a5aca380f846a7cb6841f6ee ) ) game ( - name "Konami Golf (Europe)" - description "Konami Golf (Europe)" - rom ( name "Konami Golf (Europe).gb" size 131072 crc 0fdc9fb1 sha1 59d13714f8477db50cf164254480dd25959ecd23 ) + name "J.League Winning Goal (Japan)" + description "J.League Winning Goal (Japan)" + rom ( name "J.League Winning Goal (Japan).gb" size 131072 crc adb46f9c sha1 b8630f06e8b9682e667b7b1f2139162e2f022561 ) ) game ( - name "Konamic Basket (Japan)" - description "Konamic Basket (Japan)" - rom ( name "Konamic Basket (Japan).gb" size 131072 crc 8e367457 sha1 10372339db6d65210f7d04591d92c1889cef5133 ) + name "Jack Nicklaus Golf (France)" + description "Jack Nicklaus Golf (France)" + rom ( name "Jack Nicklaus Golf (France).gb" size 131072 crc 374893d7 sha1 2bc2c3a95a49498347c49d5dd7182a1387ab531e ) ) game ( - name "Konamic Golf (Japan)" - description "Konamic Golf (Japan)" - rom ( name "Konamic Golf (Japan).gb" size 131072 crc c16d4db2 sha1 78d014f8feb88cc8b509172c1a6fa48aa5eed67c ) + name "Jack Nicklaus Golf (USA, Europe)" + description "Jack Nicklaus Golf (USA, Europe)" + rom ( name "Jack Nicklaus Golf (USA, Europe).gb" size 131072 crc 654988b2 sha1 bac74527dbd276f395d5c89f14450bb5bc2baab1 ) ) game ( - name "Konamic Ice Hockey (Japan)" - description "Konamic Ice Hockey (Japan)" - rom ( name "Konamic Ice Hockey (Japan).gb" size 131072 crc d14dee07 sha1 e7feccc615f71ebd7c3d61c3406ed63a894758f0 ) + name "Jaleco J.Cup Soccer (Japan)" + description "Jaleco J.Cup Soccer (Japan)" + rom ( name "Jaleco J.Cup Soccer (Japan).gb" size 131072 crc 98259257 sha1 984f4fd0127325311cad9fbceb5c71f305cb2b23 ) ) game ( - name "Konamic Sports in Barcelona (Japan)" - description "Konamic Sports in Barcelona (Japan)" - rom ( name "Konamic Sports in Barcelona (Japan).gb" size 131072 crc 5721e7d6 sha1 4d3b7d1a615c6783e741812a1b1de4467ed14eef ) + name "James Bond 007 (USA, Europe) (SGB Enhanced)" + description "James Bond 007 (USA, Europe) (SGB Enhanced)" + rom ( name "James Bond 007 (USA, Europe) (SGB Enhanced).gb" size 524288 crc ca3bc3ce sha1 e03754173a5d62cb9da7d2306bc41b0e23e3d519 flags verified ) ) game ( - name "Konchuu Hakase (Japan) (SGB Enhanced)" - description "Konchuu Hakase (Japan) (SGB Enhanced)" - rom ( name "Konchuu Hakase (Japan) (SGB Enhanced).gb" size 524288 crc f6b3e291 sha1 ac792793b43cc8fae098df23e6aeb845f98199cd ) + name "Jankenman (Japan)" + description "Jankenman (Japan)" + rom ( name "Jankenman (Japan).gb" size 65536 crc 37b3d081 sha1 723f34875166b73c95610a6c146eeac34dd90868 ) ) game ( - name "Konchuu Hakase (Japan) (Rev 1) (SGB Enhanced)" - description "Konchuu Hakase (Japan) (Rev 1) (SGB Enhanced)" - rom ( name "Konchuu Hakase (Japan) (Rev 1) (SGB Enhanced).gb" size 524288 crc 05753790 sha1 3e8e47b36a2171ad93d0e21fe5c22feff17c6d88 ) + name "Janshirou (Japan)" + description "Janshirou (Japan)" + rom ( name "Janshirou (Japan).gb" size 65536 crc 0530e1cc sha1 658120ff41a0fd4c2198f5618dd43a799958aa55 ) ) game ( - name "Koro Dice (Japan)" - description "Koro Dice (Japan)" - rom ( name "Koro Dice (Japan).gb" size 32768 crc 39608c31 sha1 17d51f459b854d1911c48418ff1592b11981cc84 ) + name "Janshirou II - Sekai Saikyou no Janshi (Japan)" + description "Janshirou II - Sekai Saikyou no Janshi (Japan)" + rom ( name "Janshirou II - Sekai Saikyou no Janshi (Japan).gb" size 131072 crc 2812036b sha1 f85022f21549349f95b58db57ab71998ab24c012 ) ) game ( - name "Koukiatsu Boy (Japan) (SGB Enhanced)" - description "Koukiatsu Boy (Japan) (SGB Enhanced)" - rom ( name "Koukiatsu Boy (Japan) (SGB Enhanced).gb" size 524288 crc 53ff8041 sha1 f7f5b71a8d3b393b0507eee75fbdaea7006f945f ) + name "Jantaku Boy (Japan)" + description "Jantaku Boy (Japan)" + rom ( name "Jantaku Boy (Japan).gb" size 131072 crc 04daa03b sha1 34f0a33f329915800ba681728c43d7451ff1f162 ) ) game ( - name "Krusty World (Japan)" - description "Krusty World (Japan)" - rom ( name "Krusty World (Japan).gb" size 131072 crc 01fbc9f6 sha1 ba64940bce70de459fff84a16222481344749558 ) + name "Jeep Jamboree - Off-Road Adventure (USA)" + description "Jeep Jamboree - Off-Road Adventure (USA)" + rom ( name "Jeep Jamboree - Off-Road Adventure (USA).gb" size 131072 crc a1e76a33 sha1 988a40823f7db661bc91ffff8fc1bcd80e64f18d flags verified ) ) game ( - name "Krusty's Fun House (USA, Europe)" - description "Krusty's Fun House (USA, Europe)" - rom ( name "Krusty's Fun House (USA, Europe).gb" size 131072 crc 1cedb141 sha1 e61039c52c053a8ae1bdfffa3f694934569bb570 flags verified ) + name "Jeep Jamboree - Off-Road Adventure (Europe) (Proto)" + description "Jeep Jamboree - Off-Road Adventure (Europe) (Proto)" + rom ( name "Jeep Jamboree - Off-Road Adventure (Europe) (Proto).gb" size 131072 crc 96633953 sha1 5a116101a1db86de71b6c622f5a6e60373ecdade ) ) game ( - name "Kudzu (World) (v0.96) (Demo) (Aftermarket) (Unl)" - description "Kudzu (World) (v0.96) (Demo) (Aftermarket) (Unl)" - rom ( name "Kudzu (World) (v0.96) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc 0610049a sha1 a6fbe1a524547bebabc5e6b3baff1dff8f13dbd0 ) + name "Jelly Boy (Europe)" + description "Jelly Boy (Europe)" + rom ( name "Jelly Boy (Europe).gb" size 262144 crc 7e6598bb sha1 579579d660cdc84af2428ccd1b30b40a2fb592fa ) ) game ( - name "Kuma no Puutarou - Takara Sagashi da Ooiri Game Battle! (Japan) (SGB Enhanced)" - description "Kuma no Puutarou - Takara Sagashi da Ooiri Game Battle! (Japan) (SGB Enhanced)" - rom ( name "Kuma no Puutarou - Takara Sagashi da Ooiri Game Battle! (Japan) (SGB Enhanced).gb" size 262144 crc f01d0b87 sha1 b986ce8e1a6a4a1b22e0db5bf03b8b028cce9057 ) + name "Jeopardy! (USA)" + description "Jeopardy! (USA)" + rom ( name "Jeopardy! (USA).gb" size 131072 crc 08725c79 sha1 d0bf6e71ddae1faff179309eaab554c2ae994de0 ) ) game ( - name "Kung-Fu Master (USA, Europe)" - description "Kung-Fu Master (USA, Europe)" - rom ( name "Kung-Fu Master (USA, Europe).gb" size 65536 crc 3340e600 sha1 b0bb485e2b57793da9f153db074c13a060a1e0d4 flags verified ) + name "Jeopardy! - Platinum Edition (USA) (SGB Enhanced)" + description "Jeopardy! - Platinum Edition (USA) (SGB Enhanced)" + rom ( name "Jeopardy! - Platinum Edition (USA) (SGB Enhanced).gb" size 131072 crc 5206fd09 sha1 35934633a9b301d734a6fced7c56d55eba0385aa ) ) game ( - name "Kung-Fu Master (USA, Europe) (Beta)" - description "Kung-Fu Master (USA, Europe) (Beta)" - rom ( name "Kung-Fu Master (USA, Europe) (Beta).gb" size 65536 crc e0c33c1a sha1 1ce6301d56294b71068514c666ad2157551134e7 ) + name "Jeopardy! - Sports Edition (USA)" + description "Jeopardy! - Sports Edition (USA)" + rom ( name "Jeopardy! - Sports Edition (USA).gb" size 131072 crc 3b523216 sha1 ae534dcdeaa7138e1a0c775e0574c423a8c76dfb ) ) game ( - name "Kuusou Kagaku Sekai Gulliver Boy - Kuusou Kagaku Puzzle Purittopon!! (Japan) (SGB Enhanced)" - description "Kuusou Kagaku Sekai Gulliver Boy - Kuusou Kagaku Puzzle Purittopon!! (Japan) (SGB Enhanced)" - rom ( name "Kuusou Kagaku Sekai Gulliver Boy - Kuusou Kagaku Puzzle Purittopon!! (Japan) (SGB Enhanced).gb" size 262144 crc fb291e78 sha1 1ba1abc4db088cfc57bc733634c5b02308d132f4 ) + name "Jeopardy! - Teen Tournament (USA) (SGB Enhanced)" + description "Jeopardy! - Teen Tournament (USA) (SGB Enhanced)" + rom ( name "Jeopardy! - Teen Tournament (USA) (SGB Enhanced).gb" size 131072 crc cd3df0c1 sha1 20c71f434ef093fac9361fa1db9c2282c938dd71 ) ) game ( - name "Kwirk - He's A-maze-ing! (USA, Europe)" - description "Kwirk - He's A-maze-ing! (USA, Europe)" - rom ( name "Kwirk - He's A-maze-ing! (USA, Europe).gb" size 32768 crc 21c98af2 sha1 6ef48e912a47c774048456aa870c7e810fd45685 flags verified ) + name "Jet Pack (USA, Europe) (Beta)" + description "Jet Pack (USA, Europe) (Beta)" + rom ( name "Jet Pack (USA, Europe) (Beta).gb" size 131072 crc 1c223204 sha1 df7abbcaaccd5cff4c55bb331fa5d3049fb92896 ) ) game ( - name "Kyoro-chan Land (Japan)" - description "Kyoro-chan Land (Japan)" - rom ( name "Kyoro-chan Land (Japan).gb" size 32768 crc e158d4db sha1 67b9b01fbb58c69aad716bcc0409a9dba3bd92b5 ) + name "Jet Pak Jak (Europe) (Proto)" + description "Jet Pak Jak (Europe) (Proto)" + rom ( name "Jet Pak Jak (Europe) (Proto).gb" size 131072 crc 2040e99b sha1 da739097364e31f3be5851461170eaccbcd2aeb3 ) ) game ( - name "Lamborghini American Challenge (USA, Europe)" - description "Lamborghini American Challenge (USA, Europe)" - rom ( name "Lamborghini American Challenge (USA, Europe).gb" size 131072 crc 675e1309 sha1 82a6808f0c4cb1e05a4c2a38a39b0c37874b4211 flags verified ) + name "Jet Pak Man (Europe) (Proto)" + description "Jet Pak Man (Europe) (Proto)" + rom ( name "Jet Pak Man (Europe) (Proto).gb" size 32768 crc e40dfc1b sha1 0080f76961164810d6c0543d951a465cfa1cab54 ) ) game ( - name "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl)" - description "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl)" - rom ( name "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl).gb" size 131072 crc 989a5fe0 sha1 00f139a63c0dd6cdaeac77c6747772ac394c0a79 ) + name "Jetsons, The - Robot Panic (USA, Europe)" + description "Jetsons, The - Robot Panic (USA, Europe)" + rom ( name "Jetsons, The - Robot Panic (USA, Europe).gb" size 131072 crc 6386c870 sha1 1790c7462907f803e9641a330df6f06aa5e4e985 flags verified ) ) game ( - name "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl) (Alt)" - description "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl) (Alt)" - rom ( name "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl) (Alt).gb" size 65536 crc 997fa9eb sha1 ded742d50ed553ffea524d7deec628c354c74cc4 ) + name "Jetsons, The - Robot Panic (USA, Europe) (Rev 1)" + description "Jetsons, The - Robot Panic (USA, Europe) (Rev 1)" + rom ( name "Jetsons, The - Robot Panic (USA, Europe) (Rev 1).gb" size 131072 crc cc38cf0d sha1 38b5ec2c74316696b7731cd88e56be4519084168 ) ) game ( - name "Laser Squad Alter (World) (Aftermarket) (Unl)" - description "Laser Squad Alter (World) (Aftermarket) (Unl)" - rom ( name "Laser Squad Alter (World) (Aftermarket) (Unl).gb" size 1048576 crc a39b3a5a sha1 1620e585e77a2457cffde82453bec0c7a04e07cf ) + name "Jetsons, The - Robot Panic (Japan) (Proto)" + description "Jetsons, The - Robot Panic (Japan) (Proto)" + rom ( name "Jetsons, The - Robot Panic (Japan) (Proto).gb" size 131072 crc d016d141 sha1 6035ee9364413b9eac7eb2290a806ffb57dc25cc ) ) game ( - name "Last Action Hero (USA, Europe)" - description "Last Action Hero (USA, Europe)" - rom ( name "Last Action Hero (USA, Europe).gb" size 131072 crc 10499af6 sha1 010eb2cbab987ec242cd0792c789a07c00106f48 ) + name "Jikuu Senki Mu (Japan)" + description "Jikuu Senki Mu (Japan)" + rom ( name "Jikuu Senki Mu (Japan).gb" size 262144 crc 435c4697 sha1 799790fdf14c6202a44e5c9a18023fa4245243b8 ) ) game ( - name "Last Crown Warriors (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" - description "Last Crown Warriors (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Last Crown Warriors (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl).gb" size 262144 crc 2c430576 sha1 0e290b387a45b6ea85c6d49bf18bce3ce94951b7 ) + name "Jimmy Connors no Pro Tennis Tour (Japan)" + description "Jimmy Connors no Pro Tennis Tour (Japan)" + rom ( name "Jimmy Connors no Pro Tennis Tour (Japan).gb" size 65536 crc 18671602 sha1 43ae08919dccb5129e17a3fdac553901fb6e3918 ) ) game ( - name "Last Crown Warriors (World) (v1.1.1) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" - description "Last Crown Warriors (World) (v1.1.1) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Last Crown Warriors (World) (v1.1.1) (Demo) (SGB Enhanced) (Aftermarket) (Unl).gb" size 262144 crc 5cf1a6f9 sha1 9fac1324e863f719674219eb41e45f1f745c67a9 ) + name "Jimmy Connors Tennis (USA, Europe)" + description "Jimmy Connors Tennis (USA, Europe)" + rom ( name "Jimmy Connors Tennis (USA, Europe).gb" size 65536 crc 9b7ebf91 sha1 d1f93db9a95c9023241e72fe0d7f9848322b53aa flags verified ) ) game ( - name "Lawn Mower Land (World) (Aftermarket) (Unl)" - description "Lawn Mower Land (World) (Aftermarket) (Unl)" - rom ( name "Lawn Mower Land (World) (Aftermarket) (Unl).gb" size 32768 crc 11c62e39 sha1 1d6aa817ebf2a7e5d22285b906540272b67169da ) + name "Jimmy Connors Tennis (USA, Europe) (Beta)" + description "Jimmy Connors Tennis (USA, Europe) (Beta)" + rom ( name "Jimmy Connors Tennis (USA, Europe) (Beta).gb" size 131072 crc eb50caf2 sha1 4ca04a3270e217d54d8c5fa7a254fdbcb48c5b87 ) ) game ( - name "Lawnmower Man, The (USA) (Proto 1) (1993-10-11) (Not For Resale)" - description "Lawnmower Man, The (USA) (Proto 1) (1993-10-11) (Not For Resale)" - rom ( name "Lawnmower Man, The (USA) (Proto 1) (1993-10-11) (Not For Resale).gb" size 131072 crc 1cac0775 sha1 589eedd3919dd29cbdf6fd9c2fa6b4f1c258fc97 ) + name "Jimmy Connors Tennis (USA, Europe) (1993-03-19) (Beta)" + description "Jimmy Connors Tennis (USA, Europe) (1993-03-19) (Beta)" + rom ( name "Jimmy Connors Tennis (USA, Europe) (1993-03-19) (Beta).gb" size 65536 crc 4ee3e02e sha1 06c9018f7943362f8b9571486b6412de11672718 ) ) game ( - name "Lawnmower Man, The (USA) (Proto 2) (1993-11-10)" - description "Lawnmower Man, The (USA) (Proto 2) (1993-11-10)" - rom ( name "Lawnmower Man, The (USA) (Proto 2) (1993-11-10).gb" size 131072 crc 545613e9 sha1 4e06c18e90a4100f2776e4fffb5673e622bb8053 ) + name "Jinsei Game (Japan) (SGB Enhanced)" + description "Jinsei Game (Japan) (SGB Enhanced)" + rom ( name "Jinsei Game (Japan) (SGB Enhanced).gb" size 262144 crc 09f53d55 sha1 11f883c0f5f4b62d614fd8662ae56e62ab00450b ) ) game ( - name "Lawnmower Man, The (Europe)" - description "Lawnmower Man, The (Europe)" - rom ( name "Lawnmower Man, The (Europe).gb" size 131072 crc 134f91d7 sha1 6e63a725fc802966986e6ed6917a7b976794f403 flags verified ) + name "Jinsei Game Densetsu (Japan)" + description "Jinsei Game Densetsu (Japan)" + rom ( name "Jinsei Game Densetsu (Japan).gb" size 131072 crc 590f4afc sha1 106f9671e52d15dd06d614d87b4d690ab95d4131 ) ) game ( - name "Lazlos' Leap (USA)" - description "Lazlos' Leap (USA)" - rom ( name "Lazlos' Leap (USA).gb" size 65536 crc 31fb404b sha1 c111470fcdadf191cf843e50c8f3d3dbb995a5c5 ) + name "Joe & Mac (USA)" + description "Joe & Mac (USA)" + rom ( name "Joe & Mac (USA).gb" size 262144 crc 5da86ed4 sha1 dc4dc933c3138a05ab1d11bf77b4c7405cdd524b ) ) game ( - name "Leak, The (World) (Aftermarket) (Unl)" - description "Leak, The (World) (Aftermarket) (Unl)" - rom ( name "Leak, The (World) (Aftermarket) (Unl).GB" size 65536 crc ba3cfeae sha1 98de2d8be75e6d9cb4e87afe14b1380c033de797 ) + name "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv)" + description "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv)" + rom ( name "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv).gb" size 262144 crc 9bd7f196 sha1 88ae07382560825b7cf9307d224938d3a0a89f8d ) ) game ( - name "Learn and Play - Blackjack & Solitaire (USA) (1994-08-09) (Proto)" - description "Learn and Play - Blackjack & Solitaire (USA) (1994-08-09) (Proto)" - rom ( name "Learn and Play - Blackjack & Solitaire (USA) (1994-08-09) (Proto).gb" size 131072 crc 60837c15 sha1 d69062736dfde2af8e0ede2cc3dd5d2b95996e79 ) + name "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta)" + description "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta)" + rom ( name "Joe & Mac - Caveman Ninja (Europe) (En,Fr,De,Es,It,Nl,Sv) (Beta).gb" size 262144 crc 381c62ee sha1 979e36765291153b82025b1f036c08fe9c23cfa5 ) ) game ( - name "Legend - Ashita e no Tsubasa (Japan)" - description "Legend - Ashita e no Tsubasa (Japan)" - rom ( name "Legend - Ashita e no Tsubasa (Japan).gb" size 131072 crc fc20ebf0 sha1 7447b3faa1d15e80815cdace3c6c0691bc28aa90 ) + name "John Madden Football (USA) (Proto 2) (SGB Enhanced)" + description "John Madden Football (USA) (Proto 2) (SGB Enhanced)" + rom ( name "John Madden Football (USA) (Proto 2) (SGB Enhanced).gb" size 131072 crc 22f01823 sha1 8d9e6cb3c3fc60e3746355ac7a4e8b825aab57ea ) ) game ( - name "Legend of Prince Valiant, The (Europe) (En,Fr,De)" - description "Legend of Prince Valiant, The (Europe) (En,Fr,De)" - rom ( name "Legend of Prince Valiant, The (Europe) (En,Fr,De).gb" size 131072 crc 179c494e sha1 d56b59ad9e483f6912e8e5869c43e1771cf167c2 ) + name "John Madden Football (USA) (Proto 1) (SGB Enhanced)" + description "John Madden Football (USA) (Proto 1) (SGB Enhanced)" + rom ( name "John Madden Football (USA) (Proto 1) (SGB Enhanced).gb" size 131072 crc 4f03ee8c sha1 c79ecb697723f98448423d311c3d7c76328a46a8 ) ) game ( - name "Legend of the River King GB (USA) (SGB Enhanced)" - description "Legend of the River King GB (USA) (SGB Enhanced)" - rom ( name "Legend of the River King GB (USA) (SGB Enhanced).gb" size 524288 crc a6e685dc sha1 d2e8a9aceec8639b528f712532a38fe0c2b0edef ) + name "Jordan vs Bird - One on One (Japan)" + description "Jordan vs Bird - One on One (Japan)" + rom ( name "Jordan vs Bird - One on One (Japan).gb" size 65536 crc 3fcb174d sha1 e498c76c6367daed183cc3b185557078832aa5d9 ) ) game ( - name "Legend of the River King GB (Australia) (SGB Enhanced)" - description "Legend of the River King GB (Australia) (SGB Enhanced)" - rom ( name "Legend of the River King GB (Australia) (SGB Enhanced).gb" size 524288 crc 51627213 sha1 87274e8c0d2daaac2e0dda94651c35d6a0617c0f ) + name "Jordan vs Bird - One on One (USA, Europe)" + description "Jordan vs Bird - One on One (USA, Europe)" + rom ( name "Jordan vs Bird - One on One (USA, Europe).gb" size 65536 crc c90c5456 sha1 c07fac4e1f29c4216ed94a2cdc7659dc3121b76e flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening (Canada) (Fr)" - description "Legend of Zelda, The - Link's Awakening (Canada) (Fr)" - rom ( name "Legend of Zelda, The - Link's Awakening (Canada) (Fr).gb" size 524288 crc 4407c759 sha1 4bbd38a4548e0c7922d0a6719ac5d16791e9535b flags verified ) + name "Joshua & the Battle of Jericho (USA) (Unl)" + description "Joshua & the Battle of Jericho (USA) (Unl)" + rom ( name "Joshua & the Battle of Jericho (USA) (Unl).gb" size 131072 crc e0cf879b sha1 019b4b0e76336e2613ae6e8b415b5c65f6d465a5 ) ) game ( - name "Legend of Zelda, The - Link's Awakening (France)" - description "Legend of Zelda, The - Link's Awakening (France)" - rom ( name "Legend of Zelda, The - Link's Awakening (France).gb" size 524288 crc bf2ab18b sha1 af93e1b3140f61fcd614f1ef9266d6892224767f flags verified ) + name "Judge Dredd (Japan)" + description "Judge Dredd (Japan)" + rom ( name "Judge Dredd (Japan).gb" size 262144 crc 951b9907 sha1 cb5d6f34f5289c16782edee0257649bfcb82c096 ) ) game ( - name "Legend of Zelda, The - Link's Awakening (Germany)" - description "Legend of Zelda, The - Link's Awakening (Germany)" - rom ( name "Legend of Zelda, The - Link's Awakening (Germany).gb" size 524288 crc 760ab4e7 sha1 cc468442508a8ba6c4661238aa1925a3132f1630 flags verified ) + name "Judge Dredd (USA, Europe)" + description "Judge Dredd (USA, Europe)" + rom ( name "Judge Dredd (USA, Europe).gb" size 262144 crc b9d11656 sha1 36266c67c4fb095566401c25b11981785ac20a7d flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening (USA, Europe)" - description "Legend of Zelda, The - Link's Awakening (USA, Europe)" - rom ( name "Legend of Zelda, The - Link's Awakening (USA, Europe).gb" size 524288 crc 8cf27c90 sha1 602167f897b4f56fe8cee837933da3bed5882bbd flags verified ) + name "Jungle Book, The (USA, Europe)" + description "Jungle Book, The (USA, Europe)" + rom ( name "Jungle Book, The (USA, Europe).gb" size 131072 crc b64d27ee sha1 ca69dde7b176d4bec9c51f92c37a5d68402af616 flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 1)" - description "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 1)" - rom ( name "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 1).gb" size 524288 crc 7d1b6cd6 sha1 5259e68522225a7a830e29ea17dfddc33263ced5 flags verified ) + name "Jungle Book, The (World) (Disney Classic Games)" + description "Jungle Book, The (World) (Disney Classic Games)" + rom ( name "Jungle Book, The (World) (Disney Classic Games).gb" size 131072 crc 4a2c16ff sha1 1f332d2494f831950b88ece02d296a4708e82807 ) ) game ( - name "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 2)" - description "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 2)" - rom ( name "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 2).gb" size 524288 crc 34d08e7b sha1 5ab63def958728933571c3b4f6af54db14f3f8b2 flags verified ) + name "Jungle no Ouja Tar-chan (Japan) (SGB Enhanced)" + description "Jungle no Ouja Tar-chan (Japan) (SGB Enhanced)" + rom ( name "Jungle no Ouja Tar-chan (Japan) (SGB Enhanced).gb" size 262144 crc 96555e9a sha1 5312e1804848603c41ac804243e5b2b758c75d0d ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (France) (Proto) (1998-11-17)" - description "Legend of Zelda, The - Link's Awakening DX (France) (Proto) (1998-11-17)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Proto) (1998-11-17).gb" size 524288 crc bfa800c0 sha1 3d48bcec56bf202d3362ba3e5e20233f996492c5 ) + name "Jungle Strike (Europe)" + description "Jungle Strike (Europe)" + rom ( name "Jungle Strike (Europe).gb" size 262144 crc 763ababb sha1 b4c53804f6d7ed230c092232148e69b53f9eb597 ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Proto) (1998-11-08)" - description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Proto) (1998-11-08)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Proto) (1998-11-08).gb" size 524288 crc d8ba6631 sha1 9d6da903a5481aadfb20d75954bd01917497a38d ) + name "Jungle Strike (USA)" + description "Jungle Strike (USA)" + rom ( name "Jungle Strike (USA).gb" size 262144 crc 7a8cdbe8 sha1 ea8b7a5d8d16b4448a3d758fff1f91f27db60292 flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (Germany) (Proto) (1998-11-17)" - description "Legend of Zelda, The - Link's Awakening DX (Germany) (Proto) (1998-11-17)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Proto) (1998-11-17).gb" size 524288 crc f7c59f5c sha1 d1a10a3f129bf060f16d1fb5f991ef6e2f28b97c ) + name "Jungle Wars (Japan)" + description "Jungle Wars (Japan)" + rom ( name "Jungle Wars (Japan).gb" size 262144 crc 2ad46ac7 sha1 3835a7821c11197fca87564b8d51a82c81fa7286 flags verified ) ) game ( - name "Lemmings (Europe) (Rev 1)" - description "Lemmings (Europe) (Rev 1)" - rom ( name "Lemmings (Europe) (Rev 1).gb" size 131072 crc 560d71eb sha1 c156d7ee57860a23754e87d42f952b17077994ad ) + name "Jurassic Park (Europe) (En,Fr,De,Es,It)" + description "Jurassic Park (Europe) (En,Fr,De,Es,It)" + rom ( name "Jurassic Park (Europe) (En,Fr,De,Es,It).gb" size 262144 crc 2c8ad255 sha1 efbc825bae50c0498e56b53e9d02f00c400ff6d9 flags verified ) ) game ( - name "Lemmings (Europe) (Beta) (1993-05-19)" - description "Lemmings (Europe) (Beta) (1993-05-19)" - rom ( name "Lemmings (Europe) (Beta) (1993-05-19).gb" size 131072 crc e2a65174 sha1 4f23d9dcc315f5dbd5ef2350f6623b6cd077b393 ) + name "Jurassic Park (USA)" + description "Jurassic Park (USA)" + rom ( name "Jurassic Park (USA).gb" size 262144 crc b350bedf sha1 66273f0b52f9ff2be875b1428add267a5f01adb0 flags verified ) ) game ( - name "Lemmings (Europe)" - description "Lemmings (Europe)" - rom ( name "Lemmings (Europe).gb" size 131072 crc 23467a35 sha1 8edb7e1a1a7289d4c393fba6d27776ab6af441ff flags verified ) + name "Jurassic Park Part 2 - The Chaos Continues (USA, Europe) (En,Fr,De,It)" + description "Jurassic Park Part 2 - The Chaos Continues (USA, Europe) (En,Fr,De,It)" + rom ( name "Jurassic Park Part 2 - The Chaos Continues (USA, Europe) (En,Fr,De,It).gb" size 262144 crc af3d2e95 sha1 b3df5f3bf73b42696261247c4c9c425a81322bb0 flags verified ) ) game ( - name "Lemmings (Japan)" - description "Lemmings (Japan)" - rom ( name "Lemmings (Japan).gb" size 131072 crc 7d5cc03a sha1 0a4fef2a6a09bb66b1b34b5294ff737530cff4e1 ) + name "Kachiuma Yosou Keiba Kizoku (Japan)" + description "Kachiuma Yosou Keiba Kizoku (Japan)" + rom ( name "Kachiuma Yosou Keiba Kizoku (Japan).gb" size 131072 crc a57e1ac1 sha1 de965fae7d1e744302e6a12656ebb8867ba9cfff ) ) game ( - name "Lemmings (USA)" - description "Lemmings (USA)" - rom ( name "Lemmings (USA).gb" size 131072 crc f2d1c19d sha1 1754fde0b1c40752a5716a291e842e38401baf08 ) + name "Kachiuma Yosou Keiba Kizoku EX '94 (Japan)" + description "Kachiuma Yosou Keiba Kizoku EX '94 (Japan)" + rom ( name "Kachiuma Yosou Keiba Kizoku EX '94 (Japan).gb" size 131072 crc d4319169 sha1 30aab6efed1cc00295d7a35ea8e9f3d809f96334 ) ) game ( - name "Lemmings 2 - The Tribes (Europe)" - description "Lemmings 2 - The Tribes (Europe)" - rom ( name "Lemmings 2 - The Tribes (Europe).gb" size 524288 crc 9800bd49 sha1 76ccf9ac82faebc7f9c4a4c8b5cd47ddea46c486 flags verified ) + name "Kachiuma Yosou Keiba Kizoku EX '95 (Japan)" + description "Kachiuma Yosou Keiba Kizoku EX '95 (Japan)" + rom ( name "Kachiuma Yosou Keiba Kizoku EX '95 (Japan).gb" size 131072 crc 9c6a4918 sha1 a368d20e2edcb8bc2745ae2c875505f45e40f4fb ) ) game ( - name "Lethal Weapon (USA, Europe)" - description "Lethal Weapon (USA, Europe)" - rom ( name "Lethal Weapon (USA, Europe).gb" size 131072 crc 1f8d207c sha1 8b4621471b376a6262fbed70c1191416ab3be915 ) + name "Kaeru no Tame ni Kane wa Naru (Japan)" + description "Kaeru no Tame ni Kane wa Naru (Japan)" + rom ( name "Kaeru no Tame ni Kane wa Naru (Japan).gb" size 524288 crc c18cd57a sha1 ce1e4a788327f3099877c88cc848e48c1fd055ab flags verified ) ) game ( - name "Lethal Weapon (USA, Europe) (Beta)" - description "Lethal Weapon (USA, Europe) (Beta)" - rom ( name "Lethal Weapon (USA, Europe) (Beta).gb" size 131072 crc d585ab23 sha1 2221ba322acffc9d7ae5400752e16d0455fda3ef ) + name "Kaijuu Ou Gojira (Japan)" + description "Kaijuu Ou Gojira (Japan)" + rom ( name "Kaijuu Ou Gojira (Japan).gb" size 262144 crc c529a96a sha1 56271383f34a7709668a982df95ebd083831e30f ) ) game ( - name "Life's Too Short (World) (Aftermarket) (Unl)" - description "Life's Too Short (World) (Aftermarket) (Unl)" - rom ( name "Life's Too Short (World) (Aftermarket) (Unl).gb" size 262144 crc 458174cc sha1 7b704cd999cbeeb9991d675e2b1e67a906fa766d ) + name "Kaisen Game - Navyblue (Japan)" + description "Kaisen Game - Navyblue (Japan)" + rom ( name "Kaisen Game - Navyblue (Japan).gb" size 65536 crc afd8c47c sha1 7fbf13dd0b5a4e7798724270a81006be9950f81a flags verified ) ) game ( - name "Linea, La (World) (Aftermarket) (Unl)" - description "Linea, La (World) (Aftermarket) (Unl)" - rom ( name "Linea, La (World) (Aftermarket) (Unl).gb" size 262144 crc c8750c01 sha1 00348fec54b5d3ebb762484bdcc015881bb9e95b ) + name "Kaisen Game - Navyblue 90 (Japan)" + description "Kaisen Game - Navyblue 90 (Japan)" + rom ( name "Kaisen Game - Navyblue 90 (Japan).gb" size 131072 crc 8cfeb2e2 sha1 60fa3fb83910f548047bbac02627c914a9057372 ) ) game ( - name "Lingo (Europe) (En,Fr,De,Nl)" - description "Lingo (Europe) (En,Fr,De,Nl)" - rom ( name "Lingo (Europe) (En,Fr,De,Nl).gb" size 131072 crc 0ef4637d sha1 4838c0baae82a9de62e70f2004d674b87caa2043 ) + name "Kaisen Game - Radarmission (Japan)" + description "Kaisen Game - Radarmission (Japan)" + rom ( name "Kaisen Game - Radarmission (Japan).gb" size 131072 crc 892fc0af sha1 64a808f582afcbed6a3ce0263f1dae6fde57f30b flags verified ) ) game ( - name "Lion King, The (USA)" - description "Lion King, The (USA)" - rom ( name "Lion King, The (USA).gb" size 524288 crc 3430d261 sha1 fbbdb1d2073bafa45943cb5f4d4aae5648120089 ) + name "Kakomunja (Japan)" + description "Kakomunja (Japan)" + rom ( name "Kakomunja (Japan).gb" size 32768 crc bef1fe2b sha1 560d174d34b32a35e302297d1667cf67c3d4e8b8 ) ) game ( - name "Lion King, The (Europe)" - description "Lion King, The (Europe)" - rom ( name "Lion King, The (Europe).gb" size 524288 crc 8fc3ca73 sha1 043d29ede2af013c000ff650231c10b3f62d7aca flags verified ) + name "Kamen Rider SD - Hashire! Mighty Riders (Japan)" + description "Kamen Rider SD - Hashire! Mighty Riders (Japan)" + rom ( name "Kamen Rider SD - Hashire! Mighty Riders (Japan).gb" size 131072 crc 71c804b3 sha1 03269715c9398659fa685830a6359caa3ffa3bbf ) ) game ( - name "Lion King, The (World) (Disney Classic Games)" - description "Lion King, The (World) (Disney Classic Games)" - rom ( name "Lion King, The (World) (Disney Classic Games).gb" size 524288 crc e435ed72 sha1 170c071db25da7a2b39dd1fb2675aceb8eeb87a1 flags verified ) + name "Kandume Monsters (Japan) (SGB Enhanced)" + description "Kandume Monsters (Japan) (SGB Enhanced)" + rom ( name "Kandume Monsters (Japan) (SGB Enhanced).gb" size 524288 crc 82e03e10 sha1 9444196c413a13cf326c18c5aa457bcac92114a5 flags verified ) ) game ( - name "Litti's Summer Sports (Germany)" - description "Litti's Summer Sports (Germany)" - rom ( name "Litti's Summer Sports (Germany).gb" size 131072 crc e681395b sha1 d958c99ebe387b1ba489f4ffda943c00345d2f4e flags verified ) + name "Karakuri Kengou Den Musashi Lord (Japan)" + description "Karakuri Kengou Den Musashi Lord (Japan)" + rom ( name "Karakuri Kengou Den Musashi Lord (Japan).gb" size 131072 crc 01aee24b sha1 abef454ba28d9a89cdeef53dc32549d7bd7d95bb flags verified ) ) game ( - name "Little Master - Raikuban no Densetsu (Japan)" - description "Little Master - Raikuban no Densetsu (Japan)" - rom ( name "Little Master - Raikuban no Densetsu (Japan).gb" size 131072 crc 31cd9670 sha1 7c83b3c6cd9571c422e66e64e522a0416fa477b2 ) + name "Karamuchou no Daijiken (Japan) (SGB Enhanced)" + description "Karamuchou no Daijiken (Japan) (SGB Enhanced)" + rom ( name "Karamuchou no Daijiken (Japan) (SGB Enhanced).gb" size 262144 crc fa7ea8a0 sha1 d831320bcec612c283afc2b6f194062cf98243dc ) ) game ( - name "Little Master 2 - Raikou no Kishi (Japan)" - description "Little Master 2 - Raikou no Kishi (Japan)" - rom ( name "Little Master 2 - Raikou no Kishi (Japan).gb" size 262144 crc 187de7f8 sha1 9cc2d0f5ec33ca5ebf382e68dd55503c75a889b5 ) + name "Kaseki Sousei Reborn (Japan) (SGB Enhanced)" + description "Kaseki Sousei Reborn (Japan) (SGB Enhanced)" + rom ( name "Kaseki Sousei Reborn (Japan) (SGB Enhanced).gb" size 524288 crc 42e8ba89 sha1 c61050451f8731e35b1b983c610041cb59509ed2 flags verified ) ) game ( - name "Little Mermaid, The (Europe)" - description "Little Mermaid, The (Europe)" - rom ( name "Little Mermaid, The (Europe).gb" size 131072 crc 00def37a sha1 62a5beea93d48445a0f16f5582fc4fc61ba9fc1b flags verified ) + name "Kaseki Sousei Reborn (Japan) (Rev 1) (SGB Enhanced)" + description "Kaseki Sousei Reborn (Japan) (Rev 1) (SGB Enhanced)" + rom ( name "Kaseki Sousei Reborn (Japan) (Rev 1) (SGB Enhanced).gb" size 524288 crc 7c94197c sha1 5759394e2e8bfd68ccf5519362572daaba003573 ) ) game ( - name "Little Mermaid, The (USA)" - description "Little Mermaid, The (USA)" - rom ( name "Little Mermaid, The (USA).gb" size 131072 crc d7c517e5 sha1 9c7d7a82d0eeb4d7b4f4b7ae35e5ebd80c93d780 ) + name "Kattobi Road (Japan)" + description "Kattobi Road (Japan)" + rom ( name "Kattobi Road (Japan).gb" size 131072 crc efbc23fc sha1 7ac064a877ecc8247dfb7213722dbd0f4be665f0 ) ) game ( - name "Little Mermaid, The (Spain) (Proto)" - description "Little Mermaid, The (Spain) (Proto)" - rom ( name "Little Mermaid, The (Spain) (Proto).gb" size 131072 crc d19cf413 sha1 463036660b2739e450a7bdea68772c6738e04a53 ) + name "Kawa no Nushi Tsuri 3 (Japan) (SGB Enhanced)" + description "Kawa no Nushi Tsuri 3 (Japan) (SGB Enhanced)" + rom ( name "Kawa no Nushi Tsuri 3 (Japan) (SGB Enhanced).gb" size 524288 crc 147e82ae sha1 5dc0c9b3fbaf75b44f368b8074c92a294e7382c4 flags verified ) ) game ( - name "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" - description "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" - rom ( name "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl).gb" size 524288 crc 9c4f03fd sha1 288cb53b4782df4409ee683e9aa11b4dd2a3a53e ) + name "Keitai Keiba Eight Special (Japan)" + description "Keitai Keiba Eight Special (Japan)" + rom ( name "Keitai Keiba Eight Special (Japan).gb" size 131072 crc 326273b7 sha1 1bbc35ddf540f2ad9937f57184add528c2811a5d ) ) game ( - name "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl)" - description "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl).gb" size 524288 crc e5988949 sha1 08d033c7ef20fd4d24d1f07b3ebb177fb9b78673 ) + name "Ken Griffey Jr. Presents Major League Baseball (USA, Europe) (SGB Enhanced)" + description "Ken Griffey Jr. Presents Major League Baseball (USA, Europe) (SGB Enhanced)" + rom ( name "Ken Griffey Jr. Presents Major League Baseball (USA, Europe) (SGB Enhanced).gb" size 524288 crc 0a9859c1 sha1 7092afa1c1ea592bcd3afd185ae17a7b1cdf6800 ) ) game ( - name "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl)" - description "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl).gb" size 524288 crc 59568248 sha1 6571db155f6f25eeeec86d28b105bf8fef156322 ) + name "Kenyuu Densetsu Yaiba (Japan)" + description "Kenyuu Densetsu Yaiba (Japan)" + rom ( name "Kenyuu Densetsu Yaiba (Japan).gb" size 262144 crc cc19768e sha1 c2b71ceee21f66f462df18233f7622d8ec95fcca ) ) game ( - name "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" - description "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" - rom ( name "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl).gb" size 524288 crc a26345b8 sha1 641110cb187657fd15ea254440e1c74ab4a88856 ) + name "Kick Attack (Japan) (Proto)" + description "Kick Attack (Japan) (Proto)" + rom ( name "Kick Attack (Japan) (Proto).gb" size 131072 crc 8cb898b2 sha1 ead2e41df9847e021f4638b269f85aed490aad31 ) ) game ( - name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" - description "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" - rom ( name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl).gb" size 131072 crc d70f1d25 sha1 02e2fb6cbc5cff05ed775c9e1cd9acc07fa2e036 ) + name "Kick Boxing, The (Japan)" + description "Kick Boxing, The (Japan)" + rom ( name "Kick Boxing, The (Japan).gb" size 262144 crc 8056344c sha1 6fb48835e5401d7b559b7e97c020bc8c356dfa1f ) ) game ( - name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" - description "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" - rom ( name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl).gb" size 131072 crc ae07c093 sha1 9f40b8719b3fdd2f7e6c59a4f616e9eb712d538d ) + name "Kid Dracula (USA, Europe)" + description "Kid Dracula (USA, Europe)" + rom ( name "Kid Dracula (USA, Europe).gb" size 262144 crc f27294b7 sha1 f186833a2ccec808210eb4ba669f08401f950e23 flags verified ) ) game ( - name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl)" - description "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl).gb" size 131072 crc 34671dc6 sha1 377d22d54e6e1fa4fcd4b4576d5886774f9f6c97 ) + name "Kid Icarus - Of Myths and Monsters (USA, Europe)" + description "Kid Icarus - Of Myths and Monsters (USA, Europe)" + rom ( name "Kid Icarus - Of Myths and Monsters (USA, Europe).gb" size 131072 crc 0c042862 sha1 465614bb236c507a5709ecab95827a8be4e2e6b8 flags verified ) ) game ( - name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl)" - description "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl).gb" size 131072 crc a8fb0d7a sha1 26803ba3413c7c52a8a58393f63472bc87ec3c6b ) + name "Kidou Keisatsu Patlabor - Nerawareta Machi 1990 (Japan)" + description "Kidou Keisatsu Patlabor - Nerawareta Machi 1990 (Japan)" + rom ( name "Kidou Keisatsu Patlabor - Nerawareta Machi 1990 (Japan).gb" size 131072 crc c7f7f0ac sha1 63508a4cc76bf1de2125b1055c631d9edfc6e11b ) ) game ( - name "Lock n' Chase ~ Lock 'n' Chase (World)" - description "Lock n' Chase ~ Lock 'n' Chase (World)" - rom ( name "Lock n' Chase ~ Lock 'n' Chase (World).gb" size 65536 crc dab91c7a sha1 643cbd566d35ce8dbe0f24627e4862c09805a04c flags verified ) + name "Kikou Keisatsu Metal Jack (Japan)" + description "Kikou Keisatsu Metal Jack (Japan)" + rom ( name "Kikou Keisatsu Metal Jack (Japan).gb" size 131072 crc f3cc5e62 sha1 8245f9f91126faad1f30502e1fc8012cc26c43c1 ) ) game ( - name "Lolo no Daibouken (Japan)" - description "Lolo no Daibouken (Japan)" - rom ( name "Lolo no Daibouken (Japan).gb" size 131072 crc d6185941 sha1 2f4a4215e3c95f7f3646ad678c5cd191fce02515 ) + name "Killer Instinct (USA, Europe) (SGB Enhanced)" + description "Killer Instinct (USA, Europe) (SGB Enhanced)" + rom ( name "Killer Instinct (USA, Europe) (SGB Enhanced).gb" size 524288 crc ac793b54 sha1 65ae38588abc0e699b244b0854f698ddf72c7b46 flags verified ) ) game ( - name "Long Xing Tianxia (Taiwan) (Unl)" - description "Long Xing Tianxia (Taiwan) (Unl)" - rom ( name "Long Xing Tianxia (Taiwan) (Unl).gb" size 131072 crc c2c172c3 sha1 4da29dd4530ea3c26ea738427828d2e4903c99f8 ) + name "King James Bible (USA) (Unl)" + description "King James Bible (USA) (Unl)" + rom ( name "King James Bible (USA) (Unl).gb" size 1048576 crc 23679231 sha1 6362fde9dcb08242a64f2fbea33de93d1776a6e0 ) ) game ( - name "Looney Tunes (USA, Europe)" - description "Looney Tunes (USA, Europe)" - rom ( name "Looney Tunes (USA, Europe).gb" size 131072 crc a662a8ef sha1 97d96f8ec66acba996c7bec0a713c84075f22680 flags verified ) + name "King of Fighters '95, The (Europe) (SGB Enhanced)" + description "King of Fighters '95, The (Europe) (SGB Enhanced)" + rom ( name "King of Fighters '95, The (Europe) (SGB Enhanced).gb" size 524288 crc a3e9b148 sha1 27eeb37f7be07381b6e4e01b5ae0d32f2ec209c0 flags verified ) ) game ( - name "Looney Tunes - Bugs Bunny to Yukai na Nakama-tachi (Japan)" - description "Looney Tunes - Bugs Bunny to Yukai na Nakama-tachi (Japan)" - rom ( name "Looney Tunes - Bugs Bunny to Yukai na Nakama-tachi (Japan).gb" size 131072 crc 40e47da3 sha1 ed26fd9d4011c286e2e6109967cad2564c17900b ) + name "King of Fighters '95, The (USA) (SGB Enhanced)" + description "King of Fighters '95, The (USA) (SGB Enhanced)" + rom ( name "King of Fighters '95, The (USA) (SGB Enhanced).gb" size 524288 crc 1ff84e8c sha1 59c11dd527d47b24323f84fb8a1bb3d06a531f32 ) ) game ( - name "Looney Tunes 2 - Tasmanian Devil in Island Chase (USA, Europe)" - description "Looney Tunes 2 - Tasmanian Devil in Island Chase (USA, Europe)" - rom ( name "Looney Tunes 2 - Tasmanian Devil in Island Chase (USA, Europe).gb" size 262144 crc 22d07cf6 sha1 d36d731bd2644ee84c7cf77a2c1d319851e4d6bb flags verified ) + name "King of Fighters, The - Heat of Battle (Europe) (SGB Enhanced)" + description "King of Fighters, The - Heat of Battle (Europe) (SGB Enhanced)" + rom ( name "King of Fighters, The - Heat of Battle (Europe) (SGB Enhanced).gb" size 524288 crc 4d2d8bc3 sha1 1b5ac034b1333b3340fbdc5c128bc12abd310043 ) ) game ( - name "Looney Tunes Series - Daffy Duck (Japan) (SGB Enhanced)" - description "Looney Tunes Series - Daffy Duck (Japan) (SGB Enhanced)" - rom ( name "Looney Tunes Series - Daffy Duck (Japan) (SGB Enhanced).gb" size 262144 crc 798d9489 sha1 65f063906680e65d8786e698bd51674268d7ae68 ) + name "King of the Zoo (Europe)" + description "King of the Zoo (Europe)" + rom ( name "King of the Zoo (Europe).gb" size 65536 crc d2d648c4 sha1 683fcb45cf98f8d84c221ffb180b06bf81c1cf74 flags verified ) ) game ( - name "Loopz (World)" - description "Loopz (World)" - rom ( name "Loopz (World).gb" size 32768 crc 531a3e16 sha1 dd2ddac2310409287299c287f1959196e0b4d14e flags verified ) + name "Kingdom Crusade (USA)" + description "Kingdom Crusade (USA)" + rom ( name "Kingdom Crusade (USA).gb" size 131072 crc 920202dc sha1 ceca61f9ee1e549ca5b70bf620159cf2c2290423 ) ) game ( - name "Loopz (World) (Beta)" - description "Loopz (World) (Beta)" - rom ( name "Loopz (World) (Beta).gb" size 32768 crc 15e28642 sha1 01f87439294a2a06604ae0fd41df203713460510 ) + name "Kingyo Chuuihou! - Wapiko no Wakuwaku Stamp Rally! (Japan)" + description "Kingyo Chuuihou! - Wapiko no Wakuwaku Stamp Rally! (Japan)" + rom ( name "Kingyo Chuuihou! - Wapiko no Wakuwaku Stamp Rally! (Japan).gb" size 131072 crc e69a6f0a sha1 baf5c1019c9a3752543036dca0925d370aa20d45 ) ) game ( - name "Lost World, The - Jurassic Park (USA, Europe) (SGB Enhanced)" - description "Lost World, The - Jurassic Park (USA, Europe) (SGB Enhanced)" - rom ( name "Lost World, The - Jurassic Park (USA, Europe) (SGB Enhanced).gb" size 524288 crc 391f532a sha1 68bf63ba6a6c9f3a71a933d6f00e5212c66dcd03 flags verified ) + name "Kingyo Chuuihou! 2 - Gyopi-chan o Sagase! (Japan)" + description "Kingyo Chuuihou! 2 - Gyopi-chan o Sagase! (Japan)" + rom ( name "Kingyo Chuuihou! 2 - Gyopi-chan o Sagase! (Japan).gb" size 131072 crc f3ccadc3 sha1 0674abafb9de841d658d249d06a499c14484f72c ) ) game ( - name "Lucky Luke (Europe) (En,Fr,De,Es)" - description "Lucky Luke (Europe) (En,Fr,De,Es)" - rom ( name "Lucky Luke (Europe) (En,Fr,De,Es).gb" size 262144 crc 538e0591 sha1 7d67aa8b17d7208d8ed234bd70b4def9582b362d ) + name "Kinin Koumaroku Oni (Japan)" + description "Kinin Koumaroku Oni (Japan)" + rom ( name "Kinin Koumaroku Oni (Japan).gb" size 131072 crc b7f48649 sha1 7c6c71b52c62b814945ee102054a7a3210b1ecf3 flags verified ) ) game ( - name "Lucky Monkey (Japan)" - description "Lucky Monkey (Japan)" - rom ( name "Lucky Monkey (Japan).gb" size 65536 crc a2234eb1 sha1 ab8654013dc574538b815d8b15aa3cae66afc809 ) + name "Kinin Koumaroku Oni (Japan) (Rev 1)" + description "Kinin Koumaroku Oni (Japan) (Rev 1)" + rom ( name "Kinin Koumaroku Oni (Japan) (Rev 1).gb" size 131072 crc aaf6366c sha1 298965bc2b99e49339618914114abfd0962560c1 flags verified ) ) game ( - name "Lucle (Japan, Europe) (En)" - description "Lucle (Japan, Europe) (En)" - rom ( name "Lucle (Japan, Europe) (En).gb" size 524288 crc a3d5c8d7 sha1 2fef16fac95ec4ffd252e9974eccfce538e5f797 ) + name "Kinnikuman - The Dream Match (Japan)" + description "Kinnikuman - The Dream Match (Japan)" + rom ( name "Kinnikuman - The Dream Match (Japan).gb" size 131072 crc 48c2cd38 sha1 cc55e811024f60c0097efdff5962d85830626ab0 ) ) game ( - name "Lucy and the Gem Dungeon (World) (Aftermarket) (Unl)" - description "Lucy and the Gem Dungeon (World) (Aftermarket) (Unl)" - rom ( name "Lucy and the Gem Dungeon (World) (Aftermarket) (Unl).gb" size 524288 crc 1a5106a2 sha1 f56c1b324b8c1e17da86e40c5e9a887ec19b0c80 ) + name "Kirby no Block Ball (Japan) (SGB Enhanced)" + description "Kirby no Block Ball (Japan) (SGB Enhanced)" + rom ( name "Kirby no Block Ball (Japan) (SGB Enhanced).gb" size 524288 crc df3bbcd7 sha1 3fecc964d2c13ad98abac1df49f05c488833ef5a flags verified ) ) game ( - name "Lunar Chase (USA) (Proto 1)" - description "Lunar Chase (USA) (Proto 1)" - rom ( name "Lunar Chase (USA) (Proto 1).gb" size 245760 crc cd555712 sha1 b1c5b60b82aaa0b824f7bf67fc8f111377ccfb6a ) + name "Kirby no Kirakira Kids (Japan) (SGB Enhanced)" + description "Kirby no Kirakira Kids (Japan) (SGB Enhanced)" + rom ( name "Kirby no Kirakira Kids (Japan) (SGB Enhanced).gb" size 262144 crc 47f42f42 sha1 2c46c42be76eca134e188814345afa390e298811 flags verified ) ) game ( - name "Lunar Chase (USA) (Proto 2)" - description "Lunar Chase (USA) (Proto 2)" - rom ( name "Lunar Chase (USA) (Proto 2).gb" size 262144 crc 67044675 sha1 f5e9ecd2f0d20b0d8d452a852c700a5223bdcb73 ) + name "Kirby no Pinball (Japan)" + description "Kirby no Pinball (Japan)" + rom ( name "Kirby no Pinball (Japan).gb" size 262144 crc 8b44fb7d sha1 678ca586f5a2e2fc894fb8e9f7b9efa54fabba44 flags verified ) ) game ( - name "Lunar Lander (Japan)" - description "Lunar Lander (Japan)" - rom ( name "Lunar Lander (Japan).gb" size 131072 crc 030d2054 sha1 05266f727879963a23dbbcd8c87c68597607f3b8 ) + name "Kirby's Block Ball (USA, Europe) (SGB Enhanced)" + description "Kirby's Block Ball (USA, Europe) (SGB Enhanced)" + rom ( name "Kirby's Block Ball (USA, Europe) (SGB Enhanced).gb" size 524288 crc 7ad90b4b sha1 a790d96526972d7ceb026ca27ae41ff475ccb2c5 flags verified ) ) game ( - name "Mach Go Go Go (Japan) (SGB Enhanced)" - description "Mach Go Go Go (Japan) (SGB Enhanced)" - rom ( name "Mach Go Go Go (Japan) (SGB Enhanced).gb" size 262144 crc 016d230b sha1 baea8b49ce2402c5c094ddae0320a382c0d95d86 ) + name "Kirby's Dream Land (USA, Europe)" + description "Kirby's Dream Land (USA, Europe)" + rom ( name "Kirby's Dream Land (USA, Europe).gb" size 262144 crc 40f25740 sha1 90979baa1d0e24b41b5c304c5ddaf77450692d5a flags verified ) ) game ( - name "Machine, The (World) (Aftermarket) (Unl)" - description "Machine, The (World) (Aftermarket) (Unl)" - rom ( name "Machine, The (World) (Aftermarket) (Unl).gb" size 2097152 crc b06036a9 sha1 50c5d1eb7c8946ac2d7e2c566b1ea4a9b0d58e90 ) + name "Kirby's Dream Land 2 (USA, Europe) (SGB Enhanced)" + description "Kirby's Dream Land 2 (USA, Europe) (SGB Enhanced)" + rom ( name "Kirby's Dream Land 2 (USA, Europe) (SGB Enhanced).gb" size 524288 crc 8dc07c35 sha1 8a2898ffa17e25f43793f40c88421d840d372d3c flags verified ) ) game ( - name "Mad Monster (World) (Aftermarket) (Unl)" - description "Mad Monster (World) (Aftermarket) (Unl)" - rom ( name "Mad Monster (World) (Aftermarket) (Unl).gb" size 524288 crc c3fd371c sha1 9f4bea7ca7d26080110f54392314c60761236638 ) + name "Kirby's Pinball Land (USA, Europe)" + description "Kirby's Pinball Land (USA, Europe)" + rom ( name "Kirby's Pinball Land (USA, Europe).gb" size 262144 crc 31cb6526 sha1 06efdb138ff56cd9522dece44adadd3fae169c76 flags verified ) ) game ( - name "Madden 95 (USA, Europe) (SGB Enhanced)" - description "Madden 95 (USA, Europe) (SGB Enhanced)" - rom ( name "Madden 95 (USA, Europe) (SGB Enhanced).gb" size 524288 crc d2585bbb sha1 b41a14394bbd890e341bf5d27f297cb5e906fd60 ) + name "Kirby's Star Stacker (USA, Europe) (SGB Enhanced)" + description "Kirby's Star Stacker (USA, Europe) (SGB Enhanced)" + rom ( name "Kirby's Star Stacker (USA, Europe) (SGB Enhanced).gb" size 262144 crc 91300898 sha1 3999993d31e457bb279efac3e4a65fe4967ba861 flags verified ) ) game ( - name "Madden 96 (USA, Europe) (SGB Enhanced)" - description "Madden 96 (USA, Europe) (SGB Enhanced)" - rom ( name "Madden 96 (USA, Europe) (SGB Enhanced).gb" size 524288 crc fd9dc1ad sha1 dd67d34b7801f31063df522c45349823713fe99b ) + name "Kitchen Panic (Japan)" + description "Kitchen Panic (Japan)" + rom ( name "Kitchen Panic (Japan).gb" size 131072 crc 909937cb sha1 0e1b2f25c29ebabb1bc67737f3e47b263579423b ) ) game ( - name "Madden 97 (USA) (SGB Enhanced)" - description "Madden 97 (USA) (SGB Enhanced)" - rom ( name "Madden 97 (USA) (SGB Enhanced).gb" size 524288 crc 88a837a2 sha1 e1d92b6afdd7dc2254c895ad8a9a066262fb214b ) + name "Kiteretsu Daihyakka - Bouken Ooedo Juraki (Japan)" + description "Kiteretsu Daihyakka - Bouken Ooedo Juraki (Japan)" + rom ( name "Kiteretsu Daihyakka - Bouken Ooedo Juraki (Japan).gb" size 262144 crc d53548b0 sha1 58d54cdc21c73661ccc0be22e8a40cef84861680 ) ) game ( - name "Maerchen Club (Japan)" - description "Maerchen Club (Japan)" - rom ( name "Maerchen Club (Japan).gb" size 131072 crc cdfd660a sha1 dcb42287ffdbc352cd954b28a797fcd3547730de ) + name "Kizuchi da Quiz da Gen-san da! (Japan)" + description "Kizuchi da Quiz da Gen-san da! (Japan)" + rom ( name "Kizuchi da Quiz da Gen-san da! (Japan).gb" size 262144 crc 74a52399 sha1 0729da81a62a1c30e34f5c3157de16fc014c52fe ) ) game ( - name "Magic Knight Rayearth (Japan) (SGB Enhanced)" - description "Magic Knight Rayearth (Japan) (SGB Enhanced)" - rom ( name "Magic Knight Rayearth (Japan) (SGB Enhanced).gb" size 262144 crc 94838a81 sha1 4f77031946e62772a241a9b5b046d7fcf6a28ea8 ) + name "Klax (Japan) (Hudson Soft)" + description "Klax (Japan) (Hudson Soft)" + rom ( name "Klax (Japan) (Hudson Soft).gb" size 32768 crc b4955889 sha1 0bc9af06d21b01bbecbe616c57e9a22f51da3eff ) ) game ( - name "Magic Knight Rayearth 2nd. - The Missing Colors (Japan) (SGB Enhanced)" - description "Magic Knight Rayearth 2nd. - The Missing Colors (Japan) (SGB Enhanced)" - rom ( name "Magic Knight Rayearth 2nd. - The Missing Colors (Japan) (SGB Enhanced).gb" size 262144 crc 00202dfa sha1 afe76c2d6f796813f1803e8c542107bf0827f966 ) + name "Klax (USA) (Mindscape)" + description "Klax (USA) (Mindscape)" + rom ( name "Klax (USA) (Mindscape).gb" size 65536 crc 72660774 sha1 85f6b02815e7131fdd96f3802eb0a17d93277e75 ) ) game ( - name "Magical Taruruuto-kun (Japan)" - description "Magical Taruruuto-kun (Japan)" - rom ( name "Magical Taruruuto-kun (Japan).gb" size 131072 crc 9c4f54f1 sha1 0b7723d1761a61dcf42fc93f134b59f2232d4c37 ) + name "Klustar (Europe) (Proto)" + description "Klustar (Europe) (Proto)" + rom ( name "Klustar (Europe) (Proto).gb" size 32768 crc 279dd6cc sha1 6a5e51bfb4d989fb31f5ed6572d08e5a8b703a8d ) ) game ( - name "Magical Taruruuto-kun 2 - Raibaa Zone Panic!! (Japan)" - description "Magical Taruruuto-kun 2 - Raibaa Zone Panic!! (Japan)" - rom ( name "Magical Taruruuto-kun 2 - Raibaa Zone Panic!! (Japan).gb" size 131072 crc 0aad5217 sha1 3be6c6b8cec80a0fe0f6edbbe40496f4d077c750 ) + name "Knight Quest (Japan)" + description "Knight Quest (Japan)" + rom ( name "Knight Quest (Japan).gb" size 131072 crc c6f24d2f sha1 717c65392a5ed9f19fce995be08685df5fa0978b ) ) game ( - name "Magipanels (World) (2022-02-09) (Demo) (Aftermarket) (Unl)" - description "Magipanels (World) (2022-02-09) (Demo) (Aftermarket) (Unl)" - rom ( name "Magipanels (World) (2022-02-09) (Demo) (Aftermarket) (Unl).gb" size 131072 crc 76fcbc30 sha1 7a759372bd013dcdb59c9131a2908085fc04d648 ) + name "Knight Quest (USA)" + description "Knight Quest (USA)" + rom ( name "Knight Quest (USA).gb" size 131072 crc df50f477 sha1 99eb275df25baa6d1b53f5518e93c5f5913a2b6a flags verified ) ) game ( - name "Magipanels (World) (Aftermarket) (Unl)" - description "Magipanels (World) (Aftermarket) (Unl)" - rom ( name "Magipanels (World) (Aftermarket) (Unl).gb" size 131072 crc 0b66561b sha1 c9513f6769098f2185f632f87386788f0f0b6ad8 ) + name "Koi wa Kakehiki (Japan)" + description "Koi wa Kakehiki (Japan)" + rom ( name "Koi wa Kakehiki (Japan).gb" size 32768 crc f3e1e652 sha1 d6a59fc334f93ba0d17faa66542eb74dcc3e536b ) ) game ( - name "Magnetic Soccer (Europe)" - description "Magnetic Soccer (Europe)" - rom ( name "Magnetic Soccer (Europe).gb" size 131072 crc 9c318c64 sha1 da24ba642fc6ea91d0fb395481840cd9060a6de4 flags verified ) + name "Konami GB Collection Vol.1 (Japan) (SGB Enhanced)" + description "Konami GB Collection Vol.1 (Japan) (SGB Enhanced)" + rom ( name "Konami GB Collection Vol.1 (Japan) (SGB Enhanced).gb" size 524288 crc 992cd78f sha1 dfb86b1b2db29a7086d60dc143374ef27b130580 ) ) game ( - name "Mahoujin GuruGuru - Yuusha to Kukuri no Daibouken (Japan) (SGB Enhanced)" - description "Mahoujin GuruGuru - Yuusha to Kukuri no Daibouken (Japan) (SGB Enhanced)" - rom ( name "Mahoujin GuruGuru - Yuusha to Kukuri no Daibouken (Japan) (SGB Enhanced).gb" size 262144 crc 2d439d0d sha1 10a55c546c68cb117cc47d49304f807a7bb63687 ) + name "Konami GB Collection Vol.2 (Japan) (SGB Enhanced)" + description "Konami GB Collection Vol.2 (Japan) (SGB Enhanced)" + rom ( name "Konami GB Collection Vol.2 (Japan) (SGB Enhanced).gb" size 524288 crc c3b318cd sha1 5753310cb9fbe44efc2b27ce488cd069ef243199 ) ) game ( - name "Makai Toushi Sa-Ga (Japan)" - description "Makai Toushi Sa-Ga (Japan)" - rom ( name "Makai Toushi Sa-Ga (Japan).gb" size 131072 crc 131b09f2 sha1 7a8f770a34207fee324431c47836f1ab317863f9 flags verified ) + name "Konami GB Collection Vol.3 (Japan) (SGB Enhanced)" + description "Konami GB Collection Vol.3 (Japan) (SGB Enhanced)" + rom ( name "Konami GB Collection Vol.3 (Japan) (SGB Enhanced).gb" size 524288 crc 1de9caf9 sha1 db9f1192df7e186ea498c4f576fc016fdc339539 ) ) game ( - name "Makai Toushi Sa-Ga (Japan) (Rev 1)" - description "Makai Toushi Sa-Ga (Japan) (Rev 1)" - rom ( name "Makai Toushi Sa-Ga (Japan) (Rev 1).gb" size 131072 crc 1953820f sha1 cbf480bc92bd98bae4fb79294b604d341fe58cbe flags verified ) + name "Konami GB Collection Vol.4 (Japan) (SGB Enhanced)" + description "Konami GB Collection Vol.4 (Japan) (SGB Enhanced)" + rom ( name "Konami GB Collection Vol.4 (Japan) (SGB Enhanced).gb" size 524288 crc 3a43ea33 sha1 c33ba418386b34b466b5dd28159ea76ca2db12f8 ) ) game ( - name "Makai Toushi Sa-Ga (World) (Ja) (Rev 1) (Collection of SaGa)" - description "Makai Toushi Sa-Ga (World) (Ja) (Rev 1) (Collection of SaGa)" - rom ( name "Makai Toushi Sa-Ga (World) (Ja) (Rev 1) (Collection of SaGa).gb" size 131072 crc 0006612d sha1 3ce39646bffe38a9c8fd4913f0e950bae061d094 ) + name "Konami Golf (Europe)" + description "Konami Golf (Europe)" + rom ( name "Konami Golf (Europe).gb" size 131072 crc 0fdc9fb1 sha1 59d13714f8477db50cf164254480dd25959ecd23 ) ) game ( - name "Makaimura Gaiden - The Demon Darkness (Japan)" - description "Makaimura Gaiden - The Demon Darkness (Japan)" - rom ( name "Makaimura Gaiden - The Demon Darkness (Japan).gb" size 262144 crc cfa358de sha1 961d05e91288d7ad1f2e6a1c996059d7ab96fe98 ) + name "Konamic Basket (Japan)" + description "Konamic Basket (Japan)" + rom ( name "Konamic Basket (Japan).gb" size 131072 crc 8e367457 sha1 10372339db6d65210f7d04591d92c1889cef5133 ) ) game ( - name "Make Way (World) (Aftermarket) (Unl)" - description "Make Way (World) (Aftermarket) (Unl)" - rom ( name "Make Way (World) (Aftermarket) (Unl).gb" size 1048576 crc edeee5a8 sha1 19fd02e9318ed81ec968a2fca31ea0c3d8d94a7b ) + name "Konamic Golf (Japan)" + description "Konamic Golf (Japan)" + rom ( name "Konamic Golf (Japan).gb" size 131072 crc c16d4db2 sha1 78d014f8feb88cc8b509172c1a6fa48aa5eed67c ) ) game ( - name "Malibu Beach Volleyball (USA)" - description "Malibu Beach Volleyball (USA)" - rom ( name "Malibu Beach Volleyball (USA).gb" size 65536 crc dfa5da12 sha1 f7fed41b98fc8bcdc8f72c470e20b8bab150ca33 ) + name "Konamic Ice Hockey (Japan)" + description "Konamic Ice Hockey (Japan)" + rom ( name "Konamic Ice Hockey (Japan).gb" size 131072 crc d14dee07 sha1 e7feccc615f71ebd7c3d61c3406ed63a894758f0 ) ) game ( - name "Mani 4 in 1 - Bubble Bobble + Elevator Action + Chase H.Q. + Sagaia (China) (En)" - description "Mani 4 in 1 - Bubble Bobble + Elevator Action + Chase H.Q. + Sagaia (China) (En)" - rom ( name "Mani 4 in 1 - Bubble Bobble + Elevator Action + Chase H.Q. + Sagaia (China) (En).gb" size 524288 crc 5bfc3ef5 sha1 c0639d6c993690022200f2fa4b3094249b9335c0 flags verified ) + name "Konamic Sports in Barcelona (Japan)" + description "Konamic Sports in Barcelona (Japan)" + rom ( name "Konamic Sports in Barcelona (Japan).gb" size 131072 crc 5721e7d6 sha1 4d3b7d1a615c6783e741812a1b1de4467ed14eef ) ) game ( - name "Mani 4 in 1 - Genki Bakuhatsu Gambaruger + Zettai Muteki Raijin-Oh + Zoids Densetsu + Miracle Adventure of Esparks - Ushinawareta Seiseki Perivron (China) (Ja)" - description "Mani 4 in 1 - Genki Bakuhatsu Gambaruger + Zettai Muteki Raijin-Oh + Zoids Densetsu + Miracle Adventure of Esparks - Ushinawareta Seiseki Perivron (China) (Ja)" - rom ( name "Mani 4 in 1 - Genki Bakuhatsu Gambaruger + Zettai Muteki Raijin-Oh + Zoids Densetsu + Miracle Adventure of Esparks - Ushinawareta Seiseki Perivron (China) (Ja).gb" size 524288 crc c373ac09 sha1 0030295574e4c518ff5cdf20febf6b6737426468 flags verified ) + name "Konchuu Hakase (Japan) (SGB Enhanced)" + description "Konchuu Hakase (Japan) (SGB Enhanced)" + rom ( name "Konchuu Hakase (Japan) (SGB Enhanced).gb" size 524288 crc f6b3e291 sha1 ac792793b43cc8fae098df23e6aeb845f98199cd ) ) game ( - name "Mani 4 in 1 - R-Type II + Saigo no Nindou + Ganso!! Yancha Maru + Shisenshou - Match-Mania (China) (Ja)" - description "Mani 4 in 1 - R-Type II + Saigo no Nindou + Ganso!! Yancha Maru + Shisenshou - Match-Mania (China) (Ja)" - rom ( name "Mani 4 in 1 - R-Type II + Saigo no Nindou + Ganso!! Yancha Maru + Shisenshou - Match-Mania (China) (Ja).gb" size 524288 crc cb48b6d0 sha1 1c79eb31a6754b4e96d33a182d36833208dc7177 ) + name "Konchuu Hakase (Japan) (Rev 1) (SGB Enhanced)" + description "Konchuu Hakase (Japan) (Rev 1) (SGB Enhanced)" + rom ( name "Konchuu Hakase (Japan) (Rev 1) (SGB Enhanced).gb" size 524288 crc 05753790 sha1 3e8e47b36a2171ad93d0e21fe5c22feff17c6d88 ) ) game ( - name "Mani 4 in 1 - Takahashi Meijin no Bouken-jima II + GB Genjin + Bomber Boy + Milon no Meikyuu Kumikyoku (China) (Ja)" - description "Mani 4 in 1 - Takahashi Meijin no Bouken-jima II + GB Genjin + Bomber Boy + Milon no Meikyuu Kumikyoku (China) (Ja)" - rom ( name "Mani 4 in 1 - Takahashi Meijin no Bouken-jima II + GB Genjin + Bomber Boy + Milon no Meikyuu Kumikyoku (China) (Ja).gb" size 1048576 crc 950773ee sha1 af4706da224d794668f3b2c68aea7b3c16452d83 ) + name "Koro Dice (Japan)" + description "Koro Dice (Japan)" + rom ( name "Koro Dice (Japan).gb" size 32768 crc 39608c31 sha1 17d51f459b854d1911c48418ff1592b11981cc84 ) ) game ( - name "Mani 4 in 1 - Tetris + Alleyway + Yakuman + Tennis (China) (Ja)" - description "Mani 4 in 1 - Tetris + Alleyway + Yakuman + Tennis (China) (Ja)" - rom ( name "Mani 4 in 1 - Tetris + Alleyway + Yakuman + Tennis (China) (Ja).gb" size 262144 crc 0c38a775 sha1 dfe46e066c599c17e684ddda3fd74c5357910630 flags verified ) + name "Koukiatsu Boy (Japan) (SGB Enhanced)" + description "Koukiatsu Boy (Japan) (SGB Enhanced)" + rom ( name "Koukiatsu Boy (Japan) (SGB Enhanced).gb" size 524288 crc 53ff8041 sha1 f7f5b71a8d3b393b0507eee75fbdaea7006f945f ) ) game ( - name "Marble Madness (USA, Europe)" - description "Marble Madness (USA, Europe)" - rom ( name "Marble Madness (USA, Europe).gb" size 262144 crc b9725e66 sha1 bf2a73f7adf200410038350c2c754a943d841681 flags verified ) + name "Krusty World (Japan)" + description "Krusty World (Japan)" + rom ( name "Krusty World (Japan).gb" size 131072 crc 01fbc9f6 sha1 ba64940bce70de459fff84a16222481344749558 ) ) game ( - name "Mario & Yoshi (Europe)" - description "Mario & Yoshi (Europe)" - rom ( name "Mario & Yoshi (Europe).gb" size 65536 crc 4627d88b sha1 9bf642eabdb51625d1ef1ac470666ec8f5f10f77 flags verified ) + name "Krusty's Fun House (USA, Europe)" + description "Krusty's Fun House (USA, Europe)" + rom ( name "Krusty's Fun House (USA, Europe).gb" size 131072 crc 1cedb141 sha1 e61039c52c053a8ae1bdfffa3f694934569bb570 flags verified ) ) game ( - name "Mario no Picross (Japan) (SGB Enhanced)" - description "Mario no Picross (Japan) (SGB Enhanced)" - rom ( name "Mario no Picross (Japan) (SGB Enhanced).gb" size 262144 crc 17533700 sha1 6b72cbff3e224299eff6f79e0110a477b8f840c2 flags verified ) + name "Kuma no Puutarou - Takara Sagashi da Ooiri Game Battle! (Japan) (SGB Enhanced)" + description "Kuma no Puutarou - Takara Sagashi da Ooiri Game Battle! (Japan) (SGB Enhanced)" + rom ( name "Kuma no Puutarou - Takara Sagashi da Ooiri Game Battle! (Japan) (SGB Enhanced).gb" size 262144 crc f01d0b87 sha1 b986ce8e1a6a4a1b22e0db5bf03b8b028cce9057 ) ) game ( - name "Mario's Picross (USA, Europe) (SGB Enhanced)" - description "Mario's Picross (USA, Europe) (SGB Enhanced)" - rom ( name "Mario's Picross (USA, Europe) (SGB Enhanced).gb" size 262144 crc f2d652ad sha1 9712f37171b8a0cdc99a60170ea7b2aed161195e flags verified ) + name "Kung-Fu Master (USA, Europe)" + description "Kung-Fu Master (USA, Europe)" + rom ( name "Kung-Fu Master (USA, Europe).gb" size 65536 crc 3340e600 sha1 b0bb485e2b57793da9f153db074c13a060a1e0d4 flags verified ) ) game ( - name "Marmalade Boy (Japan) (SGB Enhanced)" - description "Marmalade Boy (Japan) (SGB Enhanced)" - rom ( name "Marmalade Boy (Japan) (SGB Enhanced).gb" size 262144 crc 0f3ff7da sha1 60125690b7a354ff8e72f497c8a88ecd691e7e4b ) + name "Kung-Fu Master (USA, Europe) (Beta)" + description "Kung-Fu Master (USA, Europe) (Beta)" + rom ( name "Kung-Fu Master (USA, Europe) (Beta).gb" size 65536 crc e0c33c1a sha1 1ce6301d56294b71068514c666ad2157551134e7 ) ) game ( - name "Marron Helps a Friend (World) (Aftermarket) (Unl)" - description "Marron Helps a Friend (World) (Aftermarket) (Unl)" - rom ( name "Marron Helps a Friend (World) (Aftermarket) (Unl).gb" size 1048576 crc 08a3a987 sha1 adcd56fa3eba93edd20be25ae5cb349070cd0323 flags verified ) + name "Kuusou Kagaku Sekai Gulliver Boy - Kuusou Kagaku Puzzle Purittopon!! (Japan) (SGB Enhanced)" + description "Kuusou Kagaku Sekai Gulliver Boy - Kuusou Kagaku Puzzle Purittopon!! (Japan) (SGB Enhanced)" + rom ( name "Kuusou Kagaku Sekai Gulliver Boy - Kuusou Kagaku Puzzle Purittopon!! (Japan) (SGB Enhanced).gb" size 262144 crc fb291e78 sha1 1ba1abc4db088cfc57bc733634c5b02308d132f4 ) ) game ( - name "Maru's Mission (USA)" - description "Maru's Mission (USA)" - rom ( name "Maru's Mission (USA).gb" size 131072 crc 6e4f1eb3 sha1 91446b1cc6dbf3b98b81f13e35ffe7bfaaa027aa flags verified ) + name "Kwirk - He's A-maze-ing! (USA, Europe)" + description "Kwirk - He's A-maze-ing! (USA, Europe)" + rom ( name "Kwirk - He's A-maze-ing! (USA, Europe).gb" size 32768 crc 21c98af2 sha1 6ef48e912a47c774048456aa870c7e810fd45685 flags verified ) ) game ( - name "Marzipan Beef Reverser (World) (v2.0) (Aftermarket) (Unl)" - description "Marzipan Beef Reverser (World) (v2.0) (Aftermarket) (Unl)" - rom ( name "Marzipan Beef Reverser (World) (v2.0) (Aftermarket) (Unl).gb" size 262144 crc dccaeb60 sha1 1e4fc83bfe9c9063975a3862770e4afee3f947a4 ) + name "Kyoro-chan Land (Japan)" + description "Kyoro-chan Land (Japan)" + rom ( name "Kyoro-chan Land (Japan).gb" size 32768 crc e158d4db sha1 67b9b01fbb58c69aad716bcc0409a9dba3bd92b5 ) ) game ( - name "Marzipan Beef Reverser (World) (Aftermarket) (Unl)" - description "Marzipan Beef Reverser (World) (Aftermarket) (Unl)" - rom ( name "Marzipan Beef Reverser (World) (Aftermarket) (Unl).gb" size 131072 crc 4c3e0d15 sha1 6cbfb0390ee555718b5b0c3a5437b7d3d4ee0008 ) + name "Lamborghini American Challenge (USA, Europe)" + description "Lamborghini American Challenge (USA, Europe)" + rom ( name "Lamborghini American Challenge (USA, Europe).gb" size 131072 crc 675e1309 sha1 82a6808f0c4cb1e05a4c2a38a39b0c37874b4211 flags verified ) ) game ( - name "Masakari Densetsu - Kintarou Action Hen (Japan)" - description "Masakari Densetsu - Kintarou Action Hen (Japan)" - rom ( name "Masakari Densetsu - Kintarou Action Hen (Japan).gb" size 262144 crc 7cb70d3d sha1 ec23af3d5590b75b2a3b33708a4fe5cffe495a1f flags verified ) + name "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl)" + description "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl)" + rom ( name "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl).gb" size 131072 crc 989a5fe0 sha1 00f139a63c0dd6cdaeac77c6747772ac394c0a79 ) ) game ( - name "Masakari Densetsu - Kintarou RPG Hen (Japan) (SGB Enhanced)" - description "Masakari Densetsu - Kintarou RPG Hen (Japan) (SGB Enhanced)" - rom ( name "Masakari Densetsu - Kintarou RPG Hen (Japan) (SGB Enhanced).gb" size 524288 crc d8bab8e0 sha1 a9bcb90df5b19a372ceed81c614bb7eb295ec74c ) + name "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl) (Alt)" + description "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl) (Alt)" + rom ( name "Lasama Chuanqi - Story of Lasama (Taiwan) (Unl) (Alt).gb" size 65536 crc 997fa9eb sha1 ded742d50ed553ffea524d7deec628c354c74cc4 ) ) game ( - name "Master Karateka (Japan)" - description "Master Karateka (Japan)" - rom ( name "Master Karateka (Japan).gb" size 32768 crc 4c0fb33e sha1 1ffea01d8d91f026ce6677631bcb10991092ff13 ) + name "Last Action Hero (USA, Europe)" + description "Last Action Hero (USA, Europe)" + rom ( name "Last Action Hero (USA, Europe).gb" size 131072 crc 10499af6 sha1 010eb2cbab987ec242cd0792c789a07c00106f48 ) ) game ( - name "Matchless 23 in 1 A (Taiwan) (Unl)" - description "Matchless 23 in 1 A (Taiwan) (Unl)" - rom ( name "Matchless 23 in 1 A (Taiwan) (Unl).gb" size 2097152 crc 7ef05854 sha1 57ca49fdb23aa65bf7200c2f9690a216f5518f4d ) + name "Lawnmower Man, The (USA) (Proto 1) (1993-10-11) (Not For Resale)" + description "Lawnmower Man, The (USA) (Proto 1) (1993-10-11) (Not For Resale)" + rom ( name "Lawnmower Man, The (USA) (Proto 1) (1993-10-11) (Not For Resale).gb" size 131072 crc 1cac0775 sha1 589eedd3919dd29cbdf6fd9c2fa6b4f1c258fc97 ) ) game ( - name "Matthias Sammer Soccer (Germany) (SGB Enhanced)" - description "Matthias Sammer Soccer (Germany) (SGB Enhanced)" - rom ( name "Matthias Sammer Soccer (Germany) (SGB Enhanced).gb" size 262144 crc 631e656f sha1 eadc06e71ea4f04700e2ed1ef232b6e57cb48725 ) + name "Lawnmower Man, The (USA) (Proto 2) (1993-11-10)" + description "Lawnmower Man, The (USA) (Proto 2) (1993-11-10)" + rom ( name "Lawnmower Man, The (USA) (Proto 2) (1993-11-10).gb" size 131072 crc 545613e9 sha1 4e06c18e90a4100f2776e4fffb5673e622bb8053 ) ) game ( - name "Maui Mallard in Cold Shadow (USA)" - description "Maui Mallard in Cold Shadow (USA)" - rom ( name "Maui Mallard in Cold Shadow (USA).gb" size 262144 crc 6f30a43a sha1 eb401c5ddff1488013ff032918ed365e82104ae0 flags verified ) + name "Lawnmower Man, The (Europe)" + description "Lawnmower Man, The (Europe)" + rom ( name "Lawnmower Man, The (Europe).gb" size 131072 crc 134f91d7 sha1 6e63a725fc802966986e6ed6917a7b976794f403 flags verified ) ) game ( - name "Maus, Die (Europe) (En,Fr,De,Es)" - description "Maus, Die (Europe) (En,Fr,De,Es)" - rom ( name "Maus, Die (Europe) (En,Fr,De,Es).gb" size 262144 crc 478f573c sha1 bf2b9d7a54ff0b80c2710f747f5457578caa0cd0 flags verified ) + name "Lazlos' Leap (USA)" + description "Lazlos' Leap (USA)" + rom ( name "Lazlos' Leap (USA).gb" size 65536 crc 31fb404b sha1 c111470fcdadf191cf843e50c8f3d3dbb995a5c5 ) ) game ( - name "Max (Europe)" - description "Max (Europe)" - rom ( name "Max (Europe).gb" size 65536 crc 1b167f00 sha1 1f995332ae8a8832c178b22505d05080bf978aa8 flags verified ) + name "Learn and Play - Blackjack & Solitaire (USA) (1994-08-09) (Proto)" + description "Learn and Play - Blackjack & Solitaire (USA) (1994-08-09) (Proto)" + rom ( name "Learn and Play - Blackjack & Solitaire (USA) (1994-08-09) (Proto).gb" size 131072 crc 60837c15 sha1 d69062736dfde2af8e0ede2cc3dd5d2b95996e79 ) ) game ( - name "McDonaldland (Europe)" - description "McDonaldland (Europe)" - rom ( name "McDonaldland (Europe).gb" size 131072 crc 81de6c13 sha1 fd11d61f961a7e3c69e272ef19eb243b7df89833 flags verified ) + name "Legend - Ashita e no Tsubasa (Japan)" + description "Legend - Ashita e no Tsubasa (Japan)" + rom ( name "Legend - Ashita e no Tsubasa (Japan).gb" size 131072 crc fc20ebf0 sha1 7447b3faa1d15e80815cdace3c6c0691bc28aa90 ) ) game ( - name "Medarot - Kabuto Version (Japan) (SGB Enhanced)" - description "Medarot - Kabuto Version (Japan) (SGB Enhanced)" - rom ( name "Medarot - Kabuto Version (Japan) (SGB Enhanced).gb" size 524288 crc 1bab9900 sha1 ae26b9310ab41d94a73b807ef5f30e2d0e34d667 flags verified ) + name "Legend of Prince Valiant, The (Europe) (En,Fr,De)" + description "Legend of Prince Valiant, The (Europe) (En,Fr,De)" + rom ( name "Legend of Prince Valiant, The (Europe) (En,Fr,De).gb" size 131072 crc 179c494e sha1 d56b59ad9e483f6912e8e5869c43e1771cf167c2 ) ) game ( - name "Medarot - Kabuto Version (Japan) (Rev 1) (SGB Enhanced)" - description "Medarot - Kabuto Version (Japan) (Rev 1) (SGB Enhanced)" - rom ( name "Medarot - Kabuto Version (Japan) (Rev 1) (SGB Enhanced).gb" size 524288 crc 12a3982d sha1 1cbc7ab5941dc27bc50699a00ef2b1beb930449d flags verified ) + name "Legend of the River King GB (USA) (SGB Enhanced)" + description "Legend of the River King GB (USA) (SGB Enhanced)" + rom ( name "Legend of the River King GB (USA) (SGB Enhanced).gb" size 524288 crc a6e685dc sha1 d2e8a9aceec8639b528f712532a38fe0c2b0edef ) ) game ( - name "Medarot - Kuwagata Version (Japan) (SGB Enhanced)" - description "Medarot - Kuwagata Version (Japan) (SGB Enhanced)" - rom ( name "Medarot - Kuwagata Version (Japan) (SGB Enhanced).gb" size 524288 crc bc0588c4 sha1 f657f822ed15e459c4abcd171c9620cddbdfd022 ) + name "Legend of the River King GB (Australia) (SGB Enhanced)" + description "Legend of the River King GB (Australia) (SGB Enhanced)" + rom ( name "Legend of the River King GB (Australia) (SGB Enhanced).gb" size 524288 crc 51627213 sha1 87274e8c0d2daaac2e0dda94651c35d6a0617c0f ) ) game ( - name "Medarot - Kuwagata Version (Japan) (Rev 1) (SGB Enhanced)" - description "Medarot - Kuwagata Version (Japan) (Rev 1) (SGB Enhanced)" - rom ( name "Medarot - Kuwagata Version (Japan) (Rev 1) (SGB Enhanced).gb" size 524288 crc 5e77e82e sha1 2262f69a89abe0f66dc1554c1ee470fd536130a3 flags verified ) + name "Legend of the Sea King GB (USA) (Proto) (SGB Enhanced)" + description "Legend of the Sea King GB (USA) (Proto) (SGB Enhanced)" + rom ( name "Legend of the Sea King GB (USA) (Proto) (SGB Enhanced).gb" size 1048576 crc a45ef889 sha1 26bebc2394b5da850be55e409b9efcb4d2d29d87 ) ) game ( - name "Medarot - Parts Collection (Japan) (SGB Enhanced)" - description "Medarot - Parts Collection (Japan) (SGB Enhanced)" - rom ( name "Medarot - Parts Collection (Japan) (SGB Enhanced).gb" size 524288 crc f4cab596 sha1 eec1245abb1d97cd2df976fdf179c924a4efa720 ) + name "Legend of Zelda, The - Link's Awakening (Canada) (Fr)" + description "Legend of Zelda, The - Link's Awakening (Canada) (Fr)" + rom ( name "Legend of Zelda, The - Link's Awakening (Canada) (Fr).gb" size 524288 crc 4407c759 sha1 4bbd38a4548e0c7922d0a6719ac5d16791e9535b flags verified ) ) game ( - name "Medarot - Parts Collection 2 (Japan) (SGB Enhanced)" - description "Medarot - Parts Collection 2 (Japan) (SGB Enhanced)" - rom ( name "Medarot - Parts Collection 2 (Japan) (SGB Enhanced).gb" size 524288 crc 89f94482 sha1 edd74afbfca5e3d3366fb231c4bedd80fcf8a81e ) + name "Legend of Zelda, The - Link's Awakening (France)" + description "Legend of Zelda, The - Link's Awakening (France)" + rom ( name "Legend of Zelda, The - Link's Awakening (France).gb" size 524288 crc bf2ab18b sha1 af93e1b3140f61fcd614f1ef9266d6892224767f flags verified ) ) game ( - name "Mega Man - Dr. Wily's Revenge (Europe)" - description "Mega Man - Dr. Wily's Revenge (Europe)" - rom ( name "Mega Man - Dr. Wily's Revenge (Europe).gb" size 262144 crc 2ea4b976 sha1 11255a24344e9fed53b8f1f6f894d21e161a0d5e flags verified ) + name "Legend of Zelda, The - Link's Awakening (Germany)" + description "Legend of Zelda, The - Link's Awakening (Germany)" + rom ( name "Legend of Zelda, The - Link's Awakening (Germany).gb" size 524288 crc 760ab4e7 sha1 cc468442508a8ba6c4661238aa1925a3132f1630 flags verified ) ) game ( - name "Mega Man - Dr. Wily's Revenge (USA)" - description "Mega Man - Dr. Wily's Revenge (USA)" - rom ( name "Mega Man - Dr. Wily's Revenge (USA).gb" size 262144 crc 47e70e08 sha1 277edb3c844e812ba4b3eb9a96c9c30414541858 flags verified ) + name "Legend of Zelda, The - Link's Awakening (USA, Europe)" + description "Legend of Zelda, The - Link's Awakening (USA, Europe)" + rom ( name "Legend of Zelda, The - Link's Awakening (USA, Europe).gb" size 524288 crc 8cf27c90 sha1 602167f897b4f56fe8cee837933da3bed5882bbd flags verified ) ) game ( - name "Mega Man II (Europe)" - description "Mega Man II (Europe)" - rom ( name "Mega Man II (Europe).gb" size 262144 crc 5e90cb48 sha1 d19993a4630e7f9450ff6469115f4095f6f29667 flags verified ) + name "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 1)" + description "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 1)" + rom ( name "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 1).gb" size 524288 crc 7d1b6cd6 sha1 5259e68522225a7a830e29ea17dfddc33263ced5 flags verified ) ) game ( - name "Mega Man II (USA)" - description "Mega Man II (USA)" - rom ( name "Mega Man II (USA).gb" size 262144 crc e496f686 sha1 334f1a93346d55e1be2967f0af952e37aa52fca7 flags verified ) + name "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 2)" + description "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 2)" + rom ( name "Legend of Zelda, The - Link's Awakening (USA, Europe) (Rev 2).gb" size 524288 crc 34d08e7b sha1 5ab63def958728933571c3b4f6af54db14f3f8b2 flags verified ) ) game ( - name "Mega Man III (Europe)" - description "Mega Man III (Europe)" - rom ( name "Mega Man III (Europe).gb" size 262144 crc 03b0d4ec sha1 ecadbc9e273e4d99ccd87f98bbbd912aec43c077 flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (France) (Proto) (1998-11-17)" + description "Legend of Zelda, The - Link's Awakening DX (France) (Proto) (1998-11-17)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Proto) (1998-11-17).gb" size 524288 crc bfa800c0 sha1 3d48bcec56bf202d3362ba3e5e20233f996492c5 ) ) game ( - name "Mega Man III (USA)" - description "Mega Man III (USA)" - rom ( name "Mega Man III (USA).gb" size 262144 crc 5175d761 sha1 57347305ab297daa4332564623c4a098e6dbb1a3 flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Proto) (1998-11-08)" + description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Proto) (1998-11-08)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Proto) (1998-11-08).gb" size 524288 crc d8ba6631 sha1 9d6da903a5481aadfb20d75954bd01917497a38d ) ) game ( - name "Mega Man III (USA) (Sample)" - description "Mega Man III (USA) (Sample)" - rom ( name "Mega Man III (USA) (Sample).gb" size 262144 crc 82f4c095 sha1 7eea8a96bf64537b041b96ce2cb5dd13cdebb789 ) + name "Legend of Zelda, The - Link's Awakening DX (Germany) (Proto) (1998-11-16)" + description "Legend of Zelda, The - Link's Awakening DX (Germany) (Proto) (1998-11-16)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Proto) (1998-11-16).gb" size 524288 crc f7c59f5c sha1 d1a10a3f129bf060f16d1fb5f991ef6e2f28b97c ) ) game ( - name "Mega Man IV (Europe)" - description "Mega Man IV (Europe)" - rom ( name "Mega Man IV (Europe).gb" size 524288 crc 060b89e6 sha1 a15a05593bf9bdddb5826b148e25182e7b90f268 ) + name "Lemmings (Europe) (Rev 1)" + description "Lemmings (Europe) (Rev 1)" + rom ( name "Lemmings (Europe) (Rev 1).gb" size 131072 crc 560d71eb sha1 c156d7ee57860a23754e87d42f952b17077994ad ) ) game ( - name "Mega Man IV (USA)" - description "Mega Man IV (USA)" - rom ( name "Mega Man IV (USA).gb" size 524288 crc abcea00d sha1 6f0901db2b5dcaace0215c0abdc21a914fa21b65 flags verified ) + name "Lemmings (Europe) (Beta) (1993-05-19)" + description "Lemmings (Europe) (Beta) (1993-05-19)" + rom ( name "Lemmings (Europe) (Beta) (1993-05-19).gb" size 131072 crc e2a65174 sha1 4f23d9dcc315f5dbd5ef2350f6623b6cd077b393 ) ) game ( - name "Mega Man V (Europe) (SGB Enhanced)" - description "Mega Man V (Europe) (SGB Enhanced)" - rom ( name "Mega Man V (Europe) (SGB Enhanced).gb" size 524288 crc d12ac4fe sha1 1a377bb0571bbe48a58b5006ccb02046ec64b076 ) + name "Lemmings (Europe)" + description "Lemmings (Europe)" + rom ( name "Lemmings (Europe).gb" size 131072 crc 23467a35 sha1 8edb7e1a1a7289d4c393fba6d27776ab6af441ff flags verified ) +) + +game ( + name "Lemmings (Japan)" + description "Lemmings (Japan)" + rom ( name "Lemmings (Japan).gb" size 131072 crc 7d5cc03a sha1 0a4fef2a6a09bb66b1b34b5294ff737530cff4e1 ) +) + +game ( + name "Lemmings (USA)" + description "Lemmings (USA)" + rom ( name "Lemmings (USA).gb" size 131072 crc f2d1c19d sha1 1754fde0b1c40752a5716a291e842e38401baf08 ) +) + +game ( + name "Lemmings 2 - The Tribes (Europe)" + description "Lemmings 2 - The Tribes (Europe)" + rom ( name "Lemmings 2 - The Tribes (Europe).gb" size 524288 crc 9800bd49 sha1 76ccf9ac82faebc7f9c4a4c8b5cd47ddea46c486 flags verified ) +) + +game ( + name "Lethal Weapon (USA, Europe) (Beta)" + description "Lethal Weapon (USA, Europe) (Beta)" + rom ( name "Lethal Weapon (USA, Europe) (Beta).gb" size 131072 crc d585ab23 sha1 2221ba322acffc9d7ae5400752e16d0455fda3ef ) +) + +game ( + name "Lethal Weapon (USA, Europe)" + description "Lethal Weapon (USA, Europe)" + rom ( name "Lethal Weapon (USA, Europe).gb" size 131072 crc 1f8d207c sha1 8b4621471b376a6262fbed70c1191416ab3be915 ) +) + +game ( + name "Lingo (Europe) (En,Fr,De,Nl)" + description "Lingo (Europe) (En,Fr,De,Nl)" + rom ( name "Lingo (Europe) (En,Fr,De,Nl).gb" size 131072 crc 0ef4637d sha1 4838c0baae82a9de62e70f2004d674b87caa2043 ) +) + +game ( + name "Lion King, The (USA)" + description "Lion King, The (USA)" + rom ( name "Lion King, The (USA).gb" size 524288 crc 3430d261 sha1 fbbdb1d2073bafa45943cb5f4d4aae5648120089 ) +) + +game ( + name "Lion King, The (Europe)" + description "Lion King, The (Europe)" + rom ( name "Lion King, The (Europe).gb" size 524288 crc 8fc3ca73 sha1 043d29ede2af013c000ff650231c10b3f62d7aca flags verified ) +) + +game ( + name "Lion King, The (World) (Disney Classic Games)" + description "Lion King, The (World) (Disney Classic Games)" + rom ( name "Lion King, The (World) (Disney Classic Games).gb" size 524288 crc e435ed72 sha1 170c071db25da7a2b39dd1fb2675aceb8eeb87a1 flags verified ) +) + +game ( + name "Litti's Summer Sports (Germany)" + description "Litti's Summer Sports (Germany)" + rom ( name "Litti's Summer Sports (Germany).gb" size 131072 crc e681395b sha1 d958c99ebe387b1ba489f4ffda943c00345d2f4e flags verified ) +) + +game ( + name "Little Master - Raikuban no Densetsu (Japan)" + description "Little Master - Raikuban no Densetsu (Japan)" + rom ( name "Little Master - Raikuban no Densetsu (Japan).gb" size 131072 crc 31cd9670 sha1 7c83b3c6cd9571c422e66e64e522a0416fa477b2 ) +) + +game ( + name "Little Master 2 - Raikou no Kishi (Japan)" + description "Little Master 2 - Raikou no Kishi (Japan)" + rom ( name "Little Master 2 - Raikou no Kishi (Japan).gb" size 262144 crc 187de7f8 sha1 9cc2d0f5ec33ca5ebf382e68dd55503c75a889b5 ) +) + +game ( + name "Little Mermaid, The (Europe)" + description "Little Mermaid, The (Europe)" + rom ( name "Little Mermaid, The (Europe).gb" size 131072 crc 00def37a sha1 62a5beea93d48445a0f16f5582fc4fc61ba9fc1b flags verified ) +) + +game ( + name "Little Mermaid, The (USA)" + description "Little Mermaid, The (USA)" + rom ( name "Little Mermaid, The (USA).gb" size 131072 crc d7c517e5 sha1 9c7d7a82d0eeb4d7b4f4b7ae35e5ebd80c93d780 ) +) + +game ( + name "Little Mermaid, The (Spain) (Proto)" + description "Little Mermaid, The (Spain) (Proto)" + rom ( name "Little Mermaid, The (Spain) (Proto).gb" size 131072 crc d19cf413 sha1 463036660b2739e450a7bdea68772c6738e04a53 ) +) + +game ( + name "Lock n' Chase (World)" + description "Lock n' Chase (World)" + rom ( name "Lock n' Chase (World).gb" size 65536 crc dab91c7a sha1 643cbd566d35ce8dbe0f24627e4862c09805a04c flags verified ) +) + +game ( + name "Lolo no Daibouken (Japan)" + description "Lolo no Daibouken (Japan)" + rom ( name "Lolo no Daibouken (Japan).gb" size 131072 crc d6185941 sha1 2f4a4215e3c95f7f3646ad678c5cd191fce02515 ) +) + +game ( + name "Long Xing Tianxia (Taiwan) (Unl)" + description "Long Xing Tianxia (Taiwan) (Unl)" + rom ( name "Long Xing Tianxia (Taiwan) (Unl).gb" size 131072 crc c2c172c3 sha1 4da29dd4530ea3c26ea738427828d2e4903c99f8 ) +) + +game ( + name "Looney Tunes (USA, Europe)" + description "Looney Tunes (USA, Europe)" + rom ( name "Looney Tunes (USA, Europe).gb" size 131072 crc a662a8ef sha1 97d96f8ec66acba996c7bec0a713c84075f22680 flags verified ) +) + +game ( + name "Looney Tunes - Bugs Bunny to Yukai na Nakama-tachi (Japan)" + description "Looney Tunes - Bugs Bunny to Yukai na Nakama-tachi (Japan)" + rom ( name "Looney Tunes - Bugs Bunny to Yukai na Nakama-tachi (Japan).gb" size 131072 crc 40e47da3 sha1 ed26fd9d4011c286e2e6109967cad2564c17900b ) +) + +game ( + name "Looney Tunes 2 - Tasmanian Devil in Island Chase (USA, Europe)" + description "Looney Tunes 2 - Tasmanian Devil in Island Chase (USA, Europe)" + rom ( name "Looney Tunes 2 - Tasmanian Devil in Island Chase (USA, Europe).gb" size 262144 crc 22d07cf6 sha1 d36d731bd2644ee84c7cf77a2c1d319851e4d6bb flags verified ) +) + +game ( + name "Looney Tunes Series - Daffy Duck (Japan) (SGB Enhanced)" + description "Looney Tunes Series - Daffy Duck (Japan) (SGB Enhanced)" + rom ( name "Looney Tunes Series - Daffy Duck (Japan) (SGB Enhanced).gb" size 262144 crc 798d9489 sha1 65f063906680e65d8786e698bd51674268d7ae68 ) +) + +game ( + name "Loopz (World)" + description "Loopz (World)" + rom ( name "Loopz (World).gb" size 32768 crc 531a3e16 sha1 dd2ddac2310409287299c287f1959196e0b4d14e flags verified ) +) + +game ( + name "Loopz (World) (Beta)" + description "Loopz (World) (Beta)" + rom ( name "Loopz (World) (Beta).gb" size 32768 crc 15e28642 sha1 01f87439294a2a06604ae0fd41df203713460510 ) +) + +game ( + name "Lost World, The - Jurassic Park (USA, Europe) (SGB Enhanced)" + description "Lost World, The - Jurassic Park (USA, Europe) (SGB Enhanced)" + rom ( name "Lost World, The - Jurassic Park (USA, Europe) (SGB Enhanced).gb" size 524288 crc 391f532a sha1 68bf63ba6a6c9f3a71a933d6f00e5212c66dcd03 flags verified ) +) + +game ( + name "Lucky Luke (Europe) (En,Fr,De,Es)" + description "Lucky Luke (Europe) (En,Fr,De,Es)" + rom ( name "Lucky Luke (Europe) (En,Fr,De,Es).gb" size 262144 crc 538e0591 sha1 7d67aa8b17d7208d8ed234bd70b4def9582b362d ) +) + +game ( + name "Lucky Monkey (Japan)" + description "Lucky Monkey (Japan)" + rom ( name "Lucky Monkey (Japan).gb" size 65536 crc a2234eb1 sha1 ab8654013dc574538b815d8b15aa3cae66afc809 ) +) + +game ( + name "Lucle (Japan, Europe) (En)" + description "Lucle (Japan, Europe) (En)" + rom ( name "Lucle (Japan, Europe) (En).gb" size 524288 crc a3d5c8d7 sha1 2fef16fac95ec4ffd252e9974eccfce538e5f797 ) +) + +game ( + name "Lunar Chase (USA) (Proto 1)" + description "Lunar Chase (USA) (Proto 1)" + rom ( name "Lunar Chase (USA) (Proto 1).gb" size 245760 crc cd555712 sha1 b1c5b60b82aaa0b824f7bf67fc8f111377ccfb6a ) +) + +game ( + name "Lunar Chase (USA) (Proto 2)" + description "Lunar Chase (USA) (Proto 2)" + rom ( name "Lunar Chase (USA) (Proto 2).gb" size 262144 crc 67044675 sha1 f5e9ecd2f0d20b0d8d452a852c700a5223bdcb73 ) +) + +game ( + name "Lunar Lander (Japan)" + description "Lunar Lander (Japan)" + rom ( name "Lunar Lander (Japan).gb" size 131072 crc 030d2054 sha1 05266f727879963a23dbbcd8c87c68597607f3b8 ) +) + +game ( + name "Mach Go Go Go (Japan) (SGB Enhanced)" + description "Mach Go Go Go (Japan) (SGB Enhanced)" + rom ( name "Mach Go Go Go (Japan) (SGB Enhanced).gb" size 262144 crc 016d230b sha1 baea8b49ce2402c5c094ddae0320a382c0d95d86 ) +) + +game ( + name "Madden 95 (USA, Europe) (SGB Enhanced)" + description "Madden 95 (USA, Europe) (SGB Enhanced)" + rom ( name "Madden 95 (USA, Europe) (SGB Enhanced).gb" size 524288 crc d2585bbb sha1 b41a14394bbd890e341bf5d27f297cb5e906fd60 ) +) + +game ( + name "Madden 96 (USA, Europe) (SGB Enhanced)" + description "Madden 96 (USA, Europe) (SGB Enhanced)" + rom ( name "Madden 96 (USA, Europe) (SGB Enhanced).gb" size 524288 crc fd9dc1ad sha1 dd67d34b7801f31063df522c45349823713fe99b ) +) + +game ( + name "Madden 97 (USA) (SGB Enhanced)" + description "Madden 97 (USA) (SGB Enhanced)" + rom ( name "Madden 97 (USA) (SGB Enhanced).gb" size 524288 crc 88a837a2 sha1 e1d92b6afdd7dc2254c895ad8a9a066262fb214b ) +) + +game ( + name "Maerchen Club (Japan)" + description "Maerchen Club (Japan)" + rom ( name "Maerchen Club (Japan).gb" size 131072 crc cdfd660a sha1 dcb42287ffdbc352cd954b28a797fcd3547730de ) +) + +game ( + name "Magic Knight Rayearth (Japan) (SGB Enhanced)" + description "Magic Knight Rayearth (Japan) (SGB Enhanced)" + rom ( name "Magic Knight Rayearth (Japan) (SGB Enhanced).gb" size 262144 crc 94838a81 sha1 4f77031946e62772a241a9b5b046d7fcf6a28ea8 ) +) + +game ( + name "Magic Knight Rayearth 2nd. - The Missing Colors (Japan) (SGB Enhanced)" + description "Magic Knight Rayearth 2nd. - The Missing Colors (Japan) (SGB Enhanced)" + rom ( name "Magic Knight Rayearth 2nd. - The Missing Colors (Japan) (SGB Enhanced).gb" size 262144 crc 00202dfa sha1 afe76c2d6f796813f1803e8c542107bf0827f966 ) +) + +game ( + name "Magical Taruruuto-kun (Japan)" + description "Magical Taruruuto-kun (Japan)" + rom ( name "Magical Taruruuto-kun (Japan).gb" size 131072 crc 9c4f54f1 sha1 0b7723d1761a61dcf42fc93f134b59f2232d4c37 ) +) + +game ( + name "Magical Taruruuto-kun 2 - Raibaa Zone Panic!! (Japan)" + description "Magical Taruruuto-kun 2 - Raibaa Zone Panic!! (Japan)" + rom ( name "Magical Taruruuto-kun 2 - Raibaa Zone Panic!! (Japan).gb" size 131072 crc 0aad5217 sha1 3be6c6b8cec80a0fe0f6edbbe40496f4d077c750 ) +) + +game ( + name "Magnetic Soccer (Europe)" + description "Magnetic Soccer (Europe)" + rom ( name "Magnetic Soccer (Europe).gb" size 131072 crc 9c318c64 sha1 da24ba642fc6ea91d0fb395481840cd9060a6de4 flags verified ) +) + +game ( + name "Mahoujin GuruGuru - Yuusha to Kukuri no Daibouken (Japan) (SGB Enhanced)" + description "Mahoujin GuruGuru - Yuusha to Kukuri no Daibouken (Japan) (SGB Enhanced)" + rom ( name "Mahoujin GuruGuru - Yuusha to Kukuri no Daibouken (Japan) (SGB Enhanced).gb" size 262144 crc 2d439d0d sha1 10a55c546c68cb117cc47d49304f807a7bb63687 ) +) + +game ( + name "Makai Toushi Sa-Ga (Japan)" + description "Makai Toushi Sa-Ga (Japan)" + rom ( name "Makai Toushi Sa-Ga (Japan).gb" size 131072 crc 131b09f2 sha1 7a8f770a34207fee324431c47836f1ab317863f9 flags verified ) +) + +game ( + name "Makai Toushi Sa-Ga (Japan) (Rev 1)" + description "Makai Toushi Sa-Ga (Japan) (Rev 1)" + rom ( name "Makai Toushi Sa-Ga (Japan) (Rev 1).gb" size 131072 crc 1953820f sha1 cbf480bc92bd98bae4fb79294b604d341fe58cbe flags verified ) +) + +game ( + name "Makai Toushi Sa-Ga (World) (Ja) (Rev 1) (Collection of SaGa)" + description "Makai Toushi Sa-Ga (World) (Ja) (Rev 1) (Collection of SaGa)" + rom ( name "Makai Toushi Sa-Ga (World) (Ja) (Rev 1) (Collection of SaGa).gb" size 131072 crc 0006612d sha1 3ce39646bffe38a9c8fd4913f0e950bae061d094 ) +) + +game ( + name "Makaimura Gaiden - The Demon Darkness (Japan)" + description "Makaimura Gaiden - The Demon Darkness (Japan)" + rom ( name "Makaimura Gaiden - The Demon Darkness (Japan).gb" size 262144 crc cfa358de sha1 961d05e91288d7ad1f2e6a1c996059d7ab96fe98 ) +) + +game ( + name "Malibu Beach Volleyball (USA)" + description "Malibu Beach Volleyball (USA)" + rom ( name "Malibu Beach Volleyball (USA).gb" size 65536 crc dfa5da12 sha1 f7fed41b98fc8bcdc8f72c470e20b8bab150ca33 ) +) + +game ( + name "Mani 4 in 1 - Bubble Bobble + Elevator Action + Chase H.Q. + Sagaia (China) (En)" + description "Mani 4 in 1 - Bubble Bobble + Elevator Action + Chase H.Q. + Sagaia (China) (En)" + rom ( name "Mani 4 in 1 - Bubble Bobble + Elevator Action + Chase H.Q. + Sagaia (China) (En).gb" size 524288 crc 5bfc3ef5 sha1 c0639d6c993690022200f2fa4b3094249b9335c0 flags verified ) +) + +game ( + name "Mani 4 in 1 - Genki Bakuhatsu Gambaruger + Zettai Muteki Raijin-Oh + Zoids Densetsu + Miracle Adventure of Esparks - Ushinawareta Seiseki Perivron (China) (Ja)" + description "Mani 4 in 1 - Genki Bakuhatsu Gambaruger + Zettai Muteki Raijin-Oh + Zoids Densetsu + Miracle Adventure of Esparks - Ushinawareta Seiseki Perivron (China) (Ja)" + rom ( name "Mani 4 in 1 - Genki Bakuhatsu Gambaruger + Zettai Muteki Raijin-Oh + Zoids Densetsu + Miracle Adventure of Esparks - Ushinawareta Seiseki Perivron (China) (Ja).gb" size 524288 crc c373ac09 sha1 0030295574e4c518ff5cdf20febf6b6737426468 flags verified ) +) + +game ( + name "Mani 4 in 1 - R-Type II + Saigo no Nindou + Ganso!! Yancha Maru + Shisenshou - Match-Mania (China) (Ja)" + description "Mani 4 in 1 - R-Type II + Saigo no Nindou + Ganso!! Yancha Maru + Shisenshou - Match-Mania (China) (Ja)" + rom ( name "Mani 4 in 1 - R-Type II + Saigo no Nindou + Ganso!! Yancha Maru + Shisenshou - Match-Mania (China) (Ja).gb" size 524288 crc cb48b6d0 sha1 1c79eb31a6754b4e96d33a182d36833208dc7177 ) +) + +game ( + name "Mani 4 in 1 - Takahashi Meijin no Bouken-jima II + GB Genjin + Bomber Boy + Milon no Meikyuu Kumikyoku (China) (Ja)" + description "Mani 4 in 1 - Takahashi Meijin no Bouken-jima II + GB Genjin + Bomber Boy + Milon no Meikyuu Kumikyoku (China) (Ja)" + rom ( name "Mani 4 in 1 - Takahashi Meijin no Bouken-jima II + GB Genjin + Bomber Boy + Milon no Meikyuu Kumikyoku (China) (Ja).gb" size 1048576 crc 950773ee sha1 af4706da224d794668f3b2c68aea7b3c16452d83 ) +) + +game ( + name "Mani 4 in 1 - Tetris + Alleyway + Yakuman + Tennis (China) (Ja)" + description "Mani 4 in 1 - Tetris + Alleyway + Yakuman + Tennis (China) (Ja)" + rom ( name "Mani 4 in 1 - Tetris + Alleyway + Yakuman + Tennis (China) (Ja).gb" size 262144 crc 0c38a775 sha1 dfe46e066c599c17e684ddda3fd74c5357910630 flags verified ) +) + +game ( + name "Marble Madness (USA, Europe)" + description "Marble Madness (USA, Europe)" + rom ( name "Marble Madness (USA, Europe).gb" size 262144 crc b9725e66 sha1 bf2a73f7adf200410038350c2c754a943d841681 flags verified ) +) + +game ( + name "Mario & Yoshi (Europe)" + description "Mario & Yoshi (Europe)" + rom ( name "Mario & Yoshi (Europe).gb" size 65536 crc 4627d88b sha1 9bf642eabdb51625d1ef1ac470666ec8f5f10f77 flags verified ) +) + +game ( + name "Mario no Picross (Japan) (SGB Enhanced)" + description "Mario no Picross (Japan) (SGB Enhanced)" + rom ( name "Mario no Picross (Japan) (SGB Enhanced).gb" size 262144 crc 17533700 sha1 6b72cbff3e224299eff6f79e0110a477b8f840c2 flags verified ) +) + +game ( + name "Mario's Picross (USA, Europe) (SGB Enhanced)" + description "Mario's Picross (USA, Europe) (SGB Enhanced)" + rom ( name "Mario's Picross (USA, Europe) (SGB Enhanced).gb" size 262144 crc f2d652ad sha1 9712f37171b8a0cdc99a60170ea7b2aed161195e flags verified ) +) + +game ( + name "Marmalade Boy (Japan) (SGB Enhanced)" + description "Marmalade Boy (Japan) (SGB Enhanced)" + rom ( name "Marmalade Boy (Japan) (SGB Enhanced).gb" size 262144 crc 0f3ff7da sha1 60125690b7a354ff8e72f497c8a88ecd691e7e4b ) +) + +game ( + name "Maru's Mission (USA)" + description "Maru's Mission (USA)" + rom ( name "Maru's Mission (USA).gb" size 131072 crc 6e4f1eb3 sha1 91446b1cc6dbf3b98b81f13e35ffe7bfaaa027aa flags verified ) +) + +game ( + name "Masakari Densetsu - Kintarou Action Hen (Japan)" + description "Masakari Densetsu - Kintarou Action Hen (Japan)" + rom ( name "Masakari Densetsu - Kintarou Action Hen (Japan).gb" size 262144 crc 7cb70d3d sha1 ec23af3d5590b75b2a3b33708a4fe5cffe495a1f flags verified ) +) + +game ( + name "Masakari Densetsu - Kintarou RPG Hen (Japan) (SGB Enhanced)" + description "Masakari Densetsu - Kintarou RPG Hen (Japan) (SGB Enhanced)" + rom ( name "Masakari Densetsu - Kintarou RPG Hen (Japan) (SGB Enhanced).gb" size 524288 crc d8bab8e0 sha1 a9bcb90df5b19a372ceed81c614bb7eb295ec74c ) +) + +game ( + name "Master Karateka (Japan)" + description "Master Karateka (Japan)" + rom ( name "Master Karateka (Japan).gb" size 32768 crc 4c0fb33e sha1 1ffea01d8d91f026ce6677631bcb10991092ff13 ) +) + +game ( + name "Matchless 23 in 1 A (Taiwan) (Unl)" + description "Matchless 23 in 1 A (Taiwan) (Unl)" + rom ( name "Matchless 23 in 1 A (Taiwan) (Unl).gb" size 2097152 crc 7ef05854 sha1 57ca49fdb23aa65bf7200c2f9690a216f5518f4d ) +) + +game ( + name "Matthias Sammer Soccer (Germany) (SGB Enhanced)" + description "Matthias Sammer Soccer (Germany) (SGB Enhanced)" + rom ( name "Matthias Sammer Soccer (Germany) (SGB Enhanced).gb" size 262144 crc 631e656f sha1 eadc06e71ea4f04700e2ed1ef232b6e57cb48725 ) +) + +game ( + name "Maui Mallard in Cold Shadow (USA)" + description "Maui Mallard in Cold Shadow (USA)" + rom ( name "Maui Mallard in Cold Shadow (USA).gb" size 262144 crc 6f30a43a sha1 eb401c5ddff1488013ff032918ed365e82104ae0 flags verified ) +) + +game ( + name "Maus, Die (Europe) (En,Fr,De,Es)" + description "Maus, Die (Europe) (En,Fr,De,Es)" + rom ( name "Maus, Die (Europe) (En,Fr,De,Es).gb" size 262144 crc 478f573c sha1 bf2b9d7a54ff0b80c2710f747f5457578caa0cd0 flags verified ) +) + +game ( + name "Max (Europe)" + description "Max (Europe)" + rom ( name "Max (Europe).gb" size 65536 crc 1b167f00 sha1 1f995332ae8a8832c178b22505d05080bf978aa8 flags verified ) +) + +game ( + name "McDonaldland (Europe)" + description "McDonaldland (Europe)" + rom ( name "McDonaldland (Europe).gb" size 131072 crc 81de6c13 sha1 fd11d61f961a7e3c69e272ef19eb243b7df89833 flags verified ) +) + +game ( + name "Medarot - Kabuto Version (Japan) (SGB Enhanced)" + description "Medarot - Kabuto Version (Japan) (SGB Enhanced)" + rom ( name "Medarot - Kabuto Version (Japan) (SGB Enhanced).gb" size 524288 crc 1bab9900 sha1 ae26b9310ab41d94a73b807ef5f30e2d0e34d667 flags verified ) +) + +game ( + name "Medarot - Kabuto Version (Japan) (Rev 1) (SGB Enhanced)" + description "Medarot - Kabuto Version (Japan) (Rev 1) (SGB Enhanced)" + rom ( name "Medarot - Kabuto Version (Japan) (Rev 1) (SGB Enhanced).gb" size 524288 crc 12a3982d sha1 1cbc7ab5941dc27bc50699a00ef2b1beb930449d flags verified ) +) + +game ( + name "Medarot - Kuwagata Version (Japan) (SGB Enhanced)" + description "Medarot - Kuwagata Version (Japan) (SGB Enhanced)" + rom ( name "Medarot - Kuwagata Version (Japan) (SGB Enhanced).gb" size 524288 crc bc0588c4 sha1 f657f822ed15e459c4abcd171c9620cddbdfd022 ) +) + +game ( + name "Medarot - Kuwagata Version (Japan) (Rev 1) (SGB Enhanced)" + description "Medarot - Kuwagata Version (Japan) (Rev 1) (SGB Enhanced)" + rom ( name "Medarot - Kuwagata Version (Japan) (Rev 1) (SGB Enhanced).gb" size 524288 crc 5e77e82e sha1 2262f69a89abe0f66dc1554c1ee470fd536130a3 flags verified ) +) + +game ( + name "Medarot - Parts Collection (Japan) (SGB Enhanced)" + description "Medarot - Parts Collection (Japan) (SGB Enhanced)" + rom ( name "Medarot - Parts Collection (Japan) (SGB Enhanced).gb" size 524288 crc f4cab596 sha1 eec1245abb1d97cd2df976fdf179c924a4efa720 ) +) + +game ( + name "Medarot - Parts Collection 2 (Japan) (SGB Enhanced)" + description "Medarot - Parts Collection 2 (Japan) (SGB Enhanced)" + rom ( name "Medarot - Parts Collection 2 (Japan) (SGB Enhanced).gb" size 524288 crc 89f94482 sha1 edd74afbfca5e3d3366fb231c4bedd80fcf8a81e ) +) + +game ( + name "Mega Man - Dr. Wily's Revenge (Europe)" + description "Mega Man - Dr. Wily's Revenge (Europe)" + rom ( name "Mega Man - Dr. Wily's Revenge (Europe).gb" size 262144 crc 2ea4b976 sha1 11255a24344e9fed53b8f1f6f894d21e161a0d5e flags verified ) +) + +game ( + name "Mega Man - Dr. Wily's Revenge (USA)" + description "Mega Man - Dr. Wily's Revenge (USA)" + rom ( name "Mega Man - Dr. Wily's Revenge (USA).gb" size 262144 crc 47e70e08 sha1 277edb3c844e812ba4b3eb9a96c9c30414541858 flags verified ) +) + +game ( + name "Mega Man II (Europe)" + description "Mega Man II (Europe)" + rom ( name "Mega Man II (Europe).gb" size 262144 crc 5e90cb48 sha1 d19993a4630e7f9450ff6469115f4095f6f29667 flags verified ) +) + +game ( + name "Mega Man II (USA)" + description "Mega Man II (USA)" + rom ( name "Mega Man II (USA).gb" size 262144 crc e496f686 sha1 334f1a93346d55e1be2967f0af952e37aa52fca7 flags verified ) +) + +game ( + name "Mega Man III (Europe)" + description "Mega Man III (Europe)" + rom ( name "Mega Man III (Europe).gb" size 262144 crc 03b0d4ec sha1 ecadbc9e273e4d99ccd87f98bbbd912aec43c077 flags verified ) +) + +game ( + name "Mega Man III (USA)" + description "Mega Man III (USA)" + rom ( name "Mega Man III (USA).gb" size 262144 crc 5175d761 sha1 57347305ab297daa4332564623c4a098e6dbb1a3 flags verified ) +) + +game ( + name "Mega Man III (USA) (Sample)" + description "Mega Man III (USA) (Sample)" + rom ( name "Mega Man III (USA) (Sample).gb" size 262144 crc 82f4c095 sha1 7eea8a96bf64537b041b96ce2cb5dd13cdebb789 ) +) + +game ( + name "Mega Man IV (Europe)" + description "Mega Man IV (Europe)" + rom ( name "Mega Man IV (Europe).gb" size 524288 crc 060b89e6 sha1 a15a05593bf9bdddb5826b148e25182e7b90f268 ) +) + +game ( + name "Mega Man IV (USA)" + description "Mega Man IV (USA)" + rom ( name "Mega Man IV (USA).gb" size 524288 crc abcea00d sha1 6f0901db2b5dcaace0215c0abdc21a914fa21b65 flags verified ) +) + +game ( + name "Mega Man V (Europe) (SGB Enhanced)" + description "Mega Man V (Europe) (SGB Enhanced)" + rom ( name "Mega Man V (Europe) (SGB Enhanced).gb" size 524288 crc d12ac4fe sha1 1a377bb0571bbe48a58b5006ccb02046ec64b076 ) ) game ( @@ -27979,9 +28367,9 @@ game ( ) game ( - name "Meteorite (World) (Aftermarket) (Unl)" - description "Meteorite (World) (Aftermarket) (Unl)" - rom ( name "Meteorite (World) (Aftermarket) (Unl).gb" size 262144 crc 50cf593d sha1 0e88a47faf3273f87c1ead7f789faeb06d5333f3 ) + name "Metal Masters (World) (Limited Run Games)" + description "Metal Masters (World) (Limited Run Games)" + rom ( name "Metal Masters (World) (Limited Run Games).gb" size 131072 crc 7de862fa sha1 9d4896a198904365ebc348c557b7c15f87b5e3c5 ) ) game ( @@ -28350,12 +28738,6 @@ game ( rom ( name "Missile Command (USA, Europe).gb" size 32768 crc 3a6cd4d8 sha1 ed529062ae3d1feb4defbf54c2cc759211e3aeaa flags verified ) ) -game ( - name "Mission Mars (World) (Aftermarket) (Unl)" - description "Mission Mars (World) (Aftermarket) (Unl)" - rom ( name "Mission Mars (World) (Aftermarket) (Unl).gb" size 262144 crc cb3a9ab8 sha1 31625a90b61d28ac782909ed8b00b3a48df7742e ) -) - game ( name "Mofa Qiu - Magic Ball (Taiwan) (Multicart Rip) (Unl)" description "Mofa Qiu - Magic Ball (Taiwan) (Multicart Rip) (Unl)" @@ -28434,12 +28816,6 @@ game ( rom ( name "Momotarou Dentetsu jr. - Zenkoku Ramen Meguri no Maki (Japan) (SGB Enhanced).gb" size 524288 crc 218265b3 sha1 30edf17fc9ddd9db7613c8f78b0ebc340cc89eb0 ) ) -game ( - name "Mona and the Witch's Hat (World) (Aftermarket) (Unl)" - description "Mona and the Witch's Hat (World) (Aftermarket) (Unl)" - rom ( name "Mona and the Witch's Hat (World) (Aftermarket) (Unl).gb" size 65536 crc 32ed7f4a sha1 625d3664d99dee075021b03ea6ff074ae2e49204 ) -) - game ( name "Monde Perdu, Le - Jurassic Park (France) (En) (SGB Enhanced)" description "Monde Perdu, Le - Jurassic Park (France) (En) (SGB Enhanced)" @@ -28530,12 +28906,6 @@ game ( rom ( name "Montezuma's Return! (Europe) (En,Fr,De,Es,It).gb" size 262144 crc e7ac155b sha1 a6b90cc58aeb5b44ef674c503a55a58278b1b6fa flags verified ) ) -game ( - name "Monty on the Run (World) (Aftermarket) (Unl)" - description "Monty on the Run (World) (Aftermarket) (Unl)" - rom ( name "Monty on the Run (World) (Aftermarket) (Unl).gb" size 524288 crc e2ebb406 sha1 41ac5993fbff58be0712b554aae5e4367b68677b ) -) - game ( name "Mortal Kombat (USA, Europe) (Beta)" description "Mortal Kombat (USA, Europe) (Beta)" @@ -28680,24 +29050,12 @@ game ( rom ( name "Mulan (USA) (SGB Enhanced).gb" size 524288 crc bfcf71a1 sha1 7832fcc373ff752e757550079519b39583665c82 ) ) -game ( - name "Muncher (World) (Aftermarket) (Unl)" - description "Muncher (World) (Aftermarket) (Unl)" - rom ( name "Muncher (World) (Aftermarket) (Unl).gb" size 262144 crc 444d3d5e sha1 c3e09aff66c7e395bf95a1864963fbe979d5cb9b ) -) - game ( name "MVP Baseball (Japan)" description "MVP Baseball (Japan)" rom ( name "MVP Baseball (Japan).gb" size 262144 crc 38c126aa sha1 f0d921d13689d2afe7838eee127bf670439c8d8d ) ) -game ( - name "Mysterium (USA) (Beta)" - description "Mysterium (USA) (Beta)" - rom ( name "Mysterium (USA) (Beta).gb" size 131072 crc 004c1af7 sha1 82e058a7608a04a2837d0d8fe810270f804b43f3 ) -) - game ( name "Mysterium (Japan)" description "Mysterium (Japan)" @@ -28711,21 +29069,9 @@ game ( ) game ( - name "Mystic Quest (Europe)" - description "Mystic Quest (Europe)" - rom ( name "Mystic Quest (Europe).gb" size 262144 crc 57d95c92 sha1 3513310426c6ae88f9beb588f71c666e003273be flags verified ) -) - -game ( - name "Mystic Quest (France)" - description "Mystic Quest (France)" - rom ( name "Mystic Quest (France).gb" size 262144 crc b6e134af sha1 b52d82248849f1ead9bf22954b3cbf7bf8e02907 flags verified ) -) - -game ( - name "Mystic Quest (Germany)" - description "Mystic Quest (Germany)" - rom ( name "Mystic Quest (Germany).gb" size 262144 crc 0351b9a6 sha1 7cb65cb314e3f26b92549ddc7f4fc275186c6170 flags verified ) + name "Mysterium (USA) (Beta)" + description "Mysterium (USA) (Beta)" + rom ( name "Mysterium (USA) (Beta).gb" size 131072 crc 004c1af7 sha1 82e058a7608a04a2837d0d8fe810270f804b43f3 ) ) game ( @@ -28746,6 +29092,24 @@ game ( rom ( name "Mystic Quest (World) (De) (Collection of Mana).gb" size 262144 crc a9d7e152 sha1 69235c3494ea650db3b66d6393264f03f0022194 flags verified ) ) +game ( + name "Mystic Quest (Europe)" + description "Mystic Quest (Europe)" + rom ( name "Mystic Quest (Europe).gb" size 262144 crc 57d95c92 sha1 3513310426c6ae88f9beb588f71c666e003273be flags verified ) +) + +game ( + name "Mystic Quest (France)" + description "Mystic Quest (France)" + rom ( name "Mystic Quest (France).gb" size 262144 crc b6e134af sha1 b52d82248849f1ead9bf22954b3cbf7bf8e02907 flags verified ) +) + +game ( + name "Mystic Quest (Germany)" + description "Mystic Quest (Germany)" + rom ( name "Mystic Quest (Germany).gb" size 262144 crc 0351b9a6 sha1 7cb65cb314e3f26b92549ddc7f4fc275186c6170 flags verified ) +) + game ( name "Mystical Ninja Starring Goemon (Europe) (SGB Enhanced)" description "Mystical Ninja Starring Goemon (Europe) (SGB Enhanced)" @@ -28914,24 +29278,6 @@ game ( rom ( name "Nekketsu! Beach Volley Da yo Kunio-kun (Japan) (SGB Enhanced).gb" size 262144 crc abfb84df sha1 d3ad43c40c21d9825b4879dbf28ca58835da658a ) ) -game ( - name "Neko Can Dream (World) (Aftermarket) (Unl)" - description "Neko Can Dream (World) (Aftermarket) (Unl)" - rom ( name "Neko Can Dream (World) (Aftermarket) (Unl).gb" size 2097152 crc 6e76ef25 sha1 55686fde78d17d00adfc831eca2c699274a82273 ) -) - -game ( - name "Neko Can Dream (World) (Ja) (Demo) (Aftermarket) (Unl)" - description "Neko Can Dream (World) (Ja) (Demo) (Aftermarket) (Unl)" - rom ( name "Neko Can Dream (World) (Ja) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc a0ad7a18 sha1 5fb1a09e04cf1704b059468de8855dfa7e23043b ) -) - -game ( - name "Neko Can Dream (World) (Demo) (Aftermarket) (Unl)" - description "Neko Can Dream (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Neko Can Dream (World) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc dc011d07 sha1 43312b149355d20944e8a366584c69e5cb3be868 ) -) - game ( name "Nekojara Monogatari (Japan)" description "Nekojara Monogatari (Japan)" @@ -29262,60 +29608,18 @@ game ( rom ( name "Noobow (Japan).gb" size 262144 crc 8bbcc8bb sha1 b571d9051e3a9f1a55533b4f43941cae907aedff ) ) -game ( - name "Nyghtmare - Betrayed (World) (Alpha A) (Aftermarket) (Unl)" - description "Nyghtmare - Betrayed (World) (Alpha A) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - Betrayed (World) (Alpha A) (Aftermarket) (Unl).gb" size 262144 crc d6166c62 sha1 fa2198c5308a15195adbda004f09646589860d11 ) -) - -game ( - name "Nyghtmare - Betrayed (World) (v0.1.1) (Beta) (Aftermarket) (Unl)" - description "Nyghtmare - Betrayed (World) (v0.1.1) (Beta) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - Betrayed (World) (v0.1.1) (Beta) (Aftermarket) (Unl).gb" size 1048576 crc 42b47080 sha1 08484b0f98e72d6577d9b7cde8c49908012d1fc5 ) -) - -game ( - name "Oblique Strategies (World) (Aftermarket) (Unl)" - description "Oblique Strategies (World) (Aftermarket) (Unl)" - rom ( name "Oblique Strategies (World) (Aftermarket) (Unl).gb" size 524288 crc 30eca8d3 sha1 6a09aabf30e2ebab2e31ae845cd2e8796c84797f ) -) - game ( name "Oddworld Adventures (USA, Europe)" description "Oddworld Adventures (USA, Europe)" rom ( name "Oddworld Adventures (USA, Europe).gb" size 524288 crc 6510c0e2 sha1 be3f69371b6959dab34014cb1d3672f4f3377c3a flags verified ) ) -game ( - name "Oiopolis (World) (Es) (Demo) (Aftermarket) (Unl)" - description "Oiopolis (World) (Es) (Demo) (Aftermarket) (Unl)" - rom ( name "Oiopolis (World) (Es) (Demo) (Aftermarket) (Unl).gb" size 524288 crc d3eba01d sha1 8cf234bbcb68ca2b676a4ccec89814b0cbce1c07 ) -) - -game ( - name "Oiopolis (World) (En) (Demo) (Aftermarket) (Unl)" - description "Oiopolis (World) (En) (Demo) (Aftermarket) (Unl)" - rom ( name "Oiopolis (World) (En) (Demo) (Aftermarket) (Unl).gb" size 524288 crc 71f34822 sha1 f24da97f44d280f27f8ebe3acdc33fea758d2255 ) -) - -game ( - name "Oiopolis (World) (Ca) (Demo) (Aftermarket) (Unl)" - description "Oiopolis (World) (Ca) (Demo) (Aftermarket) (Unl)" - rom ( name "Oiopolis (World) (Ca) (Demo) (Aftermarket) (Unl).gb" size 524288 crc 76baab68 sha1 cd76da35541535dd244ad60d10eb998f7692f07a ) -) - game ( name "Oira Jajamaru! Sekai Daibouken (Japan)" description "Oira Jajamaru! Sekai Daibouken (Japan)" rom ( name "Oira Jajamaru! Sekai Daibouken (Japan).gb" size 131072 crc 2d08d27f sha1 5e13eeb635b41589689fc1b495ee077125b7e8c1 ) ) -game ( - name "Olympic Skier (World) (Aftermarket) (Unl)" - description "Olympic Skier (World) (Aftermarket) (Unl)" - rom ( name "Olympic Skier (World) (Aftermarket) (Unl).gb" size 524288 crc 93174431 sha1 7bcdf10533f8fe053e22534c4962ed4b1a5cf2e2 ) -) - game ( name "Olympic Summer Games (USA, Europe) (SGB Enhanced)" description "Olympic Summer Games (USA, Europe) (SGB Enhanced)" @@ -29424,12 +29728,6 @@ game ( rom ( name "Out of Gas (USA).gb" size 131072 crc 1b67e8b1 sha1 770ac35c0780cf432235593bd5674e72edd6cf7d ) ) -game ( - name "Out on a Limb (World) (Aftermarket) (Unl)" - description "Out on a Limb (World) (Aftermarket) (Unl)" - rom ( name "Out on a Limb (World) (Aftermarket) (Unl).gb" size 262144 crc be197f87 sha1 2ddc2378539316cf7a10e2cf8b562f17e1cf7a6a ) -) - game ( name "Outburst (Japan) (Demo)" description "Outburst (Japan) (Demo)" @@ -29661,7 +29959,7 @@ game ( game ( name "Pang (Europe)" description "Pang (Europe)" - rom ( name "Pang (Europe).gb" size 131072 crc ea9615b4 sha1 7ca64a45ea6a68770658ae39ef21c41f806988c5 ) + rom ( name "Pang (Europe).gb" size 131072 crc ea9615b4 sha1 7ca64a45ea6a68770658ae39ef21c41f806988c5 flags verified ) ) game ( @@ -29670,12 +29968,6 @@ game ( rom ( name "Pang (Europe) (Beta).gb" size 131072 crc 54d2754a sha1 b57d436d8a83f2fb1e42bad3150893ef8ffab0d4 ) ) -game ( - name "Panty Hunty (World) (v1.4) (Aftermarket) (Unl)" - description "Panty Hunty (World) (v1.4) (Aftermarket) (Unl)" - rom ( name "Panty Hunty (World) (v1.4) (Aftermarket) (Unl).gb" size 524288 crc ce707b9a sha1 b5757b268a09d9085d469eda0676991f7361ad8c ) -) - game ( name "Paperboy (USA, Europe)" description "Paperboy (USA, Europe)" @@ -29694,12 +29986,6 @@ game ( rom ( name "Parasol Henbee (Japan).gb" size 65536 crc ae97ec53 sha1 8f319d3d1929d953934e32ce900249ecf6b55fbd ) ) -game ( - name "Parasol Islands (World) (Aftermarket) (Unl)" - description "Parasol Islands (World) (Aftermarket) (Unl)" - rom ( name "Parasol Islands (World) (Aftermarket) (Unl).gb" size 1048576 crc b1d79c80 sha1 381f76af67f77e575beae2f45aefd21f079709e6 ) -) - game ( name "Parasol Stars - Rainbow Islands II (Europe)" description "Parasol Stars - Rainbow Islands II (Europe)" @@ -29754,18 +30040,6 @@ game ( rom ( name "Penta Dragon (Japan).gb" size 262144 crc 1e2efaee sha1 fd75d43258e79f14d104fb4756e219141882c837 ) ) -game ( - name "Perfect Blend (World) (v0.9) (Aftermarket) (Unl)" - description "Perfect Blend (World) (v0.9) (Aftermarket) (Unl)" - rom ( name "Perfect Blend (World) (v0.9) (Aftermarket) (Unl).gb" size 262144 crc 9b4bacaa sha1 09b0691f6823c54f1515dd3b66f135ac45a7dbc3 ) -) - -game ( - name "Perfect Blend (World) (v0.9) (Bugfix) (Aftermarket) (Unl)" - description "Perfect Blend (World) (v0.9) (Bugfix) (Aftermarket) (Unl)" - rom ( name "Perfect Blend (World) (v0.9) (Bugfix) (Aftermarket) (Unl).gb" size 262144 crc 1e8b2a29 sha1 a25dfc43408080ac116479fa55c9e7320e5cc82a ) -) - game ( name "PGA European Tour (USA, Europe) (SGB Enhanced)" description "PGA European Tour (USA, Europe) (SGB Enhanced)" @@ -29796,18 +30070,6 @@ game ( rom ( name "Philip & Marlowe in Bloomland (USA) (Proto).gb" size 131072 crc 32bae420 sha1 2f9e5cee29d0d578b2642ce8637f02fc567aebc5 ) ) -game ( - name "Phobos Dere .GB (World) (Aftermarket) (Unl)" - description "Phobos Dere .GB (World) (Aftermarket) (Unl)" - rom ( name "Phobos Dere .GB (World) (Aftermarket) (Unl).gb" size 1048576 crc ae97f4f8 sha1 e541505078ee5e7e5c897b4621cc693ce71e35ba flags verified ) -) - -game ( - name "Phobos Dere .GB (World) (2022-03-06) (Demo) (Aftermarket) (Unl)" - description "Phobos Dere .GB (World) (2022-03-06) (Demo) (Aftermarket) (Unl)" - rom ( name "Phobos Dere .GB (World) (2022-03-06) (Demo) (Aftermarket) (Unl).gb" size 262144 crc 58362b86 sha1 b4cc3c3735bc134e34b97e08ed24c57aef5c5ccf flags verified ) -) - game ( name "Picross 2 (Japan) (SGB Enhanced)" description "Picross 2 (Japan) (SGB Enhanced)" @@ -29862,18 +30124,6 @@ game ( rom ( name "Pinball Mania (Europe).gb" size 262144 crc edc8d122 sha1 0541161b4b93fffc3c75708aca86ea0873747ced ) ) -game ( - name "Pineapple Kid (World) (Aftermarket) (Unl)" - description "Pineapple Kid (World) (Aftermarket) (Unl)" - rom ( name "Pineapple Kid (World) (Aftermarket) (Unl).gb" size 131072 crc 9541488b sha1 fd574b5d407f3654db3227900a8ed7eff4fe48ae ) -) - -game ( - name "Pineapple Kid (World) (Demo) (Aftermarket) (Unl)" - description "Pineapple Kid (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Pineapple Kid (World) (Demo) (Aftermarket) (Unl).gb" size 131072 crc 9d9102d9 sha1 105e78f740d6bc517ef0079f867e9fdce8d012d2 ) -) - game ( name "Pingu - Sekai de 1ban Genki na Penguin (Japan)" description "Pingu - Sekai de 1ban Genki na Penguin (Japan)" @@ -29916,28 +30166,10 @@ game ( rom ( name "Pitman (Japan).gb" size 32768 crc a0b68136 sha1 a698d4bccd69d2ca51cb48877bde5d1f83d4317f ) ) -game ( - name "Pixel Who - The Lost Legions (World) (Aftermarket) (Unl)" - description "Pixel Who - The Lost Legions (World) (Aftermarket) (Unl)" - rom ( name "Pixel Who - The Lost Legions (World) (Aftermarket) (Unl).gb" size 1048576 crc f41cf2a7 sha1 c07378c774602060f1f93f18fbfd3f0d552fe2d2 ) -) - -game ( - name "Plants Eat My Zombies (World) (v1.1) (Aftermarket) (Unl)" - description "Plants Eat My Zombies (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Plants Eat My Zombies (World) (v1.1) (Aftermarket) (Unl).gb" size 524288 crc 60c84f2e sha1 c39ec5e6a9a0be0970b56e788c3f60e9821dbbd3 ) -) - game ( name "Play Action Football (USA)" description "Play Action Football (USA)" - rom ( name "Play Action Football (USA).gb" size 131072 crc 983caf46 sha1 dc2981baf1bb4d0a65ec45fb22d44a5ca4c06254 ) -) - -game ( - name "Pluto's Corner (World) (Aftermarket) (Unl)" - description "Pluto's Corner (World) (Aftermarket) (Unl)" - rom ( name "Pluto's Corner (World) (Aftermarket) (Unl).gb" size 65536 crc 21fc06b3 sha1 94e4a442205079d85d5ca37042eaec555f7f49db ) + rom ( name "Play Action Football (USA).gb" size 131072 crc 983caf46 sha1 dc2981baf1bb4d0a65ec45fb22d44a5ca4c06254 flags verified ) ) game ( @@ -30141,7 +30373,7 @@ game ( game ( name "Pocket Sonar (Japan)" description "Pocket Sonar (Japan)" - rom ( name "Pocket Sonar (Japan).gb" size 524288 crc d68c9f79 sha1 788cdf148431b82b5308c68b3e45b133a7074196 ) + rom ( name "Pocket Sonar (Japan).gb" size 524288 crc d68c9f79 sha1 788cdf148431b82b5308c68b3e45b133a7074196 flags verified ) ) game ( @@ -30150,12 +30382,6 @@ game ( rom ( name "Pocket Stadium (Japan).gb" size 65536 crc c7bd9228 sha1 7ba422f2b48ff09673f7f1a258be6ecc1ff6a8d7 ) ) -game ( - name "Pogo Pete (World) (Aftermarket) (Unl)" - description "Pogo Pete (World) (Aftermarket) (Unl)" - rom ( name "Pogo Pete (World) (Aftermarket) (Unl).gb" size 262144 crc 185ce1d5 sha1 74021e84c1d095b2401302e26352e810dbc432d8 ) -) - game ( name "Pokemon - Blaue Edition (Germany) (SGB Enhanced)" description "Pokemon - Blaue Edition (Germany) (SGB Enhanced)" @@ -30219,7 +30445,7 @@ game ( game ( name "Pokemon - Version Bleue (France) (SGB Enhanced)" description "Pokemon - Version Bleue (France) (SGB Enhanced)" - rom ( name "Pokemon - Version Bleue (France) (SGB Enhanced).gb" size 1048576 crc 50e2fc1d sha1 47faa910d0e073c600665bf9c83b6bd17babdf8a ) + rom ( name "Pokemon - Version Bleue (France) (SGB Enhanced).gb" size 1048576 crc 50e2fc1d sha1 47faa910d0e073c600665bf9c83b6bd17babdf8a flags verified ) ) game ( @@ -30336,12 +30562,6 @@ game ( rom ( name "Pop'n TwinBee (Europe).gb" size 131072 crc d07db274 sha1 0206230b55c15a8c18fbb85f852967e44b33a0a4 ) ) -game ( - name "Popcorn Caravan (World) (Demo) (Aftermarket) (Unl)" - description "Popcorn Caravan (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Popcorn Caravan (World) (Demo) (Aftermarket) (Unl).gb" size 65536 crc ead528f9 sha1 909d3421747d211a2dc70918d2c952db953e49b2 ) -) - game ( name "Popeye (Japan)" description "Popeye (Japan)" @@ -30396,24 +30616,6 @@ game ( rom ( name "Populous Gaiden (Japan).gb" size 131072 crc f327167e sha1 fde1789eb253309cae80faf4fe7241c6f9d72f29 ) ) -game ( - name "Porklike (World) (v1.0.3) (Aftermarket) (Unl)" - description "Porklike (World) (v1.0.3) (Aftermarket) (Unl)" - rom ( name "Porklike (World) (v1.0.3) (Aftermarket) (Unl).gb" size 65536 crc 6c57e55e sha1 143f31656a5007f65b19d6e32967698bb8f72a66 ) -) - -game ( - name "Porklike (World) (v1.0.9) (SGB Enhanced) (Aftermarket) (Unl)" - description "Porklike (World) (v1.0.9) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Porklike (World) (v1.0.9) (SGB Enhanced) (Aftermarket) (Unl).gb" size 65536 crc 7aaa853a sha1 0868bffd52b2bdc5601ab6cf1e25f40924ca643d ) -) - -game ( - name "Porklike (World) (v1.05) (SGB Enhanced) (Aftermarket) (Unl)" - description "Porklike (World) (v1.05) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Porklike (World) (v1.05) (SGB Enhanced) (Aftermarket) (Unl).gb" size 65536 crc 801f097b sha1 5da110a88799765707e027bcedec0875a637509b ) -) - game ( name "Power Mission (Japan)" description "Power Mission (Japan)" @@ -30624,18 +30826,6 @@ game ( rom ( name "Purikura Pocket 3 - Talent Debut Daisakusen (Japan) (Rev 1) (SGB Enhanced) (NP).gb" size 1048576 crc 458dd05d sha1 7779a103a7ae3e382c8ffa3a6830160af36bb3b4 ) ) -game ( - name "Purple Turtles (World) (Aftermarket) (Unl)" - description "Purple Turtles (World) (Aftermarket) (Unl)" - rom ( name "Purple Turtles (World) (Aftermarket) (Unl).gb" size 262144 crc f7041a97 sha1 d2d7eff063104c8f205c192a902a53092c0b5f4a ) -) - -game ( - name "Pushingo (World) (Aftermarket) (Unl)" - description "Pushingo (World) (Aftermarket) (Unl)" - rom ( name "Pushingo (World) (Aftermarket) (Unl).gb" size 262144 crc a8541ed0 sha1 1ac1e22b191a95fdfa00c34ccba7387c991c827b ) -) - game ( name "Puyo Puyo (Japan) (SGB Enhanced)" description "Puyo Puyo (Japan) (SGB Enhanced)" @@ -30732,12 +30922,6 @@ game ( rom ( name "Quarth (USA, Europe).gb" size 65536 crc bfb112ad sha1 89448b17700a6016a3f81de09a15e097c060d103 flags verified ) ) -game ( - name "Quick Draw (World) (Aftermarket) (Unl)" - description "Quick Draw (World) (Aftermarket) (Unl)" - rom ( name "Quick Draw (World) (Aftermarket) (Unl).gb" size 262144 crc 7704671f sha1 75f96ce54ed8739d58153780e9b573a65f1c5880 ) -) - game ( name "Quiz Nihon Mukashibanashi - Athena no Hatena (Japan)" description "Quiz Nihon Mukashibanashi - Athena no Hatena (Japan)" @@ -30822,12 +31006,6 @@ game ( rom ( name "Radar Mission (USA, Europe).gb" size 131072 crc 581da9c9 sha1 5ab5998a84eebc769f75c482cb0a5586ed97e888 ) ) -game ( - name "Raffles (World) (Aftermarket) (Unl)" - description "Raffles (World) (Aftermarket) (Unl)" - rom ( name "Raffles (World) (Aftermarket) (Unl).gb" size 262144 crc 0b400a91 sha1 aadfe3fd0720696547b73b272354b592b96f98f7 ) -) - game ( name "Raging Fighter (USA, Europe)" description "Raging Fighter (USA, Europe)" @@ -30894,12 +31072,6 @@ game ( rom ( name "Red October o Oe! (Japan).gb" size 131072 crc c2e7be35 sha1 48d5f02a126c32423569065f31d2c5695e39fd2f ) ) -game ( - name "Remute - Living Electronics (World) (Aftermarket) (Unl)" - description "Remute - Living Electronics (World) (Aftermarket) (Unl)" - rom ( name "Remute - Living Electronics (World) (Aftermarket) (Unl).gb" size 2097152 crc 1ced0a62 sha1 bc4bf12344d3b9d028a7013c84b94aea515be196 flags verified ) -) - game ( name "Ren & Stimpy Show, The - Space Cadet Adventures (USA)" description "Ren & Stimpy Show, The - Space Cadet Adventures (USA)" @@ -30930,30 +31102,6 @@ game ( rom ( name "Reservoir Rat (Europe) (En,Fr,De,Es,It).gb" size 262144 crc 2d33e175 sha1 08dad9ac1f045d1c9e403c4ea1368aee991e0094 ) ) -game ( - name "Retroid (World) (Aftermarket) (Unl)" - description "Retroid (World) (Aftermarket) (Unl)" - rom ( name "Retroid (World) (Aftermarket) (Unl).gb" size 262144 crc 9f759f25 sha1 4c7323d6a10852fe416c7bd581d6ffdd2d473bb5 ) -) - -game ( - name "Rewind Time (World) (Aftermarket) (Unl)" - description "Rewind Time (World) (Aftermarket) (Unl)" - rom ( name "Rewind Time (World) (Aftermarket) (Unl).gb" size 262144 crc d8ad184a sha1 903ef8074e58a52bc98dcb9e3f2c88b52fc1335b ) -) - -game ( - name "Rhythm Land (World) (Aftermarket) (Unl)" - description "Rhythm Land (World) (Aftermarket) (Unl)" - rom ( name "Rhythm Land (World) (Aftermarket) (Unl).gb" size 131072 crc 4312c7ff sha1 c79f26ce187edea18cf92be8340ec0a0c8beec87 ) -) - -game ( - name "Rhythm Land (World) (v1.0.1) (Aftermarket) (Unl)" - description "Rhythm Land (World) (v1.0.1) (Aftermarket) (Unl)" - rom ( name "Rhythm Land (World) (v1.0.1) (Aftermarket) (Unl).gb" size 131072 crc fbf98400 sha1 1b831806d32e1ec35bc94a84384c6989433a274d ) -) - game ( name "Riddick Bowe Boxing (Europe)" description "Riddick Bowe Boxing (Europe)" @@ -30972,12 +31120,6 @@ game ( rom ( name "Riddick Bowe Boxing (USA) (Beta).gb" size 131072 crc a07512a6 sha1 69685eaffa523bf199be0c540d9eb561bb27d584 ) ) -game ( - name "Rig Attack (World) (Aftermarket) (Unl)" - description "Rig Attack (World) (Aftermarket) (Unl)" - rom ( name "Rig Attack (World) (Aftermarket) (Unl).gb" size 262144 crc dea8749d sha1 6f0fbac6b6c2e8f2d8df0a0a0e2f0c947e37b39a ) -) - game ( name "Ring Rage (Japan)" description "Ring Rage (Japan)" @@ -31008,12 +31150,6 @@ game ( rom ( name "Roadster (Japan).gb" size 131072 crc 04453e78 sha1 685c31496de738c27160d1f75408da6b95daaae8 ) ) -game ( - name "Robby's Day Out (World) (Aftermarket) (Unl)" - description "Robby's Day Out (World) (Aftermarket) (Unl)" - rom ( name "Robby's Day Out (World) (Aftermarket) (Unl).gb" size 262144 crc c3c89cd9 sha1 9d38b69ab9a4ff7bf387c88f2afed410d450f2e0 ) -) - game ( name "Robin Hood - Prince of Thieves (Europe)" description "Robin Hood - Prince of Thieves (Europe)" @@ -31170,18 +31306,6 @@ game ( rom ( name "Rolan's Curse II (USA).gb" size 131072 crc 2754f360 sha1 7632e23853dd2579012489f75bd370473f0f2c46 flags verified ) ) -game ( - name "Roommate Simulator (World) (Aftermarket) (Unl)" - description "Roommate Simulator (World) (Aftermarket) (Unl)" - rom ( name "Roommate Simulator (World) (Aftermarket) (Unl).gb" size 131072 crc 3c95b1aa sha1 d5c99106c3bd4d46aeb75f513fd4314c19c734b2 ) -) - -game ( - name "Rosa Cupiditatis (World) (2023-05-17) (Demo) (Aftermarket) (Unl)" - description "Rosa Cupiditatis (World) (2023-05-17) (Demo) (Aftermarket) (Unl)" - rom ( name "Rosa Cupiditatis (World) (2023-05-17) (Demo) (Aftermarket) (Unl).gb" size 524288 crc 51d09337 sha1 9e935cca00cb4c3aad7b1dfce9fe59f5d913bdff ) -) - game ( name "Rubble Saver (Japan)" description "Rubble Saver (Japan)" @@ -31230,24 +31354,6 @@ game ( rom ( name "Sa-Ga 3 - Jikuu no Hasha (World) (Ja) (Collection of SaGa).gb" size 262144 crc dc4f4e34 sha1 8125677ee63e9abb4b956ed0bee18fae3e04193b ) ) -game ( - name "Sacred Meat (World) (v1.3) (Aftermarket) (Unl)" - description "Sacred Meat (World) (v1.3) (Aftermarket) (Unl)" - rom ( name "Sacred Meat (World) (v1.3) (Aftermarket) (Unl).gb" size 2097152 crc 6669f0be sha1 25bcf936e8dadb10d288473989891e4f2ec6c605 ) -) - -game ( - name "Sacred Meat (World) (v1.1) (Aftermarket) (Unl)" - description "Sacred Meat (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Sacred Meat (World) (v1.1) (Aftermarket) (Unl).gb" size 2097152 crc 1c4b7eb0 sha1 5cd15f4629fdbcfd6f752d89be755d5ac02b9435 ) -) - -game ( - name "Safe File (World) (SGB Enhanced) (Aftermarket) (Unl)" - description "Safe File (World) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Safe File (World) (SGB Enhanced) (Aftermarket) (Unl).gb" size 262144 crc 03f2dd1a sha1 78fe9c7cd6d0d7f1157c8c7716642d17c4b80303 ) -) - game ( name "Sagaia (Japan)" description "Sagaia (Japan)" @@ -31272,12 +31378,6 @@ game ( rom ( name "Sakigake!! Otoko Juku - Meioutou Kessen (Japan).gb" size 131072 crc 2f0f7f63 sha1 c731f8be269d74748ae54fe5ce5faea89a825e0f ) ) -game ( - name "Sam Mallard - The Case of the Missing Swan (World) (SGB Enhanced) (Aftermarket) (Unl)" - description "Sam Mallard - The Case of the Missing Swan (World) (SGB Enhanced) (Aftermarket) (Unl)" - rom ( name "Sam Mallard - The Case of the Missing Swan (World) (SGB Enhanced) (Aftermarket) (Unl).gb" size 1048576 crc 994a2edd sha1 0132f0311d8478d4f45b3b8e2728698570091d69 ) -) - game ( name "Same Game (Japan) (SGB Enhanced)" description "Same Game (Japan) (SGB Enhanced)" @@ -31392,12 +31492,6 @@ game ( rom ( name "Sea Battle (Europe) (En,Fr,De,Es).gb" size 131072 crc ba091b91 sha1 560d62b96a1b9820e3fd953f76e33b4f5fdc9e2f ) ) -game ( - name "Sea King GB (USA) (Proto) (SGB Enhanced)" - description "Sea King GB (USA) (Proto) (SGB Enhanced)" - rom ( name "Sea King GB (USA) (Proto) (SGB Enhanced).gb" size 1048576 crc a45ef889 sha1 26bebc2394b5da850be55e409b9efcb4d2d29d87 ) -) - game ( name "seaQuest DSV (USA, Europe) (SGB Enhanced)" description "seaQuest DSV (USA, Europe) (SGB Enhanced)" @@ -31464,12 +31558,6 @@ game ( rom ( name "Serpent (USA).gb" size 32768 crc 74d466d7 sha1 3122b3c12c2580c3a81d70c5648f767bf3590aaf flags verified ) ) -game ( - name "Severen (World) (Demo) (Aftermarket) (Unl)" - description "Severen (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Severen (World) (Demo) (Aftermarket) (Unl).gb" size 1048576 crc 642f2244 sha1 d9692aa569820db3f38458819cba21846a2e06f4 ) -) - game ( name "Shadow Warriors (Europe)" description "Shadow Warriors (Europe)" @@ -31500,30 +31588,12 @@ game ( rom ( name "Shanghai Pocket (Japan) (SGB Enhanced).gb" size 262144 crc 6b8eff2c sha1 82fe97442aa625fd36cf865d82f78b07108ede7f ) ) -game ( - name "Shapeshifter, The (World) (Aftermarket) (Unl)" - description "Shapeshifter, The (World) (Aftermarket) (Unl)" - rom ( name "Shapeshifter, The (World) (Aftermarket) (Unl).gb" size 1048576 crc ef735794 sha1 179e69199f19b403b4c1a9675a3ee431ee570797 ) -) - game ( name "Shaq Fu (USA) (SGB Enhanced)" description "Shaq Fu (USA) (SGB Enhanced)" rom ( name "Shaq Fu (USA) (SGB Enhanced).gb" size 524288 crc 7ed43fe6 sha1 5e9e68d9235cf8149232b85fd6080ba8796cb85e ) ) -game ( - name "Shark Attack (World) (Aftermarket) (Unl)" - description "Shark Attack (World) (Aftermarket) (Unl)" - rom ( name "Shark Attack (World) (Aftermarket) (Unl).gb" size 262144 crc 3032025a sha1 6cc65bb719af53128bb04c9ee7c6abbf4ff1c3cf ) -) - -game ( - name "Sheep it Up (World) (Digital) (Aftermarket) (Unl)" - description "Sheep it Up (World) (Digital) (Aftermarket) (Unl)" - rom ( name "Sheep it Up (World) (Digital) (Aftermarket) (Unl).gb" size 32768 crc fa6de2e4 sha1 9ad365ed7d4e07041c0147831a9bb1c496ea0bc8 ) -) - game ( name "Shikinjou (Japan)" description "Shikinjou (Japan)" @@ -31590,24 +31660,6 @@ game ( rom ( name "Shisenshou - Match-Mania (Japan).gb" size 32768 crc 0cdd8b04 sha1 6e84a906f9e1ce43272db84c63f1b037096ac34f flags verified ) ) -game ( - name "Shock Lobster (World) (Aftermarket) (Unl)" - description "Shock Lobster (World) (Aftermarket) (Unl)" - rom ( name "Shock Lobster (World) (Aftermarket) (Unl).gb" size 32768 crc 7a0622e6 sha1 10c1816724cd6e332d2a5aeed4e546e7bd764ebf ) -) - -game ( - name "Shock Lobster (World) (v1.3) (Aftermarket) (Unl)" - description "Shock Lobster (World) (v1.3) (Aftermarket) (Unl)" - rom ( name "Shock Lobster (World) (v1.3) (Aftermarket) (Unl).gb" size 32768 crc 8f244e86 sha1 7b8c8a9ec4758c6880598b9d508bc5805293dd87 ) -) - -game ( - name "Shootris (World) (Aftermarket) (Unl)" - description "Shootris (World) (Aftermarket) (Unl)" - rom ( name "Shootris (World) (Aftermarket) (Unl).gb" size 262144 crc 50180f64 sha1 5d978e6fc4bd5d9717d022360122458e95fffc29 ) -) - game ( name "Shougi (Japan)" description "Shougi (Japan)" @@ -31692,12 +31744,6 @@ game ( rom ( name "Skate or Die - Tour de Thrash (USA).gb" size 131072 crc 02b77c09 sha1 6e1610450da0c836983a1c310524639fefcc304f ) ) -game ( - name "Sloth Story (World) (Aftermarket) (Unl)" - description "Sloth Story (World) (Aftermarket) (Unl)" - rom ( name "Sloth Story (World) (Aftermarket) (Unl).gb" size 262144 crc c873f232 sha1 369d2afec4ffb59d4f3a59ee684c5bfec0b34ff8 ) -) - game ( name "Small Soldiers (USA, Europe) (SGB Enhanced)" description "Small Soldiers (USA, Europe) (SGB Enhanced)" @@ -31734,24 +31780,6 @@ game ( rom ( name "Smurfs, The (USA, Europe) (En,Fr,De) (Rev 1) (SGB Enhanced).gb" size 131072 crc 8b5bcde7 sha1 a0d6a85331fb034f68f05629a5ff85e13adab205 flags verified ) ) -game ( - name "Snail, The (World) (v1.3) (Aftermarket) (Unl)" - description "Snail, The (World) (v1.3) (Aftermarket) (Unl)" - rom ( name "Snail, The (World) (v1.3) (Aftermarket) (Unl).gb" size 262144 crc 422a7b44 sha1 776f7578d747f935ebccda93d6487ffa4dc4bce3 ) -) - -game ( - name "Snakebird (World) (Aftermarket) (Unl)" - description "Snakebird (World) (Aftermarket) (Unl)" - rom ( name "Snakebird (World) (Aftermarket) (Unl).gb" size 131072 crc 4627f98e sha1 99cc82279d65b86b4366bf61db9bf67a78e051dc ) -) - -game ( - name "Snaky Pocket (World) (Aftermarket) (Unl)" - description "Snaky Pocket (World) (Aftermarket) (Unl)" - rom ( name "Snaky Pocket (World) (Aftermarket) (Unl).gb" size 32768 crc 7209370d sha1 f5eab31a499f33b3ae1f7b5b006dcca1df3ac2b9 ) -) - game ( name "Sneaky Snakes (USA, Europe)" description "Sneaky Snakes (USA, Europe)" @@ -31807,9 +31835,15 @@ game ( ) game ( - name "Soccer Boy (Japan)" - description "Soccer Boy (Japan)" - rom ( name "Soccer Boy (Japan).gb" size 65536 crc 23f64e82 sha1 7554b42d1c38508fd615828c96ab58ea8f41de4d ) + name "Soccer Boy (Japan) (En)" + description "Soccer Boy (Japan) (En)" + rom ( name "Soccer Boy (Japan) (En).gb" size 65536 crc 23f64e82 sha1 7554b42d1c38508fd615828c96ab58ea8f41de4d ) +) + +game ( + name "Soccer Boy (Japan) (En) (Beta)" + description "Soccer Boy (Japan) (En) (Beta)" + rom ( name "Soccer Boy (Japan) (En) (Beta).gb" size 65536 crc a46f98d1 sha1 22db7c6096f285222aefbfe413efa1d21de59731 ) ) game ( @@ -31860,24 +31894,6 @@ game ( rom ( name "Solomon's Club (USA).gb" size 65536 crc cea9622a sha1 36abf2be4a16df8e9fe30307cbd8cb949a9b9bdb ) ) -game ( - name "Song of Morus - Gala of Battle (World) (En,Ja) (Aftermarket) (Unl)" - description "Song of Morus - Gala of Battle (World) (En,Ja) (Aftermarket) (Unl)" - rom ( name "Song of Morus - Gala of Battle (World) (En,Ja) (Aftermarket) (Unl).gb" size 262144 crc 665ad70a sha1 c5b6eb610caa2213d8db7ab204bad44d60f7d63a ) -) - -game ( - name "Song of Morus - Ghostly Night (World) (2023-05-20) (Aftermarket) (Unl)" - description "Song of Morus - Ghostly Night (World) (2023-05-20) (Aftermarket) (Unl)" - rom ( name "Song of Morus - Ghostly Night (World) (2023-05-20) (Aftermarket) (Unl).gb" size 262144 crc feed93e0 sha1 721d78d4ef167acfcc00baf909db4c94d522d681 ) -) - -game ( - name "Song of Morus - Ghostly Night (World) (2023-06-08) (Aftermarket) (Unl)" - description "Song of Morus - Ghostly Night (World) (2023-06-08) (Aftermarket) (Unl)" - rom ( name "Song of Morus - Ghostly Night (World) (2023-06-08) (Aftermarket) (Unl).gb" size 262144 crc 6547e5c8 sha1 53a42f45b7ed368d7af9d41f2442fe463c26e545 ) -) - game ( name "Sonic 6 (USA) (Pirate)" description "Sonic 6 (USA) (Pirate)" @@ -31938,12 +31954,6 @@ game ( rom ( name "Space Invaders (Europe) (Beta) (SGB Enhanced).gb" size 131072 crc 2d03dc38 sha1 6a2af41de10dbf6496b18963d904cc41d04bb970 ) ) -game ( - name "Space Trouble (World) (Proto) (Aftermarket) (Unl)" - description "Space Trouble (World) (Proto) (Aftermarket) (Unl)" - rom ( name "Space Trouble (World) (Proto) (Aftermarket) (Unl).gb" size 524288 crc f015931c sha1 ec7bc27387d4d2ac01127bc24e1adf45b6ebc936 ) -) - game ( name "Spanky's Quest (Europe)" description "Spanky's Quest (Europe)" @@ -32010,12 +32020,6 @@ game ( rom ( name "Spider-Man 3 - Invasion of the Spider-Slayers (USA, Europe) (Beta 2) (1993-04-11).gb" size 131072 crc bf2d1f10 sha1 34740dc60663ef33c42573a26e7b207f2cfe4a16 ) ) -game ( - name "Spiky Harold (World) (Aftermarket) (Unl)" - description "Spiky Harold (World) (Aftermarket) (Unl)" - rom ( name "Spiky Harold (World) (Aftermarket) (Unl).gb" size 524288 crc 2ac1b945 sha1 b8f37a64524bde4c2b6e9a1938ed6e5c0a5aad7c ) -) - game ( name "Spirit of F-1, The (Europe)" description "Spirit of F-1, The (Europe)" @@ -32202,6 +32206,12 @@ game ( rom ( name "Star Wars (USA, Europe) (Rev 1).gb" size 131072 crc 5d8deb5b sha1 f6563f526fc786c8666d75dfba9e6d42d787ea89 flags verified ) ) +game ( + name "Star Wars (World) (Limited Run Games)" + description "Star Wars (World) (Limited Run Games)" + rom ( name "Star Wars (World) (Limited Run Games).gb" size 131072 crc 08838397 sha1 02bfb690ce171214bfee900069192e0daafc010d ) +) + game ( name "Star Wars - The Empire Strikes Back (USA, Europe)" description "Star Wars - The Empire Strikes Back (USA, Europe)" @@ -32215,9 +32225,9 @@ game ( ) game ( - name "Stardiver (World) (Aftermarket) (Unl)" - description "Stardiver (World) (Aftermarket) (Unl)" - rom ( name "Stardiver (World) (Aftermarket) (Unl).gb" size 1048576 crc 25ff97f7 sha1 d609b8de2c7a61b7281fec5c761e3504aa4d94e9 ) + name "Star Wars - The Empire Strikes Back (World) (Limited Run Games)" + description "Star Wars - The Empire Strikes Back (World) (Limited Run Games)" + rom ( name "Star Wars - The Empire Strikes Back (World) (Limited Run Games).gb" size 131072 crc 799e4ae8 sha1 dc819b082f671699ac189a49075854d8ff7a2b8f ) ) game ( @@ -32238,6 +32248,12 @@ game ( rom ( name "StarHawk (Europe).gb" size 131072 crc e032e502 sha1 4c22e06cb98119923126f6500568ce9f136a33c5 flags verified ) ) +game ( + name "StarHawk (World) (Limited Run Games)" + description "StarHawk (World) (Limited Run Games)" + rom ( name "StarHawk (World) (Limited Run Games).gb" size 131072 crc 00da50e2 sha1 bf64c1b1071bd243417b6c29fd8a4dd559d3f63a ) +) + game ( name "Stop That Roach! (USA)" description "Stop That Roach! (USA)" @@ -32400,12 +32416,6 @@ game ( rom ( name "Super Chinese Land 3 (Japan) (SGB Enhanced).gb" size 262144 crc e01caf0b sha1 6d8ef3fdd1702d629c679636698e1d483fc3723b flags verified ) ) -game ( - name "Super Covid Go Get Biscuits Adventure (World) (Aftermarket) (Unl)" - description "Super Covid Go Get Biscuits Adventure (World) (Aftermarket) (Unl)" - rom ( name "Super Covid Go Get Biscuits Adventure (World) (Aftermarket) (Unl).gb" size 262144 crc 51946e8d sha1 cac4917d56da02cf88ba68e0c5189a18c2c234ac ) -) - game ( name "Super Donkey Kong 3 (Taiwan) (Unl)" description "Super Donkey Kong 3 (Taiwan) (Unl)" @@ -32598,12 +32608,6 @@ game ( rom ( name "Superman (USA, Europe) (SGB Enhanced).gb" size 131072 crc 358e0091 sha1 3a987cb4ba6f33717ea70d7388ec1dfe6ab934e8 flags verified ) ) -game ( - name "Sushi Gun (World) (Aftermarket) (Unl)" - description "Sushi Gun (World) (Aftermarket) (Unl)" - rom ( name "Sushi Gun (World) (Aftermarket) (Unl).gb" size 262144 crc a9d405d6 sha1 c075856939d4fe3cd250083b527b3e09be70052d ) -) - game ( name "Sutte Hakkun (Japan) (Proto) (SGB Enhanced)" description "Sutte Hakkun (Japan) (Proto) (SGB Enhanced)" @@ -32628,12 +32632,6 @@ game ( rom ( name "Swamp Thing (USA, Europe).gb" size 131072 crc 76ae62c8 sha1 1ff322b5f44d21c951dcdf8d062d99ffa65827e3 flags verified ) ) -game ( - name "Swaplatformer (World) (Aftermarket) (Unl)" - description "Swaplatformer (World) (Aftermarket) (Unl)" - rom ( name "Swaplatformer (World) (Aftermarket) (Unl).gb" size 1048576 crc babe7935 sha1 3df0c37862b7c391a0d091a55db0d305341529c2 ) -) - game ( name "Sword of Hope II, The (USA)" description "Sword of Hope II, The (USA)" @@ -32694,6 +32692,12 @@ game ( rom ( name "Tail 'Gator (USA, Europe).gb" size 65536 crc c5acce7c sha1 ed5f1110a9db4c48d26d53af0973e8b46fe7e4e1 ) ) +game ( + name "Tail 'Gator (World) (Limited Run Games)" + description "Tail 'Gator (World) (Limited Run Games)" + rom ( name "Tail 'Gator (World) (Limited Run Games).gb" size 65536 crc e35cd748 sha1 203f6e20e4d44792c727fe78aaa65e354d014175 ) +) + game ( name "Taito Chase H.Q. (Japan)" description "Taito Chase H.Q. (Japan)" @@ -32730,12 +32734,6 @@ game ( rom ( name "Takahashi Meijin no Bouken-jima III (Japan).gb" size 262144 crc f8fc0b41 sha1 e3fe857a1b7f00a6f7862d7dd401063f98fd0cb6 ) ) -game ( - name "Take It Racing 2 (World) (Demo) (Aftermarket) (Unl)" - description "Take It Racing 2 (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Take It Racing 2 (World) (Demo) (Aftermarket) (Unl).gb" size 1048576 crc 5898c134 sha1 bd3468395deb0009b190d0b5d487962ae65adbee ) -) - game ( name "Takeda Nobuhiro no Ace Striker (Japan)" description "Takeda Nobuhiro no Ace Striker (Japan)" @@ -32808,12 +32806,6 @@ game ( rom ( name "Taz-Mania 2 (USA).gb" size 131072 crc 4ccb65e0 sha1 60116a304e85f04209dc7eb64d9649dc41c963f6 ) ) -game ( - name "Tech and Blood (World) (Aftermarket) (Unl)" - description "Tech and Blood (World) (Aftermarket) (Unl)" - rom ( name "Tech and Blood (World) (Aftermarket) (Unl).gb" size 262144 crc 3da2a358 sha1 40a00fce49b16cb36793df30e5156e5bf3e47778 ) -) - game ( name "Tecmo Bowl (USA)" description "Tecmo Bowl (USA)" @@ -33066,24 +33058,6 @@ game ( rom ( name "Tetris Plus (USA, Europe) (SGB Enhanced).gb" size 262144 crc dafc3bff sha1 dfab75ab6bdc0765ba9a5d33a93ffdb114a49cbf flags verified ) ) -game ( - name "There's Nothing to Do in This Town (World) (Aftermarket) (Unl)" - description "There's Nothing to Do in This Town (World) (Aftermarket) (Unl)" - rom ( name "There's Nothing to Do in This Town (World) (Aftermarket) (Unl).gb" size 1048576 crc 173b549a sha1 e000fbecda9ea6bbbd0c0370cf8c3faaa54bf64e ) -) - -game ( - name "Thin Ice Rescue, The (World) (Aftermarket) (Unl)" - description "Thin Ice Rescue, The (World) (Aftermarket) (Unl)" - rom ( name "Thin Ice Rescue, The (World) (Aftermarket) (Unl).gb" size 32768 crc 3e0483d6 sha1 b789ced0fe26785e7bce765a9d6ee783f9d967d8 ) -) - -game ( - name "TimberMan (World) (Aftermarket) (Unl)" - description "TimberMan (World) (Aftermarket) (Unl)" - rom ( name "TimberMan (World) (Aftermarket) (Unl).gb" size 32768 crc e0b8459c sha1 e3f4b4c4816cc0dda2885519f1386385e6a5e817 ) -) - game ( name "Tintin - Prisoners of the Sun (Europe) (En,Fr,De)" description "Tintin - Prisoners of the Sun (Europe) (En,Fr,De)" @@ -33174,12 +33148,6 @@ game ( rom ( name "Titus the Fox (USA, Europe).gb" size 262144 crc 814fa146 sha1 ba0037aeb21de0bbba3f9294a7861d90aefa5008 flags verified ) ) -game ( - name "Tobu Tobu Girl (World) (Aftermarket) (Unl)" - description "Tobu Tobu Girl (World) (Aftermarket) (Unl)" - rom ( name "Tobu Tobu Girl (World) (Aftermarket) (Unl).gb" size 262144 crc ed12be6c sha1 8a8f3c1f21f903ea5a7df8fc8b0a6aa5a602e150 ) -) - game ( name "Tokio Senki - Eiyuu Retsuden (Japan)" description "Tokio Senki - Eiyuu Retsuden (Japan)" @@ -33342,36 +33310,12 @@ game ( rom ( name "Trappers Tengoku - Spy vs Spy (Japan).gb" size 131072 crc afefd085 sha1 c9eb687f6de7b821255fdd0cbf14f68ad789f97f ) ) -game ( - name "Traumatarium (World) (Demo) (2021-12-09) (Aftermarket) (Unl)" - description "Traumatarium (World) (Demo) (2021-12-09) (Aftermarket) (Unl)" - rom ( name "Traumatarium (World) (Demo) (2021-12-09) (Aftermarket) (Unl).gb" size 2097152 crc 15afd765 sha1 c12e603492f8bcfffd28dd4733c7bc445c507642 ) -) - -game ( - name "Traumatarium (World) (Demo) (2022-06-18) (Aftermarket) (Unl)" - description "Traumatarium (World) (Demo) (2022-06-18) (Aftermarket) (Unl)" - rom ( name "Traumatarium (World) (Demo) (2022-06-18) (Aftermarket) (Unl).gb" size 2097152 crc e1bdf67f sha1 ba492778121622b5288d4188edc344aa41aa6803 ) -) - -game ( - name "Traumatarium (World) (Demo) (2022-03-13) (Aftermarket) (Unl)" - description "Traumatarium (World) (Demo) (2022-03-13) (Aftermarket) (Unl)" - rom ( name "Traumatarium (World) (Demo) (2022-03-13) (Aftermarket) (Unl).gb" size 1048576 crc 42bb7dab sha1 70fded7ce1edc54de85b020460f779feb9bdbc01 ) -) - game ( name "Trax (USA, Europe)" description "Trax (USA, Europe)" rom ( name "Trax (USA, Europe).gb" size 131072 crc 4a38be7d sha1 3f3a31ed7e47319c5815dd6e31ca27a52377423c flags verified ) ) -game ( - name "Treasure Island (World) (Aftermarket) (Unl)" - description "Treasure Island (World) (Aftermarket) (Unl)" - rom ( name "Treasure Island (World) (Aftermarket) (Unl).gb" size 262144 crc cbdec393 sha1 adeaba2723d286d143e0987f51ce9c8ad2f5e839 ) -) - game ( name "Trip World (Europe)" description "Trip World (Europe)" @@ -33384,6 +33328,12 @@ game ( rom ( name "Trip World (Japan).gb" size 262144 crc 11568e64 sha1 ac19d49906e72aaebeffa9ab7106eb346a5efa07 ) ) +game ( + name "Trip World (World) (Limited Run Games)" + description "Trip World (World) (Limited Run Games)" + rom ( name "Trip World (World) (Limited Run Games).gb" size 262144 crc ec67f1e6 sha1 16bb82fa8708cbd159388c55e702b9fb9ed5a41f ) +) + game ( name "TripleA (USA) (Proto)" description "TripleA (USA) (Proto)" @@ -33654,12 +33604,6 @@ game ( rom ( name "V-Rally - Championship Edition (Europe) (En,Fr,De).gb" size 262144 crc d149652b sha1 67d2a6e41b6a1d8372808535ac8c8222d7c53480 flags verified ) ) -game ( - name "Vampire Night Shift (World) (Aftermarket) (Unl)" - description "Vampire Night Shift (World) (Aftermarket) (Unl)" - rom ( name "Vampire Night Shift (World) (Aftermarket) (Unl).gb" size 262144 crc 88acbc1a sha1 ef617803c2cdb14cfe3b3b2111aa239a3744e29e ) -) - game ( name "Vattle Giuce (Japan)" description "Vattle Giuce (Japan)" @@ -33714,12 +33658,6 @@ game ( rom ( name "VS Battler (Japan).gb" size 65536 crc 20ae389a sha1 5f99c7767cbbf5ad9164805214875d7054f49f14 ) ) -game ( - name "Waifu Clicker (World) (Aftermarket) (Unl)" - description "Waifu Clicker (World) (Aftermarket) (Unl)" - rom ( name "Waifu Clicker (World) (Aftermarket) (Unl).gb" size 65536 crc 155f85dc sha1 bb571ed69c3a33e45ba33fbb03a066ba98ae0b20 ) -) - game ( name "Wario Blast Featuring Bomberman! (USA, Europe) (SGB Enhanced)" description "Wario Blast Featuring Bomberman! (USA, Europe) (SGB Enhanced)" @@ -33780,16 +33718,10 @@ game ( rom ( name "Welcome Nakayoshi Park (Japan).gb" size 262144 crc f6e2baae sha1 8779a1557ba0de3c5c8b770413f30bd31717b2ef ) ) -game ( - name "What Friends Are For (World) (Aftermarket) (Unl)" - description "What Friends Are For (World) (Aftermarket) (Unl)" - rom ( name "What Friends Are For (World) (Aftermarket) (Unl).gb" size 262144 crc cbed3dd6 sha1 58538084a964f779c2f756fbe732656f3f7bef66 ) -) - game ( name "Wheel of Fortune (USA)" description "Wheel of Fortune (USA)" - rom ( name "Wheel of Fortune (USA).gb" size 131072 crc 8408fe48 sha1 43de94eda492bfabbdc6e232af9cbd9df080dfd5 ) + rom ( name "Wheel of Fortune (USA).gb" size 131072 crc 8408fe48 sha1 43de94eda492bfabbdc6e232af9cbd9df080dfd5 flags verified ) ) game ( @@ -33822,12 +33754,6 @@ game ( rom ( name "Wily & Right no Rockboard - That's Paradise (Japan) (Proto).gb" size 262144 crc af84dc97 sha1 cc917f113c5cdd1afc3340feb8bf2094d0902cec ) ) -game ( - name "Windows93 Adventure (World) (Aftermarket) (Unl)" - description "Windows93 Adventure (World) (Aftermarket) (Unl)" - rom ( name "Windows93 Adventure (World) (Aftermarket) (Unl).gb" size 1048576 crc e1ad0b6f sha1 3ad7327f6f94976c3d12054cf6deb2666ba9fa66 ) -) - game ( name "Winner's Horse (Japan)" description "Winner's Horse (Japan)" @@ -33852,12 +33778,6 @@ game ( rom ( name "Winter Olympic Games (USA) (Rev 1) (Beta).gb" size 131072 crc 1510305e sha1 6f66dc2ab6f302251591a1252be12367a8e8dfe4 ) ) -game ( - name "Wizard of Wor (World) (Aftermarket) (Unl)" - description "Wizard of Wor (World) (Aftermarket) (Unl)" - rom ( name "Wizard of Wor (World) (Aftermarket) (Unl).gb" size 524288 crc bfb1563e sha1 108eefa154412e3422dce4e63bf34f5826ec1baa ) -) - game ( name "Wizardry Gaiden I - Joou no Junan (Japan)" description "Wizardry Gaiden I - Joou no Junan (Japan)" @@ -33882,12 +33802,6 @@ game ( rom ( name "Wizards & Warriors X - The Fortress of Fear (USA, Europe).gb" size 65536 crc 104eb503 sha1 22a514056e58263dc08602778bc3bf2c0ca6e681 flags verified ) ) -game ( - name "Woolball's Backyard (World) (Aftermarket) (Unl)" - description "Woolball's Backyard (World) (Aftermarket) (Unl)" - rom ( name "Woolball's Backyard (World) (Aftermarket) (Unl).gb" size 65536 crc 69e26eb6 sha1 28795c4b829440549b3ac2afe3282d85a439f7d7 ) -) - game ( name "Wordtris (USA)" description "Wordtris (USA)" @@ -34104,6 +34018,12 @@ game ( rom ( name "Xin Nushen Zhuansheng Waizhuan - Zuihou de Shengjing (Taiwan) (Pirate).gb" size 524288 crc 2298585c sha1 f33091c0bfd840e0ce4c4f99c463cfb92f823a64 ) ) +game ( + name "Xin Shuma Baobei Huang (China) (Pirate)" + description "Xin Shuma Baobei Huang (China) (Pirate)" + rom ( name "Xin Shuma Baobei Huang (China) (Pirate).gb" size 2097152 crc 86869520 sha1 b341efb4831b0fe066fd035ba9f7f876efa3cd50 ) +) + game ( name "Yakuman (Japan)" description "Yakuman (Japan)" @@ -34122,18 +34042,6 @@ game ( rom ( name "Yannick Noah Tennis (France) (En).gb" size 65536 crc 402d4d47 sha1 5bc39c44da587a89bef7478617c402855a1b5b24 flags verified ) ) -game ( - name "Year After, The (World) (En) (Proto) (Aftermarket) (Unl)" - description "Year After, The (World) (En) (Proto) (Aftermarket) (Unl)" - rom ( name "Year After, The (World) (En) (Proto) (Aftermarket) (Unl).gb" size 1048576 crc 4e463a1a sha1 5d84f53f38aa24f54a6f897ca69ffc5d978805af ) -) - -game ( - name "Year After, The (World) (Fr) (Proto) (Aftermarket) (Unl)" - description "Year After, The (World) (Fr) (Proto) (Aftermarket) (Unl)" - rom ( name "Year After, The (World) (Fr) (Proto) (Aftermarket) (Unl).gb" size 1048576 crc fbc50ee8 sha1 52c27e64fb37412c97a53d5dde52c3803fd1e4f7 ) -) - game ( name "Yelu Wangzi (Prince Yeh Rude) (Taiwan) (En) (Unl)" description "Yelu Wangzi (Prince Yeh Rude) (Taiwan) (En) (Unl)" @@ -34224,30 +34132,12 @@ game ( rom ( name "Yu-Gi-Oh! Duel Monsters (Japan) (SGB Enhanced).gb" size 1048576 crc 8875ec54 sha1 07ae4a6437f00f6af462bf84fd0ac1cf345c8365 flags verified ) ) -game ( - name "Yuuto Ichika Makes Friends (World) (En,Ja) (Aftermarket) (Unl)" - description "Yuuto Ichika Makes Friends (World) (En,Ja) (Aftermarket) (Unl)" - rom ( name "Yuuto Ichika Makes Friends (World) (En,Ja) (Aftermarket) (Unl).gb" size 524288 crc 8a667058 sha1 e765d6915f543a5a65e8be440b3f29eb674a5448 ) -) - -game ( - name "Zagan Warrior (World) (Aftermarket) (Unl)" - description "Zagan Warrior (World) (Aftermarket) (Unl)" - rom ( name "Zagan Warrior (World) (Aftermarket) (Unl).gb" size 262144 crc 97fe7a94 sha1 88f76297a4ccf0e3a5ba16ca15237c88346c134a ) -) - game ( name "ZAS (Europe) (Proto)" description "ZAS (Europe) (Proto)" rom ( name "ZAS (Europe) (Proto).gb" size 131072 crc ae282077 sha1 a480d3a205f4c6fe7da41637180459fb2cff9139 ) ) -game ( - name "Zelda - Majora's Mask (World) (v1.1) (Demo) (Aftermarket) (Unl)" - description "Zelda - Majora's Mask (World) (v1.1) (Demo) (Aftermarket) (Unl)" - rom ( name "Zelda - Majora's Mask (World) (v1.1) (Demo) (Aftermarket) (Unl).gb" size 524288 crc f86c2766 sha1 ee86a28cf271be43739e406135e4d8bd4edf7686 ) -) - game ( name "Zelda no Densetsu - Yume o Miru Shima (Japan)" description "Zelda no Densetsu - Yume o Miru Shima (Japan)" @@ -34266,12 +34156,6 @@ game ( rom ( name "Zelda no Densetsu - Yume o Miru Shima (Japan) (Rev 1) (Demo) (Special Version).gb" size 524288 crc bcc0199a sha1 5fc7b8185096c4203536e0d8a302064e63511086 ) ) -game ( - name "Zelda's Adventure (World) (v1.3.0) (Aftermarket) (Unl)" - description "Zelda's Adventure (World) (v1.3.0) (Aftermarket) (Unl)" - rom ( name "Zelda's Adventure (World) (v1.3.0) (Aftermarket) (Unl).gb" size 2097152 crc 0b10adaf sha1 12f9ba0a4673dd2f59ba38e636332333a199dea5 ) -) - game ( name "Zen - Intergalactic Ninja (Europe)" description "Zen - Intergalactic Ninja (Europe)" @@ -34333,9 +34217,9 @@ game ( ) game ( - name "Zoop (Japan)" - description "Zoop (Japan)" - rom ( name "Zoop (Japan).gb" size 65536 crc 10e1a10c sha1 89a74970761700d591c2affc47c9306f49d22ba8 ) + name "Zoop (Japan) (En)" + description "Zoop (Japan) (En)" + rom ( name "Zoop (Japan) (En).gb" size 65536 crc 10e1a10c sha1 89a74970761700d591c2affc47c9306f49d22ba8 ) ) game ( @@ -34363,10 +34247,10 @@ game ( ) clrmamepro ( - name "Nintendo - Game Boy Color" - description "Nintendo - Game Boy Color" - version 20240107-011427 - author "akubi, Arctic Circle System, Aringon, baldjared, Bent, BigFred, bikerspade, BitLooter, C. V. Reynolds, chillerecke, coraz, darthcloud, DeadSkullzJr, Densetsu, DeriLoko3, Flashfire42, foxe, fuzzball, Gefflon, gordonj, halftheisland, Hiccup, hking0036, InternalLoss, Just001Kim, kazumi213, Lesserkuma, Madeline, Money_114, NESBrew12, NGEfreak, nnssxx, norkmetnoil577, NovaAurora, omonim2007, PPLToast, Psychofox11, rarenight, relax, Rifu, sCZther, SonGoku, Tauwasser, togemet2, UnlockerPT, Whovian9369, xprism, xuom2, zg" + name "Nintendo - Game Boy (Aftermarket)" + description "Nintendo - Game Boy (Aftermarket)" + version 20240809-004429 + author "aci68, akubi, Arctic Circle System, Aringon, baldjared, Bent, BigFred, BitLooter, buckwheat, C. V. Reynolds, chillerecke, darthcloud, DeadSkullzJr, Densetsu, DeriLoko3, ElBarto, foxe, fuzzball, Gefflon, Hiccup, hking0036, InternalLoss, Jack, jimmsu, Just001Kim, kazumi213, leekindo, Lesserkuma, Madeline, NESBrew12, NGEfreak, nnssxx, norkmetnoil577, NovaAurora, omonim2007, Powerpuff, PPLToast, Psychofox11, psykopat, rarenight, relax, RetroUprising, rpg2813, sCZther, SonGoku, Tauwasser, togemet2, UnlockerPT, xNo, xprism, xuom2" homepage No-Intro url "https://www.no-intro.org" forcenodump required @@ -34377,13660 +34261,16429 @@ emulator ( ) game ( - name "[BIOS] Challenger GB (USA) (Unl)" - description "[BIOS] Challenger GB (USA) (Unl)" - rom ( name "[BIOS] Challenger GB (USA) (Unl).gbc" size 32768 crc 59579caa sha1 d88c4f29a8d383b2becfe4123671c5ce1f5fdf7b ) + name "14 Juillet (World) (Fr) (Aftermarket) (Unl)" + description "14 Juillet (World) (Fr) (Aftermarket) (Unl)" + rom ( name "14 Juillet (World) (Fr) (Aftermarket) (Unl).gb" size 1048576 crc 7b66bee4 sha1 02f387457a779cbd2f493e52743cd32c169c098e ) ) game ( - name "[BIOS] Genius GB Backup Station (Taiwan) (Unl)" - description "[BIOS] Genius GB Backup Station (Taiwan) (Unl)" - rom ( name "[BIOS] Genius GB Backup Station (Taiwan) (Unl).gbc" size 524288 crc 8f3902f2 sha1 915c141e6dd188b580befdd034705e5c747027cf ) + name "Adulting! (World) (v2.0) (Aftermarket) (Unl)" + description "Adulting! (World) (v2.0) (Aftermarket) (Unl)" + rom ( name "Adulting! (World) (v2.0) (Aftermarket) (Unl).gb" size 524288 crc e56d1244 sha1 d107bd8bf32d0d94a988466885fe1a44aae32c9a flags verified ) ) game ( - name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Rev 1)" - description "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Rev 1)" - rom ( name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Rev 1).gbc" size 2304 crc 41884e46 sha1 1293d68bf9643bc4f36954c1e80e38f39864528d flags verified ) + name "Alley (World) (Aftermarket) (Unl)" + description "Alley (World) (Aftermarket) (Unl)" + rom ( name "Alley (World) (Aftermarket) (Unl).gb" size 32768 crc 2a26f8dd sha1 34bc4f54c0577f55bd40ce1155b6cc74a72ec4e2 ) ) game ( - name "[BIOS] Nintendo Game Boy Color Boot ROM (Japan) (En)" - description "[BIOS] Nintendo Game Boy Color Boot ROM (Japan) (En)" - rom ( name "[BIOS] Nintendo Game Boy Color Boot ROM (Japan) (En).gbc" size 2304 crc e8ef5318 sha1 df5a0d2d49de38fbd31cc2aab8e62c8550e655c0 flags verified ) + name "Alphamax (World) (Aftermarket) (Unl)" + description "Alphamax (World) (Aftermarket) (Unl)" + rom ( name "Alphamax (World) (Aftermarket) (Unl).gb" size 131072 crc 8b493b41 sha1 798dda34d04a06dcee32f44f8a4a045caf734927 ) ) game ( - name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Pokemon Stadium)" - description "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Pokemon Stadium)" - rom ( name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Pokemon Stadium).gbc" size 1008 crc b18c78e8 sha1 d24f388ac71b1cbc9b1d258fd10be13f8cdd3328 ) + name "Anctrayl (World) (Aftermarket) (Unl)" + description "Anctrayl (World) (Aftermarket) (Unl)" + rom ( name "Anctrayl (World) (Aftermarket) (Unl).gb" size 65536 crc c6eca93a sha1 403a40761eec80cf7938bcae3a6deeaf17838311 ) ) game ( - name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Beta) (Virtual Console)" - description "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Beta) (Virtual Console)" - rom ( name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Beta) (Virtual Console).gbc" size 2304 crc e95dc95d sha1 f5f33729a956131d9c44310f0ae3bb0599e9ec3e ) + name "Another Push Game (World) (v1.07) (Proto) (Aftermarket) (Unl)" + description "Another Push Game (World) (v1.07) (Proto) (Aftermarket) (Unl)" + rom ( name "Another Push Game (World) (v1.07) (Proto) (Aftermarket) (Unl).gb" size 262144 crc 8c40cbc9 sha1 6b84d7322d30e9c06a4fdac0050f2c22babaaa7d ) ) game ( - name "[BIOS] Touch Boy System ROM (Taiwan) (Unl)" - description "[BIOS] Touch Boy System ROM (Taiwan) (Unl)" - rom ( name "[BIOS] Touch Boy System ROM (Taiwan) (Unl).gbc" size 131072 crc 4a5f1e2b sha1 dce8de70944e45b5687edef09370b6449f39a918 ) + name "Aqua (World) (v1.1) (Aftermarket) (Unl)" + description "Aqua (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Aqua (World) (v1.1) (Aftermarket) (Unl).gb" size 32768 crc f9ad0e12 sha1 cb5871dc5bca8b6fd5888b9d3a591fbfe082c11d ) ) game ( - name "007 - The World Is Not Enough (USA, Europe)" - description "007 - The World Is Not Enough (USA, Europe)" - rom ( name "007 - The World Is Not Enough (USA, Europe).gbc" size 2097152 crc e038e666 sha1 dd6e952b730c4bd85f8734156d43a2616b68c053 ) + name "Aqua (World) (v1.0) (Aftermarket) (Unl)" + description "Aqua (World) (v1.0) (Aftermarket) (Unl)" + rom ( name "Aqua (World) (v1.0) (Aftermarket) (Unl).gb" size 32768 crc 561aa835 sha1 311728bfcc1c4f51842f9da5022187e749e35045 ) ) game ( - name "10-Pin Bowling (USA) (Rumble Version)" - description "10-Pin Bowling (USA) (Rumble Version)" - rom ( name "10-Pin Bowling (USA) (Rumble Version).gbc" size 1048576 crc 720c7023 sha1 eb0a65dc3069ae5261b04437ffac5efc12697c2a ) + name "Art School Pocket (World) (En) (Aftermarket) (Unl)" + description "Art School Pocket (World) (En) (Aftermarket) (Unl)" + rom ( name "Art School Pocket (World) (En) (Aftermarket) (Unl).gb" size 1048576 crc b4eab528 sha1 c482cfc6ec40b1f33c4ba48ecdc45fef4730b653 ) ) game ( - name "10-Pin Bowling (Europe)" - description "10-Pin Bowling (Europe)" - rom ( name "10-Pin Bowling (Europe).gbc" size 1048576 crc 5449cac0 sha1 90d78bf2f51eed998002d8733d6e223b6478f487 ) + name "Art School Pocket (World) (Es) (Aftermarket) (Unl)" + description "Art School Pocket (World) (Es) (Aftermarket) (Unl)" + rom ( name "Art School Pocket (World) (Es) (Aftermarket) (Unl).gb" size 1048576 crc 240067df sha1 c8a75895c87b11f9493f629c19c54d0c607505bd ) ) game ( - name "102 Dalmatas - Cachorros Al Rescate (Spain)" - description "102 Dalmatas - Cachorros Al Rescate (Spain)" - rom ( name "102 Dalmatas - Cachorros Al Rescate (Spain).gbc" size 1048576 crc f2128908 sha1 eaf3bd27cf7cb084068c5a139da5383a74105ffa ) + name "Art School Pocket (World) (Fr) (Aftermarket) (Unl)" + description "Art School Pocket (World) (Fr) (Aftermarket) (Unl)" + rom ( name "Art School Pocket (World) (Fr) (Aftermarket) (Unl).gb" size 1048576 crc 49a5b74d sha1 73ecffaee185eb2caf1db385d04b863676c777fb ) ) game ( - name "102 Dalmatians - Puppies to the Rescue (USA, Europe)" - description "102 Dalmatians - Puppies to the Rescue (USA, Europe)" - rom ( name "102 Dalmatians - Puppies to the Rescue (USA, Europe).gbc" size 1048576 crc 56b83539 sha1 9f0f45d84e60e9c6f52fde14e1c0a49992aed025 flags verified ) + name "Art School Pocket (World) (De) (Aftermarket) (Unl)" + description "Art School Pocket (World) (De) (Aftermarket) (Unl)" + rom ( name "Art School Pocket (World) (De) (Aftermarket) (Unl).gb" size 1048576 crc 82b73e5b sha1 7772e2b9d5e722e54d19fc6283ccb1fa5d19b641 ) ) game ( - name "102 Dalmatiens a la Rescousse, Les (France)" - description "102 Dalmatiens a la Rescousse, Les (France)" - rom ( name "102 Dalmatiens a la Rescousse, Les (France).gbc" size 1048576 crc e84191a8 sha1 ba028395de3456dc232bac24eda84a30e15f5550 ) + name "Asteroids Chasers (World) (Aftermarket) (Unl)" + description "Asteroids Chasers (World) (Aftermarket) (Unl)" + rom ( name "Asteroids Chasers (World) (Aftermarket) (Unl).gb" size 131072 crc 58d8b1b8 sha1 f93a4e6788eaf0231a6ca269cca297f0d45ec830 flags verified ) ) game ( - name "102 Dalmatiner (Germany)" - description "102 Dalmatiner (Germany)" - rom ( name "102 Dalmatiner (Germany).gbc" size 1048576 crc 725a3483 sha1 69109b87dae04fcb9b65374165527d03845a2dc3 ) + name "Astro-Jump (World) (Aftermarket) (Unl)" + description "Astro-Jump (World) (Aftermarket) (Unl)" + rom ( name "Astro-Jump (World) (Aftermarket) (Unl).gb" size 262144 crc c35a3b39 sha1 1bcb4be684626ce061aad105701548fa3a77e254 ) ) game ( - name "1942 (USA, Europe)" - description "1942 (USA, Europe)" - rom ( name "1942 (USA, Europe).gbc" size 1048576 crc 87431672 sha1 d960e951b18d07e79d046313df49c18313664224 ) + name "Athletic World (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" + description "Athletic World (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Athletic World (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl).gb" size 131072 crc afc128f2 sha1 956be9371990b18e351f2e10848b2ea8bb70c2b7 ) ) game ( - name "20 Second Platformer, A (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "20 Second Platformer, A (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "20 Second Platformer, A (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 2edc4684 sha1 a00b40a3f31bd875f4a0376d22099c3822c9ef98 ) + name "Auto Zone (World) (Aftermarket) (Unl)" + description "Auto Zone (World) (Aftermarket) (Unl)" + rom ( name "Auto Zone (World) (Aftermarket) (Unl).gb" size 524288 crc cee73c14 sha1 3070ec215014633dac5dbbb487aade2e2993c049 ) ) game ( - name "20 Second Platformer, A (World) (GB Compatible) (Aftermarket) (Unl)" - description "20 Second Platformer, A (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "20 Second Platformer, A (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc ff0a848b sha1 837cbb4cf3a92266833099fa06b95edfcdb1865f ) + name "Binding of Isaac, The - Game Boy Edition (World) (Aftermarket) (Unl)" + description "Binding of Isaac, The - Game Boy Edition (World) (Aftermarket) (Unl)" + rom ( name "Binding of Isaac, The - Game Boy Edition (World) (Aftermarket) (Unl).gb" size 32768 crc bf922249 sha1 187782720d4f7c0986a0d916b0c7efa2c488612e ) ) game ( - name "2001 Fatal Fury (Taiwan) (En) (Unl)" - description "2001 Fatal Fury (Taiwan) (En) (Unl)" - rom ( name "2001 Fatal Fury (Taiwan) (En) (Unl).gbc" size 1048576 crc 7eda0e26 sha1 cd632530d71c560111bfc13a341f0f9a234db50a ) + name "Birdie Bartender (World) (Aftermarket) (Unl)" + description "Birdie Bartender (World) (Aftermarket) (Unl)" + rom ( name "Birdie Bartender (World) (Aftermarket) (Unl).gb" size 262144 crc 0bf2a1c8 sha1 aa1325fc7160b84745b076de9b976a1b368da50e ) ) game ( - name "2002 Adventure Digimon 7 (Taiwan) (En) (Unl)" - description "2002 Adventure Digimon 7 (Taiwan) (En) (Unl)" - rom ( name "2002 Adventure Digimon 7 (Taiwan) (En) (Unl).gbc" size 2097152 crc 1bfc7099 sha1 532206800253fce0e81a0825ba49d60a7d6c5ca4 ) + name "Black Castle (World) (Aftermarket) (Unl)" + description "Black Castle (World) (Aftermarket) (Unl)" + rom ( name "Black Castle (World) (Aftermarket) (Unl).gb" size 65536 crc 10f577c7 sha1 45d979be572bb820835d2ecd4e990cd1eadbf5a6 ) ) game ( - name "2002 Digimon Adventure 6 (Taiwan) (En) (Unl)" - description "2002 Digimon Adventure 6 (Taiwan) (En) (Unl)" - rom ( name "2002 Digimon Adventure 6 (Taiwan) (En) (Unl).gbc" size 1048576 crc 3f0d046b sha1 eea8928b277beb56ca8878b6dbfc094b0c3c5463 ) + name "Blitz Bomber (World) (Aftermarket) (Unl)" + description "Blitz Bomber (World) (Aftermarket) (Unl)" + rom ( name "Blitz Bomber (World) (Aftermarket) (Unl).gb" size 262144 crc 5e9956de sha1 b72cbc6bfa6ceef940f49c9c82024071c6f82b90 ) +) + +game ( + name "Blockade (World) (Aftermarket) (Unl)" + description "Blockade (World) (Aftermarket) (Unl)" + rom ( name "Blockade (World) (Aftermarket) (Unl).gb" size 262144 crc b8cfab16 sha1 9e753048a0eb036ac17c08f5a64d860abd1aaaf5 ) +) + +game ( + name "Bork Paw Kisses (World) (Aftermarket) (Unl)" + description "Bork Paw Kisses (World) (Aftermarket) (Unl)" + rom ( name "Bork Paw Kisses (World) (Aftermarket) (Unl).gb" size 262144 crc c29f0d35 sha1 8f1efe6982d2b4ebc1fbeb3ade68dd9b9aabb7a6 ) +) + +game ( + name "Borruga - Neo Pinball (World) (Aftermarket) (Unl)" + description "Borruga - Neo Pinball (World) (Aftermarket) (Unl)" + rom ( name "Borruga - Neo Pinball (World) (Aftermarket) (Unl).gb" size 32768 crc 2bb55ca5 sha1 269f12091d5ab87362a2cb2cf5484f14bfcbd537 flags verified ) +) + +game ( + name "Bounce (World) (v1.1) (Aftermarket) (Unl)" + description "Bounce (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Bounce (World) (v1.1) (Aftermarket) (Unl).gb" size 32768 crc 827f2bd5 sha1 e9abf64de3faeb48151003ac8bb77dea61e838b5 ) +) + +game ( + name "Bouncing Ball, The (World) (Aftermarket) (Unl)" + description "Bouncing Ball, The (World) (Aftermarket) (Unl)" + rom ( name "Bouncing Ball, The (World) (Aftermarket) (Unl).gb" size 65536 crc 42ddf53e sha1 5d331f2e66d7d3f4b4b0fcbaf6ab4b1a0147db3e ) +) + +game ( + name "Bourgogne Game Show 2022 (World) (Aftermarket) (Unl)" + description "Bourgogne Game Show 2022 (World) (Aftermarket) (Unl)" + rom ( name "Bourgogne Game Show 2022 (World) (Aftermarket) (Unl).gb" size 262144 crc 98222a4a sha1 0bdb8ad04469a329c8cee2fb0c55da35f7752042 ) +) + +game ( + name "Breakout Lava-Lamp (World) (Aftermarket) (Unl)" + description "Breakout Lava-Lamp (World) (Aftermarket) (Unl)" + rom ( name "Breakout Lava-Lamp (World) (Aftermarket) (Unl).gb" size 32768 crc 7fbe9fb7 sha1 9de08cdb4cdab58c79e0f2bdaef8b8bb736b9c50 ) +) + +game ( + name "Brimstone (World) (Demo) (Aftermarket) (Unl)" + description "Brimstone (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Brimstone (World) (Demo) (Aftermarket) (Unl).gb" size 262144 crc f18f44a6 sha1 f193af733f6dfdf8d4403be1d9caa67d7e6f3c37 ) +) + +game ( + name "Bug Bites! (World) (Aftermarket) (Unl)" + description "Bug Bites! (World) (Aftermarket) (Unl)" + rom ( name "Bug Bites! (World) (Aftermarket) (Unl).gb" size 262144 crc bb473d7a sha1 8d601612ac262e4548d8b8f6ac19a04cb92ecfb7 ) +) + +game ( + name "Busty Bunny the Bounty Babe (World) (v1.02) (Aftermarket) (Unl)" + description "Busty Bunny the Bounty Babe (World) (v1.02) (Aftermarket) (Unl)" + rom ( name "Busty Bunny the Bounty Babe (World) (v1.02) (Aftermarket) (Unl).gb" size 1048576 crc d0ed199c sha1 a1cbaacdf32cb8fb9a9c59fcb624c729e0ca17bf ) +) + +game ( + name "Castledark (World) (v2.0) (Demo) (Aftermarket) (Unl)" + description "Castledark (World) (v2.0) (Demo) (Aftermarket) (Unl)" + rom ( name "Castledark (World) (v2.0) (Demo) (Aftermarket) (Unl).gb" size 524288 crc 3c492b31 sha1 0861af0039dab4b4f5bce747c6fcd586eced401a ) +) + +game ( + name "Cat and His Boy, A (World) (En,Es) (Demo) (Aftermarket) (Unl)" + description "Cat and His Boy, A (World) (En,Es) (Demo) (Aftermarket) (Unl)" + rom ( name "Cat and His Boy, A (World) (En,Es) (Demo) (Aftermarket) (Unl).gb" size 1048576 crc 11043693 sha1 4db27714c7af6041d5af3cf550e78d7235394afa ) +) + +game ( + name "Cave Fighter (World) (Aftermarket) (Unl)" + description "Cave Fighter (World) (Aftermarket) (Unl)" + rom ( name "Cave Fighter (World) (Aftermarket) (Unl).gb" size 262144 crc e8f91f6a sha1 290048717d0a8cabb3cc591161339550eb53c161 ) +) + +game ( + name "Cel Story (World) (Aftermarket) (Unl)" + description "Cel Story (World) (Aftermarket) (Unl)" + rom ( name "Cel Story (World) (Aftermarket) (Unl).gb" size 524288 crc 8a456b61 sha1 730627b2298806e4f7e02dceffaa0f0edfc316f0 ) +) + +game ( + name "Cel Story (World) (Demo) (Aftermarket) (Unl)" + description "Cel Story (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Cel Story (World) (Demo) (Aftermarket) (Unl).gb" size 524288 crc 92a9b588 sha1 70ab2b72b26c1d1cacc13d377984b969ddf44965 ) +) + +game ( + name "Cheesy Town (World) (En,Ja) (Aftermarket) (Unl)" + description "Cheesy Town (World) (En,Ja) (Aftermarket) (Unl)" + rom ( name "Cheesy Town (World) (En,Ja) (Aftermarket) (Unl).gb" size 262144 crc 3e20c1a8 sha1 f76645a2830fcc733b7392a52112df628f0b7a4a ) +) + +game ( + name "Cherry Rescue! (World) (Aftermarket) (Unl)" + description "Cherry Rescue! (World) (Aftermarket) (Unl)" + rom ( name "Cherry Rescue! (World) (Aftermarket) (Unl).gb" size 524288 crc ba65812a sha1 740dba1827c730cc5d8bf67495bcede3a5352643 ) +) + +game ( + name "Christmas Carols (World) (Aftermarket) (Unl)" + description "Christmas Carols (World) (Aftermarket) (Unl)" + rom ( name "Christmas Carols (World) (Aftermarket) (Unl).gb" size 262144 crc a00bb310 sha1 e19b0a698d8194467d57c00664f00f9898ee5368 ) +) + +game ( + name "Ciao Nonna (World) (v1.1) (Aftermarket) (Unl)" + description "Ciao Nonna (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Ciao Nonna (World) (v1.1) (Aftermarket) (Unl).gb" size 1048576 crc 2165f2e4 sha1 f8e5020298183c3f47836da3890b6bb398e2ecab ) +) + +game ( + name "Ciao Nonna (World) (v2.0) (Aftermarket) (Unl)" + description "Ciao Nonna (World) (v2.0) (Aftermarket) (Unl)" + rom ( name "Ciao Nonna (World) (v2.0) (Aftermarket) (Unl).gb" size 1048576 crc 6afee818 sha1 602709c8655febb42899881a8ef598fb4b3da0c9 ) +) + +game ( + name "Ciao Nonna (World) (v2.1) (Aftermarket) (Unl)" + description "Ciao Nonna (World) (v2.1) (Aftermarket) (Unl)" + rom ( name "Ciao Nonna (World) (v2.1) (Aftermarket) (Unl).gb" size 1048576 crc 225ce296 sha1 45aebfe4e7f5382a4b31c3db270b75d2c458d1b2 ) +) + +game ( + name "Ciao Nonna (World) (Aftermarket) (Unl)" + description "Ciao Nonna (World) (Aftermarket) (Unl)" + rom ( name "Ciao Nonna (World) (Aftermarket) (Unl).gb" size 1048576 crc dd7576d6 sha1 0556eb6160fdca6e7959bba1a619b8e34d974375 ) +) + +game ( + name "Coat Man (World) (Aftermarket) (Unl)" + description "Coat Man (World) (Aftermarket) (Unl)" + rom ( name "Coat Man (World) (Aftermarket) (Unl).gb" size 262144 crc db882ef2 sha1 242f4b3e04fe00b514544c5ef14288d13b5faf2c ) +) + +game ( + name "Commando (World) (Aftermarket) (Unl)" + description "Commando (World) (Aftermarket) (Unl)" + rom ( name "Commando (World) (Aftermarket) (Unl).gb" size 262144 crc 48173941 sha1 c861858e9f2cf7470e739c26ae9f17d3834ce464 ) +) + +game ( + name "Cosmic Courier - Trapped in Limbo (World) (Aftermarket) (Unl)" + description "Cosmic Courier - Trapped in Limbo (World) (Aftermarket) (Unl)" + rom ( name "Cosmic Courier - Trapped in Limbo (World) (Aftermarket) (Unl).gb" size 262144 crc fd304687 sha1 7df11ec2946099d49dd62928118b6d76703dc57c ) +) + +game ( + name "Coucou (World) (Aftermarket) (Unl)" + description "Coucou (World) (Aftermarket) (Unl)" + rom ( name "Coucou (World) (Aftermarket) (Unl).gb" size 32768 crc e6aabd72 sha1 5283268e3640e2924d00aea3b12b2d3930bef43c ) +) + +game ( + name "Counting Sheep (World) (Aftermarket) (Unl)" + description "Counting Sheep (World) (Aftermarket) (Unl)" + rom ( name "Counting Sheep (World) (Aftermarket) (Unl).GB" size 65536 crc 6e97c837 sha1 e7e251ad86fa00803837cf871de62d3f100c83ce ) +) + +game ( + name "Cuthbert in the Cooler (World) (Aftermarket) (Unl)" + description "Cuthbert in the Cooler (World) (Aftermarket) (Unl)" + rom ( name "Cuthbert in the Cooler (World) (Aftermarket) (Unl).gb" size 262144 crc 10838580 sha1 c740bc995adf2bb638bb125a36edc416558fd4c6 ) +) + +game ( + name "Cyber Dreamscape Battle-Deckers 2199 (World) (Aftermarket) (Unl)" + description "Cyber Dreamscape Battle-Deckers 2199 (World) (Aftermarket) (Unl)" + rom ( name "Cyber Dreamscape Battle-Deckers 2199 (World) (Aftermarket) (Unl).gb" size 1048576 crc e3a78253 sha1 45c9c6a7a4ec985146a4a616a49dba45decc6d3e ) +) + +game ( + name "Cyberlice (World) (Proto) (Aftermarket) (Unl)" + description "Cyberlice (World) (Proto) (Aftermarket) (Unl)" + rom ( name "Cyberlice (World) (Proto) (Aftermarket) (Unl).gb" size 131072 crc 7e443267 sha1 220219db1870c3c0a562319aab9f1316b2863689 ) +) + +game ( + name "Dangan GB (World) (v1.1) (Aftermarket) (Unl)" + description "Dangan GB (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Dangan GB (World) (v1.1) (Aftermarket) (Unl).gb" size 262144 crc 5359d6db sha1 10029774046dabec2d8c0533caf94091f6e19071 ) +) + +game ( + name "Dangan GB (World) (Aftermarket) (Unl)" + description "Dangan GB (World) (Aftermarket) (Unl)" + rom ( name "Dangan GB (World) (Aftermarket) (Unl).gb" size 262144 crc daa59c9c sha1 8375d845fcfe4c236cd68f3d56a290f8c7b76c06 ) +) + +game ( + name "Dash (World) (Aftermarket) (Unl)" + description "Dash (World) (Aftermarket) (Unl)" + rom ( name "Dash (World) (Aftermarket) (Unl).gb" size 262144 crc 73868683 sha1 c1ffe7c25a34d65ed166293bc7d2b48b65ca922b ) +) + +game ( + name "Deadeus (World) (v1.3.8) (Aftermarket) (Unl)" + description "Deadeus (World) (v1.3.8) (Aftermarket) (Unl)" + rom ( name "Deadeus (World) (v1.3.8) (Aftermarket) (Unl).gb" size 1048576 crc 7da95971 sha1 23cff594ef4b0bb21883b422940526c7fe81f1fd flags verified ) +) + +game ( + name "Deadeus (World) (v1.2.5) (Aftermarket) (Unl)" + description "Deadeus (World) (v1.2.5) (Aftermarket) (Unl)" + rom ( name "Deadeus (World) (v1.2.5) (Aftermarket) (Unl).gb" size 1048576 crc 9e2bf649 sha1 3feeba5c438880f70cdfdc4ea7e29f77e645e9be flags verified ) +) + +game ( + name "Deadeus (World) (v1.1.0) (Aftermarket) (Unl)" + description "Deadeus (World) (v1.1.0) (Aftermarket) (Unl)" + rom ( name "Deadeus (World) (v1.1.0) (Aftermarket) (Unl).gb" size 1048576 crc 818a7db7 sha1 43a93dc6f7bef002271e583edaeaf2e7162b8af4 ) +) + +game ( + name "Deep Forest (World) (v1.1) (Aftermarket) (Unl)" + description "Deep Forest (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Deep Forest (World) (v1.1) (Aftermarket) (Unl).gb" size 1048576 crc 3ddf177d sha1 517302d20cb5140975e6cd1b3c495786b6390aaf ) +) + +game ( + name "DiaMaze (World) (Aftermarket) (Unl)" + description "DiaMaze (World) (Aftermarket) (Unl)" + rom ( name "DiaMaze (World) (Aftermarket) (Unl).gb" size 262144 crc 956fa901 sha1 f41b98ac4669920ffede1736ddbd9e1f62d4cb0d ) +) + +game ( + name "Dijon Gameboy (World) (En,Fr) (Demo) (Aftermarket) (Unl)" + description "Dijon Gameboy (World) (En,Fr) (Demo) (Aftermarket) (Unl)" + rom ( name "Dijon Gameboy (World) (En,Fr) (Demo) (Aftermarket) (Unl).gb" size 1048576 crc b230b782 sha1 f1796dcbfb6f0f5e01c60222c376cc1c46945806 ) +) + +game ( + name "Dino's Offline Adventure (World) (Aftermarket) (Unl)" + description "Dino's Offline Adventure (World) (Aftermarket) (Unl)" + rom ( name "Dino's Offline Adventure (World) (Aftermarket) (Unl).gb" size 32768 crc d6bd0e6a sha1 6d11c145606f8e7ab25b2b07c299e36c8b442d23 ) +) + +game ( + name "DMG Deals Damage (World) (Aftermarket) (Unl)" + description "DMG Deals Damage (World) (Aftermarket) (Unl)" + rom ( name "DMG Deals Damage (World) (Aftermarket) (Unl).gb" size 32768 crc 250e0cbd sha1 a15539199e4b6bd2a71d1ac0e7c61ae4f19a65e7 flags verified ) +) + +game ( + name "Do I Pass (World) (En) (Demo) (Aftermarket) (Unl)" + description "Do I Pass (World) (En) (Demo) (Aftermarket) (Unl)" + rom ( name "Do I Pass (World) (En) (Demo) (Aftermarket) (Unl).gb" size 1048576 crc f339fa82 sha1 bdbc082017bdf2e4caa84e7d00dad9707727e9d4 ) +) + +game ( + name "Do I Pass (World) (En) (v1.4) (Aftermarket) (Unl)" + description "Do I Pass (World) (En) (v1.4) (Aftermarket) (Unl)" + rom ( name "Do I Pass (World) (En) (v1.4) (Aftermarket) (Unl).gb" size 1048576 crc cfb44d68 sha1 6dde71bbec8b807af5132d1ef2e99c6bb6af3a1c ) +) + +game ( + name "Do I Pass (World) (En) (v1.4) (Web) (Aftermarket) (Unl)" + description "Do I Pass (World) (En) (v1.4) (Web) (Aftermarket) (Unl)" + rom ( name "Do I Pass (World) (En) (v1.4) (Web) (Aftermarket) (Unl).gb" size 1048576 crc 62e0c3a2 sha1 e1b516e472e0c681b4ad1c7f4aeda55c91e7f340 ) +) + +game ( + name "Do I Pass (World) (Fr) (v1.4.2) (Aftermarket) (Unl)" + description "Do I Pass (World) (Fr) (v1.4.2) (Aftermarket) (Unl)" + rom ( name "Do I Pass (World) (Fr) (v1.4.2) (Aftermarket) (Unl).gb" size 1048576 crc e393d4aa sha1 d45dfcab4a76b62ea1e10730d01f755e12137484 ) +) + +game ( + name "Do I Pass (World) (En) (v1.5) (Aftermarket) (Unl)" + description "Do I Pass (World) (En) (v1.5) (Aftermarket) (Unl)" + rom ( name "Do I Pass (World) (En) (v1.5) (Aftermarket) (Unl).gb" size 1048576 crc 3890e0a4 sha1 6998e1bbf2ccb9db3d661ddac2d7edf7571d0af7 ) +) + +game ( + name "Dog's Muck Island (World) (Aftermarket) (Unl)" + description "Dog's Muck Island (World) (Aftermarket) (Unl)" + rom ( name "Dog's Muck Island (World) (Aftermarket) (Unl).gb" size 262144 crc 79a7a06c sha1 eb4cea3b9db770bf3b586578af1ad7427d88ee8e ) +) + +game ( + name "Don't Call Me Mama But Yes I Am Your Mama (World) (v2.0) (Aftermarket) (Unl)" + description "Don't Call Me Mama But Yes I Am Your Mama (World) (v2.0) (Aftermarket) (Unl)" + rom ( name "Don't Call Me Mama But Yes I Am Your Mama (World) (v2.0) (Aftermarket) (Unl).gb" size 1048576 crc 83247308 sha1 4579eaa45e2bf8f17f4dc99bdfb0b98270b871f5 ) +) + +game ( + name "Dragon Battle (World) (Demo) (Aftermarket) (Unl)" + description "Dragon Battle (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Dragon Battle (World) (Demo) (Aftermarket) (Unl).gb" size 4194304 crc c1e1e52c sha1 c5ac56e266c421a1c5b82de46859a44f75d03359 ) +) + +game ( + name "Dragonborne (World) (Aftermarket) (Unl)" + description "Dragonborne (World) (Aftermarket) (Unl)" + rom ( name "Dragonborne (World) (Aftermarket) (Unl).gb" size 2097152 crc 0ae28712 sha1 e3cd09069ee59ed3f7915a79af0667de4ebd7d50 ) +) + +game ( + name "Dragonborne (World) (Demo) (Aftermarket) (Unl)" + description "Dragonborne (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Dragonborne (World) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc eda66890 sha1 3a5bcd9daa830842da60d8ebf35fa7036a259d76 ) +) + +game ( + name "Duck (World) (Aftermarket) (Unl)" + description "Duck (World) (Aftermarket) (Unl)" + rom ( name "Duck (World) (Aftermarket) (Unl).gb" size 32768 crc 583691fd sha1 f7eccfb9ade282423db6122882adcef6fbf3e955 ) +) + +game ( + name "Elden Ring GB (World) (Aftermarket) (Unl)" + description "Elden Ring GB (World) (Aftermarket) (Unl)" + rom ( name "Elden Ring GB (World) (Aftermarket) (Unl).gb" size 524288 crc e7a420f3 sha1 2e0bec6acf1a94ae3f2f6cf2040323862933d95a ) +) + +game ( + name "ever - Lucid Space Program (World) (Aftermarket) (Unl)" + description "ever - Lucid Space Program (World) (Aftermarket) (Unl)" + rom ( name "ever - Lucid Space Program (World) (Aftermarket) (Unl).gb" size 262144 crc a5006140 sha1 051a1b8739c820424fad5103b64e578dd9a5b841 ) +) + +game ( + name "F-Zero - Project (World) (Aftermarket) (Unl)" + description "F-Zero - Project (World) (Aftermarket) (Unl)" + rom ( name "F-Zero - Project (World) (Aftermarket) (Unl).gb" size 1048576 crc 4c707059 sha1 5b823ee17691d286a45f0667cddd59ccaaab5d8b ) +) + +game ( + name "Fairy-chan (World) (v0.1.4) (Demo) (Aftermarket) (Unl)" + description "Fairy-chan (World) (v0.1.4) (Demo) (Aftermarket) (Unl)" + rom ( name "Fairy-chan (World) (v0.1.4) (Demo) (Aftermarket) (Unl).gb" size 262144 crc 4f04cdfc sha1 591980cb5e17104d826c2a915f53bfc8a21affca ) +) + +game ( + name "Farm, The (World) (Aftermarket) (Unl)" + description "Farm, The (World) (Aftermarket) (Unl)" + rom ( name "Farm, The (World) (Aftermarket) (Unl).gb" size 524288 crc fbc1b5e8 sha1 d0fe06920f7e771d76507f60881904370ffbc145 ) +) + +game ( + name "Final Fantasy XI Adventure (World) (Aftermarket) (Unl)" + description "Final Fantasy XI Adventure (World) (Aftermarket) (Unl)" + rom ( name "Final Fantasy XI Adventure (World) (Aftermarket) (Unl).gb" size 1048576 crc 6cfb4669 sha1 339fd673509a5ac8f25426af25b4ccc96e8d2880 ) +) + +game ( + name "Finders Keepers (World) (Aftermarket) (Unl)" + description "Finders Keepers (World) (Aftermarket) (Unl)" + rom ( name "Finders Keepers (World) (Aftermarket) (Unl).gb" size 524288 crc 6a98ac61 sha1 e40dd804388df8c08d3890d79eeafd8542cc8805 ) +) + +game ( + name "FlappyBird GB (World) (Aftermarket) (Unl)" + description "FlappyBird GB (World) (Aftermarket) (Unl)" + rom ( name "FlappyBird GB (World) (Aftermarket) (Unl).gb" size 131072 crc 51aa9cc2 sha1 8f2b803fdd737c9885b96d11622008f706061e00 ) +) + +game ( + name "Fly O'Clock (World) (Aftermarket) (Unl)" + description "Fly O'Clock (World) (Aftermarket) (Unl)" + rom ( name "Fly O'Clock (World) (Aftermarket) (Unl).gb" size 32768 crc 93df7f55 sha1 83dc8498bdbabc14a8f81a715c9da19970c1f0b9 ) +) + +game ( + name "Footballer of the Year (World) (v1.1) (Aftermarket) (Unl)" + description "Footballer of the Year (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Footballer of the Year (World) (v1.1) (Aftermarket) (Unl).gb" size 1048576 crc 6e6ce1bb sha1 44166b7e6e8411ae61f37c7a78e90acaae66bcc5 ) +) + +game ( + name "Footballer of the Year (World) (v1.0) (Aftermarket) (Unl)" + description "Footballer of the Year (World) (v1.0) (Aftermarket) (Unl)" + rom ( name "Footballer of the Year (World) (v1.0) (Aftermarket) (Unl).gb" size 1048576 crc 91faa9b1 sha1 b7542729c8665a1a2af47f58fc59cc90f66fd77d ) +) + +game ( + name "Fydo's Magic Tiles (World) (2022-09-01) (Aftermarket) (Unl)" + description "Fydo's Magic Tiles (World) (2022-09-01) (Aftermarket) (Unl)" + rom ( name "Fydo's Magic Tiles (World) (2022-09-01) (Aftermarket) (Unl).gb" size 32768 crc 36e2ca02 sha1 fd985703b296dd0bf74225c72155ea9e51dd6853 ) +) + +game ( + name "G-Man (World) (Aftermarket) (Unl)" + description "G-Man (World) (Aftermarket) (Unl)" + rom ( name "G-Man (World) (Aftermarket) (Unl).gb" size 524288 crc 7296da69 sha1 fdc9933d46a063575c175453b1da8042fd28b135 ) +) + +game ( + name "G-ZERO (World) (v2.6) (Aftermarket) (Unl)" + description "G-ZERO (World) (v2.6) (Aftermarket) (Unl)" + rom ( name "G-ZERO (World) (v2.6) (Aftermarket) (Unl).gb" size 65536 crc 7dd0c878 sha1 929d25a612308614ac3ac2ee5a19a9cd4a9968d6 ) +) + +game ( + name "GameBoy WORDLE (World) (Aftermarket) (Unl)" + description "GameBoy WORDLE (World) (Aftermarket) (Unl)" + rom ( name "GameBoy WORDLE (World) (Aftermarket) (Unl).gb" size 32768 crc cc971c0f sha1 ba93939b93ab3f3aa5f7aa451d50d9b89220adbc ) +) + +game ( + name "Genesis (World) (Aftermarket) (Unl)" + description "Genesis (World) (Aftermarket) (Unl)" + rom ( name "Genesis (World) (Aftermarket) (Unl).gb" size 65536 crc 74b3ec78 sha1 ca43f82d73ba0b3e43ec17f6bc6761c09ca23626 ) +) + +game ( + name "Genesis II (World) (Demo) (Aftermarket) (Unl)" + description "Genesis II (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Genesis II (World) (Demo) (Aftermarket) (Unl).gb" size 262144 crc d7aec1cc sha1 9700ea1278850df004ded7553253cfdd354f4ada ) +) + +game ( + name "Ghost Town (World) (Aftermarket) (Unl)" + description "Ghost Town (World) (Aftermarket) (Unl)" + rom ( name "Ghost Town (World) (Aftermarket) (Unl).gb" size 262144 crc 2d27cdf2 sha1 af526273cdaa6423b92d0484fb27af56fe355a5d ) +) + +game ( + name "Glory Hunters - Chapter 1 (World) (v0.1) (Demo) (Aftermarket) (Unl)" + description "Glory Hunters - Chapter 1 (World) (v0.1) (Demo) (Aftermarket) (Unl)" + rom ( name "Glory Hunters - Chapter 1 (World) (v0.1) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc 4b19366d sha1 77f3b561bf28a81f38dbedc351752e10ff4c23dc ) +) + +game ( + name "Glory Hunters - Chapter 1 (World) (v0.2) (Demo) (Aftermarket) (Unl)" + description "Glory Hunters - Chapter 1 (World) (v0.2) (Demo) (Aftermarket) (Unl)" + rom ( name "Glory Hunters - Chapter 1 (World) (v0.2) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc 3f34ff66 sha1 a0bff49b6917186d27dc24773da0674a18a6212c ) +) + +game ( + name "Great Detention Getaway, The (World) (Aftermarket) (Unl)" + description "Great Detention Getaway, The (World) (Aftermarket) (Unl)" + rom ( name "Great Detention Getaway, The (World) (Aftermarket) (Unl).gb" size 131072 crc 13b72ee4 sha1 efc3208cb99f9fb213875acd7b9b6c2e633b696a ) +) + +game ( + name "Gun Law (World) (Aftermarket) (Unl)" + description "Gun Law (World) (Aftermarket) (Unl)" + rom ( name "Gun Law (World) (Aftermarket) (Unl).gb" size 262144 crc b0d53211 sha1 ef6e3d287e99bd61861a333165c92b306238a45f ) +) + +game ( + name "Gunman Clive (World) (Demo) (Aftermarket) (Unl)" + description "Gunman Clive (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Gunman Clive (World) (Demo) (Aftermarket) (Unl).gb" size 65536 crc 11f5fded sha1 ec03763db2c0d754e2eb7e98384ed92fc8aeeb1d ) +) + +game ( + name "Gunship (World) (Aftermarket) (Unl)" + description "Gunship (World) (Aftermarket) (Unl)" + rom ( name "Gunship (World) (Aftermarket) (Unl).gb" size 131072 crc bd31eef8 sha1 a801977c3746799cfb4d8bdfd679e45cccd3b719 ) +) + +game ( + name "Harbour Attack (World) (Aftermarket) (Unl)" + description "Harbour Attack (World) (Aftermarket) (Unl)" + rom ( name "Harbour Attack (World) (Aftermarket) (Unl).gb" size 262144 crc 4018ebf7 sha1 5bbbe727ebc6a489f1a498d067e4f05d0d69b60f ) +) + +game ( + name "Heart Knight (World) (Aftermarket) (Unl)" + description "Heart Knight (World) (Aftermarket) (Unl)" + rom ( name "Heart Knight (World) (Aftermarket) (Unl).gb" size 32768 crc c7ecac73 sha1 dedcab41f58c58834e3534e877c494669a0d8952 ) +) + +game ( + name "Hermano (World) (v1.1) (Aftermarket) (Unl)" + description "Hermano (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Hermano (World) (v1.1) (Aftermarket) (Unl).gb" size 262144 crc 74a0419b sha1 c42cfe91a1ec593a76291e031c47137bd794ffda ) +) + +game ( + name "Hugo (World) (Aftermarket) (Unl)" + description "Hugo (World) (Aftermarket) (Unl)" + rom ( name "Hugo (World) (Aftermarket) (Unl).gb" size 262144 crc 8cc87f60 sha1 53fac2774b29a32501788e1eac65db23bf5c7b8f ) +) + +game ( + name "If (World) (Aftermarket) (Unl)" + description "If (World) (Aftermarket) (Unl)" + rom ( name "If (World) (Aftermarket) (Unl).gb" size 1048576 crc be7e4454 sha1 c11d8dc9ce96133f679678b07822a82f985e16f9 ) +) + +game ( + name "Impossible Gameboy (World) (Aftermarket) (Unl)" + description "Impossible Gameboy (World) (Aftermarket) (Unl)" + rom ( name "Impossible Gameboy (World) (Aftermarket) (Unl).gb" size 131072 crc ab65b738 sha1 d31cedd6227b23cf3d8ef81c73f133ab0b57e4f4 ) +) + +game ( + name "Interblocked (World) (Aftermarket) (Unl)" + description "Interblocked (World) (Aftermarket) (Unl)" + rom ( name "Interblocked (World) (Aftermarket) (Unl).gb" size 262144 crc 5c208855 sha1 8e46486533a3de9ee87cc07bf8efaf818752a61a ) +) + +game ( + name "Into the Blue (World) (Aftermarket) (Unl)" + description "Into the Blue (World) (Aftermarket) (Unl)" + rom ( name "Into the Blue (World) (Aftermarket) (Unl).gb" size 131072 crc 7714e96e sha1 5ac7a349bb37c8767c9db264ed8ae7b7647fa8ea ) +) + +game ( + name "Island, The (World) (Demo) (Aftermarket) (Unl)" + description "Island, The (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Island, The (World) (Demo) (Aftermarket) (Unl).gb" size 131072 crc d6a43a64 sha1 38419c50713b4e403b80f1da151a3e9d0654d47c ) +) + +game ( + name "Jabberwocky (World) (Aftermarket) (Unl)" + description "Jabberwocky (World) (Aftermarket) (Unl)" + rom ( name "Jabberwocky (World) (Aftermarket) (Unl).gb" size 1048576 crc cfc51717 sha1 b4e447f2197688c740a45dce27879a62c742fb96 ) +) + +game ( + name "Jane in the Jungle (World) (Aftermarket) (Unl)" + description "Jane in the Jungle (World) (Aftermarket) (Unl)" + rom ( name "Jane in the Jungle (World) (Aftermarket) (Unl).gb" size 262144 crc c68e751a sha1 dfc65dcf700a26b273d705b7cfececbc44b80587 ) +) + +game ( + name "Jet Set Willy (World) (Aftermarket) (Unl)" + description "Jet Set Willy (World) (Aftermarket) (Unl)" + rom ( name "Jet Set Willy (World) (Aftermarket) (Unl).gb" size 262144 crc 1686d7ed sha1 0e594224506fd087e36c66bb66905d4c91b02461 ) +) + +game ( + name "Joe Blade 2 (World) (Aftermarket) (Unl)" + description "Joe Blade 2 (World) (Aftermarket) (Unl)" + rom ( name "Joe Blade 2 (World) (Aftermarket) (Unl).gb" size 524288 crc 09f75c70 sha1 f001dffcd16be670c36a98dd9136f6f9fbf5b85d ) +) + +game ( + name "Jumpy (World) (Aftermarket) (Unl)" + description "Jumpy (World) (Aftermarket) (Unl)" + rom ( name "Jumpy (World) (Aftermarket) (Unl).gb" size 262144 crc 70f9af24 sha1 29152d8874c2a048f71e0be86aa9ee2d77996fb6 ) +) + +game ( + name "Just Fishing (World) (Aftermarket) (Unl)" + description "Just Fishing (World) (Aftermarket) (Unl)" + rom ( name "Just Fishing (World) (Aftermarket) (Unl).gb" size 131072 crc c0f675fc sha1 3591b258afb94e0b4d9e095ecf702fc4de3061e3 ) +) + +game ( + name "Kenzie's Birthday Dash (World) (Aftermarket) (Unl)" + description "Kenzie's Birthday Dash (World) (Aftermarket) (Unl)" + rom ( name "Kenzie's Birthday Dash (World) (Aftermarket) (Unl).gb" size 1048576 crc 986bfd75 sha1 6d15b5bc33d7c7771ba62d56ae7f25fa081bc564 ) +) + +game ( + name "Kitten's Getaway (World) (Es) (Aftermarket) (Unl)" + description "Kitten's Getaway (World) (Es) (Aftermarket) (Unl)" + rom ( name "Kitten's Getaway (World) (Es) (Aftermarket) (Unl).gb" size 262144 crc e621c535 sha1 a9e71e4a27e633e1649a131150c5811483b441d6 ) +) + +game ( + name "Krezber (World) (Aftermarket) (Unl)" + description "Krezber (World) (Aftermarket) (Unl)" + rom ( name "Krezber (World) (Aftermarket) (Unl).gb" size 65536 crc 27bddf77 sha1 2f4cffafc411b6895bf365b0773c4fa5d2ef7be3 ) +) + +game ( + name "Kudzu (World) (v0.96) (Demo) (Aftermarket) (Unl)" + description "Kudzu (World) (v0.96) (Demo) (Aftermarket) (Unl)" + rom ( name "Kudzu (World) (v0.96) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc 0610049a sha1 a6fbe1a524547bebabc5e6b3baff1dff8f13dbd0 ) +) + +game ( + name "Kudzu (World) (v1.1c) (Demo) (Aftermarket) (Unl)" + description "Kudzu (World) (v1.1c) (Demo) (Aftermarket) (Unl)" + rom ( name "Kudzu (World) (v1.1c) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc 4462ff70 sha1 18a2a762d7b994865c845ac2aa0a0cf7655af74e flags verified ) +) + +game ( + name "Laser Squad Alter (World) (Aftermarket) (Unl)" + description "Laser Squad Alter (World) (Aftermarket) (Unl)" + rom ( name "Laser Squad Alter (World) (Aftermarket) (Unl).gb" size 1048576 crc a39b3a5a sha1 1620e585e77a2457cffde82453bec0c7a04e07cf ) +) + +game ( + name "Last Crown Warriors (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" + description "Last Crown Warriors (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Last Crown Warriors (World) (Demo) (SGB Enhanced) (Aftermarket) (Unl).gb" size 262144 crc 2c430576 sha1 0e290b387a45b6ea85c6d49bf18bce3ce94951b7 ) +) + +game ( + name "Last Crown Warriors (World) (v1.1.1) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" + description "Last Crown Warriors (World) (v1.1.1) (Demo) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Last Crown Warriors (World) (v1.1.1) (Demo) (SGB Enhanced) (Aftermarket) (Unl).gb" size 262144 crc 5cf1a6f9 sha1 9fac1324e863f719674219eb41e45f1f745c67a9 ) +) + +game ( + name "Lawn Mower Land (World) (Aftermarket) (Unl)" + description "Lawn Mower Land (World) (Aftermarket) (Unl)" + rom ( name "Lawn Mower Land (World) (Aftermarket) (Unl).gb" size 32768 crc 11c62e39 sha1 1d6aa817ebf2a7e5d22285b906540272b67169da ) +) + +game ( + name "Leak, The (World) (Aftermarket) (Unl)" + description "Leak, The (World) (Aftermarket) (Unl)" + rom ( name "Leak, The (World) (Aftermarket) (Unl).GB" size 65536 crc ba3cfeae sha1 98de2d8be75e6d9cb4e87afe14b1380c033de797 ) +) + +game ( + name "Life's Too Short (World) (Aftermarket) (Unl)" + description "Life's Too Short (World) (Aftermarket) (Unl)" + rom ( name "Life's Too Short (World) (Aftermarket) (Unl).gb" size 262144 crc 458174cc sha1 7b704cd999cbeeb9991d675e2b1e67a906fa766d ) +) + +game ( + name "Linea, La (World) (Aftermarket) (Unl)" + description "Linea, La (World) (Aftermarket) (Unl)" + rom ( name "Linea, La (World) (Aftermarket) (Unl).gb" size 262144 crc c8750c01 sha1 00348fec54b5d3ebb762484bdcc015881bb9e95b ) +) + +game ( + name "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" + description "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" + rom ( name "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl).gb" size 524288 crc 9c4f03fd sha1 288cb53b4782df4409ee683e9aa11b4dd2a3a53e ) +) + +game ( + name "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl)" + description "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Little Tales of Alexandria, The (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl).gb" size 524288 crc e5988949 sha1 08d033c7ef20fd4d24d1f07b3ebb177fb9b78673 ) +) + +game ( + name "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl)" + description "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl).gb" size 524288 crc 59568248 sha1 6571db155f6f25eeeec86d28b105bf8fef156322 ) +) + +game ( + name "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" + description "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" + rom ( name "Little Tales of Alexandria, The (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl).gb" size 524288 crc a26345b8 sha1 641110cb187657fd15ea254440e1c74ab4a88856 ) +) + +game ( + name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" + description "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" + rom ( name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl).gb" size 131072 crc d70f1d25 sha1 02e2fb6cbc5cff05ed775c9e1cd9acc07fa2e036 ) +) + +game ( + name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" + description "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl)" + rom ( name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Batteryless) (Aftermarket) (Unl).gb" size 131072 crc ae07c093 sha1 9f40b8719b3fdd2f7e6c59a4f616e9eb712d538d ) +) + +game ( + name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl)" + description "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC3) (SGB Enhanced) (Aftermarket) (Unl).gb" size 131072 crc 34671dc6 sha1 377d22d54e6e1fa4fcd4b4576d5886774f9f6c97 ) +) + +game ( + name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl)" + description "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Little Tales of Alexandria, The - Mr Meows Dance Party! (World) (MBC5) (SGB Enhanced) (Aftermarket) (Unl).gb" size 131072 crc a8fb0d7a sha1 26803ba3413c7c52a8a58393f63472bc87ec3c6b ) +) + +game ( + name "Lost Knight (World) (Proto) (Aftermarket) (Unl)" + description "Lost Knight (World) (Proto) (Aftermarket) (Unl)" + rom ( name "Lost Knight (World) (Proto) (Aftermarket) (Unl).gb" size 262144 crc 5ddcc941 sha1 ca9003ead7ee153faf087a83c4bdef1d409c597b ) +) + +game ( + name "Lucy and the Gem Dungeon (World) (Aftermarket) (Unl)" + description "Lucy and the Gem Dungeon (World) (Aftermarket) (Unl)" + rom ( name "Lucy and the Gem Dungeon (World) (Aftermarket) (Unl).gb" size 524288 crc 1a5106a2 sha1 f56c1b324b8c1e17da86e40c5e9a887ec19b0c80 ) +) + +game ( + name "Machine, The (World) (v1.0) (Aftermarket) (Unl)" + description "Machine, The (World) (v1.0) (Aftermarket) (Unl)" + rom ( name "Machine, The (World) (v1.0) (Aftermarket) (Unl).gb" size 2097152 crc b06036a9 sha1 50c5d1eb7c8946ac2d7e2c566b1ea4a9b0d58e90 ) +) + +game ( + name "Mad Monster (World) (Aftermarket) (Unl)" + description "Mad Monster (World) (Aftermarket) (Unl)" + rom ( name "Mad Monster (World) (Aftermarket) (Unl).gb" size 524288 crc c3fd371c sha1 9f4bea7ca7d26080110f54392314c60761236638 ) +) + +game ( + name "Magipanels (World) (2022-02-09) (Demo) (Aftermarket) (Unl)" + description "Magipanels (World) (2022-02-09) (Demo) (Aftermarket) (Unl)" + rom ( name "Magipanels (World) (2022-02-09) (Demo) (Aftermarket) (Unl).gb" size 131072 crc 76fcbc30 sha1 7a759372bd013dcdb59c9131a2908085fc04d648 ) +) + +game ( + name "Magipanels (World) (Aftermarket) (Unl)" + description "Magipanels (World) (Aftermarket) (Unl)" + rom ( name "Magipanels (World) (Aftermarket) (Unl).gb" size 131072 crc 0b66561b sha1 c9513f6769098f2185f632f87386788f0f0b6ad8 ) +) + +game ( + name "Mai Nurse (World) (v1.01) (Aftermarket) (Unl)" + description "Mai Nurse (World) (v1.01) (Aftermarket) (Unl)" + rom ( name "Mai Nurse (World) (v1.01) (Aftermarket) (Unl).gb" size 131072 crc 20d562b2 sha1 2d3b1dac701b518f9e5109dbc5e7d2bc8420dec3 ) +) + +game ( + name "Make Way (World) (Aftermarket) (Unl)" + description "Make Way (World) (Aftermarket) (Unl)" + rom ( name "Make Way (World) (Aftermarket) (Unl).gb" size 1048576 crc edeee5a8 sha1 19fd02e9318ed81ec968a2fca31ea0c3d8d94a7b ) +) + +game ( + name "Marron Helps a Friend (World) (Aftermarket) (Unl)" + description "Marron Helps a Friend (World) (Aftermarket) (Unl)" + rom ( name "Marron Helps a Friend (World) (Aftermarket) (Unl).gb" size 1048576 crc 08a3a987 sha1 adcd56fa3eba93edd20be25ae5cb349070cd0323 flags verified ) +) + +game ( + name "Marzipan Beef Reverser (World) (v2.0) (Aftermarket) (Unl)" + description "Marzipan Beef Reverser (World) (v2.0) (Aftermarket) (Unl)" + rom ( name "Marzipan Beef Reverser (World) (v2.0) (Aftermarket) (Unl).gb" size 262144 crc dccaeb60 sha1 1e4fc83bfe9c9063975a3862770e4afee3f947a4 ) +) + +game ( + name "Marzipan Beef Reverser (World) (Aftermarket) (Unl)" + description "Marzipan Beef Reverser (World) (Aftermarket) (Unl)" + rom ( name "Marzipan Beef Reverser (World) (Aftermarket) (Unl).gb" size 131072 crc 4c3e0d15 sha1 6cbfb0390ee555718b5b0c3a5437b7d3d4ee0008 ) +) + +game ( + name "Meteorite (World) (Aftermarket) (Unl)" + description "Meteorite (World) (Aftermarket) (Unl)" + rom ( name "Meteorite (World) (Aftermarket) (Unl).gb" size 262144 crc 50cf593d sha1 0e88a47faf3273f87c1ead7f789faeb06d5333f3 ) +) + +game ( + name "Mission Mars (World) (Aftermarket) (Unl)" + description "Mission Mars (World) (Aftermarket) (Unl)" + rom ( name "Mission Mars (World) (Aftermarket) (Unl).gb" size 262144 crc cb3a9ab8 sha1 31625a90b61d28ac782909ed8b00b3a48df7742e ) +) + +game ( + name "Mona and the Witch's Hat (World) (Aftermarket) (Unl)" + description "Mona and the Witch's Hat (World) (Aftermarket) (Unl)" + rom ( name "Mona and the Witch's Hat (World) (Aftermarket) (Unl).gb" size 65536 crc 32ed7f4a sha1 625d3664d99dee075021b03ea6ff074ae2e49204 ) +) + +game ( + name "Monty on the Run (World) (Aftermarket) (Unl)" + description "Monty on the Run (World) (Aftermarket) (Unl)" + rom ( name "Monty on the Run (World) (Aftermarket) (Unl).gb" size 524288 crc e2ebb406 sha1 41ac5993fbff58be0712b554aae5e4367b68677b ) +) + +game ( + name "Muncher (World) (Aftermarket) (Unl)" + description "Muncher (World) (Aftermarket) (Unl)" + rom ( name "Muncher (World) (Aftermarket) (Unl).gb" size 262144 crc 444d3d5e sha1 c3e09aff66c7e395bf95a1864963fbe979d5cb9b ) +) + +game ( + name "My Husband is a WITCH (World) (v1.1) (Aftermarket) (Unl)" + description "My Husband is a WITCH (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "My Husband is a WITCH (World) (v1.1) (Aftermarket) (Unl).gb" size 262144 crc 68801328 sha1 3b45dc8b655b688832a6b217c5cbc93a7a9f70cd ) +) + +game ( + name "My World (World) (Aftermarket) (Unl)" + description "My World (World) (Aftermarket) (Unl)" + rom ( name "My World (World) (Aftermarket) (Unl).gb" size 131072 crc 530b2edd sha1 ae29a721e6d1894e2faf736384737da7676e4fbc ) +) + +game ( + name "Neko Can Dream (World) (En) (Aftermarket) (Unl)" + description "Neko Can Dream (World) (En) (Aftermarket) (Unl)" + rom ( name "Neko Can Dream (World) (En) (Aftermarket) (Unl).gb" size 2097152 crc 6e76ef25 sha1 55686fde78d17d00adfc831eca2c699274a82273 ) +) + +game ( + name "Neko Can Dream (World) (Ja) (Demo) (Aftermarket) (Unl)" + description "Neko Can Dream (World) (Ja) (Demo) (Aftermarket) (Unl)" + rom ( name "Neko Can Dream (World) (Ja) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc a0ad7a18 sha1 5fb1a09e04cf1704b059468de8855dfa7e23043b ) +) + +game ( + name "Neko Can Dream (World) (En) (Demo) (Aftermarket) (Unl)" + description "Neko Can Dream (World) (En) (Demo) (Aftermarket) (Unl)" + rom ( name "Neko Can Dream (World) (En) (Demo) (Aftermarket) (Unl).gb" size 2097152 crc dc011d07 sha1 43312b149355d20944e8a366584c69e5cb3be868 ) +) + +game ( + name "Nocptern (World) (v1.0) (Demo) (Aftermarket) (Unl)" + description "Nocptern (World) (v1.0) (Demo) (Aftermarket) (Unl)" + rom ( name "Nocptern (World) (v1.0) (Demo) (Aftermarket) (Unl).gb" size 131072 crc 118da307 sha1 33174a7727f6a1cc7c94b598ed6e9a4c2d1d410c ) +) + +game ( + name "Nyghtmare - Betrayed (World) (Alpha A) (Aftermarket) (Unl)" + description "Nyghtmare - Betrayed (World) (Alpha A) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - Betrayed (World) (Alpha A) (Aftermarket) (Unl).gb" size 262144 crc d6166c62 sha1 fa2198c5308a15195adbda004f09646589860d11 ) +) + +game ( + name "Nyghtmare - Betrayed (World) (v0.1.1) (Beta) (Aftermarket) (Unl)" + description "Nyghtmare - Betrayed (World) (v0.1.1) (Beta) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - Betrayed (World) (v0.1.1) (Beta) (Aftermarket) (Unl).gb" size 1048576 crc 42b47080 sha1 08484b0f98e72d6577d9b7cde8c49908012d1fc5 ) +) + +game ( + name "Oblique Strategies (World) (Aftermarket) (Unl)" + description "Oblique Strategies (World) (Aftermarket) (Unl)" + rom ( name "Oblique Strategies (World) (Aftermarket) (Unl).gb" size 524288 crc 30eca8d3 sha1 6a09aabf30e2ebab2e31ae845cd2e8796c84797f ) +) + +game ( + name "Oiopolis (World) (Es) (Demo) (Aftermarket) (Unl)" + description "Oiopolis (World) (Es) (Demo) (Aftermarket) (Unl)" + rom ( name "Oiopolis (World) (Es) (Demo) (Aftermarket) (Unl).gb" size 524288 crc d3eba01d sha1 8cf234bbcb68ca2b676a4ccec89814b0cbce1c07 ) +) + +game ( + name "Oiopolis (World) (En) (Demo) (Aftermarket) (Unl)" + description "Oiopolis (World) (En) (Demo) (Aftermarket) (Unl)" + rom ( name "Oiopolis (World) (En) (Demo) (Aftermarket) (Unl).gb" size 524288 crc 71f34822 sha1 f24da97f44d280f27f8ebe3acdc33fea758d2255 ) +) + +game ( + name "Oiopolis (World) (Ca) (Demo) (Aftermarket) (Unl)" + description "Oiopolis (World) (Ca) (Demo) (Aftermarket) (Unl)" + rom ( name "Oiopolis (World) (Ca) (Demo) (Aftermarket) (Unl).gb" size 524288 crc 76baab68 sha1 cd76da35541535dd244ad60d10eb998f7692f07a ) +) + +game ( + name "Olympic Skier (World) (Aftermarket) (Unl)" + description "Olympic Skier (World) (Aftermarket) (Unl)" + rom ( name "Olympic Skier (World) (Aftermarket) (Unl).gb" size 524288 crc 93174431 sha1 7bcdf10533f8fe053e22534c4962ed4b1a5cf2e2 ) +) + +game ( + name "Opossum a la Mode (World) (Aftermarket) (Unl)" + description "Opossum a la Mode (World) (Aftermarket) (Unl)" + rom ( name "Opossum a la Mode (World) (Aftermarket) (Unl).gb" size 262144 crc 810477a9 sha1 3b6fb1311313687afebc4fb51f1b4befb5f47e1e ) +) + +game ( + name "Out on a Limb (World) (Aftermarket) (Unl)" + description "Out on a Limb (World) (Aftermarket) (Unl)" + rom ( name "Out on a Limb (World) (Aftermarket) (Unl).gb" size 262144 crc be197f87 sha1 2ddc2378539316cf7a10e2cf8b562f17e1cf7a6a ) +) + +game ( + name "Panty Hunty (World) (v1.4) (Aftermarket) (Unl)" + description "Panty Hunty (World) (v1.4) (Aftermarket) (Unl)" + rom ( name "Panty Hunty (World) (v1.4) (Aftermarket) (Unl).gb" size 524288 crc ce707b9a sha1 b5757b268a09d9085d469eda0676991f7361ad8c ) +) + +game ( + name "Parasol Islands (World) (Aftermarket) (Unl)" + description "Parasol Islands (World) (Aftermarket) (Unl)" + rom ( name "Parasol Islands (World) (Aftermarket) (Unl).gb" size 1048576 crc b1d79c80 sha1 381f76af67f77e575beae2f45aefd21f079709e6 ) +) + +game ( + name "Penguin Migrants (World) (v1.2) (Aftermarket) (Unl)" + description "Penguin Migrants (World) (v1.2) (Aftermarket) (Unl)" + rom ( name "Penguin Migrants (World) (v1.2) (Aftermarket) (Unl).gb" size 32768 crc 866ac302 sha1 fa94f4d06eae2c49bbf1a654a8f658783dc6c28c ) +) + +game ( + name "Penguin Migrants (World) (v1.1) (Aftermarket) (Unl)" + description "Penguin Migrants (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Penguin Migrants (World) (v1.1) (Aftermarket) (Unl).gb" size 32768 crc 1bc5f8aa sha1 bf5601202eeca5b892ae4f3db7a4019cdb3bc99a ) +) + +game ( + name "Penguin Migrants (World) (v1.0) (Aftermarket) (Unl)" + description "Penguin Migrants (World) (v1.0) (Aftermarket) (Unl)" + rom ( name "Penguin Migrants (World) (v1.0) (Aftermarket) (Unl).gb" size 32768 crc f6f681fa sha1 57b9cc41fc6d1e7cecf8ba2a1613d1fd126d97ad ) +) + +game ( + name "Perfect Blend (World) (v0.9) (Aftermarket) (Unl)" + description "Perfect Blend (World) (v0.9) (Aftermarket) (Unl)" + rom ( name "Perfect Blend (World) (v0.9) (Aftermarket) (Unl).gb" size 262144 crc 9b4bacaa sha1 09b0691f6823c54f1515dd3b66f135ac45a7dbc3 ) +) + +game ( + name "Perfect Blend (World) (v0.9) (Bugfix) (Aftermarket) (Unl)" + description "Perfect Blend (World) (v0.9) (Bugfix) (Aftermarket) (Unl)" + rom ( name "Perfect Blend (World) (v0.9) (Bugfix) (Aftermarket) (Unl).gb" size 262144 crc 1e8b2a29 sha1 a25dfc43408080ac116479fa55c9e7320e5cc82a ) +) + +game ( + name "Phobos Dere .GB (World) (Aftermarket) (Unl)" + description "Phobos Dere .GB (World) (Aftermarket) (Unl)" + rom ( name "Phobos Dere .GB (World) (Aftermarket) (Unl).gb" size 1048576 crc ae97f4f8 sha1 e541505078ee5e7e5c897b4621cc693ce71e35ba flags verified ) +) + +game ( + name "Phobos Dere .GB (World) (2022-03-06) (Demo) (Aftermarket) (Unl)" + description "Phobos Dere .GB (World) (2022-03-06) (Demo) (Aftermarket) (Unl)" + rom ( name "Phobos Dere .GB (World) (2022-03-06) (Demo) (Aftermarket) (Unl).gb" size 262144 crc 58362b86 sha1 b4cc3c3735bc134e34b97e08ed24c57aef5c5ccf flags verified ) +) + +game ( + name "Pineapple Kid (World) (Aftermarket) (Unl)" + description "Pineapple Kid (World) (Aftermarket) (Unl)" + rom ( name "Pineapple Kid (World) (Aftermarket) (Unl).gb" size 131072 crc 9541488b sha1 fd574b5d407f3654db3227900a8ed7eff4fe48ae ) +) + +game ( + name "Pineapple Kid (World) (Demo) (Aftermarket) (Unl)" + description "Pineapple Kid (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Pineapple Kid (World) (Demo) (Aftermarket) (Unl).gb" size 131072 crc 9d9102d9 sha1 105e78f740d6bc517ef0079f867e9fdce8d012d2 ) +) + +game ( + name "Pixel Who - The Lost Legions (World) (Aftermarket) (Unl)" + description "Pixel Who - The Lost Legions (World) (Aftermarket) (Unl)" + rom ( name "Pixel Who - The Lost Legions (World) (Aftermarket) (Unl).gb" size 1048576 crc f41cf2a7 sha1 c07378c774602060f1f93f18fbfd3f0d552fe2d2 ) +) + +game ( + name "Plants Eat My Zombies (World) (v1.1) (Aftermarket) (Unl)" + description "Plants Eat My Zombies (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Plants Eat My Zombies (World) (v1.1) (Aftermarket) (Unl).gb" size 524288 crc 60c84f2e sha1 c39ec5e6a9a0be0970b56e788c3f60e9821dbbd3 ) +) + +game ( + name "Pluto's Corner (World) (Aftermarket) (Unl)" + description "Pluto's Corner (World) (Aftermarket) (Unl)" + rom ( name "Pluto's Corner (World) (Aftermarket) (Unl).gb" size 65536 crc 21fc06b3 sha1 94e4a442205079d85d5ca37042eaec555f7f49db ) +) + +game ( + name "Pogo Pete (World) (Aftermarket) (Unl)" + description "Pogo Pete (World) (Aftermarket) (Unl)" + rom ( name "Pogo Pete (World) (Aftermarket) (Unl).gb" size 262144 crc 185ce1d5 sha1 74021e84c1d095b2401302e26352e810dbc432d8 ) +) + +game ( + name "Popcorn Caravan (World) (Demo) (Aftermarket) (Unl)" + description "Popcorn Caravan (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Popcorn Caravan (World) (Demo) (Aftermarket) (Unl).gb" size 65536 crc ead528f9 sha1 909d3421747d211a2dc70918d2c952db953e49b2 ) +) + +game ( + name "Porklike (World) (v1.0.3) (Aftermarket) (Unl)" + description "Porklike (World) (v1.0.3) (Aftermarket) (Unl)" + rom ( name "Porklike (World) (v1.0.3) (Aftermarket) (Unl).gb" size 65536 crc 6c57e55e sha1 143f31656a5007f65b19d6e32967698bb8f72a66 ) +) + +game ( + name "Porklike (World) (v1.0.9) (SGB Enhanced) (Aftermarket) (Unl)" + description "Porklike (World) (v1.0.9) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Porklike (World) (v1.0.9) (SGB Enhanced) (Aftermarket) (Unl).gb" size 65536 crc 7aaa853a sha1 0868bffd52b2bdc5601ab6cf1e25f40924ca643d ) +) + +game ( + name "Porklike (World) (v1.05) (SGB Enhanced) (Aftermarket) (Unl)" + description "Porklike (World) (v1.05) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Porklike (World) (v1.05) (SGB Enhanced) (Aftermarket) (Unl).gb" size 65536 crc 801f097b sha1 5da110a88799765707e027bcedec0875a637509b ) +) + +game ( + name "Pull of the Void (World) (Aftermarket) (Unl)" + description "Pull of the Void (World) (Aftermarket) (Unl)" + rom ( name "Pull of the Void (World) (Aftermarket) (Unl).gb" size 262144 crc 69bfac8c sha1 df10665c8e79c587103d3de686b0261807819caf ) +) + +game ( + name "Purple Turtles (World) (Aftermarket) (Unl)" + description "Purple Turtles (World) (Aftermarket) (Unl)" + rom ( name "Purple Turtles (World) (Aftermarket) (Unl).gb" size 262144 crc f7041a97 sha1 d2d7eff063104c8f205c192a902a53092c0b5f4a ) +) + +game ( + name "Pushingo (World) (Aftermarket) (Unl)" + description "Pushingo (World) (Aftermarket) (Unl)" + rom ( name "Pushingo (World) (Aftermarket) (Unl).gb" size 262144 crc a8541ed0 sha1 1ac1e22b191a95fdfa00c34ccba7387c991c827b ) +) + +game ( + name "Pyro la Chronoflamme (World) (Fr) (Proto) (Aftermarket) (Unl)" + description "Pyro la Chronoflamme (World) (Fr) (Proto) (Aftermarket) (Unl)" + rom ( name "Pyro la Chronoflamme (World) (Fr) (Proto) (Aftermarket) (Unl).gb" size 262144 crc 2abc6b14 sha1 a13e1f09e9d3921e544c3fc17daebbadc93921b7 ) +) + +game ( + name "Quick Draw (World) (Aftermarket) (Unl)" + description "Quick Draw (World) (Aftermarket) (Unl)" + rom ( name "Quick Draw (World) (Aftermarket) (Unl).gb" size 262144 crc 7704671f sha1 75f96ce54ed8739d58153780e9b573a65f1c5880 ) +) + +game ( + name "radioRealm (World) (Ja) (Aftermarket) (Unl)" + description "radioRealm (World) (Ja) (Aftermarket) (Unl)" + rom ( name "radioRealm (World) (Ja) (Aftermarket) (Unl).gb" size 131072 crc 71375a39 sha1 489c8835c36a08f1d76a0653bf6ede3bbf53043f ) +) + +game ( + name "Raffles (World) (Aftermarket) (Unl)" + description "Raffles (World) (Aftermarket) (Unl)" + rom ( name "Raffles (World) (Aftermarket) (Unl).gb" size 262144 crc 0b400a91 sha1 aadfe3fd0720696547b73b272354b592b96f98f7 ) +) + +game ( + name "Remute - Living Electronics (World) (Album) (Aftermarket) (Unl)" + description "Remute - Living Electronics (World) (Album) (Aftermarket) (Unl)" + rom ( name "Remute - Living Electronics (World) (Album) (Aftermarket) (Unl).gb" size 2097152 crc 1ced0a62 sha1 bc4bf12344d3b9d028a7013c84b94aea515be196 flags verified ) +) + +game ( + name "Retroid (World) (Aftermarket) (Unl)" + description "Retroid (World) (Aftermarket) (Unl)" + rom ( name "Retroid (World) (Aftermarket) (Unl).gb" size 262144 crc 9f759f25 sha1 4c7323d6a10852fe416c7bd581d6ffdd2d473bb5 ) +) + +game ( + name "Rewind Time (World) (Aftermarket) (Unl)" + description "Rewind Time (World) (Aftermarket) (Unl)" + rom ( name "Rewind Time (World) (Aftermarket) (Unl).gb" size 262144 crc d8ad184a sha1 903ef8074e58a52bc98dcb9e3f2c88b52fc1335b ) +) + +game ( + name "Rhythm Land (World) (Aftermarket) (Unl)" + description "Rhythm Land (World) (Aftermarket) (Unl)" + rom ( name "Rhythm Land (World) (Aftermarket) (Unl).gb" size 131072 crc 4312c7ff sha1 c79f26ce187edea18cf92be8340ec0a0c8beec87 ) +) + +game ( + name "Rhythm Land (World) (v1.0.1) (Aftermarket) (Unl)" + description "Rhythm Land (World) (v1.0.1) (Aftermarket) (Unl)" + rom ( name "Rhythm Land (World) (v1.0.1) (Aftermarket) (Unl).gb" size 131072 crc fbf98400 sha1 1b831806d32e1ec35bc94a84384c6989433a274d ) +) + +game ( + name "Rig Attack (World) (Aftermarket) (Unl)" + description "Rig Attack (World) (Aftermarket) (Unl)" + rom ( name "Rig Attack (World) (Aftermarket) (Unl).gb" size 262144 crc dea8749d sha1 6f0fbac6b6c2e8f2d8df0a0a0e2f0c947e37b39a ) +) + +game ( + name "Robby's Day Out (World) (Aftermarket) (Unl)" + description "Robby's Day Out (World) (Aftermarket) (Unl)" + rom ( name "Robby's Day Out (World) (Aftermarket) (Unl).gb" size 262144 crc c3c89cd9 sha1 9d38b69ab9a4ff7bf387c88f2afed410d450f2e0 ) +) + +game ( + name "Roommate Simulator (World) (Aftermarket) (Unl)" + description "Roommate Simulator (World) (Aftermarket) (Unl)" + rom ( name "Roommate Simulator (World) (Aftermarket) (Unl).gb" size 131072 crc 3c95b1aa sha1 d5c99106c3bd4d46aeb75f513fd4314c19c734b2 ) +) + +game ( + name "Rosa Cupiditatis (World) (2023-05-17) (Demo) (Aftermarket) (Unl)" + description "Rosa Cupiditatis (World) (2023-05-17) (Demo) (Aftermarket) (Unl)" + rom ( name "Rosa Cupiditatis (World) (2023-05-17) (Demo) (Aftermarket) (Unl).gb" size 524288 crc 51d09337 sha1 9e935cca00cb4c3aad7b1dfce9fe59f5d913bdff ) +) + +game ( + name "Sacred Meat (World) (v1.3) (Aftermarket) (Unl)" + description "Sacred Meat (World) (v1.3) (Aftermarket) (Unl)" + rom ( name "Sacred Meat (World) (v1.3) (Aftermarket) (Unl).gb" size 2097152 crc 6669f0be sha1 25bcf936e8dadb10d288473989891e4f2ec6c605 ) +) + +game ( + name "Sacred Meat (World) (v1.1) (Aftermarket) (Unl)" + description "Sacred Meat (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Sacred Meat (World) (v1.1) (Aftermarket) (Unl).gb" size 2097152 crc 1c4b7eb0 sha1 5cd15f4629fdbcfd6f752d89be755d5ac02b9435 ) +) + +game ( + name "Safe File (World) (SGB Enhanced) (Aftermarket) (Unl)" + description "Safe File (World) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Safe File (World) (SGB Enhanced) (Aftermarket) (Unl).gb" size 262144 crc 03f2dd1a sha1 78fe9c7cd6d0d7f1157c8c7716642d17c4b80303 ) +) + +game ( + name "Sam Mallard - The Case of the Missing Swan (World) (SGB Enhanced) (Aftermarket) (Unl)" + description "Sam Mallard - The Case of the Missing Swan (World) (SGB Enhanced) (Aftermarket) (Unl)" + rom ( name "Sam Mallard - The Case of the Missing Swan (World) (SGB Enhanced) (Aftermarket) (Unl).gb" size 1048576 crc 994a2edd sha1 0132f0311d8478d4f45b3b8e2728698570091d69 ) +) + +game ( + name "Severen (World) (Demo) (Aftermarket) (Unl)" + description "Severen (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Severen (World) (Demo) (Aftermarket) (Unl).gb" size 1048576 crc 642f2244 sha1 d9692aa569820db3f38458819cba21846a2e06f4 ) +) + +game ( + name "Shapeshifter, The (World) (Aftermarket) (Unl)" + description "Shapeshifter, The (World) (Aftermarket) (Unl)" + rom ( name "Shapeshifter, The (World) (Aftermarket) (Unl).gb" size 1048576 crc ef735794 sha1 179e69199f19b403b4c1a9675a3ee431ee570797 ) +) + +game ( + name "Shark Attack (World) (Aftermarket) (Unl)" + description "Shark Attack (World) (Aftermarket) (Unl)" + rom ( name "Shark Attack (World) (Aftermarket) (Unl).gb" size 262144 crc 3032025a sha1 6cc65bb719af53128bb04c9ee7c6abbf4ff1c3cf ) +) + +game ( + name "Sheep It Up (World) (Digital) (Aftermarket) (Unl)" + description "Sheep It Up (World) (Digital) (Aftermarket) (Unl)" + rom ( name "Sheep It Up (World) (Digital) (Aftermarket) (Unl).gb" size 32768 crc fa6de2e4 sha1 9ad365ed7d4e07041c0147831a9bb1c496ea0bc8 ) +) + +game ( + name "Shock Lobster (World) (Aftermarket) (Unl)" + description "Shock Lobster (World) (Aftermarket) (Unl)" + rom ( name "Shock Lobster (World) (Aftermarket) (Unl).gb" size 32768 crc 7a0622e6 sha1 10c1816724cd6e332d2a5aeed4e546e7bd764ebf ) +) + +game ( + name "Shock Lobster (World) (v1.3) (Aftermarket) (Unl)" + description "Shock Lobster (World) (v1.3) (Aftermarket) (Unl)" + rom ( name "Shock Lobster (World) (v1.3) (Aftermarket) (Unl).gb" size 32768 crc 8f244e86 sha1 7b8c8a9ec4758c6880598b9d508bc5805293dd87 ) +) + +game ( + name "Shootris (World) (Aftermarket) (Unl)" + description "Shootris (World) (Aftermarket) (Unl)" + rom ( name "Shootris (World) (Aftermarket) (Unl).gb" size 262144 crc 50180f64 sha1 5d978e6fc4bd5d9717d022360122458e95fffc29 ) +) + +game ( + name "Sloth Story (World) (Aftermarket) (Unl)" + description "Sloth Story (World) (Aftermarket) (Unl)" + rom ( name "Sloth Story (World) (Aftermarket) (Unl).gb" size 262144 crc c873f232 sha1 369d2afec4ffb59d4f3a59ee684c5bfec0b34ff8 ) +) + +game ( + name "Slurpee Cycle (World) (Aftermarket) (Unl)" + description "Slurpee Cycle (World) (Aftermarket) (Unl)" + rom ( name "Slurpee Cycle (World) (Aftermarket) (Unl).gb" size 131072 crc 8985031a sha1 1addff376e2734513406eca69a9c6679965faba9 ) +) + +game ( + name "Smickeonn - The Game (World) (Aftermarket) (Unl)" + description "Smickeonn - The Game (World) (Aftermarket) (Unl)" + rom ( name "Smickeonn - The Game (World) (Aftermarket) (Unl).gb" size 524288 crc 93041fca sha1 e0981231d10aa8ea64eeaec1ff90210adf42ae05 ) +) + +game ( + name "Smickeonn 2 - The Game (World) (Aftermarket) (Unl)" + description "Smickeonn 2 - The Game (World) (Aftermarket) (Unl)" + rom ( name "Smickeonn 2 - The Game (World) (Aftermarket) (Unl).gb" size 1048576 crc cd99b998 sha1 ac6b35af80c98ca5822e540a725b64a8c6dd5069 ) +) + +game ( + name "Snail, The (World) (v1.3) (Aftermarket) (Unl)" + description "Snail, The (World) (v1.3) (Aftermarket) (Unl)" + rom ( name "Snail, The (World) (v1.3) (Aftermarket) (Unl).gb" size 262144 crc 422a7b44 sha1 776f7578d747f935ebccda93d6487ffa4dc4bce3 ) +) + +game ( + name "Snakebird (World) (Aftermarket) (Unl)" + description "Snakebird (World) (Aftermarket) (Unl)" + rom ( name "Snakebird (World) (Aftermarket) (Unl).gb" size 131072 crc 4627f98e sha1 99cc82279d65b86b4366bf61db9bf67a78e051dc ) +) + +game ( + name "Snaky Pocket (World) (Aftermarket) (Unl)" + description "Snaky Pocket (World) (Aftermarket) (Unl)" + rom ( name "Snaky Pocket (World) (Aftermarket) (Unl).gb" size 32768 crc 7209370d sha1 f5eab31a499f33b3ae1f7b5b006dcca1df3ac2b9 ) +) + +game ( + name "Song of Morus - Gala of Battle (World) (En,Ja) (Aftermarket) (Unl)" + description "Song of Morus - Gala of Battle (World) (En,Ja) (Aftermarket) (Unl)" + rom ( name "Song of Morus - Gala of Battle (World) (En,Ja) (Aftermarket) (Unl).gb" size 262144 crc 665ad70a sha1 c5b6eb610caa2213d8db7ab204bad44d60f7d63a ) +) + +game ( + name "Song of Morus - Ghostly Night (World) (2023-05-20) (Aftermarket) (Unl)" + description "Song of Morus - Ghostly Night (World) (2023-05-20) (Aftermarket) (Unl)" + rom ( name "Song of Morus - Ghostly Night (World) (2023-05-20) (Aftermarket) (Unl).gb" size 262144 crc feed93e0 sha1 721d78d4ef167acfcc00baf909db4c94d522d681 ) +) + +game ( + name "Song of Morus - Ghostly Night (World) (2023-06-08) (Aftermarket) (Unl)" + description "Song of Morus - Ghostly Night (World) (2023-06-08) (Aftermarket) (Unl)" + rom ( name "Song of Morus - Ghostly Night (World) (2023-06-08) (Aftermarket) (Unl).gb" size 262144 crc 6547e5c8 sha1 53a42f45b7ed368d7af9d41f2442fe463c26e545 ) +) + +game ( + name "Space Trouble (World) (Proto) (Aftermarket) (Unl)" + description "Space Trouble (World) (Proto) (Aftermarket) (Unl)" + rom ( name "Space Trouble (World) (Proto) (Aftermarket) (Unl).gb" size 524288 crc f015931c sha1 ec7bc27387d4d2ac01127bc24e1adf45b6ebc936 ) +) + +game ( + name "Spiky Harold (World) (Aftermarket) (Unl)" + description "Spiky Harold (World) (Aftermarket) (Unl)" + rom ( name "Spiky Harold (World) (Aftermarket) (Unl).gb" size 524288 crc 2ac1b945 sha1 b8f37a64524bde4c2b6e9a1938ed6e5c0a5aad7c ) +) + +game ( + name "Star Catcher (World) (Aftermarket) (Unl)" + description "Star Catcher (World) (Aftermarket) (Unl)" + rom ( name "Star Catcher (World) (Aftermarket) (Unl).gb" size 131072 crc a14dffef sha1 22a2693db5266238751ba3ae2b8ea634bfbe78aa ) +) + +game ( + name "Stardiver (World) (Aftermarket) (Unl)" + description "Stardiver (World) (Aftermarket) (Unl)" + rom ( name "Stardiver (World) (Aftermarket) (Unl).gb" size 1048576 crc 25ff97f7 sha1 d609b8de2c7a61b7281fec5c761e3504aa4d94e9 ) +) + +game ( + name "Stick Man Guy (World) (Aftermarket) (Unl)" + description "Stick Man Guy (World) (Aftermarket) (Unl)" + rom ( name "Stick Man Guy (World) (Aftermarket) (Unl).gb" size 262144 crc 3a61fefc sha1 2f7351579e09ef29e067a69dfa3556448626d68e ) +) + +game ( + name "Super Connard (World) (Fr) (Aftermarket) (Unl)" + description "Super Connard (World) (Fr) (Aftermarket) (Unl)" + rom ( name "Super Connard (World) (Fr) (Aftermarket) (Unl).gb" size 32768 crc 9aaf301a sha1 6f4bf6c8206cc95cf17bea6739aa942034c2a230 ) +) + +game ( + name "Super Connard (World) (Fr) (Digital) (Aftermarket) (Unl)" + description "Super Connard (World) (Fr) (Digital) (Aftermarket) (Unl)" + rom ( name "Super Connard (World) (Fr) (Digital) (Aftermarket) (Unl).gb" size 32768 crc 7ebd22cd sha1 24264376aeee13d7f9b9424553f7fa4ba4b3b116 ) +) + +game ( + name "Super Covid Go Get Biscuits Adventure (World) (Aftermarket) (Unl)" + description "Super Covid Go Get Biscuits Adventure (World) (Aftermarket) (Unl)" + rom ( name "Super Covid Go Get Biscuits Adventure (World) (Aftermarket) (Unl).gb" size 262144 crc 51946e8d sha1 cac4917d56da02cf88ba68e0c5189a18c2c234ac ) +) + +game ( + name "Super Hard Bouncer (World) (v1.1) (Aftermarket) (Unl)" + description "Super Hard Bouncer (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Super Hard Bouncer (World) (v1.1) (Aftermarket) (Unl).gb" size 32768 crc a653f726 sha1 09c242a4c0752f251388026df7ed4baab5a8c56f ) +) + +game ( + name "Super Hard Bouncer (World) (v1.0) (Aftermarket) (Unl)" + description "Super Hard Bouncer (World) (v1.0) (Aftermarket) (Unl)" + rom ( name "Super Hard Bouncer (World) (v1.0) (Aftermarket) (Unl).gb" size 32768 crc 6308019a sha1 549c2624767633d6898ab9623eadb9579ec2779b ) +) + +game ( + name "Sushi Gun (World) (Aftermarket) (Unl)" + description "Sushi Gun (World) (Aftermarket) (Unl)" + rom ( name "Sushi Gun (World) (Aftermarket) (Unl).gb" size 262144 crc a9d405d6 sha1 c075856939d4fe3cd250083b527b3e09be70052d ) +) + +game ( + name "Swaplatformer (World) (Aftermarket) (Unl)" + description "Swaplatformer (World) (Aftermarket) (Unl)" + rom ( name "Swaplatformer (World) (Aftermarket) (Unl).gb" size 1048576 crc babe7935 sha1 3df0c37862b7c391a0d091a55db0d305341529c2 ) +) + +game ( + name "Take It Racing 2 (World) (Demo) (Aftermarket) (Unl)" + description "Take It Racing 2 (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Take It Racing 2 (World) (Demo) (Aftermarket) (Unl).gb" size 1048576 crc 5898c134 sha1 bd3468395deb0009b190d0b5d487962ae65adbee ) +) + +game ( + name "Tech and Blood (World) (Aftermarket) (Unl)" + description "Tech and Blood (World) (Aftermarket) (Unl)" + rom ( name "Tech and Blood (World) (Aftermarket) (Unl).gb" size 262144 crc 3da2a358 sha1 40a00fce49b16cb36793df30e5156e5bf3e47778 ) +) + +game ( + name "The Light, The Fire (World) (Aftermarket) (Unl)" + description "The Light, The Fire (World) (Aftermarket) (Unl)" + rom ( name "The Light, The Fire (World) (Aftermarket) (Unl).gb" size 524288 crc b6a19823 sha1 d98e03602699f8602689f006e1f55f0c549b3cb7 ) +) + +game ( + name "There's Nothing to Do in This Town (World) (Aftermarket) (Unl)" + description "There's Nothing to Do in This Town (World) (Aftermarket) (Unl)" + rom ( name "There's Nothing to Do in This Town (World) (Aftermarket) (Unl).gb" size 1048576 crc 173b549a sha1 e000fbecda9ea6bbbd0c0370cf8c3faaa54bf64e ) +) + +game ( + name "Thin Ice Rescue, The (World) (Aftermarket) (Unl)" + description "Thin Ice Rescue, The (World) (Aftermarket) (Unl)" + rom ( name "Thin Ice Rescue, The (World) (Aftermarket) (Unl).gb" size 32768 crc 3e0483d6 sha1 b789ced0fe26785e7bce765a9d6ee783f9d967d8 ) +) + +game ( + name "TimberMan (World) (Aftermarket) (Unl)" + description "TimberMan (World) (Aftermarket) (Unl)" + rom ( name "TimberMan (World) (Aftermarket) (Unl).gb" size 32768 crc e0b8459c sha1 e3f4b4c4816cc0dda2885519f1386385e6a5e817 ) +) + +game ( + name "Tobu Tobu Girl (World) (Aftermarket) (Unl)" + description "Tobu Tobu Girl (World) (Aftermarket) (Unl)" + rom ( name "Tobu Tobu Girl (World) (Aftermarket) (Unl).gb" size 262144 crc ed12be6c sha1 8a8f3c1f21f903ea5a7df8fc8b0a6aa5a602e150 ) +) + +game ( + name "Touch the Cat (World) (Aftermarket) (Unl)" + description "Touch the Cat (World) (Aftermarket) (Unl)" + rom ( name "Touch the Cat (World) (Aftermarket) (Unl).gb" size 131072 crc 351fd00a sha1 9dc7b51a44aec9055924596c161972f366caf067 ) +) + +game ( + name "Traumatarium (World) (Demo) (2021-12-09) (Aftermarket) (Unl)" + description "Traumatarium (World) (Demo) (2021-12-09) (Aftermarket) (Unl)" + rom ( name "Traumatarium (World) (Demo) (2021-12-09) (Aftermarket) (Unl).gb" size 2097152 crc 15afd765 sha1 c12e603492f8bcfffd28dd4733c7bc445c507642 ) +) + +game ( + name "Traumatarium (World) (Demo) (2022-06-18) (Aftermarket) (Unl)" + description "Traumatarium (World) (Demo) (2022-06-18) (Aftermarket) (Unl)" + rom ( name "Traumatarium (World) (Demo) (2022-06-18) (Aftermarket) (Unl).gb" size 2097152 crc e1bdf67f sha1 ba492778121622b5288d4188edc344aa41aa6803 ) +) + +game ( + name "Traumatarium (World) (Demo) (2022-03-13) (Aftermarket) (Unl)" + description "Traumatarium (World) (Demo) (2022-03-13) (Aftermarket) (Unl)" + rom ( name "Traumatarium (World) (Demo) (2022-03-13) (Aftermarket) (Unl).gb" size 1048576 crc 42bb7dab sha1 70fded7ce1edc54de85b020460f779feb9bdbc01 ) +) + +game ( + name "Traumatarium - Penitent (World) (2024-01-12) (Proto) (Aftermarket) (Unl)" + description "Traumatarium - Penitent (World) (2024-01-12) (Proto) (Aftermarket) (Unl)" + rom ( name "Traumatarium - Penitent (World) (2024-01-12) (Proto) (Aftermarket) (Unl).gb" size 4194304 crc 805f8257 sha1 a28d68f59b7ab3a6c95d5efc35c22ab9d7a74d31 ) +) + +game ( + name "Traumatarium - Penitent (World) (Demo) (Aftermarket) (Unl)" + description "Traumatarium - Penitent (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Traumatarium - Penitent (World) (Demo) (Aftermarket) (Unl).gb" size 4194304 crc 7d368277 sha1 efc91ca2873ff8f1733036e298950033d3456927 ) +) + +game ( + name "Treasure Island (World) (Aftermarket) (Unl)" + description "Treasure Island (World) (Aftermarket) (Unl)" + rom ( name "Treasure Island (World) (Aftermarket) (Unl).gb" size 262144 crc cbdec393 sha1 adeaba2723d286d143e0987f51ce9c8ad2f5e839 ) +) + +game ( + name "Vampire Night Shift (World) (Aftermarket) (Unl)" + description "Vampire Night Shift (World) (Aftermarket) (Unl)" + rom ( name "Vampire Night Shift (World) (Aftermarket) (Unl).gb" size 262144 crc 88acbc1a sha1 ef617803c2cdb14cfe3b3b2111aa239a3744e29e ) +) + +game ( + name "Waifu Clicker (World) (Aftermarket) (Unl)" + description "Waifu Clicker (World) (Aftermarket) (Unl)" + rom ( name "Waifu Clicker (World) (Aftermarket) (Unl).gb" size 65536 crc 155f85dc sha1 bb571ed69c3a33e45ba33fbb03a066ba98ae0b20 ) +) + +game ( + name "What Friends Are For (World) (Aftermarket) (Unl)" + description "What Friends Are For (World) (Aftermarket) (Unl)" + rom ( name "What Friends Are For (World) (Aftermarket) (Unl).gb" size 262144 crc cbed3dd6 sha1 58538084a964f779c2f756fbe732656f3f7bef66 ) +) + +game ( + name "Windows93 Adventure (World) (Aftermarket) (Unl)" + description "Windows93 Adventure (World) (Aftermarket) (Unl)" + rom ( name "Windows93 Adventure (World) (Aftermarket) (Unl).gb" size 1048576 crc e1ad0b6f sha1 3ad7327f6f94976c3d12054cf6deb2666ba9fa66 ) +) + +game ( + name "Witchscape (World) (Proto) (Aftermarket) (Unl)" + description "Witchscape (World) (Proto) (Aftermarket) (Unl)" + rom ( name "Witchscape (World) (Proto) (Aftermarket) (Unl).gb" size 262144 crc 2b2fcea0 sha1 8440a578567aa40c646d01c990317f9d12c444e5 ) +) + +game ( + name "Wizard of Wor (World) (Aftermarket) (Unl)" + description "Wizard of Wor (World) (Aftermarket) (Unl)" + rom ( name "Wizard of Wor (World) (Aftermarket) (Unl).gb" size 524288 crc bfb1563e sha1 108eefa154412e3422dce4e63bf34f5826ec1baa ) +) + +game ( + name "Woolball's Backyard (World) (Aftermarket) (Unl)" + description "Woolball's Backyard (World) (Aftermarket) (Unl)" + rom ( name "Woolball's Backyard (World) (Aftermarket) (Unl).gb" size 65536 crc 69e26eb6 sha1 28795c4b829440549b3ac2afe3282d85a439f7d7 ) +) + +game ( + name "Year After, The (World) (En) (Proto) (Aftermarket) (Unl)" + description "Year After, The (World) (En) (Proto) (Aftermarket) (Unl)" + rom ( name "Year After, The (World) (En) (Proto) (Aftermarket) (Unl).gb" size 1048576 crc 4e463a1a sha1 5d84f53f38aa24f54a6f897ca69ffc5d978805af ) +) + +game ( + name "Year After, The (World) (Fr) (Proto) (Aftermarket) (Unl)" + description "Year After, The (World) (Fr) (Proto) (Aftermarket) (Unl)" + rom ( name "Year After, The (World) (Fr) (Proto) (Aftermarket) (Unl).gb" size 1048576 crc fbc50ee8 sha1 52c27e64fb37412c97a53d5dde52c3803fd1e4f7 ) +) + +game ( + name "Yuuto Ichika Makes Friends (World) (En,Ja) (Aftermarket) (Unl)" + description "Yuuto Ichika Makes Friends (World) (En,Ja) (Aftermarket) (Unl)" + rom ( name "Yuuto Ichika Makes Friends (World) (En,Ja) (Aftermarket) (Unl).gb" size 524288 crc 8a667058 sha1 e765d6915f543a5a65e8be440b3f29eb674a5448 ) +) + +game ( + name "Yvonne Goes to Carbonic (World) (v4.2) (Aftermarket) (Unl)" + description "Yvonne Goes to Carbonic (World) (v4.2) (Aftermarket) (Unl)" + rom ( name "Yvonne Goes to Carbonic (World) (v4.2) (Aftermarket) (Unl).gb" size 262144 crc d46cd738 sha1 b5e8f7b572a47aa191462bb4f980813ad6634ae0 ) +) + +game ( + name "Zagan Warrior (World) (Aftermarket) (Unl)" + description "Zagan Warrior (World) (Aftermarket) (Unl)" + rom ( name "Zagan Warrior (World) (Aftermarket) (Unl).gb" size 262144 crc 97fe7a94 sha1 88f76297a4ccf0e3a5ba16ca15237c88346c134a ) +) + +game ( + name "Zelda - Majora's Mask (World) (v1.1) (Demo) (Aftermarket) (Unl)" + description "Zelda - Majora's Mask (World) (v1.1) (Demo) (Aftermarket) (Unl)" + rom ( name "Zelda - Majora's Mask (World) (v1.1) (Demo) (Aftermarket) (Unl).gb" size 524288 crc f86c2766 sha1 ee86a28cf271be43739e406135e4d8bd4edf7686 ) +) + +game ( + name "Zelda's Adventure (World) (v1.3.0) (Aftermarket) (Unl)" + description "Zelda's Adventure (World) (v1.3.0) (Aftermarket) (Unl)" + rom ( name "Zelda's Adventure (World) (v1.3.0) (Aftermarket) (Unl).gb" size 2097152 crc 0b10adaf sha1 12f9ba0a4673dd2f59ba38e636332333a199dea5 ) +) + +clrmamepro ( + name "Nintendo - Game Boy Color" + description "Nintendo - Game Boy Color" + version 20240810-021134 + author "akubi, Arctic Circle System, Aringon, baldjared, Bent, BigFred, bikerspade, BitLooter, C. V. Reynolds, chillerecke, coraz, darthcloud, DeadSkullzJr, Densetsu, DeriLoko3, Flashfire42, foxe, fuzzball, Gefflon, gordonj, Hiccup, hking0036, InternalLoss, Just001Kim, kazumi213, Lesserkuma, Madeline, Money_114, NESBrew12, NGEfreak, nnssxx, norkmetnoil577, NovaAurora, omonim2007, PPLToast, Psychofox11, psykopat, rarenight, relax, Rifu, sCZther, SonGoku, Tauwasser, togemet2, UnlockerPT, Whovian9369, xprism, xuom2, zg" + homepage No-Intro + url "https://www.no-intro.org" + forcenodump required +) + +emulator ( + name "datafile" +) + +game ( + name "[BIOS] Challenger GB (USA) (Unl)" + description "[BIOS] Challenger GB (USA) (Unl)" + rom ( name "[BIOS] Challenger GB (USA) (Unl).gbc" size 32768 crc 59579caa sha1 d88c4f29a8d383b2becfe4123671c5ce1f5fdf7b ) +) + +game ( + name "[BIOS] Genius GB Backup Station (Taiwan) (Unl)" + description "[BIOS] Genius GB Backup Station (Taiwan) (Unl)" + rom ( name "[BIOS] Genius GB Backup Station (Taiwan) (Unl).gbc" size 524288 crc 8f3902f2 sha1 915c141e6dd188b580befdd034705e5c747027cf ) +) + +game ( + name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Rev 1)" + description "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Rev 1)" + rom ( name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Rev 1).gbc" size 2304 crc 41884e46 sha1 1293d68bf9643bc4f36954c1e80e38f39864528d flags verified ) +) + +game ( + name "[BIOS] Nintendo Game Boy Color Boot ROM (Japan) (En)" + description "[BIOS] Nintendo Game Boy Color Boot ROM (Japan) (En)" + rom ( name "[BIOS] Nintendo Game Boy Color Boot ROM (Japan) (En).gbc" size 2304 crc e8ef5318 sha1 df5a0d2d49de38fbd31cc2aab8e62c8550e655c0 flags verified ) +) + +game ( + name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Pokemon Stadium)" + description "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Pokemon Stadium)" + rom ( name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Pokemon Stadium).gbc" size 1008 crc b18c78e8 sha1 d24f388ac71b1cbc9b1d258fd10be13f8cdd3328 ) +) + +game ( + name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Beta) (Virtual Console)" + description "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Beta) (Virtual Console)" + rom ( name "[BIOS] Nintendo Game Boy Color Boot ROM (World) (Beta) (Virtual Console).gbc" size 2304 crc e95dc95d sha1 f5f33729a956131d9c44310f0ae3bb0599e9ec3e ) +) + +game ( + name "[BIOS] Touch Boy System ROM (Taiwan) (Unl)" + description "[BIOS] Touch Boy System ROM (Taiwan) (Unl)" + rom ( name "[BIOS] Touch Boy System ROM (Taiwan) (Unl).gbc" size 131072 crc 4a5f1e2b sha1 dce8de70944e45b5687edef09370b6449f39a918 ) +) + +game ( + name "007 - The World Is Not Enough (USA, Europe)" + description "007 - The World Is Not Enough (USA, Europe)" + rom ( name "007 - The World Is Not Enough (USA, Europe).gbc" size 2097152 crc e038e666 sha1 dd6e952b730c4bd85f8734156d43a2616b68c053 ) +) + +game ( + name "10-Pin Bowling (USA) (Rumble Version)" + description "10-Pin Bowling (USA) (Rumble Version)" + rom ( name "10-Pin Bowling (USA) (Rumble Version).gbc" size 1048576 crc 720c7023 sha1 eb0a65dc3069ae5261b04437ffac5efc12697c2a ) +) + +game ( + name "10-Pin Bowling (Europe)" + description "10-Pin Bowling (Europe)" + rom ( name "10-Pin Bowling (Europe).gbc" size 1048576 crc 5449cac0 sha1 90d78bf2f51eed998002d8733d6e223b6478f487 ) +) + +game ( + name "102 Dalmatas - Cachorros Al Rescate (Spain)" + description "102 Dalmatas - Cachorros Al Rescate (Spain)" + rom ( name "102 Dalmatas - Cachorros Al Rescate (Spain).gbc" size 1048576 crc f2128908 sha1 eaf3bd27cf7cb084068c5a139da5383a74105ffa ) +) + +game ( + name "102 Dalmatians - Puppies to the Rescue (USA, Europe)" + description "102 Dalmatians - Puppies to the Rescue (USA, Europe)" + rom ( name "102 Dalmatians - Puppies to the Rescue (USA, Europe).gbc" size 1048576 crc 56b83539 sha1 9f0f45d84e60e9c6f52fde14e1c0a49992aed025 flags verified ) +) + +game ( + name "102 Dalmatiens a la Rescousse, Les (France)" + description "102 Dalmatiens a la Rescousse, Les (France)" + rom ( name "102 Dalmatiens a la Rescousse, Les (France).gbc" size 1048576 crc e84191a8 sha1 ba028395de3456dc232bac24eda84a30e15f5550 ) +) + +game ( + name "102 Dalmatiner (Germany)" + description "102 Dalmatiner (Germany)" + rom ( name "102 Dalmatiner (Germany).gbc" size 1048576 crc 725a3483 sha1 69109b87dae04fcb9b65374165527d03845a2dc3 ) +) + +game ( + name "1942 (USA, Europe)" + description "1942 (USA, Europe)" + rom ( name "1942 (USA, Europe).gbc" size 1048576 crc 87431672 sha1 d960e951b18d07e79d046313df49c18313664224 ) +) + +game ( + name "2001 Fatal Fury (Taiwan) (En) (Unl)" + description "2001 Fatal Fury (Taiwan) (En) (Unl)" + rom ( name "2001 Fatal Fury (Taiwan) (En) (Unl).gbc" size 1048576 crc 7eda0e26 sha1 cd632530d71c560111bfc13a341f0f9a234db50a ) +) + +game ( + name "2002 Adventure Digimon 7 (Taiwan) (En) (Unl)" + description "2002 Adventure Digimon 7 (Taiwan) (En) (Unl)" + rom ( name "2002 Adventure Digimon 7 (Taiwan) (En) (Unl).gbc" size 2097152 crc 1bfc7099 sha1 532206800253fce0e81a0825ba49d60a7d6c5ca4 ) +) + +game ( + name "2002 Digimon Adventure 6 (Taiwan) (En) (Unl)" + description "2002 Digimon Adventure 6 (Taiwan) (En) (Unl)" + rom ( name "2002 Digimon Adventure 6 (Taiwan) (En) (Unl).gbc" size 1048576 crc 3f0d046b sha1 eea8928b277beb56ca8878b6dbfc094b0c3c5463 ) +) + +game ( + name "2003 Crash II Advance (USA) (Unl)" + description "2003 Crash II Advance (USA) (Unl)" + rom ( name "2003 Crash II Advance (USA) (Unl).gbc" size 2097152 crc 973d38a8 sha1 acdc42716f61bf11ecf08d50a980047f8fb7dc57 ) +) + +game ( + name "2003 Digimom Sapphii (Taiwan) (En) (Unl)" + description "2003 Digimom Sapphii (Taiwan) (En) (Unl)" + rom ( name "2003 Digimom Sapphii (Taiwan) (En) (Unl).gbc" size 2097152 crc 7cff9f0b sha1 1e42c461e0c6705637a698dbda8b34bc37acc51d ) +) + +game ( + name "2003 Digimom Sapphii (Taiwan) (De) (Unl)" + description "2003 Digimom Sapphii (Taiwan) (De) (Unl)" + rom ( name "2003 Digimom Sapphii (Taiwan) (De) (Unl).gbc" size 2097152 crc bd285d64 sha1 1cdffe470fde714898a2b0de92edd88e791a1bdf ) +) + +game ( + name "2003 Gu Huo Lang II (Taiwan) (Unl)" + description "2003 Gu Huo Lang II (Taiwan) (Unl)" + rom ( name "2003 Gu Huo Lang II (Taiwan) (Unl).gbc" size 2097152 crc 74d71b0c sha1 fcbb769de0896ae69fe1063fa5d87cf079c8606a ) +) + +game ( + name "2003 Hali Bote 2 - Xiaoshi de Mishi (Taiwan) (Unl)" + description "2003 Hali Bote 2 - Xiaoshi de Mishi (Taiwan) (Unl)" + rom ( name "2003 Hali Bote 2 - Xiaoshi de Mishi (Taiwan) (Unl).gbc" size 2097152 crc 1b3e1243 sha1 0829cbcab3ef5d03c94d5efe769f4f4a93ac47fa ) +) + +game ( + name "2003 Hali Xiaozi IV (Taiwan) (Unl)" + description "2003 Hali Xiaozi IV (Taiwan) (Unl)" + rom ( name "2003 Hali Xiaozi IV (Taiwan) (Unl).gbc" size 2097152 crc db3c8b95 sha1 0d230b20388f4396d6345b8eb59f54fc169ad8ee ) +) + +game ( + name "2003 Harry Potter 3 (Taiwan) (Unl)" + description "2003 Harry Potter 3 (Taiwan) (Unl)" + rom ( name "2003 Harry Potter 3 (Taiwan) (Unl).gbc" size 1048576 crc 4ea2c869 sha1 739c0e5dc0efd4ddb912236a6f630c3d6987d064 ) +) + +game ( + name "2003 King Lion Advance III (USA) (Unl)" + description "2003 King Lion Advance III (USA) (Unl)" + rom ( name "2003 King Lion Advance III (USA) (Unl).gbc" size 2097152 crc 0c22466d sha1 7c43ccfca93cae23e04e58fa0d7d7400a9694e0e ) +) + +game ( + name "2003 Koudai Guaishou - Lanbaoshi (Taiwan) (Unl)" + description "2003 Koudai Guaishou - Lanbaoshi (Taiwan) (Unl)" + rom ( name "2003 Koudai Guaishou - Lanbaoshi (Taiwan) (Unl).gbc" size 2097152 crc 4c76d4d8 sha1 d688201e6031b88f122ec753a37daedfb233b48d ) +) + +game ( + name "2003 Pocket Monster - Carbuncle (USA) (Unl)" + description "2003 Pocket Monster - Carbuncle (USA) (Unl)" + rom ( name "2003 Pocket Monster - Carbuncle (USA) (Unl).gbc" size 2097152 crc 3a0e9b6f sha1 025973627743f2f1ae1ff5b8a3f549cbcc227ef3 ) +) + +game ( + name "2003 Shuma Baolong - Gedou Ban (Taiwan) (Unl)" + description "2003 Shuma Baolong - Gedou Ban (Taiwan) (Unl)" + rom ( name "2003 Shuma Baolong - Gedou Ban (Taiwan) (Unl).gbc" size 2097152 crc 1219eec6 sha1 4a722c10e3893e04c67a66d0aea401d6d220ec7e ) +) + +game ( + name "23 in 1 (Taiwan) (Unl)" + description "23 in 1 (Taiwan) (Unl)" + rom ( name "23 in 1 (Taiwan) (Unl).gbc" size 2097152 crc 1e45fc45 sha1 e14acf52538cdde2134a79353f5f57bd8da9b4a7 ) +) + +game ( + name "3-D Ultra Pinball - Thrillride (USA) (Rumble Version)" + description "3-D Ultra Pinball - Thrillride (USA) (Rumble Version)" + rom ( name "3-D Ultra Pinball - Thrillride (USA) (Rumble Version).gbc" size 524288 crc 1766e558 sha1 2b704415803cf6172a1d07912b1155c51576a511 ) +) + +game ( + name "31 in 1 (Taiwan) (31B-001, Sachen) (Unl)" + description "31 in 1 (Taiwan) (31B-001, Sachen) (Unl)" + rom ( name "31 in 1 (Taiwan) (31B-001, Sachen) (Unl).gbc" size 2097152 crc 0eb8ddfb sha1 8fa0d40dc4c239108304e8799413a69a5668404c flags verified ) +) + +game ( + name "31-in-1 Mighty Mix (Australia) (31B-001, Sachen) (Unl)" + description "31-in-1 Mighty Mix (Australia) (31B-001, Sachen) (Unl)" + rom ( name "31-in-1 Mighty Mix (Australia) (31B-001, Sachen) (Unl).gbc" size 2097152 crc 21524051 sha1 c0c2a65b1485a2768962cb97ba2f9b668528453a ) +) + +game ( + name "36 in 1 (Taiwan) (SL36-0032) (Unl)" + description "36 in 1 (Taiwan) (SL36-0032) (Unl)" + rom ( name "36 in 1 (Taiwan) (SL36-0032) (Unl).gbc" size 4194304 crc f68d980a sha1 63181a86fa4a653744e9c393aa9f113e981d9cc7 ) +) + +game ( + name "3D Pocket Pool (Europe) (En,Fr,De,Es,It,Nl)" + description "3D Pocket Pool (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "3D Pocket Pool (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 8cdab77f sha1 11ee7ba924f80e1c546af4749ea46ac5c8c75a5d ) +) + +game ( + name "3D Pool Allstars (USA) (En,Fr,Es) (Proto)" + description "3D Pool Allstars (USA) (En,Fr,Es) (Proto)" + rom ( name "3D Pool Allstars (USA) (En,Fr,Es) (Proto).gbc" size 1048576 crc 245de3e2 sha1 f7289c3eed275286d0fb3dc7097098276b746786 ) +) + +game ( + name "4 in 1 + 8 in 1 (World) (4B-001, 4B-009, 8B-001, Sachen) (Unl)" + description "4 in 1 + 8 in 1 (World) (4B-001, 4B-009, 8B-001, Sachen) (Unl)" + rom ( name "4 in 1 + 8 in 1 (World) (4B-001, 4B-009, 8B-001, Sachen) (Unl).gbc" size 524288 crc 42a2fdf8 sha1 79a4faddfd1aca397e56d7895e45b1bc12900dab flags verified ) +) + +game ( + name "4 in 1 + 8 in 1 (World) (4B-002, 4B-004, 8B-002, Sachen) (Unl)" + description "4 in 1 + 8 in 1 (World) (4B-002, 4B-004, 8B-002, Sachen) (Unl)" + rom ( name "4 in 1 + 8 in 1 (World) (4B-002, 4B-004, 8B-002, Sachen) (Unl).gbc" size 524288 crc e7224f14 sha1 2d7d6cdc49ec71e20be9c752ceaf38c5e2c29c5f flags verified ) +) + +game ( + name "4 in 1 + 8 in 1 (World) (4B-005, 4B-006, 8B-003, Sachen) (Unl)" + description "4 in 1 + 8 in 1 (World) (4B-005, 4B-006, 8B-003, Sachen) (Unl)" + rom ( name "4 in 1 + 8 in 1 (World) (4B-005, 4B-006, 8B-003, Sachen) (Unl).gbc" size 524288 crc b18465d2 sha1 40b4f3147ee7f79dbd64a862074ce50a7b4445ec flags verified ) +) + +game ( + name "4 in 1 + 8 in 1 (World) (4B-007, 4B-008, 8B-004, Sachen) (Unl)" + description "4 in 1 + 8 in 1 (World) (4B-007, 4B-008, 8B-004, Sachen) (Unl)" + rom ( name "4 in 1 + 8 in 1 (World) (4B-007, 4B-008, 8B-004, Sachen) (Unl).gbc" size 524288 crc 0a504426 sha1 9c436bb4e2c666a92d4f695c776c2751cd3eb3b6 flags verified ) +) + +game ( + name "4x4 World Trophy (Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "4x4 World Trophy (Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "4x4 World Trophy (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc f62ad75e sha1 369e359d1b9a80fdda756411a395594b3d955100 flags verified ) +) + +game ( + name "720 Degrees (USA, Europe) (GB Compatible)" + description "720 Degrees (USA, Europe) (GB Compatible)" + rom ( name "720 Degrees (USA, Europe) (GB Compatible).gbc" size 1048576 crc e633841f sha1 78c0117c8ee32cfa605ac34eedf707cc535b3987 flags verified ) +) + +game ( + name "Absolute X (Europe) (Proto)" + description "Absolute X (Europe) (Proto)" + rom ( name "Absolute X (Europe) (Proto).gbc" size 1048576 crc 5046c427 sha1 34fa9bc6b1fec75751f1f426528f18c833128ff7 ) +) + +game ( + name "Action Man - Search for Base X (USA, Europe)" + description "Action Man - Search for Base X (USA, Europe)" + rom ( name "Action Man - Search for Base X (USA, Europe).gbc" size 1048576 crc 1226499e sha1 4b62b0344b8fed07ceb967f9a9c45bbeed3dc592 flags verified ) +) + +game ( + name "Action Replay Online (Europe) (Unl)" + description "Action Replay Online (Europe) (Unl)" + rom ( name "Action Replay Online (Europe) (Unl).gbc" size 131072 crc 04c8c858 sha1 fa441c5e376b54b3503596fe8177b3a9ad79a9a8 ) +) + +game ( + name "Action Replay Xtreme - Special Edition for Pokemon Crystal (Europe) (Unl)" + description "Action Replay Xtreme - Special Edition for Pokemon Crystal (Europe) (Unl)" + rom ( name "Action Replay Xtreme - Special Edition for Pokemon Crystal (Europe) (Unl).gbc" size 131072 crc c288e400 sha1 0280b05885fe5aca8c1884a16bd01513b99f4dc2 flags verified ) +) + +game ( + name "Adventures of the Smurfs, The (Europe) (En,Fr,De,Es,It,Nl)" + description "Adventures of the Smurfs, The (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Adventures of the Smurfs, The (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc d0d3dfed sha1 7919c5e6aa8d040b1f7953345b376d999cf22b18 ) +) + +game ( + name "AirForce Delta (Japan)" + description "AirForce Delta (Japan)" + rom ( name "AirForce Delta (Japan).gbc" size 1048576 crc 5dfff5e2 sha1 593df751cc6b1a7af7f50a9c9cfcedf8287384dc ) +) + +game ( + name "AirForce Delta (USA)" + description "AirForce Delta (USA)" + rom ( name "AirForce Delta (USA).gbc" size 1048576 crc ff31cc92 sha1 82530325b940e14edea459879289b4dce1818066 ) +) + +game ( + name "Aladdin (Europe) (En,Fr,De,Es,It,Nl)" + description "Aladdin (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Aladdin (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 446573cd sha1 23335b9654766275831115a54f5142c4cb9183fe ) +) + +game ( + name "Aladdin (USA)" + description "Aladdin (USA)" + rom ( name "Aladdin (USA).gbc" size 1048576 crc a91ec059 sha1 97b46bf9862c9a1ef73d41f18b3693c6d9c73c06 ) +) + +game ( + name "Alfred's Adventure (Europe) (En,Fr,De,Es,It)" + description "Alfred's Adventure (Europe) (En,Fr,De,Es,It)" + rom ( name "Alfred's Adventure (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 6f9ef15e sha1 81c1acf0e87755a8c16f0beeb3524b3ec04455ea ) +) + +game ( + name "Alice in Wonderland (Europe) (En,Fr,De,Es)" + description "Alice in Wonderland (Europe) (En,Fr,De,Es)" + rom ( name "Alice in Wonderland (Europe) (En,Fr,De,Es).gbc" size 2097152 crc 85545d81 sha1 ea8647cce2d4b5f7993190c6e485669cc6046a29 ) +) + +game ( + name "Alice in Wonderland (USA, Australia)" + description "Alice in Wonderland (USA, Australia)" + rom ( name "Alice in Wonderland (USA, Australia).gbc" size 2097152 crc 3199f65f sha1 02c49003d5eb1498f239149089a517cdfb6bda0b ) +) + +game ( + name "Aliens - Thanatos Encounter (USA, Europe)" + description "Aliens - Thanatos Encounter (USA, Europe)" + rom ( name "Aliens - Thanatos Encounter (USA, Europe).gbc" size 1048576 crc bec3c24b sha1 e1b1c79c15a34984dddbe270fc6770b32a31a0d7 ) +) + +game ( + name "All Star Tennis '99 (USA) (Proto) (1999-09-13) (GB Compatible)" + description "All Star Tennis '99 (USA) (Proto) (1999-09-13) (GB Compatible)" + rom ( name "All Star Tennis '99 (USA) (Proto) (1999-09-13) (GB Compatible).gbc" size 1048576 crc e1b17e76 sha1 239e79281faacf7df2abfb527e6e2adfb58b0bc3 ) +) + +game ( + name "All Star Tennis 2000 (USA) (Proto) (GB Compatible)" + description "All Star Tennis 2000 (USA) (Proto) (GB Compatible)" + rom ( name "All Star Tennis 2000 (USA) (Proto) (GB Compatible).gbc" size 1048576 crc 9890bcb4 sha1 f6829ac5bba08732f875fc5812284d62f3d727e6 ) +) + +game ( + name "All Star Tennis 2000 (Europe) (AZTX) (Proto) (GB Compatible)" + description "All Star Tennis 2000 (Europe) (AZTX) (Proto) (GB Compatible)" + rom ( name "All Star Tennis 2000 (Europe) (AZTX) (Proto) (GB Compatible).gbc" size 1048576 crc deff8dfb sha1 c9db40e3e348668fe6fc41d031263acbe9041a67 ) +) + +game ( + name "All Star Tennis 2000 (Europe) (AZTP) (GB Compatible)" + description "All Star Tennis 2000 (Europe) (AZTP) (GB Compatible)" + rom ( name "All Star Tennis 2000 (Europe) (AZTP) (GB Compatible).gbc" size 1048576 crc 952b94e5 sha1 50f99b0fc5c2f5edc2e76ba973cc42fb0a1a02c8 ) +) + +game ( + name "All-Star Baseball 2000 (USA, Europe)" + description "All-Star Baseball 2000 (USA, Europe)" + rom ( name "All-Star Baseball 2000 (USA, Europe).gbc" size 1048576 crc e17f59a5 sha1 7156ac04b7d249007f62b4b509b4661190977908 ) +) + +game ( + name "All-Star Baseball 2001 (USA)" + description "All-Star Baseball 2001 (USA)" + rom ( name "All-Star Baseball 2001 (USA).gbc" size 1048576 crc bc562466 sha1 f702df64d368b763187a5b1263a60fb3e842962b ) +) + +game ( + name "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + description "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + rom ( name "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 4194304 crc 7c101475 sha1 120e2dd012cfe47a7e37cc91fcbbce92494bdf2a ) +) + +game ( + name "Alone in the Dark - The New Nightmare (USA) (Beta) (2001-02-21)" + description "Alone in the Dark - The New Nightmare (USA) (Beta) (2001-02-21)" + rom ( name "Alone in the Dark - The New Nightmare (USA) (Beta) (2001-02-21).gbc" size 4194304 crc 3821d140 sha1 fc2a7dbe5ff60e2704ac78f83d6b6df2bf9dcc97 ) +) + +game ( + name "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl)" + description "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl).gbc" size 4194304 crc 7ff2042f sha1 818259159b5e7d3775584b478d4fd36f6a25fcaa flags verified ) +) + +game ( + name "Alone in the Dark - The New Nightmare (USA) (En,Fr,Es)" + description "Alone in the Dark - The New Nightmare (USA) (En,Fr,Es)" + rom ( name "Alone in the Dark - The New Nightmare (USA) (En,Fr,Es).gbc" size 4194304 crc c145c036 sha1 a348aeac500d0d8fdaf90f5277631a026504ff44 ) +) + +game ( + name "AMF Bowling (USA) (Proto)" + description "AMF Bowling (USA) (Proto)" + rom ( name "AMF Bowling (USA) (Proto).gbc" size 1048576 crc 392559ee sha1 1dd7d94f320d119682fd4df80297c8df1b28141b ) +) + +game ( + name "Animal Breeder 3 (Japan) (SGB Enhanced) (GB Compatible)" + description "Animal Breeder 3 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Animal Breeder 3 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc c62a4c30 sha1 f5e6e770a681bb6eba255e2584f9ed343e5d9f98 ) +) + +game ( + name "Animal Breeder 4 (Japan)" + description "Animal Breeder 4 (Japan)" + rom ( name "Animal Breeder 4 (Japan).gbc" size 4194304 crc 83d838c3 sha1 2f7854cfc227ecc395551ea4c0b62256f0757514 ) +) + +game ( + name "Animastar GB (Japan)" + description "Animastar GB (Japan)" + rom ( name "Animastar GB (Japan).gbc" size 2097152 crc b14920f0 sha1 4f141e012fc46cab0dd36655c2548dfaed0a862f flags verified ) +) + +game ( + name "Animorphs (Europe) (En,Fr,De,Es,It)" + description "Animorphs (Europe) (En,Fr,De,Es,It)" + rom ( name "Animorphs (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 7fd46da1 sha1 c936a5b3c005f72de5032c4a067a7d95ab2735fa ) +) + +game ( + name "Animorphs (USA)" + description "Animorphs (USA)" + rom ( name "Animorphs (USA).gbc" size 1048576 crc b4f293cc sha1 b3e5b34d5e97c49720861fabb6a29d557029279c ) +) + +game ( + name "Anpfiff - Der RTL Fussball-Manager (Germany)" + description "Anpfiff - Der RTL Fussball-Manager (Germany)" + rom ( name "Anpfiff - Der RTL Fussball-Manager (Germany).gbc" size 1048576 crc b54d264a sha1 4c5bd67eee82a36cf695db12169bc4393225faa0 flags verified ) +) + +game ( + name "Antz (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + description "Antz (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + rom ( name "Antz (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc 4839e0c1 sha1 2cba2b024edb4b702d2acabefbcb310f4d6e2075 ) +) + +game ( + name "Antz (USA) (En,Fr,Es) (GB Compatible)" + description "Antz (USA) (En,Fr,Es) (GB Compatible)" + rom ( name "Antz (USA) (En,Fr,Es) (GB Compatible).gbc" size 1048576 crc dc0be439 sha1 85684d5891e4ec0f9fdf61b644bdf0ffbf1ba219 flags verified ) +) + +game ( + name "Antz (Europe) (En,Fr,De,Es,It,Nl) (Beta) (GB Compatible)" + description "Antz (Europe) (En,Fr,De,Es,It,Nl) (Beta) (GB Compatible)" + rom ( name "Antz (Europe) (En,Fr,De,Es,It,Nl) (Beta) (GB Compatible).gbc" size 524288 crc f287fc49 sha1 99818cd3dc4bfe61bf0095856a0f443afae89acf ) +) + +game ( + name "Antz Racing (Europe) (En,Fr,De,Es,It,Nl)" + description "Antz Racing (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Antz Racing (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc f625a959 sha1 e4ff55112a76da72f30582476f15358527518cfd flags verified ) +) + +game ( + name "Antz Racing (USA) (En,Fr,De,Es,It,Nl)" + description "Antz Racing (USA) (En,Fr,De,Es,It,Nl)" + rom ( name "Antz Racing (USA) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc dfdf90c0 sha1 806e641b911b302f5be2a80b6003f473d1a10a88 ) +) + +game ( + name "Antz World Sportz (Europe) (En,Fr,De,Es,It,Nl)" + description "Antz World Sportz (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Antz World Sportz (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 67c7f85c sha1 d8ddf04baad3beadedf85847964f986ba89bc5ee ) +) + +game ( + name "Aqualife (Japan) (SGB Enhanced) (GB Compatible)" + description "Aqualife (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Aqualife (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e243feb4 sha1 69eaf53eccdaf98cd7cc0d436209f511b558d761 ) +) + +game ( + name "Arle no Bouken - Mahou no Jewel (Japan) (SGB Enhanced) (GB Compatible)" + description "Arle no Bouken - Mahou no Jewel (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Arle no Bouken - Mahou no Jewel (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 8ee043ea sha1 fb781637ddac30cebb1865ba939f49bb2b0b5146 ) +) + +game ( + name "Armada - FX Racers (USA)" + description "Armada - FX Racers (USA)" + rom ( name "Armada - FX Racers (USA).gbc" size 1048576 crc d952cbab sha1 b8f911e6d6dc37b9bbfd565f6919a94f17bf3073 ) +) + +game ( + name "Armorines - Project S.W.A.R.M. (USA, Europe) (En,De)" + description "Armorines - Project S.W.A.R.M. (USA, Europe) (En,De)" + rom ( name "Armorines - Project S.W.A.R.M. (USA, Europe) (En,De).gbc" size 1048576 crc ea3b9c73 sha1 2be58ee1a3a76d1259a044c6c7c9dcd6dacf8405 flags verified ) +) + +game ( + name "Army Men (USA, Europe) (En,Fr,De)" + description "Army Men (USA, Europe) (En,Fr,De)" + rom ( name "Army Men (USA, Europe) (En,Fr,De).gbc" size 1048576 crc 34411753 sha1 e98cea1a113ba4774ce26ab16d61625f0870b6ad flags verified ) +) + +game ( + name "Army Men - Air Combat (USA, Europe) (En,Fr,De)" + description "Army Men - Air Combat (USA, Europe) (En,Fr,De)" + rom ( name "Army Men - Air Combat (USA, Europe) (En,Fr,De).gbc" size 1048576 crc b0d1de8c sha1 4e1d964d31013e79ecae4a49dcd3777cc7e06af2 flags verified ) +) + +game ( + name "Army Men - Sarge's Heroes 2 (USA, Europe) (En,Fr,De)" + description "Army Men - Sarge's Heroes 2 (USA, Europe) (En,Fr,De)" + rom ( name "Army Men - Sarge's Heroes 2 (USA, Europe) (En,Fr,De).gbc" size 1048576 crc 71b857ea sha1 9a2adb5639c80282d7465f9c5d30acb669991d8e flags verified ) +) + +game ( + name "Army Men 2 (USA, Europe) (En,Fr,De)" + description "Army Men 2 (USA, Europe) (En,Fr,De)" + rom ( name "Army Men 2 (USA, Europe) (En,Fr,De).gbc" size 1048576 crc 2272baca sha1 6e52dcaca1a97ae557c4c87e4281667a9d9b14c5 flags verified ) +) + +game ( + name "Arthur's Absolutely Fun Day! (USA)" + description "Arthur's Absolutely Fun Day! (USA)" + rom ( name "Arthur's Absolutely Fun Day! (USA).gbc" size 1048576 crc f03599a3 sha1 cf1323cfd3fbe8ba8c9766a87a7c68d8b7e729f9 ) +) + +game ( + name "Asterix - Sur la Trace D'Idefix (Europe) (En,Fr,De,Es,It,Nl)" + description "Asterix - Sur la Trace D'Idefix (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Asterix - Sur la Trace D'Idefix (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 408dc5c6 sha1 5c7207137ab422d3326d183d3433db161d8ecbc5 flags verified ) +) + +game ( + name "Asterix & Obelix (Europe) (En,Fr,De,Es)" + description "Asterix & Obelix (Europe) (En,Fr,De,Es)" + rom ( name "Asterix & Obelix (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 6628cdee sha1 5f36071df7be289c169768b1683947e972d26996 ) +) + +game ( + name "Asterix & Obelix Contre Cesar (Europe) (En,Fr,De,Es,Nl) (GB Compatible)" + description "Asterix & Obelix Contre Cesar (Europe) (En,Fr,De,Es,Nl) (GB Compatible)" + rom ( name "Asterix & Obelix Contre Cesar (Europe) (En,Fr,De,Es,Nl) (GB Compatible).gbc" size 1048576 crc 71043d76 sha1 a4b892d269957d84570c07856c81f48f037b5a03 ) +) + +game ( + name "Asteroids (USA, Europe) (GB Compatible)" + description "Asteroids (USA, Europe) (GB Compatible)" + rom ( name "Asteroids (USA, Europe) (GB Compatible).gbc" size 1048576 crc 89d5d936 sha1 026f031e1bb787a4390e7873227dcb52a069a6e0 flags verified ) +) + +game ( + name "Atlantis - The Lost Empire (Europe) (En,Es,It)" + description "Atlantis - The Lost Empire (Europe) (En,Es,It)" + rom ( name "Atlantis - The Lost Empire (Europe) (En,Es,It).gbc" size 2097152 crc 28f7d5e3 sha1 ef4ab0dd852ffd1418c803c05ddcb245b3a4348d ) +) + +game ( + name "Atlantis - The Lost Empire (Europe) (Fr,De,Nl)" + description "Atlantis - The Lost Empire (Europe) (Fr,De,Nl)" + rom ( name "Atlantis - The Lost Empire (Europe) (Fr,De,Nl).gbc" size 2097152 crc 4e052510 sha1 19df06e2a8be1336a6aec8c86649b95b206dc54f ) +) + +game ( + name "Atlantis - The Lost Empire (USA, Europe)" + description "Atlantis - The Lost Empire (USA, Europe)" + rom ( name "Atlantis - The Lost Empire (USA, Europe).gbc" size 2097152 crc d594d24b sha1 ab5dd8efa36b33ce9aa090b3d990e8fc8828f7e2 ) +) + +game ( + name "Atsumete Asobu Kuma no Pooh-san - Mori no Takaramono (Japan)" + description "Atsumete Asobu Kuma no Pooh-san - Mori no Takaramono (Japan)" + rom ( name "Atsumete Asobu Kuma no Pooh-san - Mori no Takaramono (Japan).gbc" size 2097152 crc 476ede93 sha1 73b95f3b92c2d48a2580f7ac10950d56aeffb94d ) +) + +game ( + name "ATV Racing (Europe) (Unl)" + description "ATV Racing (Europe) (Unl)" + rom ( name "ATV Racing (Europe) (Unl).gbc" size 262144 crc 7987d5cd sha1 b3c6c2970c3bfa95fb2eef10e2160f55f52d8e1a ) +) + +game ( + name "ATV Racing & Karate Joe (Europe) (Unl)" + description "ATV Racing & Karate Joe (Europe) (Unl)" + rom ( name "ATV Racing & Karate Joe (Europe) (Unl).gbc" size 524288 crc a07b6e79 sha1 3701028d66564625933a3868340813e6d7c36b7b ) +) + +game ( + name "ATV Racing & Karate Joe (Europe) (Unl) (Alt)" + description "ATV Racing & Karate Joe (Europe) (Unl) (Alt)" + rom ( name "ATV Racing & Karate Joe (Europe) (Unl) (Alt).gbc" size 524288 crc 6908f4af sha1 95287b440139e88d90700f892d1da60aaa4da778 ) +) + +game ( + name "Austin Powers - Oh, Behave! (Europe) (En,Fr,De,Es,It)" + description "Austin Powers - Oh, Behave! (Europe) (En,Fr,De,Es,It)" + rom ( name "Austin Powers - Oh, Behave! (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc bf99f8cb sha1 a5d29d48b9bc3e1fa476e475da24c2d80985188d ) +) + +game ( + name "Austin Powers - Oh, Behave! (USA)" + description "Austin Powers - Oh, Behave! (USA)" + rom ( name "Austin Powers - Oh, Behave! (USA).gbc" size 4194304 crc bb89190e sha1 aa6cb6ab4fe083cbe0274c40bd30e0013a2f7645 ) +) + +game ( + name "Austin Powers - Welcome to My Underground Lair! (Europe) (En,Fr,De,Es,It)" + description "Austin Powers - Welcome to My Underground Lair! (Europe) (En,Fr,De,Es,It)" + rom ( name "Austin Powers - Welcome to My Underground Lair! (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 693f50da sha1 02c7c61928ab82b4a8a07bb067d5f5ca32511df7 ) +) + +game ( + name "Austin Powers - Welcome to My Underground Lair! (USA)" + description "Austin Powers - Welcome to My Underground Lair! (USA)" + rom ( name "Austin Powers - Welcome to My Underground Lair! (USA).gbc" size 4194304 crc aba42b78 sha1 69b5106a124bde38184875c0dd08de437360bc14 ) +) + +game ( + name "Austin Powers Episode III (Europe) (En,Fr,De,Es,It) (Proto)" + description "Austin Powers Episode III (Europe) (En,Fr,De,Es,It) (Proto)" + rom ( name "Austin Powers Episode III (Europe) (En,Fr,De,Es,It) (Proto).gbc" size 2097152 crc 0903ed53 sha1 b409782cc478104c41668360b63f8589f7677e2a ) +) + +game ( + name "Austin Powers Episode IV (Europe) (En,Fr,De,Es,It) (Proto)" + description "Austin Powers Episode IV (Europe) (En,Fr,De,Es,It) (Proto)" + rom ( name "Austin Powers Episode IV (Europe) (En,Fr,De,Es,It) (Proto).gbc" size 2097152 crc f038cda7 sha1 937df6944709732d8d372ad5f629a665ffd12eac ) +) + +game ( + name "Aventures de Buzz l'Eclair, Les (France)" + description "Aventures de Buzz l'Eclair, Les (France)" + rom ( name "Aventures de Buzz l'Eclair, Les (France).gbc" size 524288 crc 841674b0 sha1 4c4c51883b6c73627ca9b04bb0b24e6bab072f29 ) +) + +game ( + name "Azarashi Sentai Inazuma - Dokidoki Daisakusen! (Japan)" + description "Azarashi Sentai Inazuma - Dokidoki Daisakusen! (Japan)" + rom ( name "Azarashi Sentai Inazuma - Dokidoki Daisakusen! (Japan).gbc" size 1048576 crc 98f63bd4 sha1 f4278b01f445562d17a9a2fd8dd5c9bc9d32008e ) +) + +game ( + name "Azure Dreams (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + description "Azure Dreams (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + rom ( name "Azure Dreams (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc f9ccab09 sha1 81d9acd0e27639f90e38e918a4b0a96fa565d1d9 ) +) + +game ( + name "Azure Dreams (USA) (SGB Enhanced) (GB Compatible)" + description "Azure Dreams (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Azure Dreams (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 71d52876 sha1 1ebc365058dbb4d4f7ccad6185f4364d584bf250 ) +) + +game ( + name "B-Daman Bakugaiden - Victory e no Michi (Japan) (SGB Enhanced) (GB Compatible)" + description "B-Daman Bakugaiden - Victory e no Michi (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "B-Daman Bakugaiden - Victory e no Michi (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ddce76d6 sha1 4904102846a5fd0176c6f4bfd421f86fb1fab45b ) +) + +game ( + name "B-Daman Bakugaiden V - Final Mega Tune (Japan)" + description "B-Daman Bakugaiden V - Final Mega Tune (Japan)" + rom ( name "B-Daman Bakugaiden V - Final Mega Tune (Japan).gbc" size 2097152 crc 547a9a69 sha1 7933fe70912ee74f14199a149ede69bdb153f4ad ) +) + +game ( + name "Babe and Friends (Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "Babe and Friends (Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Babe and Friends (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc b3681854 sha1 52a560185b7e77e5286771f7851f69323512658e flags verified ) +) + +game ( + name "Babe and Friends (USA) (GB Compatible)" + description "Babe and Friends (USA) (GB Compatible)" + rom ( name "Babe and Friends (USA) (GB Compatible).gbc" size 1048576 crc e25407f1 sha1 51a4fd838903039b60bf5c13677cbea6bbb7d368 ) +) + +game ( + name "Baby Felix - Halloween (Europe) (En,Fr,De,Es,It,Nl)" + description "Baby Felix - Halloween (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Baby Felix - Halloween (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 7ded5c71 sha1 6c924f693e08e32c0e59f386cd728beb32d00105 ) +) + +game ( + name "Back to Earth 3D (Europe) (Demo)" + description "Back to Earth 3D (Europe) (Demo)" + rom ( name "Back to Earth 3D (Europe) (Demo).gbc" size 262144 crc d4255616 sha1 716722ed8756b656bba00cbff116f883e629cfd2 ) +) + +game ( + name "Backgammon (Europe) (En,Fr,De,Es) (GB Compatible)" + description "Backgammon (Europe) (En,Fr,De,Es) (GB Compatible)" + rom ( name "Backgammon (Europe) (En,Fr,De,Es) (GB Compatible).gbc" size 1048576 crc d33d6f7b sha1 b634a2980efe1378ecb26a761241d48f4604e5f0 ) +) + +game ( + name "Backgammon (Japan) (GB Compatible)" + description "Backgammon (Japan) (GB Compatible)" + rom ( name "Backgammon (Japan) (GB Compatible).gbc" size 1048576 crc 712a49b3 sha1 eb8b70e445174a812044ca5b101bdcb00c389940 ) +) + +game ( + name "Bad Badtz-Maru Robo Battle (Japan)" + description "Bad Badtz-Maru Robo Battle (Japan)" + rom ( name "Bad Badtz-Maru Robo Battle (Japan).gbc" size 2097152 crc 4dd29b09 sha1 da06158a4d3aed781e77a5f69faaf522b0a98cbd ) +) + +game ( + name "Baiwan Dafuweng - Jin Ban (Taiwan) (Unl)" + description "Baiwan Dafuweng - Jin Ban (Taiwan) (Unl)" + rom ( name "Baiwan Dafuweng - Jin Ban (Taiwan) (Unl).gbc" size 1048576 crc 518c7a4e sha1 03673aec3060d72982226ed5cdfdf86f31eb70a0 ) +) + +game ( + name "Bakukyuu Renpatsu!! Super B-Daman - Gekitan! Rising Valkyrie!! (Japan) (SGB Enhanced) (GB Compatible)" + description "Bakukyuu Renpatsu!! Super B-Daman - Gekitan! Rising Valkyrie!! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Bakukyuu Renpatsu!! Super B-Daman - Gekitan! Rising Valkyrie!! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 5c95d5a2 sha1 952933a658f0b4182619e7184f49aa4a47fc5f84 flags verified ) +) + +game ( + name "Bakusou Dekotora Densetsu GB Special - Otoko Dokyou no Tenka Touitsu (Japan)" + description "Bakusou Dekotora Densetsu GB Special - Otoko Dokyou no Tenka Touitsu (Japan)" + rom ( name "Bakusou Dekotora Densetsu GB Special - Otoko Dokyou no Tenka Touitsu (Japan).gbc" size 1048576 crc 92c8b9b5 sha1 50b115869bb9c488b3766c58ee44de63a84ba489 ) +) + +game ( + name "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (GB Compatible)" + description "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (GB Compatible)" + rom ( name "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (GB Compatible).gbc" size 1048576 crc d514c9a0 sha1 1f8088a739df180ecceaff1b37ed5c1a50772405 ) +) + +game ( + name "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (Rev 1) (Proto) (GB Compatible)" + description "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (Rev 1) (Proto) (GB Compatible)" + rom ( name "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (Rev 1) (Proto) (GB Compatible).gbc" size 1048576 crc 570bafdb sha1 3d6ea44dd8426e3d7bf87a8778dd91e8095ddd35 ) +) + +game ( + name "Bakuten Shoot Beyblade (Japan)" + description "Bakuten Shoot Beyblade (Japan)" + rom ( name "Bakuten Shoot Beyblade (Japan).gbc" size 2097152 crc bc306ea4 sha1 68d41bca8d2ac8e9a6855460b15e6045acd341a1 ) +) + +game ( + name "Ballistic (USA) (GB Compatible)" + description "Ballistic (USA) (GB Compatible)" + rom ( name "Ballistic (USA) (GB Compatible).gbc" size 524288 crc a9050f72 sha1 28dfdc00ec7e353f4aae4c65d671300c0b97ab90 ) +) + +game ( + name "Balloon Fight GB (Japan) (SGB Enhanced, GB Compatible) (NP)" + description "Balloon Fight GB (Japan) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Balloon Fight GB (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc d2af64ce sha1 dbaa1bf9061de0f052704d6a33892341a38f2152 ) +) + +game ( + name "Barbie - Aventura Submarina (Spain) (GB Compatible)" + description "Barbie - Aventura Submarina (Spain) (GB Compatible)" + rom ( name "Barbie - Aventura Submarina (Spain) (GB Compatible).gbc" size 1048576 crc 0cf2b7f2 sha1 7b342745f14f0a2245b961cfd6e23d1b2e98c249 ) +) + +game ( + name "Barbie - Avventure nell'Oceano (Italy) (GB Compatible)" + description "Barbie - Avventure nell'Oceano (Italy) (GB Compatible)" + rom ( name "Barbie - Avventure nell'Oceano (Italy) (GB Compatible).gbc" size 1048576 crc 59645a18 sha1 79ea73d94d2402525c718563b5613bee71b69b44 ) +) + +game ( + name "Barbie - Chasse au Tresor Sous-Marine (France) (GB Compatible)" + description "Barbie - Chasse au Tresor Sous-Marine (France) (GB Compatible)" + rom ( name "Barbie - Chasse au Tresor Sous-Marine (France) (GB Compatible).gbc" size 1048576 crc 4068e981 sha1 bc44d39cce1f3143e9fa830ede2b4126a4d61b54 ) +) + +game ( + name "Barbie - Diepzee Avontuur (Netherlands) (GB Compatible)" + description "Barbie - Diepzee Avontuur (Netherlands) (GB Compatible)" + rom ( name "Barbie - Diepzee Avontuur (Netherlands) (GB Compatible).gbc" size 1048576 crc 39c6b8df sha1 3e93df9512819679deac989895de398a6159645c flags verified ) +) + +game ( + name "Barbie - Fashion Pack Games (USA, Europe) (GB Compatible)" + description "Barbie - Fashion Pack Games (USA, Europe) (GB Compatible)" + rom ( name "Barbie - Fashion Pack Games (USA, Europe) (GB Compatible).gbc" size 1048576 crc 09ee93a8 sha1 fecbde9125d2ce9c8e772f9078ebaccd196caa43 ) +) + +game ( + name "Barbie - Magic Genie Adventure (USA)" + description "Barbie - Magic Genie Adventure (USA)" + rom ( name "Barbie - Magic Genie Adventure (USA).gbc" size 1048576 crc 57f1a202 sha1 30e779f19cd8f8c979bda38dd90e9798c742a66c ) +) + +game ( + name "Barbie - Meeres Abenteuer (Germany) (GB Compatible)" + description "Barbie - Meeres Abenteuer (Germany) (GB Compatible)" + rom ( name "Barbie - Meeres Abenteuer (Germany) (GB Compatible).gbc" size 1048576 crc 5e46d64a sha1 c392aefb3d657cae6602e285f5fb57ec079a818e ) +) + +game ( + name "Barbie - Ocean Discovery (United Kingdom) (GB Compatible)" + description "Barbie - Ocean Discovery (United Kingdom) (GB Compatible)" + rom ( name "Barbie - Ocean Discovery (United Kingdom) (GB Compatible).gbc" size 1048576 crc fdc8e7f1 sha1 c0c37864e17f11fffa8b8a61a0abe4b2b80c235c ) +) + +game ( + name "Barbie - Ocean Discovery (USA) (GB Compatible)" + description "Barbie - Ocean Discovery (USA) (GB Compatible)" + rom ( name "Barbie - Ocean Discovery (USA) (GB Compatible).gbc" size 1048576 crc 746936c6 sha1 fab988692a19d53e71fc754dea3a01506b104d9f ) +) + +game ( + name "Barbie - Pet Rescue (Europe) (En,Fr,De,Es,It)" + description "Barbie - Pet Rescue (Europe) (En,Fr,De,Es,It)" + rom ( name "Barbie - Pet Rescue (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 48e638ce sha1 191a42e0eaf6afb58bc8aaca0ee8dad0641594d4 ) +) + +game ( + name "Barbie - Pet Rescue (USA)" + description "Barbie - Pet Rescue (USA)" + rom ( name "Barbie - Pet Rescue (USA).gbc" size 1048576 crc 1fc972cc sha1 ffed44ab063c4181d5df85ff1304de10fa6392cd ) +) + +game ( + name "Barca Total 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca)" + description "Barca Total 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca)" + rom ( name "Barca Total 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca).gbc" size 1048576 crc cd15ed36 sha1 24b8f400d74e9f0aa82d27d82a3b15db3e743240 ) +) + +game ( + name "Barcode Taisen Bardigun (Japan) (SGB Enhanced) (GB Compatible)" + description "Barcode Taisen Bardigun (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Barcode Taisen Bardigun (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ddfcf4b7 sha1 bc7847dee730ba274f3c3ccb511f1dad6b6a93c7 flags verified ) +) + +game ( + name "Barcode Taisen Bardigun (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Barcode Taisen Bardigun (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Barcode Taisen Bardigun (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f6d291a9 sha1 21e386f60fcd3694c4a308de9e178762c5175b6c flags verified ) +) + +game ( + name "Bass Masters Classic (USA, Europe) (GB Compatible)" + description "Bass Masters Classic (USA, Europe) (GB Compatible)" + rom ( name "Bass Masters Classic (USA, Europe) (GB Compatible).gbc" size 1048576 crc b70028e4 sha1 b1bd238640e99e3584c8c4e4fa174ff144b600d6 ) +) + +game ( + name "Batman - Chaos in Gotham (Europe) (En,Fr,De,Es,It,Nl)" + description "Batman - Chaos in Gotham (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Batman - Chaos in Gotham (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc e025067b sha1 dbc6c729dde21abf324e2a055d819f088e696c0c ) +) + +game ( + name "Batman - Chaos in Gotham (USA)" + description "Batman - Chaos in Gotham (USA)" + rom ( name "Batman - Chaos in Gotham (USA).gbc" size 1048576 crc b241a4f3 sha1 de2d6a53316011b60fbc9a946f510effe42ede5e ) +) + +game ( + name "Batman Beyond - Return of the Joker (Japan) (NP)" + description "Batman Beyond - Return of the Joker (Japan) (NP)" + rom ( name "Batman Beyond - Return of the Joker (Japan) (NP).gbc" size 1048576 crc b8b1f8f8 sha1 47c8a56fa67d4982ed36fca56ef0f33c451a0c49 ) +) + +game ( + name "Batman Beyond - Return of the Joker (USA)" + description "Batman Beyond - Return of the Joker (USA)" + rom ( name "Batman Beyond - Return of the Joker (USA).gbc" size 1048576 crc b32f4586 sha1 8c69eb7ec5bc809edc8caa255576f919ea722dad ) +) + +game ( + name "Batman of the Future - Return of the Joker (Europe) (En,Fr,De)" + description "Batman of the Future - Return of the Joker (Europe) (En,Fr,De)" + rom ( name "Batman of the Future - Return of the Joker (Europe) (En,Fr,De).gbc" size 1048576 crc f9d5b399 sha1 102aa62c873b7316b1b019d895989dcdedb776a9 ) +) + +game ( + name "Battle Fishers (Japan)" + description "Battle Fishers (Japan)" + rom ( name "Battle Fishers (Japan).gbc" size 2097152 crc c99cf3c5 sha1 25d063b151c2d45a14d6952196490615b7e341c5 ) +) + +game ( + name "Battleship (USA, Europe) (GB Compatible)" + description "Battleship (USA, Europe) (GB Compatible)" + rom ( name "Battleship (USA, Europe) (GB Compatible).gbc" size 1048576 crc 8e6f8037 sha1 48a6cc9c5695378a118deb6b1035c15a26d476d7 flags verified ) +) + +game ( + name "BattleTanx (Europe) (En,Fr,De)" + description "BattleTanx (Europe) (En,Fr,De)" + rom ( name "BattleTanx (Europe) (En,Fr,De).gbc" size 1048576 crc 2fcecb70 sha1 d9f52594f79257dc616428a694c1f2c808797361 ) +) + +game ( + name "BattleTanx (USA)" + description "BattleTanx (USA)" + rom ( name "BattleTanx (USA).gbc" size 1048576 crc 4431f8e7 sha1 5078584e86c0b6f4687c424cc00bbd762ba6573a ) +) + +game ( + name "Beach'n Ball (Europe) (En,Fr,De,Es,It)" + description "Beach'n Ball (Europe) (En,Fr,De,Es,It)" + rom ( name "Beach'n Ball (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 82d1a721 sha1 90c0ab55136235d75a4e35bd5b0d90a99d2a42c4 ) +) + +game ( + name "Beach'n Ball (Europe) (En,Fr,De,Es,It) (Beta) (2000-11-21)" + description "Beach'n Ball (Europe) (En,Fr,De,Es,It) (Beta) (2000-11-21)" + rom ( name "Beach'n Ball (Europe) (En,Fr,De,Es,It) (Beta) (2000-11-21).gbc" size 1048576 crc a56180a8 sha1 faaf82512ad3f5429acf401d9e74d7016252e263 ) +) + +game ( + name "Beast Fighter (Taiwan) (En) (Sachen) (Unl)" + description "Beast Fighter (Taiwan) (En) (Sachen) (Unl)" + rom ( name "Beast Fighter (Taiwan) (En) (Sachen) (Unl).gbc" size 131072 crc 0bc7a3c6 sha1 bb76bc7ea3482e775efdbbf112455921d11ac317 ) +) + +game ( + name "Beatmania GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Beatmania GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Beatmania GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0d9cb195 sha1 640c4633fe8ec60b767c15a094c87ab7e113d555 flags verified ) +) + +game ( + name "Beatmania GB - Gotcha Mix 2 (Japan)" + description "Beatmania GB - Gotcha Mix 2 (Japan)" + rom ( name "Beatmania GB - Gotcha Mix 2 (Japan).gbc" size 2097152 crc b92a6d16 sha1 dcd054d461cde099df09ed61a77b05fbacd7af0b ) +) + +game ( + name "Beatmania GB 2 - Gotcha Mix (Japan) (SGB Enhanced) (GB Compatible)" + description "Beatmania GB 2 - Gotcha Mix (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Beatmania GB 2 - Gotcha Mix (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 59beb372 sha1 b6273c434e880d6f9b5f4f6f53307bda9902fff1 ) +) + +game ( + name "Beauty and the Beast - A Board Game Adventure (Europe) (En,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" + description "Beauty and the Beast - A Board Game Adventure (Europe) (En,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" + rom ( name "Beauty and the Beast - A Board Game Adventure (Europe) (En,Fr,De,Es,It) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e4c410f0 sha1 2dd29d52972948724f989008f7896d0adcba67c4 flags verified ) +) + +game ( + name "Beauty and the Beast - A Board Game Adventure (USA, Australia) (SGB Enhanced) (GB Compatible)" + description "Beauty and the Beast - A Board Game Adventure (USA, Australia) (SGB Enhanced) (GB Compatible)" + rom ( name "Beauty and the Beast - A Board Game Adventure (USA, Australia) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6de1d581 sha1 6d389c7aff887d7ffe3739e78753cf81cc71d04c ) +) + +game ( + name "Benjamin Bluemchen - Ein verrueckter Tag im Zoo (Germany)" + description "Benjamin Bluemchen - Ein verrueckter Tag im Zoo (Germany)" + rom ( name "Benjamin Bluemchen - Ein verrueckter Tag im Zoo (Germany).gbc" size 2097152 crc 51972995 sha1 560fc8468ed559a72087f630eff015ffb8de22ca ) +) + +game ( + name "Beyblade - Fighting Tournament (Japan)" + description "Beyblade - Fighting Tournament (Japan)" + rom ( name "Beyblade - Fighting Tournament (Japan).gbc" size 2097152 crc 1ec9db95 sha1 aca5562c6747bc2f127ada53f853b099ed6e12cd ) +) + +game ( + name "Bibi Blocksberg - Im Bann der Hexenkugel (Germany)" + description "Bibi Blocksberg - Im Bann der Hexenkugel (Germany)" + rom ( name "Bibi Blocksberg - Im Bann der Hexenkugel (Germany).gbc" size 1048576 crc 4d39fbfe sha1 1e26308ba5ee640540430a0b02d5f30e3be38832 ) +) + +game ( + name "Bibi und Tina - Fohlen Felix in Gefahr (Germany)" + description "Bibi und Tina - Fohlen Felix in Gefahr (Germany)" + rom ( name "Bibi und Tina - Fohlen Felix in Gefahr (Germany).gbc" size 1048576 crc 8874acd4 sha1 59843ced1e9cbcb02c6acbb8f533ec77b314882c flags verified ) +) + +game ( + name "Bikkuriman 2000 - Charging Card GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Bikkuriman 2000 - Charging Card GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Bikkuriman 2000 - Charging Card GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 5be2517c sha1 c3c608f1b3581a070c9b7eb65b6fb6d1b72d98d3 ) +) + +game ( + name "Billiard Club (Japan) (Proto)" + description "Billiard Club (Japan) (Proto)" + rom ( name "Billiard Club (Japan) (Proto).gbc" size 1048576 crc 210c4137 sha1 eb994e523550a8a7fe8a77fd2e85de011bec8627 ) +) + +game ( + name "Billy Bob's Huntin' 'n' Fishin' (USA, Europe)" + description "Billy Bob's Huntin' 'n' Fishin' (USA, Europe)" + rom ( name "Billy Bob's Huntin' 'n' Fishin' (USA, Europe).gbc" size 1048576 crc fa1e6853 sha1 9331fb3103a23340192968715adaa1e4ef140329 flags verified ) +) + +game ( + name "Binary Monster 2 (Taiwan) (En) (Unl)" + description "Binary Monster 2 (Taiwan) (En) (Unl)" + rom ( name "Binary Monster 2 (Taiwan) (En) (Unl).gbc" size 131072 crc 16297b29 sha1 bccc7bd374166171f4961b8773bb881050b8a62d ) +) + +game ( + name "Bingyuan Lixian Ji (Taiwan) (Unl)" + description "Bingyuan Lixian Ji (Taiwan) (Unl)" + rom ( name "Bingyuan Lixian Ji (Taiwan) (Unl).gbc" size 2097152 crc 7ca57891 sha1 1bebc84f0fbfa731f33343c56032c8fe5803e4ae ) +) + +game ( + name "Bingyuan Lixian Ji II (Taiwan) (Unl) (Alt)" + description "Bingyuan Lixian Ji II (Taiwan) (Unl) (Alt)" + rom ( name "Bingyuan Lixian Ji II (Taiwan) (Unl) (Alt).gbc" size 2097152 crc b149f421 sha1 39060bd6fa872738ae126b64f123a1242d06680a ) +) + +game ( + name "Bingyuan Lixian Ji II (Taiwan) (Unl)" + description "Bingyuan Lixian Ji II (Taiwan) (Unl)" + rom ( name "Bingyuan Lixian Ji II (Taiwan) (Unl).gbc" size 2097152 crc c4eba914 sha1 9e1c0c019630d7e4884ad3d5a447bd1acf668277 ) +) + +game ( + name "Biohazard Gaiden (Japan)" + description "Biohazard Gaiden (Japan)" + rom ( name "Biohazard Gaiden (Japan).gbc" size 2097152 crc c2531d36 sha1 09ca57fedc0c876f6c172e0dc73d616a6d66ea69 ) +) + +game ( + name "Bionic Commando - Elite Forces (USA, Australia)" + description "Bionic Commando - Elite Forces (USA, Australia)" + rom ( name "Bionic Commando - Elite Forces (USA, Australia).gbc" size 2097152 crc a663cf31 sha1 33c28a2183f8b95cc2d8e0b6a0b005bfc230f1fc flags verified ) +) + +game ( + name "Black Bass - Lure Fishing (USA, Europe) (GB Compatible)" + description "Black Bass - Lure Fishing (USA, Europe) (GB Compatible)" + rom ( name "Black Bass - Lure Fishing (USA, Europe) (GB Compatible).gbc" size 1048576 crc e44977dc sha1 0e8d93cd183a53aba67780372c71cca71e92a9c1 flags verified ) +) + +game ( + name "Black Onyx, The (Japan)" + description "Black Onyx, The (Japan)" + rom ( name "Black Onyx, The (Japan).gbc" size 1048576 crc 582fe338 sha1 b0f009023a25e575b59e55dec07cda2826f48b65 ) +) + +game ( + name "Blade (USA, Europe)" + description "Blade (USA, Europe)" + rom ( name "Blade (USA, Europe).gbc" size 1048576 crc 2dd5907f sha1 aaad2f4ed8dbb4455704896f8ff0bc70e7d50b65 flags verified ) +) + +game ( + name "Blaster Master - Enemy Below (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Blaster Master - Enemy Below (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Blaster Master - Enemy Below (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 2f91e17c sha1 8b2e83d7f2b7d72d5cc1ac81c28c2173ad2fc9ba ) +) + +game ( + name "Blue's Clues - Blue's Alphabet Book (USA) (Rev 1) (Proto)" + description "Blue's Clues - Blue's Alphabet Book (USA) (Rev 1) (Proto)" + rom ( name "Blue's Clues - Blue's Alphabet Book (USA) (Rev 1) (Proto).gbc" size 1048576 crc f89f58b7 sha1 7fdedfe8acde9557a5ff57661ed17082813e09a1 ) +) + +game ( + name "Blue's Clues - Blue's Alphabet Book (USA)" + description "Blue's Clues - Blue's Alphabet Book (USA)" + rom ( name "Blue's Clues - Blue's Alphabet Book (USA).gbc" size 1048576 crc 748d1345 sha1 f703b54746cb2ef08deba2518ce7b7a3836142aa ) +) + +game ( + name "Boarder Zone (USA)" + description "Boarder Zone (USA)" + rom ( name "Boarder Zone (USA).gbc" size 2097152 crc a7152869 sha1 116020a7c2d87ed16436e7710cfed7a93e81289a ) +) + +game ( + name "Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl)" + description "Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl)" + rom ( name "Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl).gbc" size 524288 crc a4c6523d sha1 2b4b8c3a4a74fdf7acc4138125fea5d8f5a9a093 ) +) + +game ( + name "Bob the Builder - Fix it Fun! (Europe) (En,Fr,De,Es,Nl)" + description "Bob the Builder - Fix it Fun! (Europe) (En,Fr,De,Es,Nl)" + rom ( name "Bob the Builder - Fix it Fun! (Europe) (En,Fr,De,Es,Nl).gbc" size 1048576 crc ea33fe3d sha1 167561998c356253c7092ad200dd1bc5386446a7 ) +) + +game ( + name "Bob the Builder - Fix it Fun! (Europe) (En,Fr,It)" + description "Bob the Builder - Fix it Fun! (Europe) (En,Fr,It)" + rom ( name "Bob the Builder - Fix it Fun! (Europe) (En,Fr,It).gbc" size 1048576 crc a8ebd88b sha1 476c75cbc05431e692dec8f4e10bcee9d3f5431a ) +) + +game ( + name "Bob the Builder - Fix it Fun! (Europe) (En,Sv,No,Da,Fi)" + description "Bob the Builder - Fix it Fun! (Europe) (En,Sv,No,Da,Fi)" + rom ( name "Bob the Builder - Fix it Fun! (Europe) (En,Sv,No,Da,Fi).gbc" size 1048576 crc f319e823 sha1 df4993587cff869c4824a5a771db5c26a748c9ea ) +) + +game ( + name "Bob the Builder - Fix it Fun! (USA)" + description "Bob the Builder - Fix it Fun! (USA)" + rom ( name "Bob the Builder - Fix it Fun! (USA).gbc" size 1048576 crc 93fa37bd sha1 68bd9a1932d4e5333ab5b4dfe0d28f126e5d470f ) +) + +game ( + name "Boku no Camp-jou (Japan)" + description "Boku no Camp-jou (Japan)" + rom ( name "Boku no Camp-jou (Japan).gbc" size 2097152 crc c87120b5 sha1 349509af42df8b8c5797838c5cda4bbae8643017 ) +) + +game ( + name "Bokujou Monogatari 2 GB (Japan) (GB Compatible)" + description "Bokujou Monogatari 2 GB (Japan) (GB Compatible)" + rom ( name "Bokujou Monogatari 2 GB (Japan) (GB Compatible).gbc" size 2097152 crc ee993302 sha1 d2ae9bc5709aa60dd5d433cd353dbb171db2ef28 flags verified ) +) + +game ( + name "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan)" + description "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan)" + rom ( name "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan).gbc" size 2097152 crc 3a18b41f sha1 e7fceb85a78c78403711521fe5fc8f86260425d0 ) +) + +game ( + name "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan) (Rev 1)" + description "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan) (Rev 1)" + rom ( name "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan) (Rev 1).gbc" size 2097152 crc 75af0e84 sha1 acb2e549fb7d107d20507af88c36f40234f74958 flags verified ) +) + +game ( + name "Bomberman Max - Ain Version (Japan)" + description "Bomberman Max - Ain Version (Japan)" + rom ( name "Bomberman Max - Ain Version (Japan).gbc" size 2097152 crc 545e0da2 sha1 7416d9430a8163cd2f953c990ef8ad325725e53a ) +) + +game ( + name "Bomberman Max - Blue Champion (USA)" + description "Bomberman Max - Blue Champion (USA)" + rom ( name "Bomberman Max - Blue Champion (USA).gbc" size 2097152 crc 5ccb66cf sha1 bb1120b0116eda3fc157c66766beffcc7a04f826 ) +) + +game ( + name "Bomberman Max - Hikari no Yuusha (Japan)" + description "Bomberman Max - Hikari no Yuusha (Japan)" + rom ( name "Bomberman Max - Hikari no Yuusha (Japan).gbc" size 2097152 crc 7a44ce88 sha1 9c38166e83e45707cbc2e0aff38fd4590dce7c3f flags verified ) +) + +game ( + name "Bomberman Max - Red Challenger (USA)" + description "Bomberman Max - Red Challenger (USA)" + rom ( name "Bomberman Max - Red Challenger (USA).gbc" size 2097152 crc 4853f586 sha1 369ce985157c55bbad6c24f49a0ad4009dec5f56 flags verified ) +) + +game ( + name "Bomberman Max - Yami no Senshi (Japan)" + description "Bomberman Max - Yami no Senshi (Japan)" + rom ( name "Bomberman Max - Yami no Senshi (Japan).gbc" size 2097152 crc 48b60e8e sha1 12addfb8f890a44b87efb900e9d6ad5028b58936 flags verified ) +) + +game ( + name "Bomberman Quest (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + description "Bomberman Quest (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + rom ( name "Bomberman Quest (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 5a9b9ae6 sha1 088ace0cfd6b3aa637b96c01106f6b1d88ba53fa flags verified ) +) + +game ( + name "Bomberman Quest (Japan) (SGB Enhanced) (GB Compatible)" + description "Bomberman Quest (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Bomberman Quest (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 55210934 sha1 b1187036734c40606cb1d5e35a6c120ee618e491 flags verified ) +) + +game ( + name "Bomberman Quest (USA) (SGB Enhanced) (GB Compatible)" + description "Bomberman Quest (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Bomberman Quest (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a089c656 sha1 4436f6ee03f7a8b2f235b64e26400c0e951d8a3a ) +) + +game ( + name "Bomberman Selection (Korea)" + description "Bomberman Selection (Korea)" + rom ( name "Bomberman Selection (Korea).gbc" size 1048576 crc af2b426e sha1 52451464a9f4dd5faefe4594954cbce03bff0d05 flags verified ) +) + +game ( + name "Bomberman Selection (Korea) (Beta 2)" + description "Bomberman Selection (Korea) (Beta 2)" + rom ( name "Bomberman Selection (Korea) (Beta 2).gbc" size 1048576 crc 06cc1e9d sha1 a3ce5d9ea4aa4203ea4bc17461e28257e4bd0a62 ) +) + +game ( + name "Bomberman Selection (Korea) (Beta 1)" + description "Bomberman Selection (Korea) (Beta 1)" + rom ( name "Bomberman Selection (Korea) (Beta 1).gbc" size 1048576 crc 005ad4b7 sha1 206a19a48a35bcff18d5872b85ba4e8963827cb3 ) +) + +game ( + name "Bouken! Dondoko Shima (Japan)" + description "Bouken! Dondoko Shima (Japan)" + rom ( name "Bouken! Dondoko Shima (Japan).gbc" size 2097152 crc 5fe759c7 sha1 c054abfea01a3ceb7b20b27e7ea937abe5157834 ) +) + +game ( + name "Bounced! (Europe) (Proto)" + description "Bounced! (Europe) (Proto)" + rom ( name "Bounced! (Europe) (Proto).gbc" size 1048576 crc 3948aee9 sha1 06d2d0eaea07d7a41834d4c9a5dfdbdda6889be9 ) +) + +game ( + name "Brave Saga - Shinshou Astaria (Japan)" + description "Brave Saga - Shinshou Astaria (Japan)" + rom ( name "Brave Saga - Shinshou Astaria (Japan).gbc" size 2097152 crc 5d5d294a sha1 952b9e16a938b986a6216b8db6d62f71c4f853fa flags verified ) +) + +game ( + name "Buffy the Vampire Slayer (USA, Europe)" + description "Buffy the Vampire Slayer (USA, Europe)" + rom ( name "Buffy the Vampire Slayer (USA, Europe).gbc" size 1048576 crc 5692e262 sha1 3310a9cfcad457a6d4d31b63d8258313051c581e flags verified ) +) + +game ( + name "Bug's Life, A (Europe) (SGB Enhanced) (GB Compatible)" + description "Bug's Life, A (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Bug's Life, A (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc db93e0f6 sha1 dfc7b45c8f2d45cbf5c7578294ca569d2cf22dcd ) +) + +game ( + name "Bug's Life, A (USA) (SGB Enhanced) (GB Compatible)" + description "Bug's Life, A (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Bug's Life, A (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 8360047a sha1 4c689ce3b99a5b585a452b095d72a688391ea0eb ) +) + +game ( + name "Bugs Bunny - Crazy Castle 3 (Japan) (GB Compatible)" + description "Bugs Bunny - Crazy Castle 3 (Japan) (GB Compatible)" + rom ( name "Bugs Bunny - Crazy Castle 3 (Japan) (GB Compatible).gbc" size 1048576 crc ae839cae sha1 403356d76a267d79fa5b72158de4e280b970160b ) +) + +game ( + name "Bugs Bunny - Crazy Castle 3 (USA, Europe) (GB Compatible)" + description "Bugs Bunny - Crazy Castle 3 (USA, Europe) (GB Compatible)" + rom ( name "Bugs Bunny - Crazy Castle 3 (USA, Europe) (GB Compatible).gbc" size 1048576 crc 7a2801fb sha1 f4ac94b7f59191f8d4adc1b5b5ac39bee5dfd064 flags verified ) +) + +game ( + name "Bugs Bunny - Crazy Castle 4 (Japan)" + description "Bugs Bunny - Crazy Castle 4 (Japan)" + rom ( name "Bugs Bunny - Crazy Castle 4 (Japan).gbc" size 1048576 crc d6387eaa sha1 e4a198d4acf5ac987071a1d2b91501caca62269b ) +) + +game ( + name "Bugs Bunny & Lola Bunny - Operation Carrot Patch (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + description "Bugs Bunny & Lola Bunny - Operation Carrot Patch (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + rom ( name "Bugs Bunny & Lola Bunny - Operation Carrot Patch (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc f0cc407f sha1 ba004fac4524b82fd74a9037a37734d0aba07e50 flags verified ) +) + +game ( + name "Bugs Bunny et le Chateau des Catastrophes (France) (En)" + description "Bugs Bunny et le Chateau des Catastrophes (France) (En)" + rom ( name "Bugs Bunny et le Chateau des Catastrophes (France) (En).gbc" size 1048576 crc 6da8e6eb sha1 19590017c888266c285360f824f5ef6cea166287 ) +) + +game ( + name "Bugs Bunny in - Crazy Castle 4 (Europe)" + description "Bugs Bunny in - Crazy Castle 4 (Europe)" + rom ( name "Bugs Bunny in - Crazy Castle 4 (Europe).gbc" size 1048576 crc 53155e60 sha1 3654f532a77035b3fc5bf7b0e1ae6941fc649b6a flags verified ) +) + +game ( + name "Bugs Bunny in - Crazy Castle 4 (USA)" + description "Bugs Bunny in - Crazy Castle 4 (USA)" + rom ( name "Bugs Bunny in - Crazy Castle 4 (USA).gbc" size 1048576 crc 98dbffe0 sha1 a22b9765e901b2a23a48c44b0b829ab73b9c1a82 ) +) + +game ( + name "Bundesliga Stars 2001 (Germany)" + description "Bundesliga Stars 2001 (Germany)" + rom ( name "Bundesliga Stars 2001 (Germany).gbc" size 1048576 crc 5622b551 sha1 9803734c45fa54463f7e2b8ce3eea3ca4d4ebdf4 ) +) + +game ( + name "Burai Senshi Color (Japan)" + description "Burai Senshi Color (Japan)" + rom ( name "Burai Senshi Color (Japan).gbc" size 1048576 crc e52fbd12 sha1 a3b140586aac09f959260c5673dfed2ed58c1469 ) +) + +game ( + name "Burger Burger Pocket - Hamburger Simulation (Japan) (SGB Enhanced) (GB Compatible)" + description "Burger Burger Pocket - Hamburger Simulation (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Burger Burger Pocket - Hamburger Simulation (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1abcedbe sha1 f4579d4bb3b39f572fdf033df01a84a925fb3f2e ) +) + +game ( + name "Burger Paradise International (Japan)" + description "Burger Paradise International (Japan)" + rom ( name "Burger Paradise International (Japan).gbc" size 1048576 crc 9092b0eb sha1 71072a7f0165769649bce8c31c36f67bb0e02963 ) +) + +game ( + name "Bust-A-Move 4 (USA, Europe) (GB Compatible)" + description "Bust-A-Move 4 (USA, Europe) (GB Compatible)" + rom ( name "Bust-A-Move 4 (USA, Europe) (GB Compatible).gbc" size 524288 crc 8e818e6f sha1 dfb5c960336ecbe074b36fdcd8c7a8f1b194df32 ) +) + +game ( + name "Bust-A-Move Millennium (USA, Europe)" + description "Bust-A-Move Millennium (USA, Europe)" + rom ( name "Bust-A-Move Millennium (USA, Europe).gbc" size 1048576 crc f8da0c4a sha1 2c14b4c82072f2a55f9f699956f71071481808ec ) +) + +game ( + name "Buzz Lightyear of Star Command (USA, Europe)" + description "Buzz Lightyear of Star Command (USA, Europe)" + rom ( name "Buzz Lightyear of Star Command (USA, Europe).gbc" size 524288 crc 84e29b87 sha1 314dacd9a5d60769105f2cde60a245074cb51c15 ) +) + +game ( + name "Caesars Palace II (USA, Europe)" + description "Caesars Palace II (USA, Europe)" + rom ( name "Caesars Palace II (USA, Europe).gbc" size 1048576 crc 351ba5ea sha1 b7520b3c91813df9a447c11ccc4d4381f106ca52 ) +) + +game ( + name "Caise Gedou 24 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl)" + description "Caise Gedou 24 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl)" + rom ( name "Caise Gedou 24 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl).gbc" size 2097152 crc dc03fb00 sha1 201dfbce0f2d5262ccd487e63927a2ff520db56d ) +) + +game ( + name "Caise Gedou 29 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl)" + description "Caise Gedou 29 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl)" + rom ( name "Caise Gedou 29 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl).gbc" size 2097152 crc 78c0e5bc sha1 358e628e680bc63227940ca6d76217d14fcd3409 flags verified ) ) game ( - name "2003 Crash II Advance (USA) (Unl)" - description "2003 Crash II Advance (USA) (Unl)" - rom ( name "2003 Crash II Advance (USA) (Unl).gbc" size 2097152 crc 973d38a8 sha1 acdc42716f61bf11ecf08d50a980047f8fb7dc57 ) + name "Cannon Fodder (Europe) (En,Fr,De,Es,It) (Beta)" + description "Cannon Fodder (Europe) (En,Fr,De,Es,It) (Beta)" + rom ( name "Cannon Fodder (Europe) (En,Fr,De,Es,It) (Beta).gbc" size 4194304 crc 222c9dc6 sha1 cee465f6987c2d580cc96fac703025989208e683 ) ) game ( - name "2003 Digimom Sapphii (Taiwan) (En) (Unl)" - description "2003 Digimom Sapphii (Taiwan) (En) (Unl)" - rom ( name "2003 Digimom Sapphii (Taiwan) (En) (Unl).gbc" size 2097152 crc 7cff9f0b sha1 1e42c461e0c6705637a698dbda8b34bc37acc51d ) + name "Cannon Fodder (Europe) (En,Fr,De,Es,It)" + description "Cannon Fodder (Europe) (En,Fr,De,Es,It)" + rom ( name "Cannon Fodder (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 824c3bf3 sha1 9a6901cad65e6d0ce89af8442688fec6a9fedd43 ) ) game ( - name "2003 Digimom Sapphii (Taiwan) (De) (Unl)" - description "2003 Digimom Sapphii (Taiwan) (De) (Unl)" - rom ( name "2003 Digimom Sapphii (Taiwan) (De) (Unl).gbc" size 2097152 crc bd285d64 sha1 1cdffe470fde714898a2b0de92edd88e791a1bdf ) + name "Cannon Fodder (USA) (En,Fr,De,Es,It)" + description "Cannon Fodder (USA) (En,Fr,De,Es,It)" + rom ( name "Cannon Fodder (USA) (En,Fr,De,Es,It).gbc" size 4194304 crc 26f8e1a0 sha1 cc601984a2b52b44cf135e42bcac1bec44b7a6a3 ) ) game ( - name "2003 Gu Huo Lang II (Taiwan) (Unl)" - description "2003 Gu Huo Lang II (Taiwan) (Unl)" - rom ( name "2003 Gu Huo Lang II (Taiwan) (Unl).gbc" size 2097152 crc 74d71b0c sha1 fcbb769de0896ae69fe1063fa5d87cf079c8606a ) + name "Capcom Fight 2003 (Hong Kong) (En) (Unl)" + description "Capcom Fight 2003 (Hong Kong) (En) (Unl)" + rom ( name "Capcom Fight 2003 (Hong Kong) (En) (Unl).gbc" size 2097152 crc 2f8ac081 sha1 3b7a16d1a5d91118960cfadcc41eecaa36097bac ) ) game ( - name "2003 Hali Bote 2 - Xiaoshi de Mishi (Taiwan) (Unl)" - description "2003 Hali Bote 2 - Xiaoshi de Mishi (Taiwan) (Unl)" - rom ( name "2003 Hali Bote 2 - Xiaoshi de Mishi (Taiwan) (Unl).gbc" size 2097152 crc 1b3e1243 sha1 0829cbcab3ef5d03c94d5efe769f4f4a93ac47fa ) + name "Capcom vs SNK - Millennium Fight 2001 (Taiwan) (En) (Unl)" + description "Capcom vs SNK - Millennium Fight 2001 (Taiwan) (En) (Unl)" + rom ( name "Capcom vs SNK - Millennium Fight 2001 (Taiwan) (En) (Unl).gbc" size 1048576 crc 97280455 sha1 cddd079eebaeeb45b22c808cfb5e369f70e7fa20 ) ) game ( - name "2003 Hali Xiaozi IV (Taiwan) (Unl)" - description "2003 Hali Xiaozi IV (Taiwan) (Unl)" - rom ( name "2003 Hali Xiaozi IV (Taiwan) (Unl).gbc" size 2097152 crc db3c8b95 sha1 0d230b20388f4396d6345b8eb59f54fc169ad8ee ) + name "Captain Buzz Lightyear - Star Command (Germany)" + description "Captain Buzz Lightyear - Star Command (Germany)" + rom ( name "Captain Buzz Lightyear - Star Command (Germany).gbc" size 524288 crc f06d296c sha1 376bcd39491fe275a3773716ffaf0259e4852340 flags verified ) ) game ( - name "2003 Harry Potter 3 (Taiwan) (Unl)" - description "2003 Harry Potter 3 (Taiwan) (Unl)" - rom ( name "2003 Harry Potter 3 (Taiwan) (Unl).gbc" size 1048576 crc 4ea2c869 sha1 739c0e5dc0efd4ddb912236a6f630c3d6987d064 ) + name "Card Sharks (USA) (Proto)" + description "Card Sharks (USA) (Proto)" + rom ( name "Card Sharks (USA) (Proto).gbc" size 262144 crc e2b2dcfe sha1 f5e1850efa9ac1df8a879815d4193a1157408ca3 ) ) game ( - name "2003 King Lion Advance III (USA) (Unl)" - description "2003 King Lion Advance III (USA) (Unl)" - rom ( name "2003 King Lion Advance III (USA) (Unl).gbc" size 2097152 crc 0c22466d sha1 7c43ccfca93cae23e04e58fa0d7d7400a9694e0e ) + name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (GB Compatible)" + description "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (GB Compatible)" + rom ( name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (GB Compatible).gbc" size 524288 crc 89ba58ed sha1 8a11954329dcabe4bb39cb522505545a41da5356 ) ) game ( - name "2003 Koudai Guaishou - Lanbaoshi (Taiwan) (Unl)" - description "2003 Koudai Guaishou - Lanbaoshi (Taiwan) (Unl)" - rom ( name "2003 Koudai Guaishou - Lanbaoshi (Taiwan) (Unl).gbc" size 2097152 crc 4c76d4d8 sha1 d688201e6031b88f122ec753a37daedfb233b48d ) + name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 1) (GB Compatible)" + description "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 1) (GB Compatible)" + rom ( name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 1) (GB Compatible).gbc" size 524288 crc 43f28e22 sha1 b3926ac213b9f88f570b0587fae89e3151018d63 ) ) game ( - name "2003 Pocket Monster - Carbuncle (USA) (Unl)" - description "2003 Pocket Monster - Carbuncle (USA) (Unl)" - rom ( name "2003 Pocket Monster - Carbuncle (USA) (Unl).gbc" size 2097152 crc 3a0e9b6f sha1 025973627743f2f1ae1ff5b8a3f549cbcc227ef3 ) + name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 2) (GB Compatible)" + description "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 2) (GB Compatible)" + rom ( name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 2) (GB Compatible).gbc" size 524288 crc 7243e258 sha1 a53e7f8d95375aea144e870977b0966cc1fd4b94 flags verified ) ) game ( - name "2003 Shuma Baolong - Gedou Ban (Taiwan) (Unl)" - description "2003 Shuma Baolong - Gedou Ban (Taiwan) (Unl)" - rom ( name "2003 Shuma Baolong - Gedou Ban (Taiwan) (Unl).gbc" size 2097152 crc 1219eec6 sha1 4a722c10e3893e04c67a66d0aea401d6d220ec7e ) + name "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan) (Rev 1) (Proto)" + description "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan) (Rev 1) (Proto)" + rom ( name "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan) (Rev 1) (Proto).gbc" size 2097152 crc d2cc40c2 sha1 031b00495b3700b2145a741f2d03cc820ffa6fde ) ) game ( - name "2123 (World) (Aftermarket) (Unl)" - description "2123 (World) (Aftermarket) (Unl)" - rom ( name "2123 (World) (Aftermarket) (Unl).gbc" size 262144 crc 22836942 sha1 eb9a2aff6485962f1a7773b7138f3c4208fa36e4 ) + name "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan)" + description "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan)" + rom ( name "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan).gbc" size 2097152 crc f78f7998 sha1 1809154979b289750b572a61da1dc93b1b76360f ) ) game ( - name "23 in 1 (Taiwan) (Unl)" - description "23 in 1 (Taiwan) (Unl)" - rom ( name "23 in 1 (Taiwan) (Unl).gbc" size 2097152 crc 1e45fc45 sha1 e14acf52538cdde2134a79353f5f57bd8da9b4a7 ) + name "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl)" + description "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 15430979 sha1 76e898c00f47628710eaef7551a7d1fe04e2a2bc flags verified ) ) game ( - name "3-D Ultra Pinball - Thrillride (USA) (Rumble Version)" - description "3-D Ultra Pinball - Thrillride (USA) (Rumble Version)" - rom ( name "3-D Ultra Pinball - Thrillride (USA) (Rumble Version).gbc" size 524288 crc 1766e558 sha1 2b704415803cf6172a1d07912b1155c51576a511 ) + name "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + description "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + rom ( name "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 1048576 crc da8d6283 sha1 0a94857f23640b36117b7bfe4ce7cc291da63c58 ) ) game ( - name "31 in 1 (Taiwan) (31B-001, Sachen) (Unl)" - description "31 in 1 (Taiwan) (31B-001, Sachen) (Unl)" - rom ( name "31 in 1 (Taiwan) (31B-001, Sachen) (Unl).gbc" size 2097152 crc 0eb8ddfb sha1 8fa0d40dc4c239108304e8799413a69a5668404c flags verified ) + name "Carmageddon - Carpocalypse Now (USA) (En,Es) (Beta)" + description "Carmageddon - Carpocalypse Now (USA) (En,Es) (Beta)" + rom ( name "Carmageddon - Carpocalypse Now (USA) (En,Es) (Beta).gbc" size 2097152 crc e9751f81 sha1 9f41f86214031dad6440206863bffc13c3e61fc4 ) ) game ( - name "31-in-1 Mighty Mix (Australia) (31B-001, Sachen) (Unl)" - description "31-in-1 Mighty Mix (Australia) (31B-001, Sachen) (Unl)" - rom ( name "31-in-1 Mighty Mix (Australia) (31B-001, Sachen) (Unl).gbc" size 2097152 crc 21524051 sha1 c0c2a65b1485a2768962cb97ba2f9b668528453a ) + name "Carmageddon - Carpocalypse Now (Germany)" + description "Carmageddon - Carpocalypse Now (Germany)" + rom ( name "Carmageddon - Carpocalypse Now (Germany).gbc" size 2097152 crc b447bc06 sha1 505b29e070ce034b179169d834abb3969e84c7e0 flags verified ) ) game ( - name "36 in 1 (Taiwan) (SL36-0032) (Unl)" - description "36 in 1 (Taiwan) (SL36-0032) (Unl)" - rom ( name "36 in 1 (Taiwan) (SL36-0032) (Unl).gbc" size 4194304 crc f68d980a sha1 63181a86fa4a653744e9c393aa9f113e981d9cc7 ) + name "Carmageddon - Carpocalypse Now (USA, Europe) (En,Fr,Es,It)" + description "Carmageddon - Carpocalypse Now (USA, Europe) (En,Fr,Es,It)" + rom ( name "Carmageddon - Carpocalypse Now (USA, Europe) (En,Fr,Es,It).gbc" size 2097152 crc bb482ed7 sha1 df37636bbd57a426e23d21581376d7e3a87c7933 flags verified ) ) game ( - name "3D Pocket Pool (Europe) (En,Fr,De,Es,It,Nl)" - description "3D Pocket Pool (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "3D Pocket Pool (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 8cdab77f sha1 11ee7ba924f80e1c546af4749ea46ac5c8c75a5d ) + name "Carmageddon TDR 2000 (Europe) (En,Fr,De,Es,It) (Proto)" + description "Carmageddon TDR 2000 (Europe) (En,Fr,De,Es,It) (Proto)" + rom ( name "Carmageddon TDR 2000 (Europe) (En,Fr,De,Es,It) (Proto).gbc" size 2097152 crc 0bd8e676 sha1 fe059ee25e2a00a129842f452bcc86ce78213c6b ) ) game ( - name "3D Pool Allstars (USA) (En,Fr,Es) (Proto)" - description "3D Pool Allstars (USA) (En,Fr,Es) (Proto)" - rom ( name "3D Pool Allstars (USA) (En,Fr,Es) (Proto).gbc" size 1048576 crc 245de3e2 sha1 f7289c3eed275286d0fb3dc7097098276b746786 ) + name "Carnivale (USA) (Proto)" + description "Carnivale (USA) (Proto)" + rom ( name "Carnivale (USA) (Proto).gbc" size 1048576 crc e9503c71 sha1 07d41e21bc82f64d788e720583169fb0e588da89 ) ) game ( - name "3D Quasars (World) (Aftermarket) (Unl)" - description "3D Quasars (World) (Aftermarket) (Unl)" - rom ( name "3D Quasars (World) (Aftermarket) (Unl).gbc" size 262144 crc 1fd94e67 sha1 3f32226538d8c7f0c866c4b73e9f828265f2bb5b ) + name "Carrera (Europe) (En,Fr,De) (Proto)" + description "Carrera (Europe) (En,Fr,De) (Proto)" + rom ( name "Carrera (Europe) (En,Fr,De) (Proto).gbc" size 2097152 crc f8000653 sha1 1b70600b9e3a0f2736b5a23d88ebc1ad52597426 ) ) game ( - name "4 in 1 + 8 in 1 (World) (4B-001, 4B-009, 8B-001, Sachen) (Unl)" - description "4 in 1 + 8 in 1 (World) (4B-001, 4B-009, 8B-001, Sachen) (Unl)" - rom ( name "4 in 1 + 8 in 1 (World) (4B-001, 4B-009, 8B-001, Sachen) (Unl).gbc" size 524288 crc 42a2fdf8 sha1 79a4faddfd1aca397e56d7895e45b1bc12900dab flags verified ) + name "Casper (USA) (Rev 1) (Proto)" + description "Casper (USA) (Rev 1) (Proto)" + rom ( name "Casper (USA) (Rev 1) (Proto).gbc" size 1048576 crc 5edd88b5 sha1 6f44a817c7424a5b24919b01e1e868d2c2650341 ) ) game ( - name "4 in 1 + 8 in 1 (World) (4B-002, 4B-004, 8B-002, Sachen) (Unl)" - description "4 in 1 + 8 in 1 (World) (4B-002, 4B-004, 8B-002, Sachen) (Unl)" - rom ( name "4 in 1 + 8 in 1 (World) (4B-002, 4B-004, 8B-002, Sachen) (Unl).gbc" size 524288 crc e7224f14 sha1 2d7d6cdc49ec71e20be9c752ceaf38c5e2c29c5f flags verified ) + name "Casper (Europe) (En,Es,It)" + description "Casper (Europe) (En,Es,It)" + rom ( name "Casper (Europe) (En,Es,It).gbc" size 1048576 crc daefe53c sha1 1a964811c1d808403c4bae1adc7b7f78bf610399 ) ) game ( - name "4 in 1 + 8 in 1 (World) (4B-005, 4B-006, 8B-003, Sachen) (Unl)" - description "4 in 1 + 8 in 1 (World) (4B-005, 4B-006, 8B-003, Sachen) (Unl)" - rom ( name "4 in 1 + 8 in 1 (World) (4B-005, 4B-006, 8B-003, Sachen) (Unl).gbc" size 524288 crc b18465d2 sha1 40b4f3147ee7f79dbd64a862074ce50a7b4445ec flags verified ) + name "Casper (Europe) (En,Fr,De)" + description "Casper (Europe) (En,Fr,De)" + rom ( name "Casper (Europe) (En,Fr,De).gbc" size 1048576 crc e6b9f155 sha1 0a8560a35157dc5270309a7b4c0227e2f2a8c461 ) ) game ( - name "4 in 1 + 8 in 1 (World) (4B-007, 4B-008, 8B-004, Sachen) (Unl)" - description "4 in 1 + 8 in 1 (World) (4B-007, 4B-008, 8B-004, Sachen) (Unl)" - rom ( name "4 in 1 + 8 in 1 (World) (4B-007, 4B-008, 8B-004, Sachen) (Unl).gbc" size 524288 crc 0a504426 sha1 9c436bb4e2c666a92d4f695c776c2751cd3eb3b6 flags verified ) + name "Casper (USA)" + description "Casper (USA)" + rom ( name "Casper (USA).gbc" size 1048576 crc c775d653 sha1 82ac50380c3ed39fad13cc0bbe35e6457806a294 ) ) game ( - name "4x4 World Trophy (Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "4x4 World Trophy (Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "4x4 World Trophy (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc f62ad75e sha1 369e359d1b9a80fdda756411a395594b3d955100 flags verified ) + name "Caterpillar Construction Zone (USA, Europe) (GB Compatible)" + description "Caterpillar Construction Zone (USA, Europe) (GB Compatible)" + rom ( name "Caterpillar Construction Zone (USA, Europe) (GB Compatible).gbc" size 1048576 crc d20dc670 sha1 0ec92ea836c729efebcd76282f90dfb579396aa6 flags verified ) ) game ( - name "720 Degrees (USA, Europe) (GB Compatible)" - description "720 Degrees (USA, Europe) (GB Compatible)" - rom ( name "720 Degrees (USA, Europe) (GB Compatible).gbc" size 1048576 crc e633841f sha1 78c0117c8ee32cfa605ac34eedf707cc535b3987 flags verified ) + name "Catwoman (Europe)" + description "Catwoman (Europe)" + rom ( name "Catwoman (Europe).gbc" size 1048576 crc 41e78645 sha1 e2446731abef2a3c78a0bfa5d2bbda0084b7b3ea ) ) game ( - name "Aardvark (World) (Aftermarket) (Unl)" - description "Aardvark (World) (Aftermarket) (Unl)" - rom ( name "Aardvark (World) (Aftermarket) (Unl).gbc" size 262144 crc 270d45b9 sha1 34a8d00af6be9083409e6fccd0825c6f185d135d flags verified ) + name "Catwoman (USA)" + description "Catwoman (USA)" + rom ( name "Catwoman (USA).gbc" size 1048576 crc 12f0c196 sha1 c6f364d15fe9c0982b6a03ee67fd463dc32e7ed0 ) ) game ( - name "Absolute X (Europe) (Proto)" - description "Absolute X (Europe) (Proto)" - rom ( name "Absolute X (Europe) (Proto).gbc" size 1048576 crc 5046c427 sha1 34fa9bc6b1fec75751f1f426528f18c833128ff7 ) + name "Catwoman (Japan) (Proto)" + description "Catwoman (Japan) (Proto)" + rom ( name "Catwoman (Japan) (Proto).gbc" size 1048576 crc e8dfae9d sha1 f4cb746b4bc9b16acc0f3cf38cefc6cbd6db24be ) ) game ( - name "Action Man - Search for Base X (USA, Europe)" - description "Action Man - Search for Base X (USA, Europe)" - rom ( name "Action Man - Search for Base X (USA, Europe).gbc" size 1048576 crc 1226499e sha1 4b62b0344b8fed07ceb967f9a9c45bbeed3dc592 flags verified ) + name "Catz (Europe)" + description "Catz (Europe)" + rom ( name "Catz (Europe).gbc" size 1048576 crc 099d6555 sha1 16b749d0c57c6d837364b3c55a353647304a55a0 ) ) game ( - name "Action Replay Online (Europe) (Unl)" - description "Action Replay Online (Europe) (Unl)" - rom ( name "Action Replay Online (Europe) (Unl).gbc" size 131072 crc 04c8c858 sha1 fa441c5e376b54b3503596fe8177b3a9ad79a9a8 ) + name "Catz (USA)" + description "Catz (USA)" + rom ( name "Catz (USA).gbc" size 1048576 crc 769a2c5a sha1 5c3c9a4d85a92779c7e8304f2c122296f62f9a9c ) ) game ( - name "Action Replay Xtreme - Special Edition for Pokemon Crystal (Europe) (Unl)" - description "Action Replay Xtreme - Special Edition for Pokemon Crystal (Europe) (Unl)" - rom ( name "Action Replay Xtreme - Special Edition for Pokemon Crystal (Europe) (Unl).gbc" size 131072 crc c288e400 sha1 0280b05885fe5aca8c1884a16bd01513b99f4dc2 flags verified ) + name "Centipede (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + description "Centipede (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + rom ( name "Centipede (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 524288 crc 255db8be sha1 f8d2a8eab2a8a76a51006d438849509837f008d3 ) ) game ( - name "Adulting! Soundtrack (World) (GB Compatible) (Aftermarket) (Unl)" - description "Adulting! Soundtrack (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Adulting! Soundtrack (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 1b5b9e64 sha1 c5dad32be800c36814a0f9b940e99b5eada34150 ) + name "Centipede (USA) (GB Compatible)" + description "Centipede (USA) (GB Compatible)" + rom ( name "Centipede (USA) (GB Compatible).gbc" size 1048576 crc 13ad07b1 sha1 3e964fb53517c286b97375e6988208987f7bfa21 ) ) game ( - name "Adventures in Carnal Hell, The (World) (v1.02) (GB Compatible) (Aftermarket) (Unl)" - description "Adventures in Carnal Hell, The (World) (v1.02) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Adventures in Carnal Hell, The (World) (v1.02) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 9f81e7a0 sha1 895148bc0a3b6f9ec59bebae43413d1f4eafd21a ) + name "CGB Test Cartridge (Japan) (En) [b]" + description "CGB Test Cartridge (Japan) (En) [b]" + rom ( name "CGB Test Cartridge (Japan) (En) [b].gbc" size 65536 crc 4c050e29 sha1 5133d3dc7a4ced9d059dc72f0f351cb44e22f096 flags baddump ) ) game ( - name "Adventures in Carnal Hell, The (World) (v1.01) (GB Compatible) (Aftermarket) (Unl)" - description "Adventures in Carnal Hell, The (World) (v1.01) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Adventures in Carnal Hell, The (World) (v1.01) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc a5d0d1ec sha1 bc6367f77c235640cea5a1230cee253c99f846e5 ) + name "Championship Motocross 2001 featuring Ricky Carmichael (USA, Europe)" + description "Championship Motocross 2001 featuring Ricky Carmichael (USA, Europe)" + rom ( name "Championship Motocross 2001 featuring Ricky Carmichael (USA, Europe).gbc" size 1048576 crc cbb336ed sha1 3712801102df2b17d1deb75fbe7fda0c1a596db0 ) ) game ( - name "Adventures of the Smurfs, The (Europe) (En,Fr,De,Es,It,Nl)" - description "Adventures of the Smurfs, The (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Adventures of the Smurfs, The (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc d0d3dfed sha1 7919c5e6aa8d040b1f7953345b376d999cf22b18 ) + name "Chao Jinhua - Shuma Baobei D-3 (Taiwan) (Unl)" + description "Chao Jinhua - Shuma Baobei D-3 (Taiwan) (Unl)" + rom ( name "Chao Jinhua - Shuma Baobei D-3 (Taiwan) (Unl).gbc" size 1048576 crc 1517d27e sha1 0d14f2e2ab630b6f99a8125e5c0120c2d7967270 ) ) game ( - name "AF+ER (World) (GB Compatible) (Aftermarket) (Unl)" - description "AF+ER (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "AF+ER (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc f689b91e sha1 e55e427819916bb02189efe3883fb1dab3d80d35 ) + name "Chao Jinhua - Shuma Baolong - Zuanshi Ban (Taiwan) (Unl)" + description "Chao Jinhua - Shuma Baolong - Zuanshi Ban (Taiwan) (Unl)" + rom ( name "Chao Jinhua - Shuma Baolong - Zuanshi Ban (Taiwan) (Unl).gbc" size 1048576 crc 50babe99 sha1 c153550886e812f5e37746fe1be6f294f13f97b3 ) ) game ( - name "Agency (World) (Aftermarket) (Unl)" - description "Agency (World) (Aftermarket) (Unl)" - rom ( name "Agency (World) (Aftermarket) (Unl).gbc" size 1048576 crc 0d1bb2f7 sha1 5266589244fab2e9ff047af9f72641cda91e1d90 ) + name "Chaoji Gedou 2001 Alpha (Taiwan) (Unl)" + description "Chaoji Gedou 2001 Alpha (Taiwan) (Unl)" + rom ( name "Chaoji Gedou 2001 Alpha (Taiwan) (Unl).gbc" size 2097152 crc afd7a0cc sha1 f44f629687ec91aade40ff52014587003f728ec9 flags verified ) ) game ( - name "Agent B (World) (GB Compatible) (Aftermarket) (Unl)" - description "Agent B (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Agent B (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 31b6e3fa sha1 11b3ce59c4eb86cee05873eb473dbf262cf986bd ) + name "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl)" + description "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl)" + rom ( name "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl).gbc" size 2097152 crc 279be0cc sha1 c2a64ba4c1fd60829429330bc13b70d9bd18f023 ) ) game ( - name "Agent B (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Agent B (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Agent B (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ae767ad7 sha1 1a332aac66b24381f16819d1145fd4a917f2e0f3 ) + name "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl) (Alt)" + description "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl) (Alt)" + rom ( name "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl) (Alt).gbc" size 2097152 crc 1feaeb47 sha1 26d5841fc898dab17458dc39e871dab4947a7f2b ) ) game ( - name "AirForce Delta (Japan)" - description "AirForce Delta (Japan)" - rom ( name "AirForce Delta (Japan).gbc" size 1048576 crc 5dfff5e2 sha1 593df751cc6b1a7af7f50a9c9cfcedf8287384dc ) + name "Chaoji Yinsu de Xiaozi II - Super Sonik II (Taiwan) (Unl)" + description "Chaoji Yinsu de Xiaozi II - Super Sonik II (Taiwan) (Unl)" + rom ( name "Chaoji Yinsu de Xiaozi II - Super Sonik II (Taiwan) (Unl).gbc" size 2097152 crc a9dd9da7 sha1 006df0ddb10c5970002134da4d75ccc466e95edd ) ) game ( - name "AirForce Delta (USA)" - description "AirForce Delta (USA)" - rom ( name "AirForce Delta (USA).gbc" size 1048576 crc ff31cc92 sha1 82530325b940e14edea459879289b4dce1818066 ) + name "Chaoren Tegong Dui (Taiwan) (Unl)" + description "Chaoren Tegong Dui (Taiwan) (Unl)" + rom ( name "Chaoren Tegong Dui (Taiwan) (Unl).gbc" size 2097152 crc e1d61242 sha1 31f54bdfa59d1e76777f044c1ef4686552f715f6 flags verified ) ) game ( - name "Aladdin (Europe) (En,Fr,De,Es,It,Nl)" - description "Aladdin (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Aladdin (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 446573cd sha1 23335b9654766275831115a54f5142c4cb9183fe ) + name "Chase H.Q. - Secret Police (Europe) (SGB Enhanced) (GB Compatible)" + description "Chase H.Q. - Secret Police (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Chase H.Q. - Secret Police (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc cfdf816b sha1 e8770aeb76042fe5001dd48f55379350fa092a6f ) ) game ( - name "Aladdin (USA)" - description "Aladdin (USA)" - rom ( name "Aladdin (USA).gbc" size 1048576 crc a91ec059 sha1 97b46bf9862c9a1ef73d41f18b3693c6d9c73c06 ) + name "Chase H.Q. - Secret Police (USA) (SGB Enhanced) (GB Compatible)" + description "Chase H.Q. - Secret Police (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Chase H.Q. - Secret Police (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 7c7fdefc sha1 030b45eb8929c1512826f288e4ba035e0083505c ) ) game ( - name "Alfred's Adventure (Europe) (En,Fr,De,Es,It)" - description "Alfred's Adventure (Europe) (En,Fr,De,Es,It)" - rom ( name "Alfred's Adventure (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 6f9ef15e sha1 81c1acf0e87755a8c16f0beeb3524b3ec04455ea ) + name "Checkmate (Japan) (En,Ja) (GB Compatible)" + description "Checkmate (Japan) (En,Ja) (GB Compatible)" + rom ( name "Checkmate (Japan) (En,Ja) (GB Compatible).gbc" size 1048576 crc 1aab415d sha1 84e6c93daf1ab6c59bd23c0358a0704a663556b5 ) ) game ( - name "Alice in Wonderland (Europe) (En,Fr,De,Es)" - description "Alice in Wonderland (Europe) (En,Fr,De,Es)" - rom ( name "Alice in Wonderland (Europe) (En,Fr,De,Es).gbc" size 2097152 crc 85545d81 sha1 ea8647cce2d4b5f7993190c6e485669cc6046a29 ) + name "Chee-Chai Alien (Japan) (Rumble Version)" + description "Chee-Chai Alien (Japan) (Rumble Version)" + rom ( name "Chee-Chai Alien (Japan) (Rumble Version).gbc" size 4194304 crc 9e988ffe sha1 dec72ed497eb207d0e0af142c05fc813dab04385 flags verified ) ) game ( - name "Alice in Wonderland (USA, Australia)" - description "Alice in Wonderland (USA, Australia)" - rom ( name "Alice in Wonderland (USA, Australia).gbc" size 2097152 crc 3199f65f sha1 02c49003d5eb1498f239149089a517cdfb6bda0b ) + name "Chessmaster (USA, Europe) (GB Compatible)" + description "Chessmaster (USA, Europe) (GB Compatible)" + rom ( name "Chessmaster (USA, Europe) (GB Compatible).gbc" size 1048576 crc 1c13dbb0 sha1 84930fa75eccc34a8e9fb6a0387791d437d1a442 flags verified ) ) game ( - name "Aliens - Thanatos Encounter (USA, Europe)" - description "Aliens - Thanatos Encounter (USA, Europe)" - rom ( name "Aliens - Thanatos Encounter (USA, Europe).gbc" size 1048576 crc bec3c24b sha1 e1b1c79c15a34984dddbe270fc6770b32a31a0d7 ) + name "Chi to Ase to Namida no Koukou Yakyuu (Japan)" + description "Chi to Ase to Namida no Koukou Yakyuu (Japan)" + rom ( name "Chi to Ase to Namida no Koukou Yakyuu (Japan).gbc" size 1048576 crc 3c39bcab sha1 172d7a7048851a2d0a0be1f21a2a60176f038e01 ) ) game ( - name "All Humans Must Die! (World) (GB Compatible) (Aftermarket) (Unl)" - description "All Humans Must Die! (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "All Humans Must Die! (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc b4d50eed sha1 f4513fc525cbcfa4a2804b55ce20c809e01d1c87 ) + name "Chibi Maruko-chan - Go Chounai Minna de Game Da yo! (Japan)" + description "Chibi Maruko-chan - Go Chounai Minna de Game Da yo! (Japan)" + rom ( name "Chibi Maruko-chan - Go Chounai Minna de Game Da yo! (Japan).gbc" size 1048576 crc 20faa0d1 sha1 31a0e557b36382f260a8297226e14737217c9763 ) ) game ( - name "All Star Tennis 2000 (Europe) (AZTP) (GB Compatible)" - description "All Star Tennis 2000 (Europe) (AZTP) (GB Compatible)" - rom ( name "All Star Tennis 2000 (Europe) (AZTP) (GB Compatible).gbc" size 1048576 crc 952b94e5 sha1 50f99b0fc5c2f5edc2e76ba973cc42fb0a1a02c8 ) + name "Chicken Run (USA, Europe) (En,Fr,De,Es,It)" + description "Chicken Run (USA, Europe) (En,Fr,De,Es,It)" + rom ( name "Chicken Run (USA, Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc f8bd2a01 sha1 8dfd72e622c39ed8fd03046253474f38fb482c77 flags verified ) ) game ( - name "All Star Tennis 2000 (USA) (Proto) (GB Compatible)" - description "All Star Tennis 2000 (USA) (Proto) (GB Compatible)" - rom ( name "All Star Tennis 2000 (USA) (Proto) (GB Compatible).gbc" size 1048576 crc 9890bcb4 sha1 f6829ac5bba08732f875fc5812284d62f3d727e6 ) + name "Chiki Chiki Machine Mou Race (Japan)" + description "Chiki Chiki Machine Mou Race (Japan)" + rom ( name "Chiki Chiki Machine Mou Race (Japan).gbc" size 1048576 crc 36c04be0 sha1 77ccf3a535e21e28d73059d3bfe42b58fee17d2a ) ) game ( - name "All Star Tennis 2000 (Europe) (AZTX) (Proto) (GB Compatible)" - description "All Star Tennis 2000 (Europe) (AZTX) (Proto) (GB Compatible)" - rom ( name "All Star Tennis 2000 (Europe) (AZTX) (Proto) (GB Compatible).gbc" size 1048576 crc deff8dfb sha1 c9db40e3e348668fe6fc41d031263acbe9041a67 ) + name "Chongwu Xiao Jingling - Jiejin Ta Zhi Wang (Taiwan) (Unl)" + description "Chongwu Xiao Jingling - Jiejin Ta Zhi Wang (Taiwan) (Unl)" + rom ( name "Chongwu Xiao Jingling - Jiejin Ta Zhi Wang (Taiwan) (Unl).gbc" size 1048576 crc 620e785d sha1 74da832c2eeb27a4260fe6f42514539473f48b11 ) ) game ( - name "All-Star Baseball 2000 (USA, Europe)" - description "All-Star Baseball 2000 (USA, Europe)" - rom ( name "All-Star Baseball 2000 (USA, Europe).gbc" size 1048576 crc e17f59a5 sha1 7156ac04b7d249007f62b4b509b4661190977908 ) + name "Choro Q - Hyper Customable GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Choro Q - Hyper Customable GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Choro Q - Hyper Customable GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 65610ca4 sha1 8af215c632599aaab9bc4614194ac45802407bbc ) ) game ( - name "All-Star Baseball 2001 (USA)" - description "All-Star Baseball 2001 (USA)" - rom ( name "All-Star Baseball 2001 (USA).gbc" size 1048576 crc bc562466 sha1 f702df64d368b763187a5b1263a60fb3e842962b ) + name "Chuanshuo (Taiwan) (Unl)" + description "Chuanshuo (Taiwan) (Unl)" + rom ( name "Chuanshuo (Taiwan) (Unl).gbc" size 2097152 crc 0b20d3af sha1 f390b702d4b160149c1030bcccb5ed6f76c0b94a ) ) game ( - name "Alley Cat (World) (Aftermarket) (Unl)" - description "Alley Cat (World) (Aftermarket) (Unl)" - rom ( name "Alley Cat (World) (Aftermarket) (Unl).gbc" size 262144 crc edb3ac37 sha1 a9aa1ecad6b67a6e5096fb1c10e39899c00a96a0 ) + name "Classic Bubble Bobble (Europe) (SGB Enhanced) (GB Compatible)" + description "Classic Bubble Bobble (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Classic Bubble Bobble (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a0f66d87 sha1 3c52b09072077c210af93e4b13c3ee0886676f83 ) ) game ( - name "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - description "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - rom ( name "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 4194304 crc 7c101475 sha1 120e2dd012cfe47a7e37cc91fcbbce92494bdf2a ) + name "Classic Bubble Bobble (USA) (SGB Enhanced) (GB Compatible)" + description "Classic Bubble Bobble (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Classic Bubble Bobble (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c1b22246 sha1 6e3739c0538467c220750f2e8d474433692bac09 ) ) game ( - name "Alone in the Dark - The New Nightmare (USA) (Beta) (2001-02-21)" - description "Alone in the Dark - The New Nightmare (USA) (Beta) (2001-02-21)" - rom ( name "Alone in the Dark - The New Nightmare (USA) (Beta) (2001-02-21).gbc" size 4194304 crc 3821d140 sha1 fc2a7dbe5ff60e2704ac78f83d6b6df2bf9dcc97 ) + name "Colin McRae Rally (Europe)" + description "Colin McRae Rally (Europe)" + rom ( name "Colin McRae Rally (Europe).gbc" size 2097152 crc e93af9c8 sha1 0b824ba294248c185967bc813eba1faa26a320cc ) ) game ( - name "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl)" - description "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Alone in the Dark - The New Nightmare (Europe) (En,Fr,De,Es,It,Nl).gbc" size 4194304 crc 7ff2042f sha1 818259159b5e7d3775584b478d4fd36f6a25fcaa flags verified ) + name "Columns GB - Tezuka Osamu Characters (Japan) (SGB Enhanced) (GB Compatible)" + description "Columns GB - Tezuka Osamu Characters (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Columns GB - Tezuka Osamu Characters (Japan) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc fbe5de37 sha1 a8d9a6631f1d203d99be38fb90135c10e5f0c880 ) ) game ( - name "Alone in the Dark - The New Nightmare (USA) (En,Fr,Es)" - description "Alone in the Dark - The New Nightmare (USA) (En,Fr,Es)" - rom ( name "Alone in the Dark - The New Nightmare (USA) (En,Fr,Es).gbc" size 4194304 crc c145c036 sha1 a348aeac500d0d8fdaf90f5277631a026504ff44 ) + name "Command Master (Japan)" + description "Command Master (Japan)" + rom ( name "Command Master (Japan).gbc" size 2097152 crc d10b5645 sha1 f1d3a1ff7a76c49ce3e094ca994d488dbdadf9a2 flags verified ) ) game ( - name "AMF Bowling (USA) (Proto)" - description "AMF Bowling (USA) (Proto)" - rom ( name "AMF Bowling (USA) (Proto).gbc" size 1048576 crc 392559ee sha1 1dd7d94f320d119682fd4df80297c8df1b28141b ) + name "Commander Keen (USA, Europe)" + description "Commander Keen (USA, Europe)" + rom ( name "Commander Keen (USA, Europe).gbc" size 1048576 crc 4af4cc9c sha1 a00b7bdaaedeb67ad7e7555139301c8b4c92edea flags verified ) ) game ( - name "Animal Breeder 3 (Japan) (SGB Enhanced) (GB Compatible)" - description "Animal Breeder 3 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Animal Breeder 3 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc c62a4c30 sha1 f5e6e770a681bb6eba255e2584f9ed343e5d9f98 ) + name "Conker's Pocket Tales (USA, Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + description "Conker's Pocket Tales (USA, Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + rom ( name "Conker's Pocket Tales (USA, Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc a50be9a8 sha1 e9c3b1bb20ea74f363191ea9144009d1b13246bb flags verified ) ) game ( - name "Animal Breeder 4 (Japan)" - description "Animal Breeder 4 (Japan)" - rom ( name "Animal Breeder 4 (Japan).gbc" size 4194304 crc 83d838c3 sha1 2f7854cfc227ecc395551ea4c0b62256f0757514 ) + name "Cool Bricks (Europe) (En,Fr,De,Es,It)" + description "Cool Bricks (Europe) (En,Fr,De,Es,It)" + rom ( name "Cool Bricks (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 04fe7790 sha1 0f0410e2ee2ce1a9e6b12399492f8bd2ddf67406 ) ) game ( - name "Animastar GB (Japan)" - description "Animastar GB (Japan)" - rom ( name "Animastar GB (Japan).gbc" size 2097152 crc b14920f0 sha1 4f141e012fc46cab0dd36655c2548dfaed0a862f flags verified ) + name "Cool Hand (Europe) (En,Fr,De) (GB Compatible)" + description "Cool Hand (Europe) (En,Fr,De) (GB Compatible)" + rom ( name "Cool Hand (Europe) (En,Fr,De) (GB Compatible).gbc" size 524288 crc e6c91fb8 sha1 d116a77c501d5e553d1490993f8c0a9a92c3ea0c ) ) game ( - name "Animorphs (Europe) (En,Fr,De,Es,It)" - description "Animorphs (Europe) (En,Fr,De,Es,It)" - rom ( name "Animorphs (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 7fd46da1 sha1 c936a5b3c005f72de5032c4a067a7d95ab2735fa ) + name "Crazy Bikers (Europe)" + description "Crazy Bikers (Europe)" + rom ( name "Crazy Bikers (Europe).gbc" size 1048576 crc 53e02b87 sha1 c625608b5165e971827af8434e72d8ca8d200ab8 ) ) game ( - name "Animorphs (USA)" - description "Animorphs (USA)" - rom ( name "Animorphs (USA).gbc" size 1048576 crc b4f293cc sha1 b3e5b34d5e97c49720861fabb6a29d557029279c ) + name "Crazy Climber (USA) (Proto 2) (2000-11-21)" + description "Crazy Climber (USA) (Proto 2) (2000-11-21)" + rom ( name "Crazy Climber (USA) (Proto 2) (2000-11-21).gbc" size 131072 crc 45389344 sha1 68979eb91a968998c2fb58396971265be5b312ca ) ) game ( - name "Another Adventure (World) (En,Es) (GB Compatible) (Aftermarket) (Unl)" - description "Another Adventure (World) (En,Es) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Another Adventure (World) (En,Es) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc dfcd02ef sha1 041473b2381dd9e11b3cbda5858f9841324327af ) + name "Crazy Climber (USA) (Proto 1) (2000-09-22)" + description "Crazy Climber (USA) (Proto 1) (2000-09-22)" + rom ( name "Crazy Climber (USA) (Proto 1) (2000-09-22).gbc" size 131072 crc 748fa8b4 sha1 eb0eaed85cf5a72e0461eebbad38227bd018a999 ) ) game ( - name "Anpfiff - Der RTL Fussball-Manager (Germany)" - description "Anpfiff - Der RTL Fussball-Manager (Germany)" - rom ( name "Anpfiff - Der RTL Fussball-Manager (Germany).gbc" size 1048576 crc b54d264a sha1 4c5bd67eee82a36cf695db12169bc4393225faa0 flags verified ) + name "Croc (USA, Europe)" + description "Croc (USA, Europe)" + rom ( name "Croc (USA, Europe).gbc" size 1048576 crc 4664a167 sha1 dac6de548743c6b51a3daa5903c28b7fccdb6cb2 ) ) game ( - name "Antz (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - description "Antz (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - rom ( name "Antz (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc 4839e0c1 sha1 2cba2b024edb4b702d2acabefbcb310f4d6e2075 ) + name "Croc 2 (USA, Europe)" + description "Croc 2 (USA, Europe)" + rom ( name "Croc 2 (USA, Europe).gbc" size 1048576 crc c1d60129 sha1 fa29d6c4239405b12b320bb6e8a65ca2083a4b1c flags verified ) ) game ( - name "Antz (USA) (En,Fr,Es) (GB Compatible)" - description "Antz (USA) (En,Fr,Es) (GB Compatible)" - rom ( name "Antz (USA) (En,Fr,Es) (GB Compatible).gbc" size 1048576 crc dc0be439 sha1 85684d5891e4ec0f9fdf61b644bdf0ffbf1ba219 ) + name "Cross Country Racing (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + description "Cross Country Racing (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + rom ( name "Cross Country Racing (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b7b91fe9 sha1 67bcac922b14a6fde311ca693f297248ceebbea6 ) ) game ( - name "Antz (Europe) (En,Fr,De,Es,It,Nl) (Beta) (GB Compatible)" - description "Antz (Europe) (En,Fr,De,Es,It,Nl) (Beta) (GB Compatible)" - rom ( name "Antz (Europe) (En,Fr,De,Es,It,Nl) (Beta) (GB Compatible).gbc" size 524288 crc f287fc49 sha1 99818cd3dc4bfe61bf0095856a0f443afae89acf ) + name "Cross Hunter - Monster Hunter Version (Japan)" + description "Cross Hunter - Monster Hunter Version (Japan)" + rom ( name "Cross Hunter - Monster Hunter Version (Japan).gbc" size 4194304 crc 48e1ba7d sha1 15383fdba1bca2c11ed00dc271b4a6f69d500f75 ) ) game ( - name "Antz Racing (Europe) (En,Fr,De,Es,It,Nl)" - description "Antz Racing (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Antz Racing (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc f625a959 sha1 e4ff55112a76da72f30582476f15358527518cfd flags verified ) + name "Cross Hunter - Treasure Hunter Version (Japan)" + description "Cross Hunter - Treasure Hunter Version (Japan)" + rom ( name "Cross Hunter - Treasure Hunter Version (Japan).gbc" size 4194304 crc 623c1516 sha1 b54fcdebd54484113923b899eed7c63550609f74 ) ) game ( - name "Antz Racing (USA) (En,Fr,De,Es,It,Nl)" - description "Antz Racing (USA) (En,Fr,De,Es,It,Nl)" - rom ( name "Antz Racing (USA) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc dfdf90c0 sha1 806e641b911b302f5be2a80b6003f473d1a10a88 ) + name "Cross Hunter - X Hunter Version (Japan)" + description "Cross Hunter - X Hunter Version (Japan)" + rom ( name "Cross Hunter - X Hunter Version (Japan).gbc" size 4194304 crc 858010e0 sha1 2c9d8994635957f1080d785f47a596e02880be6c ) ) game ( - name "Antz World Sportz (Europe) (En,Fr,De,Es,It,Nl)" - description "Antz World Sportz (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Antz World Sportz (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 67c7f85c sha1 d8ddf04baad3beadedf85847964f986ba89bc5ee ) + name "Cruis'n Exotica (USA)" + description "Cruis'n Exotica (USA)" + rom ( name "Cruis'n Exotica (USA).gbc" size 2097152 crc 9562e7e8 sha1 e3f7bab776d76048a6cf1745fb4d8ecaf2d44f46 ) ) game ( - name "Apollo Mission (World) (Aftermarket) (Unl)" - description "Apollo Mission (World) (Aftermarket) (Unl)" - rom ( name "Apollo Mission (World) (Aftermarket) (Unl).gbc" size 262144 crc bec9d9a2 sha1 b2bcc61bcf269c0f5c0ce2a6e0bb1c7015dc9ff9 ) + name "Crystalis (USA)" + description "Crystalis (USA)" + rom ( name "Crystalis (USA).gbc" size 2097152 crc 909bb02d sha1 85d9cfaae2ae4995d834cc9b95ec3126707a6332 ) ) game ( - name "Aqualife (Japan) (SGB Enhanced) (GB Compatible)" - description "Aqualife (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Aqualife (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e243feb4 sha1 69eaf53eccdaf98cd7cc0d436209f511b558d761 ) + name "Cubix - Robots for Everyone - Race 'n Robots (USA) (En,Fr,De,Es,It)" + description "Cubix - Robots for Everyone - Race 'n Robots (USA) (En,Fr,De,Es,It)" + rom ( name "Cubix - Robots for Everyone - Race 'n Robots (USA) (En,Fr,De,Es,It).gbc" size 1048576 crc 9f883b0f sha1 d62b85c664e0a42c84e56b939a201fe90d05a360 ) ) game ( - name "Arena 3000 (World) (Aftermarket) (Unl)" - description "Arena 3000 (World) (Aftermarket) (Unl)" - rom ( name "Arena 3000 (World) (Aftermarket) (Unl).gbc" size 262144 crc 9c17c15c sha1 007d23f73f68de01c250ec3d07403679137851ff ) + name "CyberTiger (USA, Europe)" + description "CyberTiger (USA, Europe)" + rom ( name "CyberTiger (USA, Europe).gbc" size 1048576 crc e470cafa sha1 3eb14447bd2a349be16eb6e51066c65a51b35e69 flags verified ) ) game ( - name "Arle no Bouken - Mahou no Jewel (Japan) (SGB Enhanced) (GB Compatible)" - description "Arle no Bouken - Mahou no Jewel (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Arle no Bouken - Mahou no Jewel (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 8ee043ea sha1 fb781637ddac30cebb1865ba939f49bb2b0b5146 ) + name "Cyborg Kuro-chan - Devil Fukkatsu (Japan)" + description "Cyborg Kuro-chan - Devil Fukkatsu (Japan)" + rom ( name "Cyborg Kuro-chan - Devil Fukkatsu (Japan).gbc" size 1048576 crc 392d630f sha1 b544d1a49128bc5ab3664ced872d2d1dcc51b667 ) ) game ( - name "Armada - FX Racers (USA)" - description "Armada - FX Racers (USA)" - rom ( name "Armada - FX Racers (USA).gbc" size 1048576 crc d952cbab sha1 b8f911e6d6dc37b9bbfd565f6919a94f17bf3073 ) + name "Cyborg Kuro-chan 2 - White Woods no Gyakushuu (Japan)" + description "Cyborg Kuro-chan 2 - White Woods no Gyakushuu (Japan)" + rom ( name "Cyborg Kuro-chan 2 - White Woods no Gyakushuu (Japan).gbc" size 1048576 crc e86bf12e sha1 8ce6261de9dc2ae1a02a2ac00fa45b855fae34a2 ) ) game ( - name "Armorines - Project S.W.A.R.M. (USA, Europe) (En,De)" - description "Armorines - Project S.W.A.R.M. (USA, Europe) (En,De)" - rom ( name "Armorines - Project S.W.A.R.M. (USA, Europe) (En,De).gbc" size 1048576 crc ea3b9c73 sha1 2be58ee1a3a76d1259a044c6c7c9dcd6dacf8405 flags verified ) + name "Daa! Daa! Daa! - Totsuzen Card de Battle de Uranai de! (Japan)" + description "Daa! Daa! Daa! - Totsuzen Card de Battle de Uranai de! (Japan)" + rom ( name "Daa! Daa! Daa! - Totsuzen Card de Battle de Uranai de! (Japan).gbc" size 1048576 crc f41bb392 sha1 b716720f25ec84fa51181125494a009345d0b20f ) ) game ( - name "Army Men (USA, Europe) (En,Fr,De)" - description "Army Men (USA, Europe) (En,Fr,De)" - rom ( name "Army Men (USA, Europe) (En,Fr,De).gbc" size 1048576 crc 34411753 sha1 e98cea1a113ba4774ce26ab16d61625f0870b6ad flags verified ) + name "Daffy Duck - Fowl Play (USA, Europe) (GB Compatible)" + description "Daffy Duck - Fowl Play (USA, Europe) (GB Compatible)" + rom ( name "Daffy Duck - Fowl Play (USA, Europe) (GB Compatible).gbc" size 1048576 crc 45ebf09c sha1 5d9373d934dc3c672ff426960d565d8cf635925b ) ) game ( - name "Army Men - Air Combat (USA, Europe) (En,Fr,De)" - description "Army Men - Air Combat (USA, Europe) (En,Fr,De)" - rom ( name "Army Men - Air Combat (USA, Europe) (En,Fr,De).gbc" size 1048576 crc b0d1de8c sha1 4e1d964d31013e79ecae4a49dcd3777cc7e06af2 flags verified ) + name "Daffy Duck - Subette Koron de Oogane Mochi (Japan) (GB Compatible)" + description "Daffy Duck - Subette Koron de Oogane Mochi (Japan) (GB Compatible)" + rom ( name "Daffy Duck - Subette Koron de Oogane Mochi (Japan) (GB Compatible).gbc" size 1048576 crc 5b4507d9 sha1 5578b7973a65eea2f09c6150b9154377d237da75 ) ) game ( - name "Army Men - Sarge's Heroes 2 (USA, Europe) (En,Fr,De)" - description "Army Men - Sarge's Heroes 2 (USA, Europe) (En,Fr,De)" - rom ( name "Army Men - Sarge's Heroes 2 (USA, Europe) (En,Fr,De).gbc" size 1048576 crc 71b857ea sha1 9a2adb5639c80282d7465f9c5d30acb669991d8e flags verified ) + name "Daikaijuu Monogatari - Poyon no Dungeon Room (Japan) (SGB Enhanced) (GB Compatible)" + description "Daikaijuu Monogatari - Poyon no Dungeon Room (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Daikaijuu Monogatari - Poyon no Dungeon Room (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 2f368da6 sha1 0854b7ea4791a460c75ce9096583934b1af053e8 flags verified ) ) game ( - name "Army Men 2 (USA, Europe) (En,Fr,De)" - description "Army Men 2 (USA, Europe) (En,Fr,De)" - rom ( name "Army Men 2 (USA, Europe) (En,Fr,De).gbc" size 1048576 crc 2272baca sha1 6e52dcaca1a97ae557c4c87e4281667a9d9b14c5 flags verified ) + name "Daikaijuu Monogatari - Poyon no Dungeon Room 2 (Japan)" + description "Daikaijuu Monogatari - Poyon no Dungeon Room 2 (Japan)" + rom ( name "Daikaijuu Monogatari - Poyon no Dungeon Room 2 (Japan).gbc" size 2097152 crc 5e312730 sha1 e9bc47efd971f2caf9ebe9b4d85516d3813d8247 ) ) game ( - name "Arthur's Absolutely Fun Day! (USA)" - description "Arthur's Absolutely Fun Day! (USA)" - rom ( name "Arthur's Absolutely Fun Day! (USA).gbc" size 1048576 crc f03599a3 sha1 cf1323cfd3fbe8ba8c9766a87a7c68d8b7e729f9 ) + name "Daikaijuu Monogatari - The Miracle of the Zone II (Japan) (SGB Enhanced) (GB Compatible)" + description "Daikaijuu Monogatari - The Miracle of the Zone II (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Daikaijuu Monogatari - The Miracle of the Zone II (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 692d6794 sha1 7bf6e2d7fc58e8abe61785e413bcf4150fa8bee5 flags verified ) ) game ( - name "Asterix - Sur la Trace D'Idefix (Europe) (En,Fr,De,Es,It,Nl)" - description "Asterix - Sur la Trace D'Idefix (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Asterix - Sur la Trace D'Idefix (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 408dc5c6 sha1 5c7207137ab422d3326d183d3433db161d8ecbc5 flags verified ) + name "Daikatana (USA) (Proto 1) (2000-04-19)" + description "Daikatana (USA) (Proto 1) (2000-04-19)" + rom ( name "Daikatana (USA) (Proto 1) (2000-04-19).gbc" size 4194304 crc 351862bb sha1 361d05119aa6671415a8c583150dbfa4dfd93e5e ) ) game ( - name "Asterix & Obelix (Europe) (En,Fr,De,Es)" - description "Asterix & Obelix (Europe) (En,Fr,De,Es)" - rom ( name "Asterix & Obelix (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 6628cdee sha1 5f36071df7be289c169768b1683947e972d26996 ) + name "Daikatana (USA) (Proto 2)" + description "Daikatana (USA) (Proto 2)" + rom ( name "Daikatana (USA) (Proto 2).gbc" size 1048576 crc 7d451688 sha1 6eef48f4d467596ff3734bb9ac12db392170eb14 ) ) game ( - name "Asterix & Obelix Contre Cesar (Europe) (En,Fr,De,Es,Nl) (GB Compatible)" - description "Asterix & Obelix Contre Cesar (Europe) (En,Fr,De,Es,Nl) (GB Compatible)" - rom ( name "Asterix & Obelix Contre Cesar (Europe) (En,Fr,De,Es,Nl) (GB Compatible).gbc" size 1048576 crc 71043d76 sha1 a4b892d269957d84570c07856c81f48f037b5a03 ) + name "Daikatana GB (Japan) (NP)" + description "Daikatana GB (Japan) (NP)" + rom ( name "Daikatana GB (Japan) (NP).gbc" size 1048576 crc 2bb01aad sha1 268aef9fa88a4921bdc10c1828cd88b49d65635e ) ) game ( - name "Asteroids (USA, Europe) (GB Compatible)" - description "Asteroids (USA, Europe) (GB Compatible)" - rom ( name "Asteroids (USA, Europe) (GB Compatible).gbc" size 1048576 crc 89d5d936 sha1 026f031e1bb787a4390e7873227dcb52a069a6e0 flags verified ) + name "Daiku no Gen-san - Kachikachi no Tonkachi ga Kachi (Japan) (SGB Enhanced) (GB Compatible)" + description "Daiku no Gen-san - Kachikachi no Tonkachi ga Kachi (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Daiku no Gen-san - Kachikachi no Tonkachi ga Kachi (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e2071293 sha1 2d961353e7242babce49dda8d017a459f4ef7609 ) ) game ( - name "Astro Plumber (World) (Aftermarket) (Unl)" - description "Astro Plumber (World) (Aftermarket) (Unl)" - rom ( name "Astro Plumber (World) (Aftermarket) (Unl).gbc" size 262144 crc d746db41 sha1 bf46ab2a3a1ffc3b712b9ae5cfa05441781ac9e4 ) + name "Dance Dance Revolution GB (Japan)" + description "Dance Dance Revolution GB (Japan)" + rom ( name "Dance Dance Revolution GB (Japan).gbc" size 2097152 crc c64ff2b6 sha1 5be4cc1a810b48b843b60b5b37b2012a47e5742b ) ) game ( - name "Astro-Jump - The Sequel (World) (GB Compatible) (Aftermarket) (Unl)" - description "Astro-Jump - The Sequel (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Astro-Jump - The Sequel (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc e6a96130 sha1 2cd0ef086c4b89497d9497a17d871a6568a9e2d3 ) + name "Dance Dance Revolution GB - Disney Mix (Japan)" + description "Dance Dance Revolution GB - Disney Mix (Japan)" + rom ( name "Dance Dance Revolution GB - Disney Mix (Japan).gbc" size 2097152 crc b31a59bf sha1 91c653d792ddaadf6cab9f6b1d62d4194cd23c1a ) ) game ( - name "Atlantis - The Lost Empire (Europe) (En,Es,It)" - description "Atlantis - The Lost Empire (Europe) (En,Es,It)" - rom ( name "Atlantis - The Lost Empire (Europe) (En,Es,It).gbc" size 2097152 crc 28f7d5e3 sha1 ef4ab0dd852ffd1418c803c05ddcb245b3a4348d ) + name "Dance Dance Revolution GB 2 (Japan)" + description "Dance Dance Revolution GB 2 (Japan)" + rom ( name "Dance Dance Revolution GB 2 (Japan).gbc" size 2097152 crc 565fec36 sha1 d44e2905b9436be7b278bc30816023375a677ea1 ) ) game ( - name "Atlantis - The Lost Empire (Europe) (Fr,De,Nl)" - description "Atlantis - The Lost Empire (Europe) (Fr,De,Nl)" - rom ( name "Atlantis - The Lost Empire (Europe) (Fr,De,Nl).gbc" size 2097152 crc 4e052510 sha1 19df06e2a8be1336a6aec8c86649b95b206dc54f ) + name "Dance Dance Revolution GB 3 (Japan)" + description "Dance Dance Revolution GB 3 (Japan)" + rom ( name "Dance Dance Revolution GB 3 (Japan).gbc" size 2097152 crc 58f26f36 sha1 e23a69ad358623be715908860e8e6bf04020552c ) ) game ( - name "Atlantis - The Lost Empire (USA, Europe)" - description "Atlantis - The Lost Empire (USA, Europe)" - rom ( name "Atlantis - The Lost Empire (USA, Europe).gbc" size 2097152 crc d594d24b sha1 ab5dd8efa36b33ce9aa090b3d990e8fc8828f7e2 ) + name "Dancing Furby (Japan) (GB Compatible)" + description "Dancing Furby (Japan) (GB Compatible)" + rom ( name "Dancing Furby (Japan) (GB Compatible).gbc" size 1048576 crc 3263f692 sha1 f3f7e37d64eef74d65456bae490e0a0b25897ac0 ) ) game ( - name "Atop the Witch's Tower (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "Atop the Witch's Tower (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Atop the Witch's Tower (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 0d60b100 sha1 9cc1a5140b96ad072d36151f5d99ff6eb699e605 ) + name "Data-Navi Pro Yakyuu (Japan)" + description "Data-Navi Pro Yakyuu (Japan)" + rom ( name "Data-Navi Pro Yakyuu (Japan).gbc" size 1048576 crc c958ad75 sha1 408fda7442f00a315e6b1f39963b00bc4264a142 ) ) game ( - name "Atsumete Asobu Kuma no Pooh-san - Mori no Takaramono (Japan)" - description "Atsumete Asobu Kuma no Pooh-san - Mori no Takaramono (Japan)" - rom ( name "Atsumete Asobu Kuma no Pooh-san - Mori no Takaramono (Japan).gbc" size 2097152 crc 476ede93 sha1 73b95f3b92c2d48a2580f7ac10950d56aeffb94d ) + name "Data-Navi Pro Yakyuu 2 (Japan)" + description "Data-Navi Pro Yakyuu 2 (Japan)" + rom ( name "Data-Navi Pro Yakyuu 2 (Japan).gbc" size 1048576 crc 96071ad0 sha1 f59cf8ba729f6992d348f6bb14d24695e357f492 ) ) game ( - name "ATV Racing (Europe) (Unl)" - description "ATV Racing (Europe) (Unl)" - rom ( name "ATV Racing (Europe) (Unl).gbc" size 262144 crc 7987d5cd sha1 b3c6c2970c3bfa95fb2eef10e2160f55f52d8e1a ) + name "Dave Mirra Freestyle BMX (USA, Europe)" + description "Dave Mirra Freestyle BMX (USA, Europe)" + rom ( name "Dave Mirra Freestyle BMX (USA, Europe).gbc" size 1048576 crc 2df6e230 sha1 7d03bbc95a6d0e67186ab110266e8eeb0066d16b flags verified ) ) game ( - name "ATV Racing & Karate Joe (Europe) (Unl)" - description "ATV Racing & Karate Joe (Europe) (Unl)" - rom ( name "ATV Racing & Karate Joe (Europe) (Unl).gbc" size 524288 crc a07b6e79 sha1 3701028d66564625933a3868340813e6d7c36b7b ) + name "David Beckham Soccer (Europe) (En,Fr,De,Es,It)" + description "David Beckham Soccer (Europe) (En,Fr,De,Es,It)" + rom ( name "David Beckham Soccer (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 753bdce4 sha1 01567d19fcbfeeae38df505ec689998936351380 ) ) game ( - name "ATV Racing & Karate Joe (Europe) (Unl) (Alt)" - description "ATV Racing & Karate Joe (Europe) (Unl) (Alt)" - rom ( name "ATV Racing & Karate Joe (Europe) (Unl) (Alt).gbc" size 524288 crc 6908f4af sha1 95287b440139e88d90700f892d1da60aaa4da778 ) + name "David Beckham Soccer (USA) (En,Es) (Proto)" + description "David Beckham Soccer (USA) (En,Es) (Proto)" + rom ( name "David Beckham Soccer (USA) (En,Es) (Proto).gbc" size 1048576 crc c08f3254 sha1 1d8970ed5aacadd0bdb7e4d78a7eb70a2d0f9650 ) ) game ( - name "Austin Powers - Oh, Behave! (Europe) (En,Fr,De,Es,It)" - description "Austin Powers - Oh, Behave! (Europe) (En,Fr,De,Es,It)" - rom ( name "Austin Powers - Oh, Behave! (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc bf99f8cb sha1 a5d29d48b9bc3e1fa476e475da24c2d80985188d ) + name "David O'Leary's Total Soccer 2000 (Europe) (En,Fr,De,Es,It,Nl)" + description "David O'Leary's Total Soccer 2000 (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "David O'Leary's Total Soccer 2000 (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc c25ee35a sha1 be0703ee2667ddc53cff9d6c7d22b30d272c0738 flags verified ) ) game ( - name "Austin Powers - Oh, Behave! (USA)" - description "Austin Powers - Oh, Behave! (USA)" - rom ( name "Austin Powers - Oh, Behave! (USA).gbc" size 4194304 crc bb89190e sha1 aa6cb6ab4fe083cbe0274c40bd30e0013a2f7645 ) + name "Deadly Skies (Europe) (En,Fr,De)" + description "Deadly Skies (Europe) (En,Fr,De)" + rom ( name "Deadly Skies (Europe) (En,Fr,De).gbc" size 1048576 crc 402de378 sha1 aa9118da41e7d29385352f29593aed8c016329d1 ) ) game ( - name "Austin Powers - Welcome to My Underground Lair! (Europe) (En,Fr,De,Es,It)" - description "Austin Powers - Welcome to My Underground Lair! (Europe) (En,Fr,De,Es,It)" - rom ( name "Austin Powers - Welcome to My Underground Lair! (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 693f50da sha1 02c7c61928ab82b4a8a07bb067d5f5ca32511df7 ) + name "Dear Daniel no Sweet Adventure - Kitty-chan o Sagashite (Japan) (SGB Enhanced) (GB Compatible)" + description "Dear Daniel no Sweet Adventure - Kitty-chan o Sagashite (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Dear Daniel no Sweet Adventure - Kitty-chan o Sagashite (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0fd34427 sha1 8598594285f0342b3d93c447b475fadd4722c6cb ) ) game ( - name "Austin Powers - Welcome to My Underground Lair! (USA)" - description "Austin Powers - Welcome to My Underground Lair! (USA)" - rom ( name "Austin Powers - Welcome to My Underground Lair! (USA).gbc" size 4194304 crc aba42b78 sha1 69b5106a124bde38184875c0dd08de437360bc14 ) + name "Deer Hunter (USA)" + description "Deer Hunter (USA)" + rom ( name "Deer Hunter (USA).gbc" size 1048576 crc 40a715fb sha1 87a012e82f2361760ae337b30e9d41ef2245419a ) ) game ( - name "Austin Powers Episode III (Europe) (En,Fr,De,Es,It) (Proto)" - description "Austin Powers Episode III (Europe) (En,Fr,De,Es,It) (Proto)" - rom ( name "Austin Powers Episode III (Europe) (En,Fr,De,Es,It) (Proto).gbc" size 2097152 crc 0903ed53 sha1 b409782cc478104c41668360b63f8589f7677e2a ) + name "Deja Vu I & II (Japan)" + description "Deja Vu I & II (Japan)" + rom ( name "Deja Vu I & II (Japan).gbc" size 1048576 crc baf2cc96 sha1 4f3af0a47de674531c0fede3783f8c6cc7f31cca ) ) game ( - name "Austin Powers Episode IV (Europe) (En,Fr,De,Es,It) (Proto)" - description "Austin Powers Episode IV (Europe) (En,Fr,De,Es,It) (Proto)" - rom ( name "Austin Powers Episode IV (Europe) (En,Fr,De,Es,It) (Proto).gbc" size 2097152 crc f038cda7 sha1 937df6944709732d8d372ad5f629a665ffd12eac ) + name "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (En,Fr)" + description "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (En,Fr)" + rom ( name "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (En,Fr).gbc" size 1048576 crc 71f798b5 sha1 10c2ed4098a07979426d359da57a5289c6bc73fe ) ) game ( - name "Auto Zone (World) (Aftermarket) (Unl)" - description "Auto Zone (World) (Aftermarket) (Unl)" - rom ( name "Auto Zone (World) (Aftermarket) (Unl).gbc" size 524288 crc 2a86d386 sha1 83a37fb5c5d82e0ff06bb22b63761af996e4ad61 ) + name "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (Fr,De)" + description "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (Fr,De)" + rom ( name "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (Fr,De).gbc" size 1048576 crc c6e7f3c6 sha1 ed1a11e2a02fc11d6b58dedf65ce57eeb430e6e3 ) ) game ( - name "Autumn With You, An (World) (GB Compatible) (Aftermarket) (Unl)" - description "Autumn With You, An (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Autumn With You, An (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc eac459fa sha1 68a5520be76c52a4936ad1756ea274667f2ac0e3 ) + name "Deja Vu I & II - The Casebooks of Ace Harding (USA)" + description "Deja Vu I & II - The Casebooks of Ace Harding (USA)" + rom ( name "Deja Vu I & II - The Casebooks of Ace Harding (USA).gbc" size 1048576 crc ad0937f4 sha1 63266fc1f0a14678d5cd5dd1c5e3658ef4a944c3 ) ) game ( - name "Aventures de Buzz l'Eclair, Les (France)" - description "Aventures de Buzz l'Eclair, Les (France)" - rom ( name "Aventures de Buzz l'Eclair, Les (France).gbc" size 524288 crc 841674b0 sha1 4c4c51883b6c73627ca9b04bb0b24e6bab072f29 ) + name "Dejiko no Mahjong Party (Japan)" + description "Dejiko no Mahjong Party (Japan)" + rom ( name "Dejiko no Mahjong Party (Japan).gbc" size 2097152 crc c5501fce sha1 d9dd4196a85bceee6e77a317a357e9e0b14d26eb ) ) game ( - name "Azarashi Sentai Inazuma - Dokidoki Daisakusen! (Japan)" - description "Azarashi Sentai Inazuma - Dokidoki Daisakusen! (Japan)" - rom ( name "Azarashi Sentai Inazuma - Dokidoki Daisakusen! (Japan).gbc" size 1048576 crc 98f63bd4 sha1 f4278b01f445562d17a9a2fd8dd5c9bc9d32008e ) + name "Dejiko no Mahjong Party (Japan) (Rev 1) (Proto)" + description "Dejiko no Mahjong Party (Japan) (Rev 1) (Proto)" + rom ( name "Dejiko no Mahjong Party (Japan) (Rev 1) (Proto).gbc" size 2097152 crc 7e515a7e sha1 fbc2b66a6595bbb3ed85f35545152442283eaea3 ) ) game ( - name "Azure Dreams (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - description "Azure Dreams (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - rom ( name "Azure Dreams (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc f9ccab09 sha1 81d9acd0e27639f90e38e918a4b0a96fa565d1d9 ) + name "Denki Blocks! (USA) (En,Es) (Proto)" + description "Denki Blocks! (USA) (En,Es) (Proto)" + rom ( name "Denki Blocks! (USA) (En,Es) (Proto).gbc" size 1048576 crc aafc35c3 sha1 bca594d5d90219b263638dd86a96e3e9a64ce71e ) ) game ( - name "Azure Dreams (USA) (SGB Enhanced) (GB Compatible)" - description "Azure Dreams (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Azure Dreams (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 71d52876 sha1 1ebc365058dbb4d4f7ccad6185f4364d584bf250 ) + name "Denki Blocks! (Europe) (En,Fr,De,Es,It)" + description "Denki Blocks! (Europe) (En,Fr,De,Es,It)" + rom ( name "Denki Blocks! (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 38f00974 sha1 cf4037db23525937e6dceea7343a9ea7a22f928d ) ) game ( - name "B-Daman Bakugaiden - Victory e no Michi (Japan) (SGB Enhanced) (GB Compatible)" - description "B-Daman Bakugaiden - Victory e no Michi (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "B-Daman Bakugaiden - Victory e no Michi (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ddce76d6 sha1 4904102846a5fd0176c6f4bfd421f86fb1fab45b ) + name "Densha de Go! (Japan)" + description "Densha de Go! (Japan)" + rom ( name "Densha de Go! (Japan).gbc" size 4194304 crc 14375072 sha1 9661a5cfa2dc4fedbca1f15b69cf81a3fc7fc097 ) ) game ( - name "B-Daman Bakugaiden V - Final Mega Tune (Japan)" - description "B-Daman Bakugaiden V - Final Mega Tune (Japan)" - rom ( name "B-Daman Bakugaiden V - Final Mega Tune (Japan).gbc" size 2097152 crc 547a9a69 sha1 7933fe70912ee74f14199a149ede69bdb153f4ad ) + name "Densha de Go! 2 (Japan)" + description "Densha de Go! 2 (Japan)" + rom ( name "Densha de Go! 2 (Japan).gbc" size 8388608 crc b72603fc sha1 63bcca7177712a9bc6f032c83c2e129d9b9af0fa flags verified ) ) game ( - name "Babe and Friends (Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "Babe and Friends (Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Babe and Friends (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc b3681854 sha1 52a560185b7e77e5286771f7851f69323512658e flags verified ) + name "Dexter's Laboratory - Robot Rampage (USA, Europe)" + description "Dexter's Laboratory - Robot Rampage (USA, Europe)" + rom ( name "Dexter's Laboratory - Robot Rampage (USA, Europe).gbc" size 1048576 crc d24d6601 sha1 db107af55df07fb8c771c712b05d6aebb175e3c5 flags verified ) ) game ( - name "Babe and Friends (USA) (GB Compatible)" - description "Babe and Friends (USA) (GB Compatible)" - rom ( name "Babe and Friends (USA) (GB Compatible).gbc" size 1048576 crc e25407f1 sha1 51a4fd838903039b60bf5c13677cbea6bbb7d368 ) + name "Digimon - Yellow Jade (USA) (Unl)" + description "Digimon - Yellow Jade (USA) (Unl)" + rom ( name "Digimon - Yellow Jade (USA) (Unl).gbc" size 2097152 crc 96662e76 sha1 743bf9b07245ae5df98898b7794f304ac09d2ed4 ) ) game ( - name "Baby Felix - Halloween (Europe) (En,Fr,De,Es,It,Nl)" - description "Baby Felix - Halloween (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Baby Felix - Halloween (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 7ded5c71 sha1 6c924f693e08e32c0e59f386cd728beb32d00105 ) + name "Digimon 02 4 (Taiwan) (En) (Unl)" + description "Digimon 02 4 (Taiwan) (En) (Unl)" + rom ( name "Digimon 02 4 (Taiwan) (En) (Unl).gbc" size 1048576 crc a90061e9 sha1 0c8280e5349dda05fdd27bb1eb68a1be2f3d5c04 ) ) game ( - name "Back to Earth 3D (Europe) (Demo)" - description "Back to Earth 3D (Europe) (Demo)" - rom ( name "Back to Earth 3D (Europe) (Demo).gbc" size 262144 crc d4255616 sha1 716722ed8756b656bba00cbff116f883e629cfd2 ) + name "Digimon 02 5 (USA) (Unl)" + description "Digimon 02 5 (USA) (Unl)" + rom ( name "Digimon 02 5 (USA) (Unl).gbc" size 1048576 crc 0bcbe728 sha1 f868fecce3bdec242937b93549f4861a0f481065 ) ) game ( - name "Back to Nature (World) (Aftermarket) (Unl)" - description "Back to Nature (World) (Aftermarket) (Unl)" - rom ( name "Back to Nature (World) (Aftermarket) (Unl).gbc" size 262144 crc 861f9a63 sha1 3f4a6cd105d4c8af0312bef482c08784bbbfb0eb ) + name "Digimon 2 (Taiwan) (En) (Unl)" + description "Digimon 2 (Taiwan) (En) (Unl)" + rom ( name "Digimon 2 (Taiwan) (En) (Unl).gbc" size 1048576 crc a43ab22b sha1 8476385e380bee46f19f874dfed91b3aa61bbf66 ) ) game ( - name "Backgammon (Europe) (En,Fr,De,Es) (GB Compatible)" - description "Backgammon (Europe) (En,Fr,De,Es) (GB Compatible)" - rom ( name "Backgammon (Europe) (En,Fr,De,Es) (GB Compatible).gbc" size 1048576 crc d33d6f7b sha1 b634a2980efe1378ecb26a761241d48f4604e5f0 ) + name "Digimon 3 Crystal (Taiwan) (En) (Unl)" + description "Digimon 3 Crystal (Taiwan) (En) (Unl)" + rom ( name "Digimon 3 Crystal (Taiwan) (En) (Unl).gbc" size 1048576 crc fe8bf4e8 sha1 b844ee8f803e48ec786bc6f5d2953af22dda45e2 ) ) game ( - name "Backgammon (Japan) (GB Compatible)" - description "Backgammon (Japan) (GB Compatible)" - rom ( name "Backgammon (Japan) (GB Compatible).gbc" size 1048576 crc 712a49b3 sha1 eb8b70e445174a812044ca5b101bdcb00c389940 ) + name "Digimon Adventure 2001 (USA) (Unl)" + description "Digimon Adventure 2001 (USA) (Unl)" + rom ( name "Digimon Adventure 2001 (USA) (Unl).gbc" size 1048576 crc 01f1fcee sha1 cb4327829bc90c7bb448e7591e6ee3729a12a8cd ) ) game ( - name "Bad Badtz-Maru Robo Battle (Japan)" - description "Bad Badtz-Maru Robo Battle (Japan)" - rom ( name "Bad Badtz-Maru Robo Battle (Japan).gbc" size 2097152 crc 4dd29b09 sha1 da06158a4d3aed781e77a5f69faaf522b0a98cbd ) + name "Digimon Amethyst (USA) (Unl)" + description "Digimon Amethyst (USA) (Unl)" + rom ( name "Digimon Amethyst (USA) (Unl).gbc" size 2097152 crc 726eed2a sha1 0b5f44cc2f583182a91ed8a815a3e7cec3bd1a58 ) ) game ( - name "Baiwan Dafuweng - Jin Ban (Taiwan) (Unl)" - description "Baiwan Dafuweng - Jin Ban (Taiwan) (Unl)" - rom ( name "Baiwan Dafuweng - Jin Ban (Taiwan) (Unl).gbc" size 1048576 crc 518c7a4e sha1 03673aec3060d72982226ed5cdfdf86f31eb70a0 ) + name "Digimon Crystal II (USA) (Unl)" + description "Digimon Crystal II (USA) (Unl)" + rom ( name "Digimon Crystal II (USA) (Unl).gbc" size 2097152 crc 685e76df sha1 4e981044ac3a40d7a9cd63b79d5982b4b4e670a5 ) ) game ( - name "Bakukyuu Renpatsu!! Super B-Daman - Gekitan! Rising Valkyrie!! (Japan) (SGB Enhanced) (GB Compatible)" - description "Bakukyuu Renpatsu!! Super B-Daman - Gekitan! Rising Valkyrie!! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Bakukyuu Renpatsu!! Super B-Daman - Gekitan! Rising Valkyrie!! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 5c95d5a2 sha1 952933a658f0b4182619e7184f49aa4a47fc5f84 flags verified ) + name "Digimon Pocket (Taiwan) (En) (Unl)" + description "Digimon Pocket (Taiwan) (En) (Unl)" + rom ( name "Digimon Pocket (Taiwan) (En) (Unl).gbc" size 524288 crc 6791b106 sha1 87750928d5f005e67e51e4d08a6d82351effc7b2 ) ) game ( - name "Bakusou Dekotora Densetsu GB Special - Otoko Dokyou no Tenka Touitsu (Japan)" - description "Bakusou Dekotora Densetsu GB Special - Otoko Dokyou no Tenka Touitsu (Japan)" - rom ( name "Bakusou Dekotora Densetsu GB Special - Otoko Dokyou no Tenka Touitsu (Japan).gbc" size 1048576 crc 92c8b9b5 sha1 50b115869bb9c488b3766c58ee44de63a84ba489 ) + name "Digimon Pocket (Taiwan) (Zh) (Unl)" + description "Digimon Pocket (Taiwan) (Zh) (Unl)" + rom ( name "Digimon Pocket (Taiwan) (Zh) (Unl).gbc" size 524288 crc 6d39574e sha1 9560dac8eb9d676aeb5f2d92fbb0228cb4ec27cc ) ) game ( - name "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (GB Compatible)" - description "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (GB Compatible)" - rom ( name "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (GB Compatible).gbc" size 1048576 crc d514c9a0 sha1 1f8088a739df180ecceaff1b37ed5c1a50772405 ) + name "Digimon Saphire (USA) (Unl)" + description "Digimon Saphire (USA) (Unl)" + rom ( name "Digimon Saphire (USA) (Unl).gbc" size 1048576 crc be4c1d83 sha1 f5706a80bae20027d7643ab151607adbe13e6b1d ) ) game ( - name "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (Rev 1) (Proto) (GB Compatible)" - description "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (Rev 1) (Proto) (GB Compatible)" - rom ( name "Bakusou Senki Metal Walker GB - Koutetsu no Yuujou (Japan) (Rev 1) (Proto) (GB Compatible).gbc" size 1048576 crc 570bafdb sha1 3d6ea44dd8426e3d7bf87a8778dd91e8095ddd35 ) + name "Digital Monster 2001 (Taiwan) (En) (Unl)" + description "Digital Monster 2001 (Taiwan) (En) (Unl)" + rom ( name "Digital Monster 2001 (Taiwan) (En) (Unl).gbc" size 524288 crc d9eb3f2a sha1 cc7d4a2e5bf1fbee8e0a0e0960f4038fca3e458f ) ) game ( - name "Bakuten Shoot Beyblade (Japan)" - description "Bakuten Shoot Beyblade (Japan)" - rom ( name "Bakuten Shoot Beyblade (Japan).gbc" size 2097152 crc bc306ea4 sha1 68d41bca8d2ac8e9a6855460b15e6045acd341a1 ) + name "Dino Breeder 3 - Gaia Fukkatsu (Japan) (SGB Enhanced) (GB Compatible)" + description "Dino Breeder 3 - Gaia Fukkatsu (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Dino Breeder 3 - Gaia Fukkatsu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc d9f071bb sha1 f571a591a2f4fc4f70897e380fdbe9011be75f8d ) ) game ( - name "Ballistic (USA) (GB Compatible)" - description "Ballistic (USA) (GB Compatible)" - rom ( name "Ballistic (USA) (GB Compatible).gbc" size 524288 crc a9050f72 sha1 28dfdc00ec7e353f4aae4c65d671300c0b97ab90 ) + name "Dino Breeder 4 (Japan) (SGB Enhanced) (GB Compatible)" + description "Dino Breeder 4 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Dino Breeder 4 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b0106777 sha1 b25681defda961837a28be1432076b65574fd1be ) ) game ( - name "Balloon Fight GB (Japan) (SGB Enhanced, GB Compatible) (NP)" - description "Balloon Fight GB (Japan) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Balloon Fight GB (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc d2af64ce sha1 dbaa1bf9061de0f052704d6a33892341a38f2152 ) + name "Dinosaur (Europe) (En,Fr,De,Es,It)" + description "Dinosaur (Europe) (En,Fr,De,Es,It)" + rom ( name "Dinosaur (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 0aa8d0cc sha1 9123d3528bf295c5cba4284ca276af23a32ec725 ) ) game ( - name "Bandits at Zero (World) (Aftermarket) (Unl)" - description "Bandits at Zero (World) (Aftermarket) (Unl)" - rom ( name "Bandits at Zero (World) (Aftermarket) (Unl).gbc" size 524288 crc c70f413e sha1 c885e109fbb53445db9618c6768c2259e6135921 ) + name "Dinosaur (USA)" + description "Dinosaur (USA)" + rom ( name "Dinosaur (USA).gbc" size 2097152 crc 276ecaae sha1 f566c37ab95537d88f6d1ab91804f47f7c0b4027 ) ) game ( - name "Barbie - Aventura Submarina (Spain) (GB Compatible)" - description "Barbie - Aventura Submarina (Spain) (GB Compatible)" - rom ( name "Barbie - Aventura Submarina (Spain) (GB Compatible).gbc" size 1048576 crc 0cf2b7f2 sha1 7b342745f14f0a2245b961cfd6e23d1b2e98c249 ) + name "Dinosaur (USA) (Beta)" + description "Dinosaur (USA) (Beta)" + rom ( name "Dinosaur (USA) (Beta).gbc" size 2097152 crc 0b087fe7 sha1 e8042138b56777733e8e9e397ea084cf61383cd9 ) ) game ( - name "Barbie - Avventure nell'Oceano (Italy) (GB Compatible)" - description "Barbie - Avventure nell'Oceano (Italy) (GB Compatible)" - rom ( name "Barbie - Avventure nell'Oceano (Italy) (GB Compatible).gbc" size 1048576 crc 59645a18 sha1 79ea73d94d2402525c718563b5613bee71b69b44 ) + name "Dinosaur'us (Europe) (En,Fr,De,Es,It,Nl)" + description "Dinosaur'us (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Dinosaur'us (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc f4609fe3 sha1 d0caf4b5172651aee2bbe38efdae084ce3d7a7ff ) ) game ( - name "Barbie - Chasse au Tresor Sous-Marine (France) (GB Compatible)" - description "Barbie - Chasse au Tresor Sous-Marine (France) (GB Compatible)" - rom ( name "Barbie - Chasse au Tresor Sous-Marine (France) (GB Compatible).gbc" size 1048576 crc 4068e981 sha1 bc44d39cce1f3143e9fa830ede2b4126a4d61b54 ) + name "Diva Starz (Europe)" + description "Diva Starz (Europe)" + rom ( name "Diva Starz (Europe).gbc" size 1048576 crc 4476e79f sha1 9ae754470a116555373a47eae0fe611160219925 ) ) game ( - name "Barbie - Diepzee Avontuur (Netherlands) (GB Compatible)" - description "Barbie - Diepzee Avontuur (Netherlands) (GB Compatible)" - rom ( name "Barbie - Diepzee Avontuur (Netherlands) (GB Compatible).gbc" size 1048576 crc 39c6b8df sha1 3e93df9512819679deac989895de398a6159645c flags verified ) + name "Diva Starz (France)" + description "Diva Starz (France)" + rom ( name "Diva Starz (France).gbc" size 1048576 crc fc1b36d1 sha1 fcbfbef077feec07f93b867de5b537f45812d5a4 ) ) game ( - name "Barbie - Fashion Pack Games (USA, Europe) (GB Compatible)" - description "Barbie - Fashion Pack Games (USA, Europe) (GB Compatible)" - rom ( name "Barbie - Fashion Pack Games (USA, Europe) (GB Compatible).gbc" size 1048576 crc 09ee93a8 sha1 fecbde9125d2ce9c8e772f9078ebaccd196caa43 ) + name "Diva Starz (Germany)" + description "Diva Starz (Germany)" + rom ( name "Diva Starz (Germany).gbc" size 1048576 crc 56095f86 sha1 286d16d697caa2dfc1ebcad88a9633dd45c20e67 flags verified ) ) game ( - name "Barbie - Magic Genie Adventure (USA)" - description "Barbie - Magic Genie Adventure (USA)" - rom ( name "Barbie - Magic Genie Adventure (USA).gbc" size 1048576 crc 57f1a202 sha1 30e779f19cd8f8c979bda38dd90e9798c742a66c ) + name "Diva Starz - Mall Mania (USA)" + description "Diva Starz - Mall Mania (USA)" + rom ( name "Diva Starz - Mall Mania (USA).gbc" size 1048576 crc ebe0ecd6 sha1 1d0edb87404409f1e4c124503be4cc59165c01da ) ) game ( - name "Barbie - Meeres Abenteuer (Germany) (GB Compatible)" - description "Barbie - Meeres Abenteuer (Germany) (GB Compatible)" - rom ( name "Barbie - Meeres Abenteuer (Germany) (GB Compatible).gbc" size 1048576 crc 5e46d64a sha1 c392aefb3d657cae6602e285f5fb57ec079a818e ) + name "Dogz (Europe)" + description "Dogz (Europe)" + rom ( name "Dogz (Europe).gbc" size 1048576 crc ce8dd179 sha1 ad1e238f180eaa55b4c76cd39a03a88f28dc9649 ) ) game ( - name "Barbie - Ocean Discovery (United Kingdom) (GB Compatible)" - description "Barbie - Ocean Discovery (United Kingdom) (GB Compatible)" - rom ( name "Barbie - Ocean Discovery (United Kingdom) (GB Compatible).gbc" size 1048576 crc fdc8e7f1 sha1 c0c37864e17f11fffa8b8a61a0abe4b2b80c235c ) + name "Dogz (USA)" + description "Dogz (USA)" + rom ( name "Dogz (USA).gbc" size 1048576 crc a8397183 sha1 d0d4c661e2ced3664ff07b15f2fb2c57a63d2dad ) ) game ( - name "Barbie - Ocean Discovery (USA) (GB Compatible)" - description "Barbie - Ocean Discovery (USA) (GB Compatible)" - rom ( name "Barbie - Ocean Discovery (USA) (GB Compatible).gbc" size 1048576 crc 746936c6 sha1 fab988692a19d53e71fc754dea3a01506b104d9f ) + name "Dokapon! - Millennium Quest (Japan) (SGB Enhanced) (GB Compatible)" + description "Dokapon! - Millennium Quest (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Dokapon! - Millennium Quest (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4fe9e966 sha1 2ac27b1f9b8821fcf1cb4bf347156e29dcde689c ) ) game ( - name "Barbie - Pet Rescue (Europe) (En,Fr,De,Es,It)" - description "Barbie - Pet Rescue (Europe) (En,Fr,De,Es,It)" - rom ( name "Barbie - Pet Rescue (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 48e638ce sha1 191a42e0eaf6afb58bc8aaca0ee8dad0641594d4 ) + name "Doki x Doki Sasete!! (Japan)" + description "Doki x Doki Sasete!! (Japan)" + rom ( name "Doki x Doki Sasete!! (Japan).gbc" size 2097152 crc 19a73f60 sha1 d2d424bdd151222aa8316db1fd1df2cafcb3a15d ) ) game ( - name "Barbie - Pet Rescue (USA)" - description "Barbie - Pet Rescue (USA)" - rom ( name "Barbie - Pet Rescue (USA).gbc" size 1048576 crc 1fc972cc sha1 ffed44ab063c4181d5df85ff1304de10fa6392cd ) + name "Dokidoki Densetsu - Mahoujin Guruguru (Japan)" + description "Dokidoki Densetsu - Mahoujin Guruguru (Japan)" + rom ( name "Dokidoki Densetsu - Mahoujin Guruguru (Japan).gbc" size 4194304 crc 83e47a1a sha1 1b4627699b45af36a42e75c1a217b40fb5bec4ba ) ) game ( - name "Barca Total 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca)" - description "Barca Total 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca)" - rom ( name "Barca Total 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca).gbc" size 1048576 crc cd15ed36 sha1 24b8f400d74e9f0aa82d27d82a3b15db3e743240 ) + name "Donald Duck - Daisy o Sukue! (Japan)" + description "Donald Duck - Daisy o Sukue! (Japan)" + rom ( name "Donald Duck - Daisy o Sukue! (Japan).gbc" size 4194304 crc 333c124c sha1 46ecfe890cb225563bcd45f8607962840b5fd587 ) ) game ( - name "Barcode Taisen Bardigun (Japan) (SGB Enhanced) (GB Compatible)" - description "Barcode Taisen Bardigun (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Barcode Taisen Bardigun (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ddfcf4b7 sha1 bc7847dee730ba274f3c3ccb511f1dad6b6a93c7 flags verified ) + name "Donald Duck - Goin' Quackers (USA) (En,Fr,De,Es,It)" + description "Donald Duck - Goin' Quackers (USA) (En,Fr,De,Es,It)" + rom ( name "Donald Duck - Goin' Quackers (USA) (En,Fr,De,Es,It).gbc" size 4194304 crc 4685909b sha1 f2fa670fd20485b3bc1875dc8d31fb40374942bd ) ) game ( - name "Barcode Taisen Bardigun (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Barcode Taisen Bardigun (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Barcode Taisen Bardigun (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f6d291a9 sha1 21e386f60fcd3694c4a308de9e178762c5175b6c flags verified ) + name "Donald Duck - Quack Attack (Europe) (En,Fr,De,Es,It)" + description "Donald Duck - Quack Attack (Europe) (En,Fr,De,Es,It)" + rom ( name "Donald Duck - Quack Attack (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 07a13b5b sha1 946e473ad7f363295f2c4bb488618f2325f51004 flags verified ) ) game ( - name "Bass Masters Classic (USA, Europe) (GB Compatible)" - description "Bass Masters Classic (USA, Europe) (GB Compatible)" - rom ( name "Bass Masters Classic (USA, Europe) (GB Compatible).gbc" size 1048576 crc b70028e4 sha1 b1bd238640e99e3584c8c4e4fa174ff144b600d6 ) + name "Donkey Kong 2001 (Japan)" + description "Donkey Kong 2001 (Japan)" + rom ( name "Donkey Kong 2001 (Japan).gbc" size 4194304 crc cb065eba sha1 5be5500d9ff9c4416df77816ebd21cca7a0b19de flags verified ) ) game ( - name "Batman - Chaos in Gotham (Europe) (En,Fr,De,Es,It,Nl)" - description "Batman - Chaos in Gotham (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Batman - Chaos in Gotham (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc e025067b sha1 dbc6c729dde21abf324e2a055d819f088e696c0c ) + name "Donkey Kong 5 - The Journey of Over Time and Space (Taiwan) (En) (Unl)" + description "Donkey Kong 5 - The Journey of Over Time and Space (Taiwan) (En) (Unl)" + rom ( name "Donkey Kong 5 - The Journey of Over Time and Space (Taiwan) (En) (Unl).gbc" size 2097152 crc 1a369dd5 sha1 1ff1ac88dea7431866016970c4f4ae049302201b ) ) game ( - name "Batman - Chaos in Gotham (USA)" - description "Batman - Chaos in Gotham (USA)" - rom ( name "Batman - Chaos in Gotham (USA).gbc" size 1048576 crc b241a4f3 sha1 de2d6a53316011b60fbc9a946f510effe42ede5e ) + name "Donkey Kong Country (USA) (En,Fr,De,Es,It) (Demo) (Kiosk)" + description "Donkey Kong Country (USA) (En,Fr,De,Es,It) (Demo) (Kiosk)" + rom ( name "Donkey Kong Country (USA) (En,Fr,De,Es,It) (Demo) (Kiosk).gbc" size 4194304 crc 080605a3 sha1 38fedd71736d258e31d3062864d28449e7c3f1c5 ) ) game ( - name "Batman Beyond - Return of the Joker (Japan) (NP)" - description "Batman Beyond - Return of the Joker (Japan) (NP)" - rom ( name "Batman Beyond - Return of the Joker (Japan) (NP).gbc" size 1048576 crc b8b1f8f8 sha1 47c8a56fa67d4982ed36fca56ef0f33c451a0c49 ) + name "Donkey Kong Country (USA, Europe) (En,Fr,De,Es,It)" + description "Donkey Kong Country (USA, Europe) (En,Fr,De,Es,It)" + rom ( name "Donkey Kong Country (USA, Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc b1743477 sha1 32522dfce902d564e69348541348afc054307f65 flags verified ) ) game ( - name "Batman Beyond - Return of the Joker (USA)" - description "Batman Beyond - Return of the Joker (USA)" - rom ( name "Batman Beyond - Return of the Joker (USA).gbc" size 1048576 crc b32f4586 sha1 8c69eb7ec5bc809edc8caa255576f919ea722dad ) + name "Donkey Kong GB - Dinky Kong & Dixie Kong (Japan)" + description "Donkey Kong GB - Dinky Kong & Dixie Kong (Japan)" + rom ( name "Donkey Kong GB - Dinky Kong & Dixie Kong (Japan).gbc" size 1048576 crc 28d7e8d3 sha1 55b133b739a5472d477336647cb9ec97b7fa85a2 flags verified ) ) game ( - name "Batman of the Future - Return of the Joker (Europe) (En,Fr,De)" - description "Batman of the Future - Return of the Joker (Europe) (En,Fr,De)" - rom ( name "Batman of the Future - Return of the Joker (Europe) (En,Fr,De).gbc" size 1048576 crc f9d5b399 sha1 102aa62c873b7316b1b019d895989dcdedb776a9 ) + name "Doraemon - Aruke Aruke Labyrinth (Japan) (GB Compatible)" + description "Doraemon - Aruke Aruke Labyrinth (Japan) (GB Compatible)" + rom ( name "Doraemon - Aruke Aruke Labyrinth (Japan) (GB Compatible).gbc" size 1048576 crc f6d79a79 sha1 f825279feec357baba2b39423aa596ce02e34921 ) ) game ( - name "Battle Fishers (Japan)" - description "Battle Fishers (Japan)" - rom ( name "Battle Fishers (Japan).gbc" size 2097152 crc c99cf3c5 sha1 25d063b151c2d45a14d6952196490615b7e341c5 ) + name "Doraemon - Kimi to Pet no Monogatari (Japan) (GB Compatible)" + description "Doraemon - Kimi to Pet no Monogatari (Japan) (GB Compatible)" + rom ( name "Doraemon - Kimi to Pet no Monogatari (Japan) (GB Compatible).gbc" size 1048576 crc 2fa46211 sha1 1fb01a4a492243c1768bdbf5db88fd95d0cc4f59 ) ) game ( - name "Battle Star (World) (Aftermarket) (Unl)" - description "Battle Star (World) (Aftermarket) (Unl)" - rom ( name "Battle Star (World) (Aftermarket) (Unl).gbc" size 524288 crc b2fd062f sha1 ac4206129704e31386c9c0a1c961a148398f0ba3 ) + name "Doraemon Kart 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Doraemon Kart 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Doraemon Kart 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc cf1a2038 sha1 b29695b9944c030c518140341d748d1a1f21f982 ) ) game ( - name "Battleship (USA, Europe) (GB Compatible)" - description "Battleship (USA, Europe) (GB Compatible)" - rom ( name "Battleship (USA, Europe) (GB Compatible).gbc" size 1048576 crc 8e6f8037 sha1 48a6cc9c5695378a118deb6b1035c15a26d476d7 flags verified ) + name "Doraemon Memories - Nobita no Omoide Daibouken (Japan) (GB Compatible)" + description "Doraemon Memories - Nobita no Omoide Daibouken (Japan) (GB Compatible)" + rom ( name "Doraemon Memories - Nobita no Omoide Daibouken (Japan) (GB Compatible).gbc" size 1048576 crc d187cec4 sha1 3152a167021ff536186051c42c6e8f131d72ad41 ) ) game ( - name "BattleTanx (Europe) (En,Fr,De)" - description "BattleTanx (Europe) (En,Fr,De)" - rom ( name "BattleTanx (Europe) (En,Fr,De).gbc" size 1048576 crc 2fcecb70 sha1 d9f52594f79257dc616428a694c1f2c808797361 ) + name "Doraemon no Quiz Boy (Japan)" + description "Doraemon no Quiz Boy (Japan)" + rom ( name "Doraemon no Quiz Boy (Japan).gbc" size 1048576 crc 3bbf9ea8 sha1 fd05adb1a6face86ff263883fdf4cebf14e055e9 ) ) game ( - name "BattleTanx (USA)" - description "BattleTanx (USA)" - rom ( name "BattleTanx (USA).gbc" size 1048576 crc 4431f8e7 sha1 5078584e86c0b6f4687c424cc00bbd762ba6573a ) + name "Doraemon no Quiz Boy (Japan) (Rev 1)" + description "Doraemon no Quiz Boy (Japan) (Rev 1)" + rom ( name "Doraemon no Quiz Boy (Japan) (Rev 1).gbc" size 1048576 crc 915356e3 sha1 ae48f07e608d76143a4a51f18f9454cd990d766a flags verified ) ) game ( - name "Beach'n Ball (Europe) (En,Fr,De,Es,It)" - description "Beach'n Ball (Europe) (En,Fr,De,Es,It)" - rom ( name "Beach'n Ball (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 82d1a721 sha1 90c0ab55136235d75a4e35bd5b0d90a99d2a42c4 ) + name "Doraemon no Quiz Boy 2 (Japan)" + description "Doraemon no Quiz Boy 2 (Japan)" + rom ( name "Doraemon no Quiz Boy 2 (Japan).gbc" size 1048576 crc 9e80199a sha1 c6b5ffc4b8f7c106807ed7e2c72e37090d3faa97 flags verified ) ) game ( - name "Beach'n Ball (Europe) (En,Fr,De,Es,It) (Beta) (2000-11-21)" - description "Beach'n Ball (Europe) (En,Fr,De,Es,It) (Beta) (2000-11-21)" - rom ( name "Beach'n Ball (Europe) (En,Fr,De,Es,It) (Beta) (2000-11-21).gbc" size 1048576 crc a56180a8 sha1 faaf82512ad3f5429acf401d9e74d7016252e263 ) + name "Doraemon no Study Boy - Gakushuu Kanji Game (Japan)" + description "Doraemon no Study Boy - Gakushuu Kanji Game (Japan)" + rom ( name "Doraemon no Study Boy - Gakushuu Kanji Game (Japan).gbc" size 1048576 crc 67413f65 sha1 1f8aad0fc2a8d03244c69f3a6d80af1a21164ddc flags verified ) ) game ( - name "Beast Fighter (Taiwan) (En) (Sachen) (Unl)" - description "Beast Fighter (Taiwan) (En) (Sachen) (Unl)" - rom ( name "Beast Fighter (Taiwan) (En) (Sachen) (Unl).gbc" size 131072 crc 0bc7a3c6 sha1 bb76bc7ea3482e775efdbbf112455921d11ac317 ) + name "Doraemon no Study Boy - Kanji Yomikaki Master (Japan)" + description "Doraemon no Study Boy - Kanji Yomikaki Master (Japan)" + rom ( name "Doraemon no Study Boy - Kanji Yomikaki Master (Japan).gbc" size 1048576 crc 70156da7 sha1 4b7ec303305daed053243b125a9aebc44f3e221e flags verified ) ) game ( - name "Beatmania GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Beatmania GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Beatmania GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0d9cb195 sha1 640c4633fe8ec60b767c15a094c87ab7e113d555 flags verified ) + name "Doraemon no Study Boy - Kuku Game (Japan)" + description "Doraemon no Study Boy - Kuku Game (Japan)" + rom ( name "Doraemon no Study Boy - Kuku Game (Japan).gbc" size 1048576 crc a8a353d8 sha1 9b5c8b89b6e69d3803fbd43b2fe5130ad6d2f50b ) ) game ( - name "Beatmania GB - Gotcha Mix 2 (Japan)" - description "Beatmania GB - Gotcha Mix 2 (Japan)" - rom ( name "Beatmania GB - Gotcha Mix 2 (Japan).gbc" size 2097152 crc b92a6d16 sha1 dcd054d461cde099df09ed61a77b05fbacd7af0b ) + name "Doug - La Grande Aventure (France)" + description "Doug - La Grande Aventure (France)" + rom ( name "Doug - La Grande Aventure (France).gbc" size 1048576 crc a9e62f1a sha1 818804e3bc300b0a027a4e34055412c58d73f05e ) ) game ( - name "Beatmania GB 2 - Gotcha Mix (Japan) (SGB Enhanced) (GB Compatible)" - description "Beatmania GB 2 - Gotcha Mix (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Beatmania GB 2 - Gotcha Mix (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 59beb372 sha1 b6273c434e880d6f9b5f4f6f53307bda9902fff1 ) + name "Doug's Big Game (Germany)" + description "Doug's Big Game (Germany)" + rom ( name "Doug's Big Game (Germany).gbc" size 1048576 crc 5dc254d1 sha1 df95173e91cd83bf7cb617629541c815e1ad3577 flags verified ) ) game ( - name "Beauty and the Beast - A Board Game Adventure (Europe) (En,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" - description "Beauty and the Beast - A Board Game Adventure (Europe) (En,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" - rom ( name "Beauty and the Beast - A Board Game Adventure (Europe) (En,Fr,De,Es,It) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e4c410f0 sha1 2dd29d52972948724f989008f7896d0adcba67c4 flags verified ) + name "Doug's Big Game (USA)" + description "Doug's Big Game (USA)" + rom ( name "Doug's Big Game (USA).gbc" size 1048576 crc 08e3d065 sha1 be8b0f966a43954084244ccd636ad3bb5a8b721c ) ) game ( - name "Beauty and the Beast - A Board Game Adventure (USA, Australia) (SGB Enhanced) (GB Compatible)" - description "Beauty and the Beast - A Board Game Adventure (USA, Australia) (SGB Enhanced) (GB Compatible)" - rom ( name "Beauty and the Beast - A Board Game Adventure (USA, Australia) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6de1d581 sha1 6d389c7aff887d7ffe3739e78753cf81cc71d04c ) + name "Doug's Big Game (Europe)" + description "Doug's Big Game (Europe)" + rom ( name "Doug's Big Game (Europe).gbc" size 1048576 crc b6ffbcca sha1 e9c207bb9b03b5762afd53c8f5295703cc1474b1 ) ) game ( - name "Benjamin Bluemchen - Ein verrueckter Tag im Zoo (Germany)" - description "Benjamin Bluemchen - Ein verrueckter Tag im Zoo (Germany)" - rom ( name "Benjamin Bluemchen - Ein verrueckter Tag im Zoo (Germany).gbc" size 2097152 crc 51972995 sha1 560fc8468ed559a72087f630eff015ffb8de22ca ) + name "Dr. Rin ni Kiitemite! - Koi no Rin Fuusui (Japan)" + description "Dr. Rin ni Kiitemite! - Koi no Rin Fuusui (Japan)" + rom ( name "Dr. Rin ni Kiitemite! - Koi no Rin Fuusui (Japan).gbc" size 2097152 crc ec168a61 sha1 7810ea39edd661d2a9e95f57c9847d7e5a172ff6 flags verified ) ) game ( - name "Berks (World) (Aftermarket) (Unl)" - description "Berks (World) (Aftermarket) (Unl)" - rom ( name "Berks (World) (Aftermarket) (Unl).gbc" size 262144 crc 10ded9ab sha1 8b4c282cf973cdd9926a69ae1d8fcbaf79f8552b ) + name "Dracula - Crazy Vampire (Europe) (En,Fr,De,Es,It)" + description "Dracula - Crazy Vampire (Europe) (En,Fr,De,Es,It)" + rom ( name "Dracula - Crazy Vampire (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 2f7aef51 sha1 815f252f761e0fd3f29b7acf32b2360264aefab1 flags verified ) ) game ( - name "Beyblade - Fighting Tournament (Japan)" - description "Beyblade - Fighting Tournament (Japan)" - rom ( name "Beyblade - Fighting Tournament (Japan).gbc" size 2097152 crc 1ec9db95 sha1 aca5562c6747bc2f127ada53f853b099ed6e12cd ) + name "Dracula - Crazy Vampire (USA)" + description "Dracula - Crazy Vampire (USA)" + rom ( name "Dracula - Crazy Vampire (USA).gbc" size 1048576 crc 283742e4 sha1 049727b428b01c5309a86039007c97bed7bf856a ) ) game ( - name "Bibi Blocksberg - Im Bann der Hexenkugel (Germany)" - description "Bibi Blocksberg - Im Bann der Hexenkugel (Germany)" - rom ( name "Bibi Blocksberg - Im Bann der Hexenkugel (Germany).gbc" size 1048576 crc 4d39fbfe sha1 1e26308ba5ee640540430a0b02d5f30e3be38832 ) + name "Dragon Ball - Final Bout (Taiwan) (Unl)" + description "Dragon Ball - Final Bout (Taiwan) (Unl)" + rom ( name "Dragon Ball - Final Bout (Taiwan) (Unl).gbc" size 1048576 crc 039079bd sha1 682b1be82eccb9044fc61af689c39d07fa325fec ) ) game ( - name "Bibi und Tina - Fohlen Felix in Gefahr (Germany)" - description "Bibi und Tina - Fohlen Felix in Gefahr (Germany)" - rom ( name "Bibi und Tina - Fohlen Felix in Gefahr (Germany).gbc" size 1048576 crc 8874acd4 sha1 59843ced1e9cbcb02c6acbb8f533ec77b314882c flags verified ) + name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta) (All Unlocked)" + description "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta) (All Unlocked)" + rom ( name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta) (All Unlocked).gbc" size 2097152 crc fb942e08 sha1 075f4a1498d0b5f98f76984aca52ca1f03b1f85d ) ) game ( - name "BIG2SMALL (World) (Digital) (GB Compatible) (Aftermarket) (Unl)" - description "BIG2SMALL (World) (Digital) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "BIG2SMALL (World) (Digital) (GB Compatible) (Aftermarket) (Unl).gbc" size 65536 crc b0401d96 sha1 ee5f2db597bb2fa06efe4a279a887b97bf23cac6 ) + name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta)" + description "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta)" + rom ( name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta).gbc" size 2097152 crc 3f511f57 sha1 45f5a6fa7eff38b1bb8786472d0eeadf58f692a8 ) ) game ( - name "Bikkuriman 2000 - Charging Card GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Bikkuriman 2000 - Charging Card GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Bikkuriman 2000 - Charging Card GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 5be2517c sha1 c3c608f1b3581a070c9b7eb65b6fb6d1b72d98d3 ) + name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan)" + description "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan)" + rom ( name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan).gbc" size 2097152 crc 7d28689a sha1 b094ae04fe665371cf0f5cb6942a67a379e8e645 ) ) game ( - name "Billiard Club (Japan) (Proto)" - description "Billiard Club (Japan) (Proto)" - rom ( name "Billiard Club (Japan) (Proto).gbc" size 1048576 crc 210c4137 sha1 eb994e523550a8a7fe8a77fd2e85de011bec8627 ) + name "Dragon Ball Z - Guerreros de Leyenda (Spain)" + description "Dragon Ball Z - Guerreros de Leyenda (Spain)" + rom ( name "Dragon Ball Z - Guerreros de Leyenda (Spain).gbc" size 2097152 crc 9dad6e23 sha1 0318fa8930608cbf4dc69a8b6e2a41c96a51ea04 ) ) game ( - name "Billy Bob's Huntin' 'n' Fishin' (USA, Europe)" - description "Billy Bob's Huntin' 'n' Fishin' (USA, Europe)" - rom ( name "Billy Bob's Huntin' 'n' Fishin' (USA, Europe).gbc" size 1048576 crc fa1e6853 sha1 9331fb3103a23340192968715adaa1e4ef140329 flags verified ) + name "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta) (All Unlocked)" + description "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta) (All Unlocked)" + rom ( name "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta) (All Unlocked).gbc" size 2097152 crc d7654e34 sha1 ac3b5f50578210a29ce08e7e89d456cfc16b5ae9 ) ) game ( - name "Binary Monster 2 (Taiwan) (En) (Unl)" - description "Binary Monster 2 (Taiwan) (En) (Unl)" - rom ( name "Binary Monster 2 (Taiwan) (En) (Unl).gbc" size 131072 crc 16297b29 sha1 bccc7bd374166171f4961b8773bb881050b8a62d ) + name "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta)" + description "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta)" + rom ( name "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta).gbc" size 2097152 crc f017924f sha1 ad8235817bec5165a16478301cbfa7fa7d090ecf ) ) game ( - name "Bingyuan Lixian Ji (Taiwan) (Unl)" - description "Bingyuan Lixian Ji (Taiwan) (Unl)" - rom ( name "Bingyuan Lixian Ji (Taiwan) (Unl).gbc" size 2097152 crc 7ca57891 sha1 1bebc84f0fbfa731f33343c56032c8fe5803e4ae ) + name "Dragon Ball Z - I Leggendari Super Guerrieri (Italy) (Beta) (All Unlocked)" + description "Dragon Ball Z - I Leggendari Super Guerrieri (Italy) (Beta) (All Unlocked)" + rom ( name "Dragon Ball Z - I Leggendari Super Guerrieri (Italy) (Beta) (All Unlocked).gbc" size 2097152 crc 35790637 sha1 621571759c021b564339efdc969d9bcef4c908dc ) ) game ( - name "Bingyuan Lixian Ji II (Taiwan) (Unl) (Alt)" - description "Bingyuan Lixian Ji II (Taiwan) (Unl) (Alt)" - rom ( name "Bingyuan Lixian Ji II (Taiwan) (Unl) (Alt).gbc" size 2097152 crc b149f421 sha1 39060bd6fa872738ae126b64f123a1242d06680a ) + name "Dragon Ball Z - I Leggendari Super Guerrieri (Italy)" + description "Dragon Ball Z - I Leggendari Super Guerrieri (Italy)" + rom ( name "Dragon Ball Z - I Leggendari Super Guerrieri (Italy).gbc" size 2097152 crc a888a049 sha1 56dee34337a8893097cbffd7ea8aff76caef92d0 flags verified ) ) game ( - name "Bingyuan Lixian Ji II (Taiwan) (Unl)" - description "Bingyuan Lixian Ji II (Taiwan) (Unl)" - rom ( name "Bingyuan Lixian Ji II (Taiwan) (Unl).gbc" size 2097152 crc c4eba914 sha1 9e1c0c019630d7e4884ad3d5a447bd1acf668277 ) + name "Dragon Ball Z - Legendaere Superkaempfer (Germany)" + description "Dragon Ball Z - Legendaere Superkaempfer (Germany)" + rom ( name "Dragon Ball Z - Legendaere Superkaempfer (Germany).gbc" size 2097152 crc ec7dfdc1 sha1 8eb99e87c58a471b9af5f91b2aeab2bf4ec516d9 flags verified ) ) game ( - name "Biohazard Gaiden (Japan)" - description "Biohazard Gaiden (Japan)" - rom ( name "Biohazard Gaiden (Japan).gbc" size 2097152 crc c2531d36 sha1 09ca57fedc0c876f6c172e0dc73d616a6d66ea69 ) + name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 1)" + description "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 1)" + rom ( name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 1).gbc" size 2097152 crc 276f7895 sha1 3e2ba8228b0e804f2e581af5cc1e4bb95a8c9354 ) ) game ( - name "Bionic Commando - Elite Forces (USA, Australia)" - description "Bionic Commando - Elite Forces (USA, Australia)" - rom ( name "Bionic Commando - Elite Forces (USA, Australia).gbc" size 2097152 crc a663cf31 sha1 33c28a2183f8b95cc2d8e0b6a0b005bfc230f1fc flags verified ) + name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 2)" + description "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 2)" + rom ( name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 2).gbc" size 2097152 crc 2353bbe4 sha1 b93c142b6da94c7d69956011ccbda9f22e5fae9f ) ) game ( - name "Bitterroot (World) (En) (GB Compatible) (Aftermarket) (Unl)" - description "Bitterroot (World) (En) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Bitterroot (World) (En) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 0d464785 sha1 790b9d231f6e66027e76264ef646c7a7cb9c878c ) + name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3) (All Unlocked)" + description "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3) (All Unlocked)" + rom ( name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3) (All Unlocked).gbc" size 2097152 crc f646bd3b sha1 08a947763c36f4ad64f51c388da863d5852540a1 ) ) game ( - name "Bitterroot (World) (Es) (GB Compatible) (Aftermarket) (Unl)" - description "Bitterroot (World) (Es) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Bitterroot (World) (Es) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 936443e2 sha1 b874c45d4866d5ef0c0d9837502ae42dd0ea3787 ) + name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3)" + description "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3)" + rom ( name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3).gbc" size 2097152 crc 72acbcb4 sha1 4b22b1949aed367036a84e0e7d36dd0a57bdd11f ) ) game ( - name "Black Bass - Lure Fishing (USA, Europe) (GB Compatible)" - description "Black Bass - Lure Fishing (USA, Europe) (GB Compatible)" - rom ( name "Black Bass - Lure Fishing (USA, Europe) (GB Compatible).gbc" size 1048576 crc e44977dc sha1 0e8d93cd183a53aba67780372c71cca71e92a9c1 flags verified ) + name "Dragon Ball Z - Legendary Super Warriors (Europe) (Beta) (All Unlocked)" + description "Dragon Ball Z - Legendary Super Warriors (Europe) (Beta) (All Unlocked)" + rom ( name "Dragon Ball Z - Legendary Super Warriors (Europe) (Beta) (All Unlocked).gbc" size 2097152 crc 4ec4f8ed sha1 073eb096c0454032d8632549ad4c60adc5b8cf9a ) ) game ( - name "Black Onyx, The (Japan)" - description "Black Onyx, The (Japan)" - rom ( name "Black Onyx, The (Japan).gbc" size 1048576 crc 582fe338 sha1 b0f009023a25e575b59e55dec07cda2826f48b65 ) + name "Dragon Ball Z - Legendary Super Warriors (Europe)" + description "Dragon Ball Z - Legendary Super Warriors (Europe)" + rom ( name "Dragon Ball Z - Legendary Super Warriors (Europe).gbc" size 2097152 crc 7bf836db sha1 c190d34beac5157e98076d6a94ffa3033579b7a2 ) ) game ( - name "Black Tape (World) (GB Compatible) (Aftermarket) (Unl)" - description "Black Tape (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Black Tape (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 45c5f990 sha1 ec8c467e955d69b2084805f11a954e0d90855461 ) + name "Dragon Ball Z - Legendary Super Warriors (USA)" + description "Dragon Ball Z - Legendary Super Warriors (USA)" + rom ( name "Dragon Ball Z - Legendary Super Warriors (USA).gbc" size 2097152 crc 025aa88a sha1 e8184e1ae44d744aa54a082bd9979a46e144e6fb flags verified ) ) game ( - name "Blade (USA, Europe)" - description "Blade (USA, Europe)" - rom ( name "Blade (USA, Europe).gbc" size 1048576 crc 2dd5907f sha1 aaad2f4ed8dbb4455704896f8ff0bc70e7d50b65 flags verified ) + name "Dragon Ball Z - Les Guerriers Legendaires (France)" + description "Dragon Ball Z - Les Guerriers Legendaires (France)" + rom ( name "Dragon Ball Z - Les Guerriers Legendaires (France).gbc" size 2097152 crc c07e9438 sha1 f5f0bc375f4559c9a0d62b52afd2eee18273c193 ) ) game ( - name "Blaster Master - Enemy Below (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Blaster Master - Enemy Below (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Blaster Master - Enemy Below (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 2f91e17c sha1 8b2e83d7f2b7d72d5cc1ac81c28c2173ad2fc9ba ) + name "Dragon Ball Z - Les Guerriers Legendaires (France) (Beta) (All Unlocked)" + description "Dragon Ball Z - Les Guerriers Legendaires (France) (Beta) (All Unlocked)" + rom ( name "Dragon Ball Z - Les Guerriers Legendaires (France) (Beta) (All Unlocked).gbc" size 2097152 crc f4041d28 sha1 72e25b25b9f2516879648e0051bb8ad8d4069003 ) ) game ( - name "Blaze (World) (Aftermarket) (Unl)" - description "Blaze (World) (Aftermarket) (Unl)" - rom ( name "Blaze (World) (Aftermarket) (Unl).gbc" size 262144 crc 7d2519c7 sha1 f9b1422a91cc1f3a55526ef8ba81b7a8297fc55e ) + name "Dragon Ball Z 3 - 2002 Fighting (Taiwan) (En) (Unl)" + description "Dragon Ball Z 3 - 2002 Fighting (Taiwan) (En) (Unl)" + rom ( name "Dragon Ball Z 3 - 2002 Fighting (Taiwan) (En) (Unl).gbc" size 2097152 crc dbe0f44e sha1 baea9e5ee1411988039d563ece97d8d7f765396a ) ) game ( - name "Blinky's Revenge (World) (Aftermarket) (Unl)" - description "Blinky's Revenge (World) (Aftermarket) (Unl)" - rom ( name "Blinky's Revenge (World) (Aftermarket) (Unl).gbc" size 262144 crc 2d2f9c2b sha1 1c39cc02396c74e7b0b282ead510e94c77ff7f1e ) + name "Dragon Ball Z Gedou 2005 (Taiwan) (Unl)" + description "Dragon Ball Z Gedou 2005 (Taiwan) (Unl)" + rom ( name "Dragon Ball Z Gedou 2005 (Taiwan) (Unl).gbc" size 2097152 crc d1c48145 sha1 8637ed614dc94e846c32adbc723e09a06b3da3ce ) ) game ( - name "Blue's Clues - Blue's Alphabet Book (USA) (Rev 1) (Proto)" - description "Blue's Clues - Blue's Alphabet Book (USA) (Rev 1) (Proto)" - rom ( name "Blue's Clues - Blue's Alphabet Book (USA) (Rev 1) (Proto).gbc" size 1048576 crc f89f58b7 sha1 7fdedfe8acde9557a5ff57661ed17082813e09a1 ) + name "Dragon Dance (USA) (SGB Enhanced) (GB Compatible)" + description "Dragon Dance (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Dance (USA) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 0602dbe1 sha1 a28bfabc4db62ad5aa6bfe29114b0878429586cc ) ) game ( - name "Blue's Clues - Blue's Alphabet Book (USA)" - description "Blue's Clues - Blue's Alphabet Book (USA)" - rom ( name "Blue's Clues - Blue's Alphabet Book (USA).gbc" size 1048576 crc 748d1345 sha1 f703b54746cb2ef08deba2518ce7b7a3836142aa ) + name "Dragon Dance (Europe) (Proto) (SGB Enhanced) (GB Compatible)" + description "Dragon Dance (Europe) (Proto) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Dance (Europe) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 8b0dd3b2 sha1 76de183317c952276dbdad9d8f0592493652f31e ) ) game ( - name "Board (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Board (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Board (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 440a2260 sha1 8472981264122ea588d991628c51020545779926 ) + name "Dragon Dance (USA) (Beta 1) (SGB Enhanced) (GB Compatible)" + description "Dragon Dance (USA) (Beta 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Dance (USA) (Beta 1) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc a0cd0ed7 sha1 7df48e776ce2be88f7a9459530b855cef2f012b6 ) ) game ( - name "Boarder Zone (USA)" - description "Boarder Zone (USA)" - rom ( name "Boarder Zone (USA).gbc" size 2097152 crc a7152869 sha1 116020a7c2d87ed16436e7710cfed7a93e81289a ) + name "Dragon Dance (USA) (Beta 2) (SGB Enhanced) (GB Compatible)" + description "Dragon Dance (USA) (Beta 2) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Dance (USA) (Beta 2) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 9a90adbe sha1 5fc97752a98a18b7e2db238d1ab88c6b09e34602 ) ) game ( - name "Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl)" - description "Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl)" - rom ( name "Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl).gbc" size 524288 crc a4c6523d sha1 2b4b8c3a4a74fdf7acc4138125fea5d8f5a9a093 ) + name "Dragon Quest I & II (Japan) (SGB Enhanced) (GB Compatible)" + description "Dragon Quest I & II (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Quest I & II (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc a053b42e sha1 8cfdfb7a76dd0012af3b441e162fcd37e4370958 flags verified ) ) game ( - name "Bob the Builder - Fix it Fun! (Europe) (En,Fr,De,Es,Nl)" - description "Bob the Builder - Fix it Fun! (Europe) (En,Fr,De,Es,Nl)" - rom ( name "Bob the Builder - Fix it Fun! (Europe) (En,Fr,De,Es,Nl).gbc" size 1048576 crc ea33fe3d sha1 167561998c356253c7092ad200dd1bc5386446a7 ) + name "Dragon Quest III - Soshite Densetsu e... (Japan)" + description "Dragon Quest III - Soshite Densetsu e... (Japan)" + rom ( name "Dragon Quest III - Soshite Densetsu e... (Japan).gbc" size 4194304 crc 21078c16 sha1 1f30968a5ebd32643acd32351e78e68cfffb8ae9 flags verified ) ) game ( - name "Bob the Builder - Fix it Fun! (Europe) (En,Fr,It)" - description "Bob the Builder - Fix it Fun! (Europe) (En,Fr,It)" - rom ( name "Bob the Builder - Fix it Fun! (Europe) (En,Fr,It).gbc" size 1048576 crc a8ebd88b sha1 476c75cbc05431e692dec8f4e10bcee9d3f5431a ) + name "Dragon Quest Monsters (Germany) (SGB Enhanced) (GB Compatible)" + description "Dragon Quest Monsters (Germany) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Quest Monsters (Germany) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 2a82b63b sha1 ae8a05d616785391ba4bbdca4c408d4a641c6683 ) ) game ( - name "Bob the Builder - Fix it Fun! (Europe) (En,Sv,No,Da,Fi)" - description "Bob the Builder - Fix it Fun! (Europe) (En,Sv,No,Da,Fi)" - rom ( name "Bob the Builder - Fix it Fun! (Europe) (En,Sv,No,Da,Fi).gbc" size 1048576 crc f319e823 sha1 df4993587cff869c4824a5a771db5c26a748c9ea ) + name "Dragon Quest Monsters - Terry no Wonderland (Japan) (SGB Enhanced) (GB Compatible)" + description "Dragon Quest Monsters - Terry no Wonderland (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Quest Monsters - Terry no Wonderland (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4702c4f1 sha1 eebaf3d553bb915340e64cb85022eb8344ddf1b0 flags verified ) ) game ( - name "Bob the Builder - Fix it Fun! (USA)" - description "Bob the Builder - Fix it Fun! (USA)" - rom ( name "Bob the Builder - Fix it Fun! (USA).gbc" size 1048576 crc 93fa37bd sha1 68bd9a1932d4e5333ab5b4dfe0d28f126e5d470f ) + name "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc d263d88d sha1 a32198d1645741979e24956afd6479b64c258647 flags verified ) ) game ( - name "Boing! (World) (Aftermarket) (Unl)" - description "Boing! (World) (Aftermarket) (Unl)" - rom ( name "Boing! (World) (Aftermarket) (Unl).gbc" size 2097152 crc 91961796 sha1 09fde4065941784bab4cf8f624a0398049ed4add ) + name "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (Possible Proto) (SGB Enhanced) (GB Compatible) (Alt)" + description "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (Possible Proto) (SGB Enhanced) (GB Compatible) (Alt)" + rom ( name "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (Possible Proto) (SGB Enhanced) (GB Compatible) (Alt).gbc" size 2097152 crc 66b83e3a sha1 378794e041f2eb286f2d5243a3cada2faf265bb5 ) ) game ( - name "Boku no Camp-jou (Japan)" - description "Boku no Camp-jou (Japan)" - rom ( name "Boku no Camp-jou (Japan).gbc" size 2097152 crc c87120b5 sha1 349509af42df8b8c5797838c5cda4bbae8643017 ) + name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Iru no Bouken (Japan) (SGB Enhanced) (GB Compatible)" + description "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Iru no Bouken (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Iru no Bouken (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 68ba18d7 sha1 9193778b28e2e4a6303e09cb4170ca00d0058ae5 ) ) game ( - name "Bokujou Monogatari 2 GB (Japan) (GB Compatible)" - description "Bokujou Monogatari 2 GB (Japan) (GB Compatible)" - rom ( name "Bokujou Monogatari 2 GB (Japan) (GB Compatible).gbc" size 2097152 crc ee993302 sha1 d2ae9bc5709aa60dd5d433cd353dbb171db2ef28 flags verified ) + name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (SGB Enhanced) (GB Compatible)" + description "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 2c428a87 sha1 5d2daec53938805236328a0f8a614debffa34048 flags verified ) ) game ( - name "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan)" - description "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan)" - rom ( name "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan).gbc" size 2097152 crc 3a18b41f sha1 e7fceb85a78c78403711521fe5fc8f86260425d0 ) + name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 649e8d97 sha1 217faaf8e7d60545bd07f818a3b3373843e6318d flags verified ) ) game ( - name "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan) (Rev 1)" - description "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan) (Rev 1)" - rom ( name "Bokujou Monogatari 3 GB - Boy Meets Girl (Japan) (Rev 1).gbc" size 2097152 crc 75af0e84 sha1 acb2e549fb7d107d20507af88c36f40234f74958 flags verified ) + name "Dragon Tales - Dragon Adventures (USA)" + description "Dragon Tales - Dragon Adventures (USA)" + rom ( name "Dragon Tales - Dragon Adventures (USA).gbc" size 1048576 crc de390609 sha1 3daa96d9d66f686077f03f0820c63f751047e791 ) ) game ( - name "Bomb Runner 1-2 (World) (Aftermarket) (Unl)" - description "Bomb Runner 1-2 (World) (Aftermarket) (Unl)" - rom ( name "Bomb Runner 1-2 (World) (Aftermarket) (Unl).gbc" size 262144 crc d4c95ac0 sha1 3d020eb6e118b431899d79ce4a7bda9bc571c3a0 ) + name "Dragon Tales - Dragon Wings (Europe)" + description "Dragon Tales - Dragon Wings (Europe)" + rom ( name "Dragon Tales - Dragon Wings (Europe).gbc" size 1048576 crc 137d7b45 sha1 fa30510eb396143b3b0025005ee82de207562e65 ) ) game ( - name "Bomberman Max - Ain Version (Japan)" - description "Bomberman Max - Ain Version (Japan)" - rom ( name "Bomberman Max - Ain Version (Japan).gbc" size 2097152 crc 545e0da2 sha1 7416d9430a8163cd2f953c990ef8ad325725e53a ) + name "Dragon Tales - Dragon Wings (USA)" + description "Dragon Tales - Dragon Wings (USA)" + rom ( name "Dragon Tales - Dragon Wings (USA).gbc" size 1048576 crc 191d31ec sha1 de220565bfdd27e48de4ba886cd3c135953140e5 ) ) game ( - name "Bomberman Max - Blue Champion (USA)" - description "Bomberman Max - Blue Champion (USA)" - rom ( name "Bomberman Max - Blue Champion (USA).gbc" size 2097152 crc 5ccb66cf sha1 bb1120b0116eda3fc157c66766beffcc7a04f826 ) + name "Dragon Warrior I & II (USA) (SGB Enhanced) (GB Compatible)" + description "Dragon Warrior I & II (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Warrior I & II (USA) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 71d693da sha1 01c4e2145365a12560d162116378f1991807ef95 flags verified ) ) game ( - name "Bomberman Max - Hikari no Yuusha (Japan)" - description "Bomberman Max - Hikari no Yuusha (Japan)" - rom ( name "Bomberman Max - Hikari no Yuusha (Japan).gbc" size 2097152 crc 7a44ce88 sha1 9c38166e83e45707cbc2e0aff38fd4590dce7c3f flags verified ) + name "Dragon Warrior III (USA)" + description "Dragon Warrior III (USA)" + rom ( name "Dragon Warrior III (USA).gbc" size 4194304 crc 0fd9c59c sha1 581a12695ae42becaa078ac2694a11767a96dc61 flags verified ) ) game ( - name "Bomberman Max - Red Challenger (USA)" - description "Bomberman Max - Red Challenger (USA)" - rom ( name "Bomberman Max - Red Challenger (USA).gbc" size 2097152 crc 4853f586 sha1 369ce985157c55bbad6c24f49a0ad4009dec5f56 flags verified ) + name "Dragon Warrior Monsters (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Dragon Warrior Monsters (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Warrior Monsters (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc e56c35b1 sha1 728e458d4b13cdc8a0026dc28c5a14f1d72d9da4 flags verified ) ) game ( - name "Bomberman Max - Yami no Senshi (Japan)" - description "Bomberman Max - Yami no Senshi (Japan)" - rom ( name "Bomberman Max - Yami no Senshi (Japan).gbc" size 2097152 crc 48b60e8e sha1 12addfb8f890a44b87efb900e9d6ad5028b58936 flags verified ) + name "Dragon Warrior Monsters 2 - Cobi's Journey (USA) (SGB Enhanced) (GB Compatible)" + description "Dragon Warrior Monsters 2 - Cobi's Journey (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Warrior Monsters 2 - Cobi's Journey (USA) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc ab7bfdd5 sha1 76901b7e5cadf9611dd4fac52e8501155c1e33a2 ) ) game ( - name "Bomberman Quest (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - description "Bomberman Quest (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - rom ( name "Bomberman Quest (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 5a9b9ae6 sha1 088ace0cfd6b3aa637b96c01106f6b1d88ba53fa flags verified ) + name "Dragon Warrior Monsters 2 - Tara's Adventure (USA) (SGB Enhanced) (GB Compatible)" + description "Dragon Warrior Monsters 2 - Tara's Adventure (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Dragon Warrior Monsters 2 - Tara's Adventure (USA) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 35ec5fb2 sha1 a68451e7d3accd81b240c4b60a1f552e39211ede ) ) game ( - name "Bomberman Quest (Japan) (SGB Enhanced) (GB Compatible)" - description "Bomberman Quest (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Bomberman Quest (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 55210934 sha1 b1187036734c40606cb1d5e35a6c120ee618e491 flags verified ) + name "Dragon's Lair (USA, Europe) (En,Ja,Fr,De,Es,Zh)" + description "Dragon's Lair (USA, Europe) (En,Ja,Fr,De,Es,Zh)" + rom ( name "Dragon's Lair (USA, Europe) (En,Ja,Fr,De,Es,Zh).gbc" size 4194304 crc bf076ca5 sha1 15fb0865314e43a83910d52cca7307502aab29fc ) ) game ( - name "Bomberman Quest (USA) (SGB Enhanced) (GB Compatible)" - description "Bomberman Quest (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Bomberman Quest (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a089c656 sha1 4436f6ee03f7a8b2f235b64e26400c0e951d8a3a ) + name "Driver (Europe) (En,Fr,De,Es,It)" + description "Driver (Europe) (En,Fr,De,Es,It)" + rom ( name "Driver (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc e9e67403 sha1 5001f0f4904ca4fb6ab287b52136d00ac94b49d7 ) ) game ( - name "Bomberman Selection (Korea)" - description "Bomberman Selection (Korea)" - rom ( name "Bomberman Selection (Korea).gbc" size 1048576 crc af2b426e sha1 52451464a9f4dd5faefe4594954cbce03bff0d05 flags verified ) + name "Driver (Europe) (En,Fr,De,Es,It) (Beta)" + description "Driver (Europe) (En,Fr,De,Es,It) (Beta)" + rom ( name "Driver (Europe) (En,Fr,De,Es,It) (Beta).gbc" size 1048576 crc 33e9d438 sha1 07e25b8c7569e064d060258981814a151202edbb ) ) game ( - name "Bomberman Selection (Korea) (Beta 2)" - description "Bomberman Selection (Korea) (Beta 2)" - rom ( name "Bomberman Selection (Korea) (Beta 2).gbc" size 1048576 crc 06cc1e9d sha1 a3ce5d9ea4aa4203ea4bc17461e28257e4bd0a62 ) + name "Driver - You Are the Wheelman (USA) (En,Fr,De,Es,It)" + description "Driver - You Are the Wheelman (USA) (En,Fr,De,Es,It)" + rom ( name "Driver - You Are the Wheelman (USA) (En,Fr,De,Es,It).gbc" size 1048576 crc d4c7f6df sha1 9add1e67f39f900f2c004e4d8bbd1fec368eef4c ) ) game ( - name "Bomberman Selection (Korea) (Beta 1)" - description "Bomberman Selection (Korea) (Beta 1)" - rom ( name "Bomberman Selection (Korea) (Beta 1).gbc" size 1048576 crc 005ad4b7 sha1 206a19a48a35bcff18d5872b85ba4e8963827cb3 ) + name "Dropzone (Europe) (GB Compatible)" + description "Dropzone (Europe) (GB Compatible)" + rom ( name "Dropzone (Europe) (GB Compatible).gbc" size 262144 crc 1e71b67e sha1 e5bb7c075c2953e99ca2abe66592810125febf0a flags verified ) ) game ( - name "Booty (World) (Aftermarket) (Unl)" - description "Booty (World) (Aftermarket) (Unl)" - rom ( name "Booty (World) (Aftermarket) (Unl).gbc" size 262144 crc ef6c39c8 sha1 3c487ddc03d935b583e186d1cc395966ef490412 ) + name "DryMouth (USA) (Unl)" + description "DryMouth (USA) (Unl)" + rom ( name "DryMouth (USA) (Unl).gbc" size 1048576 crc 6471622c sha1 6bf5cbd0b5d2ce170b0334abafa59cf3aa18adb2 ) ) game ( - name "Borbo's Quest (World) (GB Compatible) (Aftermarket) (Unl)" - description "Borbo's Quest (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Borbo's Quest (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc e92ce3d4 sha1 1ddf864188dfd741ccda0b0715e75e162d212605 ) + name "DT - Lords of Genomes (Japan) (SGB Enhanced) (GB Compatible)" + description "DT - Lords of Genomes (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "DT - Lords of Genomes (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 42ceb854 sha1 66988a201f77cd4c33fb0a9b3981ff5831206c9d ) ) game ( - name "Bouken! Dondoko Shima (Japan)" - description "Bouken! Dondoko Shima (Japan)" - rom ( name "Bouken! Dondoko Shima (Japan).gbc" size 2097152 crc 5fe759c7 sha1 c054abfea01a3ceb7b20b27e7ea937abe5157834 ) + name "Duke Nukem (Europe) (En,Fr,De,Es,It)" + description "Duke Nukem (Europe) (En,Fr,De,Es,It)" + rom ( name "Duke Nukem (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc fc3d1bb7 sha1 665961e875350d9335e467c2ad752a4dd3dcaef4 flags verified ) ) game ( - name "Bounced! (Europe) (Proto)" - description "Bounced! (Europe) (Proto)" - rom ( name "Bounced! (Europe) (Proto).gbc" size 1048576 crc 3948aee9 sha1 06d2d0eaea07d7a41834d4c9a5dfdbdda6889be9 ) + name "Duke Nukem (USA) (En,Fr,De,Es,It)" + description "Duke Nukem (USA) (En,Fr,De,Es,It)" + rom ( name "Duke Nukem (USA) (En,Fr,De,Es,It).gbc" size 1048576 crc 846fc830 sha1 b9bd0cfe64a7f40c243bc65e0489b5187ad11560 ) ) game ( - name "Boxed In (World) (GB Compatible) (Aftermarket) (Unl)" - description "Boxed In (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Boxed In (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ee1c2e1d sha1 b95dfdf10820671ab5f734ed7180cbf1967ca277 ) + name "Dukes of Hazzard, The - Racing for Home (Europe) (En,Fr,De)" + description "Dukes of Hazzard, The - Racing for Home (Europe) (En,Fr,De)" + rom ( name "Dukes of Hazzard, The - Racing for Home (Europe) (En,Fr,De).gbc" size 2097152 crc 21826adc sha1 782337f5338a242bc8cbaeb69ce7f1e87bb0f6b9 flags verified ) ) game ( - name "Brave Saga - Shinshou Astaria (Japan)" - description "Brave Saga - Shinshou Astaria (Japan)" - rom ( name "Brave Saga - Shinshou Astaria (Japan).gbc" size 2097152 crc 5d5d294a sha1 952b9e16a938b986a6216b8db6d62f71c4f853fa flags verified ) + name "Dukes of Hazzard, The - Racing for Home (USA)" + description "Dukes of Hazzard, The - Racing for Home (USA)" + rom ( name "Dukes of Hazzard, The - Racing for Home (USA).gbc" size 2097152 crc fb08dceb sha1 6a39dfbce8b86db84615cdb5fb24012cbbac7b36 ) ) game ( - name "Bub-O Escape - Tournament Edition (World) (Aftermarket) (Unl)" - description "Bub-O Escape - Tournament Edition (World) (Aftermarket) (Unl)" - rom ( name "Bub-O Escape - Tournament Edition (World) (Aftermarket) (Unl).gbc" size 524288 crc 437a2973 sha1 9c219e2c489f5140314e89fbdc0bb387e1f1eed0 ) + name "Dungeon Savior (Japan) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible)" + description "Dungeon Savior (Japan) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible)" + rom ( name "Dungeon Savior (Japan) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 0180364b sha1 c5e93f04cc41404320aaf70eb10b55465edb1083 ) ) game ( - name "Bubble Trouble (World) (Aftermarket) (Unl)" - description "Bubble Trouble (World) (Aftermarket) (Unl)" - rom ( name "Bubble Trouble (World) (Aftermarket) (Unl).gbc" size 262144 crc 3374918b sha1 892388f81f7815ea3bca17632a6a9a33a6edafac ) + name "Dungeon Savior (Japan) (SGB Enhanced) (GB Compatible)" + description "Dungeon Savior (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Dungeon Savior (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 2bcb5f78 sha1 766ab65d9420f361d8d9a4754ea8c6b692e34c36 ) ) game ( - name "Bubblegum Attack (World) (GB Compatible) (Aftermarket) (Unl)" - description "Bubblegum Attack (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Bubblegum Attack (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc e3f64fec sha1 51e302fd27d579c9a4e8109e6ea4af3275d475dd ) + name "DX Jinsei Game (Japan)" + description "DX Jinsei Game (Japan)" + rom ( name "DX Jinsei Game (Japan).gbc" size 2097152 crc 7e15b3dd sha1 cd14fe4e7c7a8a4c6af76682a954ef24919d89ad flags verified ) ) game ( - name "Buffy the Vampire Slayer (USA, Europe)" - description "Buffy the Vampire Slayer (USA, Europe)" - rom ( name "Buffy the Vampire Slayer (USA, Europe).gbc" size 1048576 crc 5692e262 sha1 3310a9cfcad457a6d4d31b63d8258313051c581e flags verified ) + name "DX Monopoly GB (Japan) (SGB Enhanced) (GB Compatible)" + description "DX Monopoly GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "DX Monopoly GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 3f1e076c sha1 524d9459d357e209d64a2ef17b4072478f290806 ) ) game ( - name "Bug's Life, A (Europe) (SGB Enhanced) (GB Compatible)" - description "Bug's Life, A (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Bug's Life, A (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc db93e0f6 sha1 dfc7b45c8f2d45cbf5c7578294ca569d2cf22dcd ) + name "DynaMike (Europe) (Proto)" + description "DynaMike (Europe) (Proto)" + rom ( name "DynaMike (Europe) (Proto).gbc" size 1048576 crc 53c069e9 sha1 692a583da5890e83da5a5eac8d0d31315da316df ) ) game ( - name "Bug's Life, A (USA) (SGB Enhanced) (GB Compatible)" - description "Bug's Life, A (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Bug's Life, A (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 8360047a sha1 4c689ce3b99a5b585a452b095d72a688391ea0eb ) + name "E.T. - The Extra-Terrestrial - Digital Companion (USA)" + description "E.T. - The Extra-Terrestrial - Digital Companion (USA)" + rom ( name "E.T. - The Extra-Terrestrial - Digital Companion (USA).gbc" size 1048576 crc 84872999 sha1 7dd940c8044ccc0e18a511fa32c73551ce30463e ) ) game ( - name "Bugs Bunny - Crazy Castle 3 (Japan) (GB Compatible)" - description "Bugs Bunny - Crazy Castle 3 (Japan) (GB Compatible)" - rom ( name "Bugs Bunny - Crazy Castle 3 (Japan) (GB Compatible).gbc" size 1048576 crc ae839cae sha1 403356d76a267d79fa5b72158de4e280b970160b ) + name "E.T. - The Extra-Terrestrial - Digital Companion (Europe) (Proto)" + description "E.T. - The Extra-Terrestrial - Digital Companion (Europe) (Proto)" + rom ( name "E.T. - The Extra-Terrestrial - Digital Companion (Europe) (Proto).gbc" size 1048576 crc 513f38b7 sha1 14ad36a7939be12d1212c12a59de31d27e4df8f3 ) ) game ( - name "Bugs Bunny - Crazy Castle 3 (USA, Europe) (GB Compatible)" - description "Bugs Bunny - Crazy Castle 3 (USA, Europe) (GB Compatible)" - rom ( name "Bugs Bunny - Crazy Castle 3 (USA, Europe) (GB Compatible).gbc" size 1048576 crc 7a2801fb sha1 f4ac94b7f59191f8d4adc1b5b5ac39bee5dfd064 flags verified ) + name "E.T. - The Extra-Terrestrial - Escape from Planet Earth (Europe) (En,Fr,De,Es,It,Nl)" + description "E.T. - The Extra-Terrestrial - Escape from Planet Earth (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "E.T. - The Extra-Terrestrial - Escape from Planet Earth (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc b25f3db5 sha1 95fd6b8f5b4f550d6e28f21f23e2e0794176d9b7 ) ) game ( - name "Bugs Bunny - Crazy Castle 4 (Japan)" - description "Bugs Bunny - Crazy Castle 4 (Japan)" - rom ( name "Bugs Bunny - Crazy Castle 4 (Japan).gbc" size 1048576 crc d6387eaa sha1 e4a198d4acf5ac987071a1d2b91501caca62269b ) + name "E.T. - The Extra-Terrestrial - Escape from Planet Earth (USA)" + description "E.T. - The Extra-Terrestrial - Escape from Planet Earth (USA)" + rom ( name "E.T. - The Extra-Terrestrial - Escape from Planet Earth (USA).gbc" size 1048576 crc 086106de sha1 d90e6a76a6cadc4b364f36c01345a26e086adb73 ) ) game ( - name "Bugs Bunny & Lola Bunny - Operation Carrot Patch (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - description "Bugs Bunny & Lola Bunny - Operation Carrot Patch (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - rom ( name "Bugs Bunny & Lola Bunny - Operation Carrot Patch (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc f0cc407f sha1 ba004fac4524b82fd74a9037a37734d0aba07e50 flags verified ) + name "E.T. - The Extra-Terrestrial and the Cosmic Garden (Europe) (En,Fr,De,Es,It,Nl)" + description "E.T. - The Extra-Terrestrial and the Cosmic Garden (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "E.T. - The Extra-Terrestrial and the Cosmic Garden (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 8321a1b9 sha1 c4f4179f391fc57ea4db3688d95f2d53533db995 flags verified ) ) game ( - name "Bugs Bunny et le Chateau des Catastrophes (France) (En)" - description "Bugs Bunny et le Chateau des Catastrophes (France) (En)" - rom ( name "Bugs Bunny et le Chateau des Catastrophes (France) (En).gbc" size 1048576 crc 6da8e6eb sha1 19590017c888266c285360f824f5ef6cea166287 ) + name "E.T. - The Extra-Terrestrial and the Cosmic Garden (USA)" + description "E.T. - The Extra-Terrestrial and the Cosmic Garden (USA)" + rom ( name "E.T. - The Extra-Terrestrial and the Cosmic Garden (USA).gbc" size 1048576 crc 32c87958 sha1 da71b581f7415b6535ac4af2e8fccd2040c54215 ) ) game ( - name "Bugs Bunny in - Crazy Castle 4 (Europe)" - description "Bugs Bunny in - Crazy Castle 4 (Europe)" - rom ( name "Bugs Bunny in - Crazy Castle 4 (Europe).gbc" size 1048576 crc 53155e60 sha1 3654f532a77035b3fc5bf7b0e1ae6941fc649b6a flags verified ) + name "e'Fighter HOT (Taiwan) (En) (Unl)" + description "e'Fighter HOT (Taiwan) (En) (Unl)" + rom ( name "e'Fighter HOT (Taiwan) (En) (Unl).gbc" size 1048576 crc 8fa2539d sha1 93a3716f8f41b89bee795af6e8f6fdddfcd8acf1 ) ) game ( - name "Bugs Bunny in - Crazy Castle 4 (USA)" - description "Bugs Bunny in - Crazy Castle 4 (USA)" - rom ( name "Bugs Bunny in - Crazy Castle 4 (USA).gbc" size 1048576 crc 98dbffe0 sha1 a22b9765e901b2a23a48c44b0b829ab73b9c1a82 ) + name "Earthworm Jim - Menace 2 the Galaxy (USA, Europe) (GB Compatible)" + description "Earthworm Jim - Menace 2 the Galaxy (USA, Europe) (GB Compatible)" + rom ( name "Earthworm Jim - Menace 2 the Galaxy (USA, Europe) (GB Compatible).gbc" size 1048576 crc 2e65daaf sha1 78f9bd7f8c40274cf7282892a45e814103944060 flags verified ) ) game ( - name "Bundesliga Stars 2001 (Germany)" - description "Bundesliga Stars 2001 (Germany)" - rom ( name "Bundesliga Stars 2001 (Germany).gbc" size 1048576 crc 5622b551 sha1 9803734c45fa54463f7e2b8ce3eea3ca4d4ebdf4 ) + name "ECW Hardcore Revolution (USA, Europe)" + description "ECW Hardcore Revolution (USA, Europe)" + rom ( name "ECW Hardcore Revolution (USA, Europe).gbc" size 1048576 crc 484eba10 sha1 c337d0480e84f5e2b7e28b13c3667b8cf92d9649 ) ) game ( - name "Burai Senshi Color (Japan)" - description "Burai Senshi Color (Japan)" - rom ( name "Burai Senshi Color (Japan).gbc" size 1048576 crc e52fbd12 sha1 a3b140586aac09f959260c5673dfed2ed58c1469 ) + name "Elang 2003 - Mark of the Wolfs (Taiwan) (En) (Unl)" + description "Elang 2003 - Mark of the Wolfs (Taiwan) (En) (Unl)" + rom ( name "Elang 2003 - Mark of the Wolfs (Taiwan) (En) (Unl).gbc" size 1048576 crc 50a1e9a9 sha1 4a3ac88b7be532d5fd5c4d9e500532e96441a966 ) ) game ( - name "Burger Burger Pocket - Hamburger Simulation (Japan) (SGB Enhanced) (GB Compatible)" - description "Burger Burger Pocket - Hamburger Simulation (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Burger Burger Pocket - Hamburger Simulation (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1abcedbe sha1 f4579d4bb3b39f572fdf033df01a84a925fb3f2e ) + name "Elang Chuanshuo - Shiji Zhi Zhan (Taiwan) (Unl)" + description "Elang Chuanshuo - Shiji Zhi Zhan (Taiwan) (Unl)" + rom ( name "Elang Chuanshuo - Shiji Zhi Zhan (Taiwan) (Unl).gbc" size 1048576 crc 1cb8e67f sha1 334bebed71956822f7cf9af9a2e2be2f1280654c ) ) game ( - name "Burger Paradise International (Japan)" - description "Burger Paradise International (Japan)" - rom ( name "Burger Paradise International (Japan).gbc" size 1048576 crc 9092b0eb sha1 71072a7f0165769649bce8c31c36f67bb0e02963 ) + name "Elemental Fighter (USA) (Proto)" + description "Elemental Fighter (USA) (Proto)" + rom ( name "Elemental Fighter (USA) (Proto).gbc" size 262144 crc 03fc3d03 sha1 92cce7614474d3f9ed9e3fdbd2e2bb434e074565 ) ) game ( - name "Buried Behind the Cabin (World) (GB Compatible) (Aftermarket) (Unl)" - description "Buried Behind the Cabin (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Buried Behind the Cabin (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc a5d6cd6a sha1 7464af8e6d9d0a4b11f510d22789a6830cd4c272 ) + name "Elevator Action EX (Europe) (En,Fr,De,Es,It)" + description "Elevator Action EX (Europe) (En,Fr,De,Es,It)" + rom ( name "Elevator Action EX (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 2154763c sha1 498308efb907c8dc79c9699d27ff349941fac23a ) ) game ( - name "Bust-A-Move 4 (USA, Europe) (GB Compatible)" - description "Bust-A-Move 4 (USA, Europe) (GB Compatible)" - rom ( name "Bust-A-Move 4 (USA, Europe) (GB Compatible).gbc" size 524288 crc 8e818e6f sha1 dfb5c960336ecbe074b36fdcd8c7a8f1b194df32 ) + name "Elevator Action EX (Japan)" + description "Elevator Action EX (Japan)" + rom ( name "Elevator Action EX (Japan).gbc" size 1048576 crc b70c4ddb sha1 db91028de0a07479f53f7449d0a6794d295e0b97 ) ) game ( - name "Bust-A-Move Millennium (USA, Europe)" - description "Bust-A-Move Millennium (USA, Europe)" - rom ( name "Bust-A-Move Millennium (USA, Europe).gbc" size 1048576 crc f8da0c4a sha1 2c14b4c82072f2a55f9f699956f71071481808ec ) + name "Elie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Elie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Elie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 7967320e sha1 95797142058700b13577c21ed118b6508b84c8a6 ) ) game ( - name "Buzz Lightyear of Star Command (USA, Europe)" - description "Buzz Lightyear of Star Command (USA, Europe)" - rom ( name "Buzz Lightyear of Star Command (USA, Europe).gbc" size 524288 crc 84e29b87 sha1 314dacd9a5d60769105f2cde60a245074cb51c15 ) + name "Emo Cheng 2 - Fengyun Pian (Taiwan) (Unl)" + description "Emo Cheng 2 - Fengyun Pian (Taiwan) (Unl)" + rom ( name "Emo Cheng 2 - Fengyun Pian (Taiwan) (Unl).gbc" size 524288 crc a98eec81 sha1 6da2499578b3cd362a21594034278c3ab2b9b374 ) ) game ( - name "Caesars Palace II (USA, Europe)" - description "Caesars Palace II (USA, Europe)" - rom ( name "Caesars Palace II (USA, Europe).gbc" size 1048576 crc 351ba5ea sha1 b7520b3c91813df9a447c11ccc4d4381f106ca52 ) + name "Emo Cheng DX (Taiwan) (Demo) (Unl)" + description "Emo Cheng DX (Taiwan) (Demo) (Unl)" + rom ( name "Emo Cheng DX (Taiwan) (Demo) (Unl).gbc" size 1048576 crc ebf7bf6e sha1 29b1b595ca8f5ad76ebf4f997d0e4fb8069829f1 ) ) game ( - name "Caise Gedou 24 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl)" - description "Caise Gedou 24 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl)" - rom ( name "Caise Gedou 24 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl).gbc" size 2097152 crc dc03fb00 sha1 201dfbce0f2d5262ccd487e63927a2ff520db56d ) + name "Emo Cheng DX (Taiwan) (Unl)" + description "Emo Cheng DX (Taiwan) (Unl)" + rom ( name "Emo Cheng DX (Taiwan) (Unl).gbc" size 4194304 crc 5c388c6d sha1 7919fe7b54a5bc53ebacc13dd338be9e841dadf7 ) ) game ( - name "Caise Gedou 29 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl)" - description "Caise Gedou 29 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl)" - rom ( name "Caise Gedou 29 in 1 Diannao Huamian Xuan Game (Taiwan) (Unl).gbc" size 2097152 crc 78c0e5bc sha1 358e628e680bc63227940ca6d76217d14fcd3409 flags verified ) + name "Emo Dao (Taiwan) (Unl)" + description "Emo Dao (Taiwan) (Unl)" + rom ( name "Emo Dao (Taiwan) (Unl).gbc" size 524288 crc 2b2acb79 sha1 929784599694efc6db16163f5bf91e49c2e459fc ) ) game ( - name "Cancer Culture VS The Illuminati (World) (2023-05-03) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Cancer Culture VS The Illuminati (World) (2023-05-03) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Cancer Culture VS The Illuminati (World) (2023-05-03) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 52da152b sha1 1bb4a376c03af67ca1e8426375fe1a644499d9ae ) + name "Emperor's New Groove, The (Europe) (En,Fr,De,Es,It)" + description "Emperor's New Groove, The (Europe) (En,Fr,De,Es,It)" + rom ( name "Emperor's New Groove, The (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc eb29c584 sha1 2f53318aa7f1c82df95bf3da6b29701a2c563d13 ) ) game ( - name "Candy Quest (World) (v2) (Demo) (Aftermarket) (Unl)" - description "Candy Quest (World) (v2) (Demo) (Aftermarket) (Unl)" - rom ( name "Candy Quest (World) (v2) (Demo) (Aftermarket) (Unl).gbc" size 1048576 crc 1f2823cb sha1 8906832db7816be01ed37728f6e5a23e981e7e38 ) + name "Emperor's New Groove, The (USA)" + description "Emperor's New Groove, The (USA)" + rom ( name "Emperor's New Groove, The (USA).gbc" size 2097152 crc 6ebad539 sha1 ba663289bd5d9d09bc8b9ac2c1d38293dcba9c02 ) ) game ( - name "Cannon Fodder (Europe) (En,Fr,De,Es,It) (Beta)" - description "Cannon Fodder (Europe) (En,Fr,De,Es,It) (Beta)" - rom ( name "Cannon Fodder (Europe) (En,Fr,De,Es,It) (Beta).gbc" size 4194304 crc 222c9dc6 sha1 cee465f6987c2d580cc96fac703025989208e683 ) + name "Equestriad 2001 (Europe) (Proto)" + description "Equestriad 2001 (Europe) (Proto)" + rom ( name "Equestriad 2001 (Europe) (Proto).gbc" size 1048576 crc 626f978f sha1 7698801ef38b63d45fdd2110f9b3ea87e59b9476 ) ) game ( - name "Cannon Fodder (Europe) (En,Fr,De,Es,It)" - description "Cannon Fodder (Europe) (En,Fr,De,Es,It)" - rom ( name "Cannon Fodder (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 824c3bf3 sha1 9a6901cad65e6d0ce89af8442688fec6a9fedd43 ) + name "ESPN International Track & Field (USA)" + description "ESPN International Track & Field (USA)" + rom ( name "ESPN International Track & Field (USA).gbc" size 1048576 crc 4005d541 sha1 397d76c85859d0fa9b58b49f7eae16f76ad45a17 ) ) game ( - name "Cannon Fodder (USA) (En,Fr,De,Es,It)" - description "Cannon Fodder (USA) (En,Fr,De,Es,It)" - rom ( name "Cannon Fodder (USA) (En,Fr,De,Es,It).gbc" size 4194304 crc 26f8e1a0 sha1 cc601984a2b52b44cf135e42bcac1bec44b7a6a3 ) + name "ESPN National Hockey Night (USA)" + description "ESPN National Hockey Night (USA)" + rom ( name "ESPN National Hockey Night (USA).gbc" size 2097152 crc 600f61f9 sha1 3ddf8cf9afe08c6079737a232ea071cedafeaa14 ) ) game ( - name "Capcom vs SNK - Millennium Fight 2001 (Taiwan) (En) (Unl)" - description "Capcom vs SNK - Millennium Fight 2001 (Taiwan) (En) (Unl)" - rom ( name "Capcom vs SNK - Millennium Fight 2001 (Taiwan) (En) (Unl).gbc" size 1048576 crc 97280455 sha1 cddd079eebaeeb45b22c808cfb5e369f70e7fa20 ) + name "Estpolis Denki - Yomigaeru Densetsu (Japan)" + description "Estpolis Denki - Yomigaeru Densetsu (Japan)" + rom ( name "Estpolis Denki - Yomigaeru Densetsu (Japan).gbc" size 2097152 crc 54617416 sha1 dde3b4fbbef61b1e20abc1d71408f59e6c90e79a ) ) game ( - name "Captain Buzz Lightyear - Star Command (Germany)" - description "Captain Buzz Lightyear - Star Command (Germany)" - rom ( name "Captain Buzz Lightyear - Star Command (Germany).gbc" size 524288 crc f06d296c sha1 376bcd39491fe275a3773716ffaf0259e4852340 flags verified ) + name "European Super League (Europe) (En,Fr,De,Es,It)" + description "European Super League (Europe) (En,Fr,De,Es,It)" + rom ( name "European Super League (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 5a0b7c72 sha1 2b403fc1c01aa82645960df4fe7e93801ef735a3 ) ) game ( - name "Card Sharks (USA) (Proto)" - description "Card Sharks (USA) (Proto)" - rom ( name "Card Sharks (USA) (Proto).gbc" size 262144 crc e2b2dcfe sha1 f5e1850efa9ac1df8a879815d4193a1157408ca3 ) + name "EuroSport Pro Champ Fishing (Europe) (Proto) (GB Compatible)" + description "EuroSport Pro Champ Fishing (Europe) (Proto) (GB Compatible)" + rom ( name "EuroSport Pro Champ Fishing (Europe) (Proto) (GB Compatible).gbc" size 1048576 crc 32083abd sha1 565c16da5d2bc5dacffa992ed3f0466ec4888e73 ) ) game ( - name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (GB Compatible)" - description "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (GB Compatible)" - rom ( name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (GB Compatible).gbc" size 524288 crc 89ba58ed sha1 8a11954329dcabe4bb39cb522505545a41da5356 ) + name "EuroSport XS Racing (Europe) (Proto) (GB Compatible)" + description "EuroSport XS Racing (Europe) (Proto) (GB Compatible)" + rom ( name "EuroSport XS Racing (Europe) (Proto) (GB Compatible).gbc" size 1048576 crc ca0abfca sha1 b3dda41ef755cc78680858103bad07d064e155ac ) ) game ( - name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 1) (GB Compatible)" - description "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 1) (GB Compatible)" - rom ( name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 1) (GB Compatible).gbc" size 524288 crc 43f28e22 sha1 b3926ac213b9f88f570b0587fae89e3151018d63 ) + name "Evel Knievel (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + description "Evel Knievel (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + rom ( name "Evel Knievel (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 2097152 crc dfd6a908 sha1 0841f55e18fe6e4a50df826703db22681169f2e7 ) ) game ( - name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 2) (GB Compatible)" - description "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 2) (GB Compatible)" - rom ( name "Cardcaptor Sakura - Itsumo Sakura-chan to Issho (Japan) (Rev 2) (GB Compatible).gbc" size 524288 crc 7243e258 sha1 a53e7f8d95375aea144e870977b0966cc1fd4b94 flags verified ) + name "Evel Knievel (USA) (GB Compatible)" + description "Evel Knievel (USA) (GB Compatible)" + rom ( name "Evel Knievel (USA) (GB Compatible).gbc" size 2097152 crc 51e951b5 sha1 24cac6ab0151b33d2b1fd06ee01931802fb98267 flags verified ) ) game ( - name "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan) (Rev 1) (Proto)" - description "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan) (Rev 1) (Proto)" - rom ( name "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan) (Rev 1) (Proto).gbc" size 2097152 crc d2cc40c2 sha1 031b00495b3700b2145a741f2d03cc820ffa6fde ) + name "Extreme Ghostbusters (Europe) (En,Fr,De,Es,It,Pt)" + description "Extreme Ghostbusters (Europe) (En,Fr,De,Es,It,Pt)" + rom ( name "Extreme Ghostbusters (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc cc777b98 sha1 01e1bf3cea7ccd7b8853727ac252adddc540fa2f ) ) game ( - name "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan)" - description "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan)" - rom ( name "Cardcaptor Sakura - Tomoeda Shougakkou Daiundoukai (Japan).gbc" size 2097152 crc f78f7998 sha1 1809154979b289750b572a61da1dc93b1b76360f ) + name "Extreme Sports with the Berenstain Bears (USA, Europe) (En,Fr,De,Es,It)" + description "Extreme Sports with the Berenstain Bears (USA, Europe) (En,Fr,De,Es,It)" + rom ( name "Extreme Sports with the Berenstain Bears (USA, Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 5c0e7b44 sha1 ee56328e88729f929da717221d72826c872253c2 flags verified ) ) game ( - name "Cargo (World) (GB Compatible) (Aftermarket) (Unl)" - description "Cargo (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Cargo (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc a65d66f4 sha1 83c35ad553bde5ce3a6af418d7f8ad1fbe73b0f6 ) + name "F-1 World Grand Prix (Europe) (En,Fr,De,Es)" + description "F-1 World Grand Prix (Europe) (En,Fr,De,Es)" + rom ( name "F-1 World Grand Prix (Europe) (En,Fr,De,Es).gbc" size 2097152 crc 8d9a9182 sha1 16aa2e02e9b7f236f12a49c3224ca4cc89cdf98c flags verified ) ) game ( - name "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl)" - description "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 15430979 sha1 76e898c00f47628710eaef7551a7d1fe04e2a2bc flags verified ) + name "F-1 World Grand Prix (Europe) (Beta)" + description "F-1 World Grand Prix (Europe) (Beta)" + rom ( name "F-1 World Grand Prix (Europe) (Beta).gbc" size 2097152 crc d6496fe9 sha1 9285bb4fbab8678b65cc8736f43e4ea3895c1cf4 ) ) game ( - name "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - description "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - rom ( name "Carl Lewis Athletics 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 1048576 crc da8d6283 sha1 0a94857f23640b36117b7bfe4ce7cc291da63c58 ) + name "F-1 World Grand Prix (Japan) (En) (Beta 2)" + description "F-1 World Grand Prix (Japan) (En) (Beta 2)" + rom ( name "F-1 World Grand Prix (Japan) (En) (Beta 2).gbc" size 1048576 crc 5e24811e sha1 25c83cb589ce85917b99757090a94e588cb799b9 ) ) game ( - name "Carmageddon - Carpocalypse Now (USA) (En,Es) (Beta)" - description "Carmageddon - Carpocalypse Now (USA) (En,Es) (Beta)" - rom ( name "Carmageddon - Carpocalypse Now (USA) (En,Es) (Beta).gbc" size 2097152 crc e9751f81 sha1 9f41f86214031dad6440206863bffc13c3e61fc4 ) + name "F-1 World Grand Prix (Japan) (En) (Beta 1)" + description "F-1 World Grand Prix (Japan) (En) (Beta 1)" + rom ( name "F-1 World Grand Prix (Japan) (En) (Beta 1).gbc" size 2097152 crc 3122807b sha1 afc4b8f0487b0c6b0ca6470d4002eaca6616a04b ) ) game ( - name "Carmageddon - Carpocalypse Now (Germany)" - description "Carmageddon - Carpocalypse Now (Germany)" - rom ( name "Carmageddon - Carpocalypse Now (Germany).gbc" size 2097152 crc b447bc06 sha1 505b29e070ce034b179169d834abb3969e84c7e0 flags verified ) + name "F-18 Thunder Strike (USA, Europe) (Beta) (Rumble Version)" + description "F-18 Thunder Strike (USA, Europe) (Beta) (Rumble Version)" + rom ( name "F-18 Thunder Strike (USA, Europe) (Beta) (Rumble Version).gbc" size 1048576 crc 9e253e73 sha1 f7ccfc1f0822bdc611751d77b9f164c6aaa64c01 ) ) game ( - name "Carmageddon - Carpocalypse Now (USA, Europe) (En,Fr,Es,It)" - description "Carmageddon - Carpocalypse Now (USA, Europe) (En,Fr,Es,It)" - rom ( name "Carmageddon - Carpocalypse Now (USA, Europe) (En,Fr,Es,It).gbc" size 2097152 crc bb482ed7 sha1 df37636bbd57a426e23d21581376d7e3a87c7933 flags verified ) + name "F-18 Thunder Strike (USA, Europe)" + description "F-18 Thunder Strike (USA, Europe)" + rom ( name "F-18 Thunder Strike (USA, Europe).gbc" size 1048576 crc 410fa858 sha1 530aecae5b89e580be8a8d4827be95522d8319c4 ) ) game ( - name "Carmageddon TDR 2000 (Europe) (En,Fr,De,Es,It) (Proto)" - description "Carmageddon TDR 2000 (Europe) (En,Fr,De,Es,It) (Proto)" - rom ( name "Carmageddon TDR 2000 (Europe) (En,Fr,De,Es,It) (Proto).gbc" size 2097152 crc 0bd8e676 sha1 fe059ee25e2a00a129842f452bcc86ce78213c6b ) + name "F.A. Premier League Stars 2001, The (Europe)" + description "F.A. Premier League Stars 2001, The (Europe)" + rom ( name "F.A. Premier League Stars 2001, The (Europe).gbc" size 1048576 crc 5e3844fb sha1 9fee426307ebfc373ab60a17f8f2f08d2ff8661c ) ) game ( - name "Carnivale (USA) (Proto)" - description "Carnivale (USA) (Proto)" - rom ( name "Carnivale (USA) (Proto).gbc" size 1048576 crc e9503c71 sha1 07d41e21bc82f64d788e720583169fb0e588da89 ) + name "F1 Championship Season 2000 (Europe) (En,Fr,De,Es,It)" + description "F1 Championship Season 2000 (Europe) (En,Fr,De,Es,It)" + rom ( name "F1 Championship Season 2000 (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 5c10315e sha1 dc566028e0e86f32d99d5b0846d4b113525be0a2 ) ) game ( - name "Carrera (Europe) (En,Fr,De) (Proto)" - description "Carrera (Europe) (En,Fr,De) (Proto)" - rom ( name "Carrera (Europe) (En,Fr,De) (Proto).gbc" size 2097152 crc f8000653 sha1 1b70600b9e3a0f2736b5a23d88ebc1ad52597426 ) + name "F1 Championship Season 2000 (Brazil) (En,Fr,De,Es,It)" + description "F1 Championship Season 2000 (Brazil) (En,Fr,De,Es,It)" + rom ( name "F1 Championship Season 2000 (Brazil) (En,Fr,De,Es,It).gbc" size 2097152 crc f4f5ed18 sha1 4731a7442bbff31c6d470b84938a3f148a4f1f6c ) ) game ( - name "Casper (USA) (Rev 1) (Proto)" - description "Casper (USA) (Rev 1) (Proto)" - rom ( name "Casper (USA) (Rev 1) (Proto).gbc" size 1048576 crc 5edd88b5 sha1 6f44a817c7424a5b24919b01e1e868d2c2650341 ) + name "F1 Racing Championship (USA) (En,Fr,De,Es,It) (Proto)" + description "F1 Racing Championship (USA) (En,Fr,De,Es,It) (Proto)" + rom ( name "F1 Racing Championship (USA) (En,Fr,De,Es,It) (Proto).gbc" size 4194304 crc 9ec98cab sha1 83f1791b5fc7d7e589c105d87a14abb8087edaed ) ) game ( - name "Casper (Europe) (En,Es,It)" - description "Casper (Europe) (En,Es,It)" - rom ( name "Casper (Europe) (En,Es,It).gbc" size 1048576 crc daefe53c sha1 1a964811c1d808403c4bae1adc7b7f78bf610399 ) + name "F1 Racing Championship (Europe) (En,Fr,De,Es,It) (Beta)" + description "F1 Racing Championship (Europe) (En,Fr,De,Es,It) (Beta)" + rom ( name "F1 Racing Championship (Europe) (En,Fr,De,Es,It) (Beta).gbc" size 4194304 crc e115ddb1 sha1 e9616a53ab9474c0bb85451ff19b62bed9e7f1a4 ) ) game ( - name "Casper (Europe) (En,Fr,De)" - description "Casper (Europe) (En,Fr,De)" - rom ( name "Casper (Europe) (En,Fr,De).gbc" size 1048576 crc e6b9f155 sha1 0a8560a35157dc5270309a7b4c0227e2f2a8c461 ) + name "F1 Racing Championship (Europe) (En,Fr,De,Es,It)" + description "F1 Racing Championship (Europe) (En,Fr,De,Es,It)" + rom ( name "F1 Racing Championship (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 93a9789f sha1 ea844051c0b5c6f9a6a8c472f4f67ee6b9b3d8e7 ) ) game ( - name "Casper (USA)" - description "Casper (USA)" - rom ( name "Casper (USA).gbc" size 1048576 crc c775d653 sha1 82ac50380c3ed39fad13cc0bbe35e6457806a294 ) + name "F1 World Grand Prix II for Game Boy Color (Europe) (En,Fr,De,Es)" + description "F1 World Grand Prix II for Game Boy Color (Europe) (En,Fr,De,Es)" + rom ( name "F1 World Grand Prix II for Game Boy Color (Europe) (En,Fr,De,Es).gbc" size 1048576 crc eef4a20b sha1 ce114896da10c8a0a14164cd9958922523491a59 ) ) game ( - name "Cat Boy's Stellar Journey (World) (GB Compatible) (Aftermarket) (Unl)" - description "Cat Boy's Stellar Journey (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Cat Boy's Stellar Journey (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 280937cc sha1 9ec53942f0136076b6468671562764e1ab9dee3b ) + name "F1 World Grand Prix II for Game Boy Color (Japan) (En,Ja)" + description "F1 World Grand Prix II for Game Boy Color (Japan) (En,Ja)" + rom ( name "F1 World Grand Prix II for Game Boy Color (Japan) (En,Ja).gbc" size 1048576 crc 28453467 sha1 b4d5e42c10c2bcd9204d282e9d91312f34ff768a ) ) game ( - name "Caterpillar Construction Zone (USA, Europe) (GB Compatible)" - description "Caterpillar Construction Zone (USA, Europe) (GB Compatible)" - rom ( name "Caterpillar Construction Zone (USA, Europe) (GB Compatible).gbc" size 1048576 crc d20dc670 sha1 0ec92ea836c729efebcd76282f90dfb579396aa6 flags verified ) + name "F1 World Grand Prix II for Game Boy Color (USA) (En,Fr,De,Es)" + description "F1 World Grand Prix II for Game Boy Color (USA) (En,Fr,De,Es)" + rom ( name "F1 World Grand Prix II for Game Boy Color (USA) (En,Fr,De,Es).gbc" size 1048576 crc 482e10c5 sha1 c39e33fd9d5f06bc8f0f74eafb45fa0c254f9c84 ) ) game ( - name "Catwoman (Europe)" - description "Catwoman (Europe)" - rom ( name "Catwoman (Europe).gbc" size 1048576 crc 41e78645 sha1 e2446731abef2a3c78a0bfa5d2bbda0084b7b3ea ) + name "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (SGB Enhanced) (GB Compatible)" + description "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b59a51c4 sha1 a27b498c6170b4136d2ca8a75c3d529dd6c06639 ) ) game ( - name "Catwoman (USA)" - description "Catwoman (USA)" - rom ( name "Catwoman (USA).gbc" size 1048576 crc 12f0c196 sha1 c6f364d15fe9c0982b6a03ee67fd463dc32e7ed0 ) + name "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c4d3628f sha1 d07b600cc9af8cadc2581a6ac19aadea79313d69 flags verified ) ) game ( - name "Catwoman (Japan) (Proto)" - description "Catwoman (Japan) (Proto)" - rom ( name "Catwoman (Japan) (Proto).gbc" size 1048576 crc e8dfae9d sha1 f4cb746b4bc9b16acc0f3cf38cefc6cbd6db24be ) + name "Fellowship of the Rings (Taiwan) (En) (Unl)" + description "Fellowship of the Rings (Taiwan) (En) (Unl)" + rom ( name "Fellowship of the Rings (Taiwan) (En) (Unl).gbc" size 524288 crc 4bcc59dc sha1 837232bd2eeb50b276049d0908f8ed4dc7efbcfe ) ) game ( - name "Catz (Europe)" - description "Catz (Europe)" - rom ( name "Catz (Europe).gbc" size 1048576 crc 099d6555 sha1 16b749d0c57c6d837364b3c55a353647304a55a0 ) + name "Fellowship of the Rings (China) (En) (Unl)" + description "Fellowship of the Rings (China) (En) (Unl)" + rom ( name "Fellowship of the Rings (China) (En) (Unl).gbc" size 524288 crc 759f07bd sha1 83fec0fb02fdeda160a0de610acdf7446e373022 ) ) game ( - name "Catz (USA)" - description "Catz (USA)" - rom ( name "Catz (USA).gbc" size 1048576 crc 769a2c5a sha1 5c3c9a4d85a92779c7e8304f2c122296f62f9a9c ) + name "Feng Kuang A Gei III - Chaoji Zhadan Ren (Taiwan) (Unl)" + description "Feng Kuang A Gei III - Chaoji Zhadan Ren (Taiwan) (Unl)" + rom ( name "Feng Kuang A Gei III - Chaoji Zhadan Ren (Taiwan) (Unl).gbc" size 2097152 crc 8059e009 sha1 84011e3ae407613cfd7b6b1fe85f3812097afc66 flags verified ) ) game ( - name "Cave Fighter (World) (Aftermarket) (Unl)" - description "Cave Fighter (World) (Aftermarket) (Unl)" - rom ( name "Cave Fighter (World) (Aftermarket) (Unl).gbc" size 262144 crc 6f4641f0 sha1 05b441e3542452b1724017d20e2db602d0997773 ) + name "Feng Zhi Gou II (Taiwan) (Unl)" + description "Feng Zhi Gou II (Taiwan) (Unl)" + rom ( name "Feng Zhi Gou II (Taiwan) (Unl).gbc" size 2097152 crc 842cb4fe sha1 4322980e5b21332a71fb7fcadbf57a79aad6346b ) ) game ( - name "Cave Hunter (World) (GB Compatible) (Aftermarket) (Unl)" - description "Cave Hunter (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Cave Hunter (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc defb3151 sha1 94770d13bd9b1b52224fe753f94ec580e1b4017c ) + name "Fengkuang Dafuweng (Taiwan) (Unl)" + description "Fengkuang Dafuweng (Taiwan) (Unl)" + rom ( name "Fengkuang Dafuweng (Taiwan) (Unl).gbc" size 2097152 crc fbf62c35 sha1 7128a6ddbb44ba5ba226516996eb9a6077d365a9 ) ) game ( - name "Centipede (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - description "Centipede (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - rom ( name "Centipede (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 524288 crc 255db8be sha1 f8d2a8eab2a8a76a51006d438849509837f008d3 ) + name "Fengkuang Dafuweng (Taiwan) (Unl) (Alt)" + description "Fengkuang Dafuweng (Taiwan) (Unl) (Alt)" + rom ( name "Fengkuang Dafuweng (Taiwan) (Unl) (Alt).gbc" size 2097152 crc 45b79edc sha1 cc86e1247a352a7c7134db927cc41a1e9950fb96 ) ) game ( - name "Centipede (USA) (GB Compatible)" - description "Centipede (USA) (GB Compatible)" - rom ( name "Centipede (USA) (GB Compatible).gbc" size 1048576 crc 13ad07b1 sha1 3e964fb53517c286b97375e6988208987f7bfa21 ) + name "Ferret Monogatari (Japan)" + description "Ferret Monogatari (Japan)" + rom ( name "Ferret Monogatari (Japan).gbc" size 1048576 crc 8b742fb5 sha1 9a35dbd3d474f838e21584c249232ff8905b14c0 ) ) game ( - name "CGB Test Cartridge (Japan) (En) [b]" - description "CGB Test Cartridge (Japan) (En) [b]" - rom ( name "CGB Test Cartridge (Japan) (En) [b].gbc" size 65536 crc 4c050e29 sha1 5133d3dc7a4ced9d059dc72f0f351cb44e22f096 flags baddump ) + name "FGB (USA) (Proto) (2001-05-15)" + description "FGB (USA) (Proto) (2001-05-15)" + rom ( name "FGB (USA) (Proto) (2001-05-15).gbc" size 1048576 crc 800c74b6 sha1 dc41aa4e29ad4c0ba0bb1dee1e90c7bfb9506a46 ) ) game ( - name "Championship Motocross 2001 featuring Ricky Carmichael (USA, Europe)" - description "Championship Motocross 2001 featuring Ricky Carmichael (USA, Europe)" - rom ( name "Championship Motocross 2001 featuring Ricky Carmichael (USA, Europe).gbc" size 1048576 crc cbb336ed sha1 3712801102df2b17d1deb75fbe7fda0c1a596db0 ) + name "FIFA 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "FIFA 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "FIFA 2000 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e6bc2e8c sha1 c40dd26a6d600818eca960bade3afa374a19bc12 ) ) game ( - name "Chao Jinhua - Shuma Baobei D-3 (Taiwan) (Unl)" - description "Chao Jinhua - Shuma Baobei D-3 (Taiwan) (Unl)" - rom ( name "Chao Jinhua - Shuma Baobei D-3 (Taiwan) (Unl).gbc" size 1048576 crc 1517d27e sha1 0d14f2e2ab630b6f99a8125e5c0120c2d7967270 ) + name "Fish Files, The (Europe) (En,Fr,De,Es,It)" + description "Fish Files, The (Europe) (En,Fr,De,Es,It)" + rom ( name "Fish Files, The (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc d6abc1f8 sha1 07b071cbbca12234d9ee9bfb0a3f3a47aa2b0bfa ) ) game ( - name "Chao Jinhua - Shuma Baolong - Zuanshi Ban (Taiwan) (Unl)" - description "Chao Jinhua - Shuma Baolong - Zuanshi Ban (Taiwan) (Unl)" - rom ( name "Chao Jinhua - Shuma Baolong - Zuanshi Ban (Taiwan) (Unl).gbc" size 1048576 crc 50babe99 sha1 c153550886e812f5e37746fe1be6f294f13f97b3 ) + name "Fix & Foxi - Episode 1 - Lupo (Europe) (En,Fr,De)" + description "Fix & Foxi - Episode 1 - Lupo (Europe) (En,Fr,De)" + rom ( name "Fix & Foxi - Episode 1 - Lupo (Europe) (En,Fr,De).gbc" size 1048576 crc 5dfc61e8 sha1 6d14bf255eb042e7185da32137f679f4e2c24ce5 ) ) game ( - name "Chaoji Gedou 2001 Alpha (Taiwan) (Unl)" - description "Chaoji Gedou 2001 Alpha (Taiwan) (Unl)" - rom ( name "Chaoji Gedou 2001 Alpha (Taiwan) (Unl).gbc" size 2097152 crc afd7a0cc sha1 f44f629687ec91aade40ff52014587003f728ec9 flags verified ) + name "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It)" + description "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It)" + rom ( name "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc a5b09726 sha1 2f7fb1afedd6c9657715b45397dc5492e40dfe45 flags verified ) ) game ( - name "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl)" - description "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl)" - rom ( name "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl).gbc" size 2097152 crc 279be0cc sha1 c2a64ba4c1fd60829429330bc13b70d9bd18f023 ) + name "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It) (Beta)" + description "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It) (Beta)" + rom ( name "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It) (Beta).gbc" size 1048576 crc ecccd908 sha1 80ec102f3cf45602c6facffcdd44232650897dab ) ) game ( - name "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl) (Alt)" - description "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl) (Alt)" - rom ( name "Chaoji Jiqiren Dazhan X - Super Robot War X (Taiwan) (Unl) (Alt).gbc" size 2097152 crc 1feaeb47 sha1 26d5841fc898dab17458dc39e871dab4947a7f2b ) + name "Flintstones, The - Burgertime in Bedrock (USA)" + description "Flintstones, The - Burgertime in Bedrock (USA)" + rom ( name "Flintstones, The - Burgertime in Bedrock (USA).gbc" size 1048576 crc 14d8cc5d sha1 065851358f6720d4926faa42b015da68cafa6c28 ) ) game ( - name "Chaoji Yinsu de Xiaozi II - Super Sonik II (Taiwan) (Unl)" - description "Chaoji Yinsu de Xiaozi II - Super Sonik II (Taiwan) (Unl)" - rom ( name "Chaoji Yinsu de Xiaozi II - Super Sonik II (Taiwan) (Unl).gbc" size 2097152 crc a9dd9da7 sha1 006df0ddb10c5970002134da4d75ccc466e95edd ) + name "Flipper & Lopaka (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" + description "Flipper & Lopaka (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" + rom ( name "Flipper & Lopaka (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gbc" size 1048576 crc 08b9e4aa sha1 3d538b78ef5f1238f47531c069921056b00e33b3 ) ) game ( - name "Chaoren Tegong Dui (Taiwan) (Unl)" - description "Chaoren Tegong Dui (Taiwan) (Unl)" - rom ( name "Chaoren Tegong Dui (Taiwan) (Unl).gbc" size 2097152 crc e1d61242 sha1 31f54bdfa59d1e76777f044c1ef4686552f715f6 flags verified ) + name "Floracy (Europe) (Proto) (2000-10-10)" + description "Floracy (Europe) (Proto) (2000-10-10)" + rom ( name "Floracy (Europe) (Proto) (2000-10-10).gbc" size 524288 crc d760ccff sha1 bb24ea021d873990d2e381d711376ba1d300b81f ) ) game ( - name "Chase H.Q. - Secret Police (Europe) (SGB Enhanced) (GB Compatible)" - description "Chase H.Q. - Secret Police (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Chase H.Q. - Secret Police (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc cfdf816b sha1 e8770aeb76042fe5001dd48f55379350fa092a6f ) + name "Force 21 (USA) (En,Fr,De)" + description "Force 21 (USA) (En,Fr,De)" + rom ( name "Force 21 (USA) (En,Fr,De).gbc" size 1048576 crc 2dcd0a0a sha1 a1a912851bf265d6228dc807c58339cd51ec9d44 ) ) game ( - name "Chase H.Q. - Secret Police (USA) (SGB Enhanced) (GB Compatible)" - description "Chase H.Q. - Secret Police (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Chase H.Q. - Secret Police (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 7c7fdefc sha1 030b45eb8929c1512826f288e4ba035e0083505c ) + name "Formula One 2000 (USA)" + description "Formula One 2000 (USA)" + rom ( name "Formula One 2000 (USA).gbc" size 1048576 crc 703c057f sha1 7a38195842e536581fdcea42e4ebe50967581736 ) ) game ( - name "Chase the Chuck Wagon (World) (Aftermarket) (Unl)" - description "Chase the Chuck Wagon (World) (Aftermarket) (Unl)" - rom ( name "Chase the Chuck Wagon (World) (Aftermarket) (Unl).gbc" size 262144 crc 3c3d653c sha1 27b462be532a37c15798eba0fd48154eff596753 ) + name "Formula One 2000 (Europe) (En,Fr,De,Es,It) (Proto)" + description "Formula One 2000 (Europe) (En,Fr,De,Es,It) (Proto)" + rom ( name "Formula One 2000 (Europe) (En,Fr,De,Es,It) (Proto).gbc" size 1048576 crc e689bf16 sha1 7aa7073b7b494522f7cfcd268aa066b7fe52c671 ) ) game ( - name "Checkmate (Japan) (En,Ja) (GB Compatible)" - description "Checkmate (Japan) (En,Ja) (GB Compatible)" - rom ( name "Checkmate (Japan) (En,Ja) (GB Compatible).gbc" size 1048576 crc 1aab415d sha1 84e6c93daf1ab6c59bd23c0358a0704a663556b5 ) + name "Fort Boyard (Europe) (En,Fr,De,Es,It,Nl,Pt)" + description "Fort Boyard (Europe) (En,Fr,De,Es,It,Nl,Pt)" + rom ( name "Fort Boyard (Europe) (En,Fr,De,Es,It,Nl,Pt).gbc" size 1048576 crc 06c8e50a sha1 a5b2d892568bc44424577f0a62228d05aa355efd ) ) game ( - name "Chee-Chai Alien (Japan) (Rumble Version)" - description "Chee-Chai Alien (Japan) (Rumble Version)" - rom ( name "Chee-Chai Alien (Japan) (Rumble Version).gbc" size 4194304 crc 9e988ffe sha1 dec72ed497eb207d0e0af142c05fc813dab04385 flags verified ) + name "Freestyle Scooter (Europe)" + description "Freestyle Scooter (Europe)" + rom ( name "Freestyle Scooter (Europe).gbc" size 1048576 crc ee79117d sha1 cf6ae174584bbfb5ae30478841114443adc00245 ) ) game ( - name "Chessmaster (USA, Europe) (GB Compatible)" - description "Chessmaster (USA, Europe) (GB Compatible)" - rom ( name "Chessmaster (USA, Europe) (GB Compatible).gbc" size 1048576 crc 1c13dbb0 sha1 84930fa75eccc34a8e9fb6a0387791d437d1a442 flags verified ) + name "Frogger (USA) (Rev 2) (GB Compatible)" + description "Frogger (USA) (Rev 2) (GB Compatible)" + rom ( name "Frogger (USA) (Rev 2) (GB Compatible).gbc" size 1048576 crc d9a22e5d sha1 cf4801c7f82519344a50a25e35b1f5c7ee45c9a6 flags verified ) ) game ( - name "Chester's Big Ol' Day (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "Chester's Big Ol' Day (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Chester's Big Ol' Day (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 490a874a sha1 92567a6a58739a38e0d7b35d1327ccb999527fa0 ) + name "Frogger (USA) (Rev 1) (GB Compatible)" + description "Frogger (USA) (Rev 1) (GB Compatible)" + rom ( name "Frogger (USA) (Rev 1) (GB Compatible).gbc" size 1048576 crc ba907064 sha1 db3d21977c17a505936d1e2fc3626a0b43addf16 ) ) game ( - name "Chi to Ase to Namida no Koukou Yakyuu (Japan)" - description "Chi to Ase to Namida no Koukou Yakyuu (Japan)" - rom ( name "Chi to Ase to Namida no Koukou Yakyuu (Japan).gbc" size 1048576 crc 3c39bcab sha1 172d7a7048851a2d0a0be1f21a2a60176f038e01 ) + name "Frogger (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + description "Frogger (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + rom ( name "Frogger (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 524288 crc b6bf0672 sha1 538d2fa68e2e877a80bbdf4d58b2b4dcf051c17c ) ) game ( - name "Chibi Maruko-chan - Go Chounai Minna de Game Da yo! (Japan)" - description "Chibi Maruko-chan - Go Chounai Minna de Game Da yo! (Japan)" - rom ( name "Chibi Maruko-chan - Go Chounai Minna de Game Da yo! (Japan).gbc" size 1048576 crc 20faa0d1 sha1 31a0e557b36382f260a8297226e14737217c9763 ) + name "Frogger (USA) (GB Compatible)" + description "Frogger (USA) (GB Compatible)" + rom ( name "Frogger (USA) (GB Compatible).gbc" size 1048576 crc af46ea77 sha1 5b7c097a12a8408fd20b81289e03ad9ea2fd2691 ) ) game ( - name "Chicken Run (USA, Europe) (En,Fr,De,Es,It)" - description "Chicken Run (USA, Europe) (En,Fr,De,Es,It)" - rom ( name "Chicken Run (USA, Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc f8bd2a01 sha1 8dfd72e622c39ed8fd03046253474f38fb482c77 flags verified ) + name "Frogger 2 (USA)" + description "Frogger 2 (USA)" + rom ( name "Frogger 2 (USA).gbc" size 1048576 crc 6a2666aa sha1 566e0afb3a6f25342399a3e39f3fbcacef68eb72 ) ) game ( - name "Chiki Chiki Machine Mou Race (Japan)" - description "Chiki Chiki Machine Mou Race (Japan)" - rom ( name "Chiki Chiki Machine Mou Race (Japan).gbc" size 1048576 crc 36c04be0 sha1 77ccf3a535e21e28d73059d3bfe42b58fee17d2a ) + name "Frogger 2 (USA) (Rev 1)" + description "Frogger 2 (USA) (Rev 1)" + rom ( name "Frogger 2 (USA) (Rev 1).gbc" size 1048576 crc e3227b7d sha1 0d5028ca6fcc10df46d11cd4b56e5add1dc5e63e ) ) game ( - name "Chongwu Xiao Jingling - Jiejin Ta Zhi Wang (Taiwan) (Unl)" - description "Chongwu Xiao Jingling - Jiejin Ta Zhi Wang (Taiwan) (Unl)" - rom ( name "Chongwu Xiao Jingling - Jiejin Ta Zhi Wang (Taiwan) (Unl).gbc" size 1048576 crc 620e785d sha1 74da832c2eeb27a4260fe6f42514539473f48b11 ) + name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 1) (SGB Enhanced) (GB Compatible)" + description "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 1) (SGB Enhanced) (GB Compatible)" + rom ( name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 1) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc a86de7b7 sha1 f2c04440f5d668b14623c924faec460f63158a29 ) ) game ( - name "Chopper War (World) (Aftermarket) (Unl)" - description "Chopper War (World) (Aftermarket) (Unl)" - rom ( name "Chopper War (World) (Aftermarket) (Unl).gbc" size 524288 crc eb0f4f3e sha1 26970bb0753e792aaeb328e0f88d650acd413a9d ) + name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 2) (SGB Enhanced) (GB Compatible)" + description "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 2) (SGB Enhanced) (GB Compatible)" + rom ( name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 2) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 419befcc sha1 e11809babdca45527b81d7db02741263407aeb46 ) ) game ( - name "Choro Q - Hyper Customable GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Choro Q - Hyper Customable GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Choro Q - Hyper Customable GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 65610ca4 sha1 8af215c632599aaab9bc4614194ac45802407bbc ) + name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (SGB Enhanced) (GB Compatible)" + description "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc a7317bb8 sha1 7fa5fbb94390876dee807216c2097cdb42510efe flags verified ) ) game ( - name "Choro-Q (World) (Aftermarket) (Unl)" - description "Choro-Q (World) (Aftermarket) (Unl)" - rom ( name "Choro-Q (World) (Aftermarket) (Unl).gbc" size 262144 crc e40e99bd sha1 8534c4fe58aef32b8cfd4812fa1f2c1094e6b129 ) + name "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (SGB Enhanced) (GB Compatible)" + description "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc c693aa37 sha1 459f1ae41f6c5c6464745a23ea42bbba5385a83b flags verified ) ) game ( - name "Chuanshuo (Taiwan) (Unl)" - description "Chuanshuo (Taiwan) (Unl)" - rom ( name "Chuanshuo (Taiwan) (Unl).gbc" size 2097152 crc 0b20d3af sha1 f390b702d4b160149c1030bcccb5ed6f76c0b94a ) + name "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc a4dde805 sha1 53da28b16a4bf0efab1f65c21f7931ce4948865b flags verified ) ) game ( - name "Classic Bubble Bobble (Europe) (SGB Enhanced) (GB Compatible)" - description "Classic Bubble Bobble (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Classic Bubble Bobble (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a0f66d87 sha1 3c52b09072077c210af93e4b13c3ee0886676f83 ) + name "Front Line - The Next Mission (Japan)" + description "Front Line - The Next Mission (Japan)" + rom ( name "Front Line - The Next Mission (Japan).gbc" size 1048576 crc f48e1643 sha1 7456b221f95a64f36a70d024477032a4b6615948 ) ) game ( - name "Classic Bubble Bobble (USA) (SGB Enhanced) (GB Compatible)" - description "Classic Bubble Bobble (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Classic Bubble Bobble (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c1b22246 sha1 6e3739c0538467c220750f2e8d474433692bac09 ) + name "Front Row (Japan)" + description "Front Row (Japan)" + rom ( name "Front Row (Japan).gbc" size 1048576 crc 6eea9243 sha1 64c8a9459d7c80e297774dab7775b5edf59432cc ) ) game ( - name "Climb It (World) (Aftermarket) (Unl)" - description "Climb It (World) (Aftermarket) (Unl)" - rom ( name "Climb It (World) (Aftermarket) (Unl).gbc" size 262144 crc e7210290 sha1 19f3b825eada3eda3135350bd0ddca6a20a5281f ) + name "Full Time Soccer (Europe) (Unl)" + description "Full Time Soccer (Europe) (Unl)" + rom ( name "Full Time Soccer (Europe) (Unl).gbc" size 262144 crc b99beda2 sha1 a2b1268df08b583d033999b894638dadf32e37f4 ) ) game ( - name "Clockmaker's Tale, A (World) (GB Compatible) (Aftermarket) (Unl)" - description "Clockmaker's Tale, A (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Clockmaker's Tale, A (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c4b00adb sha1 07e4254c7f74b9d4caa6a1231558b2430dff163a flags verified ) + name "Full Time Soccer & Hang Time Basketball (Europe) (Unl)" + description "Full Time Soccer & Hang Time Basketball (Europe) (Unl)" + rom ( name "Full Time Soccer & Hang Time Basketball (Europe) (Unl).gbc" size 524288 crc 0634c196 sha1 aefb746984b3450b90bbfaa5de21a252685ddabb ) ) game ( - name "Colin McRae Rally (Europe)" - description "Colin McRae Rally (Europe)" - rom ( name "Colin McRae Rally (Europe).gbc" size 2097152 crc e93af9c8 sha1 0b824ba294248c185967bc813eba1faa26a320cc ) + name "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (AFMJ)" + description "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (AFMJ)" + rom ( name "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (AFMJ).gbc" size 4194304 crc 2c97e90f sha1 5264f6d0c4f12c9144de1d12fddadbadd82b3e33 ) ) game ( - name "Columns GB - Tezuka Osamu Characters (Japan) (SGB Enhanced) (GB Compatible)" - description "Columns GB - Tezuka Osamu Characters (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Columns GB - Tezuka Osamu Characters (Japan) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc fbe5de37 sha1 a8d9a6631f1d203d99be38fb90135c10e5f0c880 ) + name "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (BFWJ)" + description "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (BFWJ)" + rom ( name "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (BFWJ).gbc" size 4194304 crc f3c20fbe sha1 d9c490af97c08ac7053bbb9f7ae06d3501035127 flags verified ) ) game ( - name "Command Master (Japan)" - description "Command Master (Japan)" - rom ( name "Command Master (Japan).gbc" size 2097152 crc d10b5645 sha1 f1d3a1ff7a76c49ce3e094ca994d488dbdadf9a2 flags verified ) + name "Gaiamaster Duel - Card Attackers (Japan)" + description "Gaiamaster Duel - Card Attackers (Japan)" + rom ( name "Gaiamaster Duel - Card Attackers (Japan).gbc" size 2097152 crc 78206460 sha1 26601cd806c588b232ea1275b2bcb434ccd81e6d ) ) game ( - name "Commander Keen (USA, Europe)" - description "Commander Keen (USA, Europe)" - rom ( name "Commander Keen (USA, Europe).gbc" size 1048576 crc 4af4cc9c sha1 a00b7bdaaedeb67ad7e7555139301c8b4c92edea flags verified ) + name "Gakkyuu Ou Yamazaki (Japan) (Rev 1) (GB Compatible)" + description "Gakkyuu Ou Yamazaki (Japan) (Rev 1) (GB Compatible)" + rom ( name "Gakkyuu Ou Yamazaki (Japan) (Rev 1) (GB Compatible).gbc" size 1048576 crc ef2cfd99 sha1 3a2718efa3d1cac7345fbbcddb7c3f666fc6c70c flags verified ) ) game ( - name "Commando (World) (Aftermarket) (Unl)" - description "Commando (World) (Aftermarket) (Unl)" - rom ( name "Commando (World) (Aftermarket) (Unl).gbc" size 262144 crc 5381b103 sha1 414bb6bdc1ed5647707d7d49f194c387d4098f00 ) + name "Gakkyuu Ou Yamazaki (Japan) (Possible Proto) (GB Compatible)" + description "Gakkyuu Ou Yamazaki (Japan) (Possible Proto) (GB Compatible)" + rom ( name "Gakkyuu Ou Yamazaki (Japan) (Possible Proto) (GB Compatible).gbc" size 1048576 crc b8147b5c sha1 132b872391565d418ccc9d0e1c643510d778c066 ) ) game ( - name "Conker's Pocket Tales (USA, Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - description "Conker's Pocket Tales (USA, Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - rom ( name "Conker's Pocket Tales (USA, Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc a50be9a8 sha1 e9c3b1bb20ea74f363191ea9144009d1b13246bb flags verified ) + name "Galaga - Destination Earth (USA)" + description "Galaga - Destination Earth (USA)" + rom ( name "Galaga - Destination Earth (USA).gbc" size 1048576 crc e3c4abc6 sha1 e2d16612c7cbeb3da07be696d154e366cbb3fcdd ) ) game ( - name "Cookie's Bakery (World) (v1.0.3) (GB Compatible) (Aftermarket) (Unl)" - description "Cookie's Bakery (World) (v1.0.3) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Cookie's Bakery (World) (v1.0.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc c53ace00 sha1 02fdc52bc934b80aa41520d92cf0340753d8f668 ) + name "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan)" + description "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan)" + rom ( name "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan).gbc" size 1048576 crc 28356950 sha1 8ba0973997bdaeecdf23c45a4fb7e18e06132dfb ) ) game ( - name "Cool Bricks (Europe) (En,Fr,De,Es,It)" - description "Cool Bricks (Europe) (En,Fr,De,Es,It)" - rom ( name "Cool Bricks (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 04fe7790 sha1 0f0410e2ee2ce1a9e6b12399492f8bd2ddf67406 ) + name "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan) (Rev 1)" + description "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan) (Rev 1)" + rom ( name "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan) (Rev 1).gbc" size 1048576 crc 91739def sha1 b62f8e56b995874c0e1a2533df5a37f6996df12e flags verified ) ) game ( - name "Cool Hand (Europe) (En,Fr,De) (GB Compatible)" - description "Cool Hand (Europe) (En,Fr,De) (GB Compatible)" - rom ( name "Cool Hand (Europe) (En,Fr,De) (GB Compatible).gbc" size 524288 crc e6c91fb8 sha1 d116a77c501d5e553d1490993f8c0a9a92c3ea0c ) + name "Game & Watch Gallery 2 (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Game & Watch Gallery 2 (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Game & Watch Gallery 2 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 969c8961 sha1 ce81d3260e8c5e1dd241caf6de315eb3e63dbc15 flags verified ) ) game ( - name "Coria and the Sunken City (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Coria and the Sunken City (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Coria and the Sunken City (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc fe1bdae6 sha1 00d86bbdbc228ff3ea0684984a261cadbed5fb0a ) + name "Game & Watch Gallery 3 (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Game & Watch Gallery 3 (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Game & Watch Gallery 3 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1ac625da sha1 64ccb3b41715080a9aa13970678aa9047fc7a9fd flags verified ) ) game ( - name "Cosmo Knight ZiON (World) (En) (v0.24) (Demo) (Aftermarket) (Unl)" - description "Cosmo Knight ZiON (World) (En) (v0.24) (Demo) (Aftermarket) (Unl)" - rom ( name "Cosmo Knight ZiON (World) (En) (v0.24) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc 1780b904 sha1 fcbe2c2389e6c51a38eb17eb80ffb2e51955c7f2 ) + name "Game Boy Color (World) (Demo) (Kiosk)" + description "Game Boy Color (World) (Demo) (Kiosk)" + rom ( name "Game Boy Color (World) (Demo) (Kiosk).gbc" size 524288 crc f5e9aa8c sha1 bcbc9ede4a06e52e5dea809e20e0b34901b6ae91 flags verified ) ) game ( - name "Cosmo Knight ZiON (World) (En,Es) (v0.47) (Demo) (Aftermarket) (Unl)" - description "Cosmo Knight ZiON (World) (En,Es) (v0.47) (Demo) (Aftermarket) (Unl)" - rom ( name "Cosmo Knight ZiON (World) (En,Es) (v0.47) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc e983a31f sha1 1d811dd440572243f9e95527d970f3ffa91ddbdf ) + name "Game Boy Gallery 2 (Japan) (Possible Proto) (SGB Enhanced, GB Compatible) (NP)" + description "Game Boy Gallery 2 (Japan) (Possible Proto) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Game Boy Gallery 2 (Japan) (Possible Proto) (SGB Enhanced, GB Compatible) (NP).gbc" size 1048576 crc e99beba5 sha1 90a9b368bca0f47fe72028ff4d50fb3d3060c32f ) ) game ( - name "Crazy Bikers (Europe)" - description "Crazy Bikers (Europe)" - rom ( name "Crazy Bikers (Europe).gbc" size 1048576 crc 53e02b87 sha1 c625608b5165e971827af8434e72d8ca8d200ab8 ) + name "Game Boy Gallery 3 (Australia) (SGB Enhanced) (GB Compatible)" + description "Game Boy Gallery 3 (Australia) (SGB Enhanced) (GB Compatible)" + rom ( name "Game Boy Gallery 3 (Australia) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6935fea1 sha1 fde6a70e7ad6a3a116d918435f7efbc1fd95b4cc flags verified ) ) game ( - name "Crazy Climber (USA) (Proto 2) (2000-11-21)" - description "Crazy Climber (USA) (Proto 2) (2000-11-21)" - rom ( name "Crazy Climber (USA) (Proto 2) (2000-11-21).gbc" size 131072 crc 45389344 sha1 68979eb91a968998c2fb58396971265be5b312ca ) + name "Game Boy Gallery 3 (Japan) (SGB Enhanced) (GB Compatible)" + description "Game Boy Gallery 3 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Game Boy Gallery 3 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 149f807e sha1 18c3e0a015fa79c8694b8554e3c46fd67f034c71 flags verified ) ) game ( - name "Crazy Climber (USA) (Proto 1) (2000-09-22)" - description "Crazy Climber (USA) (Proto 1) (2000-09-22)" - rom ( name "Crazy Climber (USA) (Proto 1) (2000-09-22).gbc" size 131072 crc 748fa8b4 sha1 eb0eaed85cf5a72e0461eebbad38227bd018a999 ) + name "Game Boy Gallery 4 (Australia) (SGB Enhanced) (GB Compatible)" + description "Game Boy Gallery 4 (Australia) (SGB Enhanced) (GB Compatible)" + rom ( name "Game Boy Gallery 4 (Australia) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 2549fdde sha1 fb8b98ae16f79fd70d2c0f0911dfcb2fdf1e7149 flags verified ) ) game ( - name "Crazy Golf (World) (Aftermarket) (Unl)" - description "Crazy Golf (World) (Aftermarket) (Unl)" - rom ( name "Crazy Golf (World) (Aftermarket) (Unl).gbc" size 262144 crc f7fe3d01 sha1 b06f47a713b66efa9133be43653c7c4cb5ebc93c ) + name "Game Boy Wars 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Game Boy Wars 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Game Boy Wars 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c69dc37b sha1 db511650fdc9a6c130add7eada9562b6443b565d ) ) game ( - name "Croc (USA, Europe)" - description "Croc (USA, Europe)" - rom ( name "Croc (USA, Europe).gbc" size 1048576 crc 4664a167 sha1 dac6de548743c6b51a3daa5903c28b7fccdb6cb2 ) + name "Game Boy Wars 3 (Japan)" + description "Game Boy Wars 3 (Japan)" + rom ( name "Game Boy Wars 3 (Japan).gbc" size 1048576 crc 30c26262 sha1 61e08f96261b5f85c65c70db5464b4298f9f2cf8 flags verified ) ) game ( - name "Croc 2 (USA, Europe)" - description "Croc 2 (USA, Europe)" - rom ( name "Croc 2 (USA, Europe).gbc" size 1048576 crc c1d60129 sha1 fa29d6c4239405b12b320bb6e8a65ca2083a4b1c ) + name "Game Boy Wars Pocket Tactics (Japan) (Beta)" + description "Game Boy Wars Pocket Tactics (Japan) (Beta)" + rom ( name "Game Boy Wars Pocket Tactics (Japan) (Beta).gbc" size 1048576 crc 7e8ea9a5 sha1 a729d9ecd2b2abcd04b11122183f48c303d227b1 ) ) game ( - name "Cross Country Racing (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - description "Cross Country Racing (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - rom ( name "Cross Country Racing (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b7b91fe9 sha1 67bcac922b14a6fde311ca693f297248ceebbea6 ) + name "Game Conveni 21 (Japan) (GB Compatible)" + description "Game Conveni 21 (Japan) (GB Compatible)" + rom ( name "Game Conveni 21 (Japan) (GB Compatible).gbc" size 1048576 crc 994314b3 sha1 6803617abc46db83dbec08d10e03b9f9297f260e ) ) game ( - name "Cross Hunter - Monster Hunter Version (Japan)" - description "Cross Hunter - Monster Hunter Version (Japan)" - rom ( name "Cross Hunter - Monster Hunter Version (Japan).gbc" size 4194304 crc 48e1ba7d sha1 15383fdba1bca2c11ed00dc271b4a6f69d500f75 ) + name "Games Frenzy (Europe) (En,Fr,De)" + description "Games Frenzy (Europe) (En,Fr,De)" + rom ( name "Games Frenzy (Europe) (En,Fr,De).gbc" size 1048576 crc 308a4ccb sha1 fd3c38d61b723e12614fa5e0b809d083827b9ae5 ) ) game ( - name "Cross Hunter - Treasure Hunter Version (Japan)" - description "Cross Hunter - Treasure Hunter Version (Japan)" - rom ( name "Cross Hunter - Treasure Hunter Version (Japan).gbc" size 4194304 crc 623c1516 sha1 b54fcdebd54484113923b899eed7c63550609f74 ) + name "GameShark MX (USA) (v1.02) (Unl)" + description "GameShark MX (USA) (v1.02) (Unl)" + rom ( name "GameShark MX (USA) (v1.02) (Unl).gbc" size 262144 crc 300e03ba sha1 d3eb3e7bc9042a3a9bdc6017620842c52d07cb07 ) ) game ( - name "Cross Hunter - X Hunter Version (Japan)" - description "Cross Hunter - X Hunter Version (Japan)" - rom ( name "Cross Hunter - X Hunter Version (Japan).gbc" size 4194304 crc 858010e0 sha1 2c9d8994635957f1080d785f47a596e02880be6c ) + name "GameShark Online (USA) (Unl)" + description "GameShark Online (USA) (Unl)" + rom ( name "GameShark Online (USA) (Unl).gbc" size 81920 crc c37d21d9 sha1 22f00e604acb827a48d4c9e109ba622f59a9d0a9 ) ) game ( - name "Cruis'n Exotica (USA)" - description "Cruis'n Exotica (USA)" - rom ( name "Cruis'n Exotica (USA).gbc" size 2097152 crc 9562e7e8 sha1 e3f7bab776d76048a6cf1745fb4d8ecaf2d44f46 ) + name "Ganbare Goemon - Mononoke Douchuu Tobidase Nabebugyou! (Japan) (SGB Enhanced) (GB Compatible)" + description "Ganbare Goemon - Mononoke Douchuu Tobidase Nabebugyou! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Ganbare Goemon - Mononoke Douchuu Tobidase Nabebugyou! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 73311cfa sha1 4bc3928f3528a2c566b09613e538253dd128864c ) ) game ( - name "Crystalis (USA)" - description "Crystalis (USA)" - rom ( name "Crystalis (USA).gbc" size 2097152 crc 909bb02d sha1 85d9cfaae2ae4995d834cc9b95ec3126707a6332 ) + name "Ganbare Goemon - Seikuushi Dynamites Arawaru!! (Japan)" + description "Ganbare Goemon - Seikuushi Dynamites Arawaru!! (Japan)" + rom ( name "Ganbare Goemon - Seikuushi Dynamites Arawaru!! (Japan).gbc" size 1048576 crc 2ea8d9d4 sha1 fc44dd6ac4a91ab32dc7096a364406433b48b7d8 ) ) game ( - name "Cubix - Robots for Everyone - Race 'n Robots (USA) (En,Fr,De,Es,It)" - description "Cubix - Robots for Everyone - Race 'n Robots (USA) (En,Fr,De,Es,It)" - rom ( name "Cubix - Robots for Everyone - Race 'n Robots (USA) (En,Fr,De,Es,It).gbc" size 1048576 crc 9f883b0f sha1 d62b85c664e0a42c84e56b939a201fe90d05a360 ) + name "Ganbare Goemon - Tengutou no Gyakushuu (Japan) (GB Compatible)" + description "Ganbare Goemon - Tengutou no Gyakushuu (Japan) (GB Compatible)" + rom ( name "Ganbare Goemon - Tengutou no Gyakushuu (Japan) (GB Compatible).gbc" size 1048576 crc d829eb2f sha1 337cbcbd185a74c6fd5b10823fda3dcf8dca30e4 ) ) game ( - name "Cuthbert in the Cooler (World) (Aftermarket) (Unl)" - description "Cuthbert in the Cooler (World) (Aftermarket) (Unl)" - rom ( name "Cuthbert in the Cooler (World) (Aftermarket) (Unl).gbc" size 262144 crc 30204c4e sha1 d6fb35f3bdd44429f88c10551692e1adf14356ab ) + name "Ganbare! Nippon! Olympic 2000 (Japan)" + description "Ganbare! Nippon! Olympic 2000 (Japan)" + rom ( name "Ganbare! Nippon! Olympic 2000 (Japan).gbc" size 1048576 crc ffd919a7 sha1 5abaac9c4cb3d06e20fcb4c9985a6c4b52e62871 ) ) game ( - name "CyberTiger (USA, Europe)" - description "CyberTiger (USA, Europe)" - rom ( name "CyberTiger (USA, Europe).gbc" size 1048576 crc e470cafa sha1 3eb14447bd2a349be16eb6e51066c65a51b35e69 flags verified ) + name "Gangdan Wuyu 2 (Taiwan) (Unl)" + description "Gangdan Wuyu 2 (Taiwan) (Unl)" + rom ( name "Gangdan Wuyu 2 (Taiwan) (Unl).gbc" size 2097152 crc 09dee8cb sha1 6753a7a34f057f952172dff5ef9e8961d3af6649 ) ) game ( - name "Cyborg Kuro-chan - Devil Fukkatsu (Japan)" - description "Cyborg Kuro-chan - Devil Fukkatsu (Japan)" - rom ( name "Cyborg Kuro-chan - Devil Fukkatsu (Japan).gbc" size 1048576 crc 392d630f sha1 b544d1a49128bc5ab3664ced872d2d1dcc51b667 ) + name "Ganso! Doubutsu Uranai (Japan) (Proto)" + description "Ganso! Doubutsu Uranai (Japan) (Proto)" + rom ( name "Ganso! Doubutsu Uranai (Japan) (Proto).gbc" size 1048576 crc 58421179 sha1 d2512b7bb05771deac7b732cce17671d7807273d ) ) game ( - name "Cyborg Kuro-chan 2 - White Woods no Gyakushuu (Japan)" - description "Cyborg Kuro-chan 2 - White Woods no Gyakushuu (Japan)" - rom ( name "Cyborg Kuro-chan 2 - White Woods no Gyakushuu (Japan).gbc" size 1048576 crc e86bf12e sha1 8ce6261de9dc2ae1a02a2ac00fa45b855fae34a2 ) + name "GB Harobots (Japan)" + description "GB Harobots (Japan)" + rom ( name "GB Harobots (Japan).gbc" size 2097152 crc 1c0368fa sha1 0fc2198938fcd259c525591f74c8aae4b048f298 ) ) game ( - name "Daa! Daa! Daa! - Totsuzen Card de Battle de Uranai de! (Japan)" - description "Daa! Daa! Daa! - Totsuzen Card de Battle de Uranai de! (Japan)" - rom ( name "Daa! Daa! Daa! - Totsuzen Card de Battle de Uranai de! (Japan).gbc" size 1048576 crc f41bb392 sha1 b716720f25ec84fa51181125494a009345d0b20f ) + name "GB Karan Koron Gakuen - Hanafuda Mahjong (Japan)" + description "GB Karan Koron Gakuen - Hanafuda Mahjong (Japan)" + rom ( name "GB Karan Koron Gakuen - Hanafuda Mahjong (Japan).gbc" size 2097152 crc aaba1ea4 sha1 8e84f233279c543799663bd7c62b4f2fb84e5dff ) ) game ( - name "Daffy Duck - Fowl Play (USA, Europe) (GB Compatible)" - description "Daffy Duck - Fowl Play (USA, Europe) (GB Compatible)" - rom ( name "Daffy Duck - Fowl Play (USA, Europe) (GB Compatible).gbc" size 1048576 crc 45ebf09c sha1 5d9373d934dc3c672ff426960d565d8cf635925b ) + name "GB-Memory Multi Menu (Japan) (SGB Enhanced, GB Compatible) (NP)" + description "GB-Memory Multi Menu (Japan) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "GB-Memory Multi Menu (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 131072 crc ec823cc1 sha1 0781eaecb7fd25c068e396b5eb02c6231baf6ea3 ) ) game ( - name "Daffy Duck - Subette Koron de Oogane Mochi (Japan) (GB Compatible)" - description "Daffy Duck - Subette Koron de Oogane Mochi (Japan) (GB Compatible)" - rom ( name "Daffy Duck - Subette Koron de Oogane Mochi (Japan) (GB Compatible).gbc" size 1048576 crc 5b4507d9 sha1 5578b7973a65eea2f09c6150b9154377d237da75 ) + name "Gedou Jian Shen - Soul Falchion (Taiwan) (En) (Unl) (Alt 2)" + description "Gedou Jian Shen - Soul Falchion (Taiwan) (En) (Unl) (Alt 2)" + rom ( name "Gedou Jian Shen - Soul Falchion (Taiwan) (En) (Unl) (Alt 2).gbc" size 1048576 crc 7afae089 sha1 b33c9f5012cc1a1a8c7ac9d95a183fd28d9bf9f3 ) ) game ( - name "Daikaijuu Monogatari - Poyon no Dungeon Room (Japan) (SGB Enhanced) (GB Compatible)" - description "Daikaijuu Monogatari - Poyon no Dungeon Room (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Daikaijuu Monogatari - Poyon no Dungeon Room (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 2f368da6 sha1 0854b7ea4791a460c75ce9096583934b1af053e8 flags verified ) + name "Gedou Jian Shen - Soul Falchion (Taiwan) (En) (Unl) (Alt)" + description "Gedou Jian Shen - Soul Falchion (Taiwan) (En) (Unl) (Alt)" + rom ( name "Gedou Jian Shen - Soul Falchion (Taiwan) (En) (Unl) (Alt).gbc" size 1048576 crc c0ac1b50 sha1 4dcef6fcfe009e17da0bb13e50e7410a3f586e23 ) ) game ( - name "Daikaijuu Monogatari - Poyon no Dungeon Room 2 (Japan)" - description "Daikaijuu Monogatari - Poyon no Dungeon Room 2 (Japan)" - rom ( name "Daikaijuu Monogatari - Poyon no Dungeon Room 2 (Japan).gbc" size 2097152 crc 5e312730 sha1 e9bc47efd971f2caf9ebe9b4d85516d3813d8247 ) + name "Gedou Jian Shen - Soul Falchion (Taiwan) (En) (Unl)" + description "Gedou Jian Shen - Soul Falchion (Taiwan) (En) (Unl)" + rom ( name "Gedou Jian Shen - Soul Falchion (Taiwan) (En) (Unl).gbc" size 1048576 crc 1b1c6f68 sha1 fd06c62b42878e8094e610b180c1848c785f67e9 ) ) game ( - name "Daikaijuu Monogatari - The Miracle of the Zone II (Japan) (SGB Enhanced) (GB Compatible)" - description "Daikaijuu Monogatari - The Miracle of the Zone II (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Daikaijuu Monogatari - The Miracle of the Zone II (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 692d6794 sha1 7bf6e2d7fc58e8abe61785e413bcf4150fa8bee5 flags verified ) + name "Gedou Jian Shen KF (Taiwan) (En) (Unl)" + description "Gedou Jian Shen KF (Taiwan) (En) (Unl)" + rom ( name "Gedou Jian Shen KF (Taiwan) (En) (Unl).gbc" size 1048576 crc 190702b3 sha1 be03f86ef0c6df8c6741fe1298496670fcc682cf ) ) game ( - name "Daikatana (USA) (Proto 1) (2000-04-19)" - description "Daikatana (USA) (Proto 1) (2000-04-19)" - rom ( name "Daikatana (USA) (Proto 1) (2000-04-19).gbc" size 4194304 crc 351862bb sha1 361d05119aa6671415a8c583150dbfa4dfd93e5e ) + name "Gedou Qi Long Qiu 2002 (Taiwan) (Zh) (Unl)" + description "Gedou Qi Long Qiu 2002 (Taiwan) (Zh) (Unl)" + rom ( name "Gedou Qi Long Qiu 2002 (Taiwan) (Zh) (Unl).gbc" size 2097152 crc 8fa35740 sha1 008a559635c9d351d9f68b3a1ac0c687521821cf ) ) game ( - name "Daikatana (USA) (Proto 2)" - description "Daikatana (USA) (Proto 2)" - rom ( name "Daikatana (USA) (Proto 2).gbc" size 1048576 crc 7d451688 sha1 6eef48f4d467596ff3734bb9ac12db392170eb14 ) + name "Gedou Zhizun 2003 (Taiwan) (Unl)" + description "Gedou Zhizun 2003 (Taiwan) (Unl)" + rom ( name "Gedou Zhizun 2003 (Taiwan) (Unl).gbc" size 1048576 crc f7630d88 sha1 f43c4055f69a1ff6b325494b5b34c8043914cd9d ) ) game ( - name "Daikatana GB (Japan) (NP)" - description "Daikatana GB (Japan) (NP)" - rom ( name "Daikatana GB (Japan) (NP).gbc" size 1048576 crc 2bb01aad sha1 268aef9fa88a4921bdc10c1828cd88b49d65635e ) + name "Geheimnis der Happy Hippo-Insel, Das (Germany)" + description "Geheimnis der Happy Hippo-Insel, Das (Germany)" + rom ( name "Geheimnis der Happy Hippo-Insel, Das (Germany).gbc" size 1048576 crc 25b480c3 sha1 f2ab35743f477a98007665f2a5686ab4da2b9049 flags verified ) ) game ( - name "Daiku no Gen-san - Kachikachi no Tonkachi ga Kachi (Japan) (SGB Enhanced) (GB Compatible)" - description "Daiku no Gen-san - Kachikachi no Tonkachi ga Kachi (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Daiku no Gen-san - Kachikachi no Tonkachi ga Kachi (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e2071293 sha1 2d961353e7242babce49dda8d017a459f4ef7609 ) + name "Gekido (Europe) (Proto) (2000-09-04)" + description "Gekido (Europe) (Proto) (2000-09-04)" + rom ( name "Gekido (Europe) (Proto) (2000-09-04).gbc" size 262144 crc 4869c684 sha1 41b65a1399f92162f06423cb27d6ee25d3fcfa8d ) ) game ( - name "Daisu-ki (World) (v1.2.1) (Aftermarket) (Unl)" - description "Daisu-ki (World) (v1.2.1) (Aftermarket) (Unl)" - rom ( name "Daisu-ki (World) (v1.2.1) (Aftermarket) (Unl).gbc" size 262144 crc 502385c4 sha1 3a310be21d5cc077da6eb8e3afa99ccff2eda84e ) + name "Gekisou Dangun Racer - Onsoku Buster Dangun Dan (Japan)" + description "Gekisou Dangun Racer - Onsoku Buster Dangun Dan (Japan)" + rom ( name "Gekisou Dangun Racer - Onsoku Buster Dangun Dan (Japan).gbc" size 2097152 crc 06fccefc sha1 0b9c99a614d31cc0cb4047deeee6de76b64a5f8b ) ) game ( - name "Daisu-ki (World) (v1.1) (Aftermarket) (Unl)" - description "Daisu-ki (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Daisu-ki (World) (v1.1) (Aftermarket) (Unl).gbc" size 262144 crc a504b906 sha1 4634631f2c0b4a618aeefc114e5b8e4ba9c7ee04 ) + name "Gem Gem Monster (Japan) (SGB Enhanced) (GB Compatible)" + description "Gem Gem Monster (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Gem Gem Monster (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc de7505c0 sha1 8b1396cf9dbc77246b3443810282b8b9bcb65a67 ) ) game ( - name "Daisu-ki (World) (v1.1.1) (Aftermarket) (Unl)" - description "Daisu-ki (World) (v1.1.1) (Aftermarket) (Unl)" - rom ( name "Daisu-ki (World) (v1.1.1) (Aftermarket) (Unl).gbc" size 262144 crc a9714871 sha1 7d5b22d1c528603007e340f9d3562c1e53f10796 ) + name "Gensou Maden Saiyuuki - Sabaku no Shijin (Japan)" + description "Gensou Maden Saiyuuki - Sabaku no Shijin (Japan)" + rom ( name "Gensou Maden Saiyuuki - Sabaku no Shijin (Japan).gbc" size 1048576 crc 918a40e7 sha1 9226b76621495ae0fc893c0a835973605414638f ) ) game ( - name "Daisu-ki (World) (v1.2) (Aftermarket) (Unl)" - description "Daisu-ki (World) (v1.2) (Aftermarket) (Unl)" - rom ( name "Daisu-ki (World) (v1.2) (Aftermarket) (Unl).gbc" size 262144 crc 26d3fe7a sha1 36c9649d4e99fdcaa4cf590963d0c49a3cf8084e ) + name "Get Chuu Club - Minna no Konchuu Daizukan (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" + description "Get Chuu Club - Minna no Konchuu Daizukan (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" + rom ( name "Get Chuu Club - Minna no Konchuu Daizukan (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 9ebdb6c6 sha1 8a04a1c6374df1d6393a8af395422b63aad2e3d1 ) ) game ( - name "Daisu-ki - Jam Edition (World) (GB Compatible) (Aftermarket) (Unl)" - description "Daisu-ki - Jam Edition (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Daisu-ki - Jam Edition (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc d34b719a sha1 446ca937d3e54ce33a49d1fff4692b3b906b539e ) + name "Gex - Enter the Gecko (USA, Europe) (GB Compatible)" + description "Gex - Enter the Gecko (USA, Europe) (GB Compatible)" + rom ( name "Gex - Enter the Gecko (USA, Europe) (GB Compatible).gbc" size 1048576 crc dccc7514 sha1 a05a530b3272634c8d3fedb6fd6eaf8b00b5cf9c ) ) game ( - name "Dance Dance Revolution GB (Japan)" - description "Dance Dance Revolution GB (Japan)" - rom ( name "Dance Dance Revolution GB (Japan).gbc" size 2097152 crc c64ff2b6 sha1 5be4cc1a810b48b843b60b5b37b2012a47e5742b ) + name "Gex 3 - Deep Cover Gecko (Europe) (En,Fr,De,Es,It)" + description "Gex 3 - Deep Cover Gecko (Europe) (En,Fr,De,Es,It)" + rom ( name "Gex 3 - Deep Cover Gecko (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 025f305d sha1 176ec4347ce08b15214e68fcec39c9c4c57ad773 ) ) game ( - name "Dance Dance Revolution GB - Disney Mix (Japan)" - description "Dance Dance Revolution GB - Disney Mix (Japan)" - rom ( name "Dance Dance Revolution GB - Disney Mix (Japan).gbc" size 2097152 crc b31a59bf sha1 91c653d792ddaadf6cab9f6b1d62d4194cd23c1a ) + name "Gex 3 - Deep Pocket Gecko (USA)" + description "Gex 3 - Deep Pocket Gecko (USA)" + rom ( name "Gex 3 - Deep Pocket Gecko (USA).gbc" size 2097152 crc 85a98c7d sha1 0da71536a3e92dd537c7067ec1014a262dbc3837 ) ) game ( - name "Dance Dance Revolution GB 2 (Japan)" - description "Dance Dance Revolution GB 2 (Japan)" - rom ( name "Dance Dance Revolution GB 2 (Japan).gbc" size 2097152 crc 565fec36 sha1 d44e2905b9436be7b278bc30816023375a677ea1 ) + name "Ghosts'n Goblins (USA, Europe) (GB Compatible)" + description "Ghosts'n Goblins (USA, Europe) (GB Compatible)" + rom ( name "Ghosts'n Goblins (USA, Europe) (GB Compatible).gbc" size 1048576 crc ae024c23 sha1 af9e69fc65fbe0d4fabe145472c1340e9f541a7b ) ) game ( - name "Dance Dance Revolution GB 3 (Japan)" - description "Dance Dance Revolution GB 3 (Japan)" - rom ( name "Dance Dance Revolution GB 3 (Japan).gbc" size 2097152 crc 58f26f36 sha1 e23a69ad358623be715908860e8e6bf04020552c ) + name "Gift (Europe)" + description "Gift (Europe)" + rom ( name "Gift (Europe).gbc" size 1048576 crc 1b0034e8 sha1 a8c6b7ca2e4ed75cf037625b603cfc8ab67c0aef flags verified ) ) game ( - name "Dancing Furby (Japan) (GB Compatible)" - description "Dancing Furby (Japan) (GB Compatible)" - rom ( name "Dancing Furby (Japan) (GB Compatible).gbc" size 1048576 crc 3263f692 sha1 f3f7e37d64eef74d65456bae490e0a0b25897ac0 ) + name "Gift (Europe) (Sample)" + description "Gift (Europe) (Sample)" + rom ( name "Gift (Europe) (Sample).gbc" size 1048576 crc d8e357ba sha1 a9e2d5e1fd5d3993acb87888d287612a09ecaa8b ) ) game ( - name "Dark Winter Wander, A (World) (GB Compatible) (Aftermarket) (Unl)" - description "Dark Winter Wander, A (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Dark Winter Wander, A (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc df19aa9f sha1 412f18ba08f2f2a2afbf3bfb5281e360d7aba31d ) + name "Gift (Europe) (Rev 1) (Proto)" + description "Gift (Europe) (Rev 1) (Proto)" + rom ( name "Gift (Europe) (Rev 1) (Proto).gbc" size 1048576 crc 19681ac2 sha1 12561be4c0979b9dc8ba22caff8ac3513e1611a6 ) ) game ( - name "Data-Navi Pro Yakyuu (Japan)" - description "Data-Navi Pro Yakyuu (Japan)" - rom ( name "Data-Navi Pro Yakyuu (Japan).gbc" size 1048576 crc c958ad75 sha1 408fda7442f00a315e6b1f39963b00bc4264a142 ) + name "Gifty (Germany) (En) (Rev 1) (Proto)" + description "Gifty (Germany) (En) (Rev 1) (Proto)" + rom ( name "Gifty (Germany) (En) (Rev 1) (Proto).gbc" size 1048576 crc 96b929e8 sha1 b0c9eb2ad7a41f17d8621c40a5c0ae3e53166253 ) ) game ( - name "Data-Navi Pro Yakyuu 2 (Japan)" - description "Data-Navi Pro Yakyuu 2 (Japan)" - rom ( name "Data-Navi Pro Yakyuu 2 (Japan).gbc" size 1048576 crc 96071ad0 sha1 f59cf8ba729f6992d348f6bb14d24695e357f492 ) + name "Gifty (Germany) (En)" + description "Gifty (Germany) (En)" + rom ( name "Gifty (Germany) (En).gbc" size 1048576 crc b97a8cb8 sha1 f92997128f6bce74f5e5c0787f98fa3d2b6c3133 ) ) game ( - name "Dave Mirra Freestyle BMX (USA, Europe)" - description "Dave Mirra Freestyle BMX (USA, Europe)" - rom ( name "Dave Mirra Freestyle BMX (USA, Europe).gbc" size 1048576 crc 2df6e230 sha1 7d03bbc95a6d0e67186ab110266e8eeb0066d16b flags verified ) + name "Gimmick Land (Japan) (Proto)" + description "Gimmick Land (Japan) (Proto)" + rom ( name "Gimmick Land (Japan) (Proto).gbc" size 2097152 crc 228d0b0c sha1 f63adff202d7351c61411766c5b57efefac58bcd ) ) game ( - name "David Beckham Soccer (Europe) (En,Fr,De,Es,It)" - description "David Beckham Soccer (Europe) (En,Fr,De,Es,It)" - rom ( name "David Beckham Soccer (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 753bdce4 sha1 01567d19fcbfeeae38df505ec689998936351380 ) + name "Glocal Hexcite (Japan) (SGB Enhanced) (GB Compatible)" + description "Glocal Hexcite (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Glocal Hexcite (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f1908391 sha1 7d13220593c8d89af1b4cae955caacff7df3817a ) ) game ( - name "David Beckham Soccer (USA) (En,Es) (Proto)" - description "David Beckham Soccer (USA) (En,Es) (Proto)" - rom ( name "David Beckham Soccer (USA) (En,Es) (Proto).gbc" size 1048576 crc c08f3254 sha1 1d8970ed5aacadd0bdb7e4d78a7eb70a2d0f9650 ) + name "Gobs of Games (USA) (En,Fr,De)" + description "Gobs of Games (USA) (En,Fr,De)" + rom ( name "Gobs of Games (USA) (En,Fr,De).gbc" size 1048576 crc 2e61c391 sha1 89695361ccbca372662f6634678a40ea676076a7 ) ) game ( - name "David O'Leary's Total Soccer 2000 (Europe) (En,Fr,De,Es,It,Nl)" - description "David O'Leary's Total Soccer 2000 (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "David O'Leary's Total Soccer 2000 (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc c25ee35a sha1 be0703ee2667ddc53cff9d6c7d22b30d272c0738 ) + name "Godzilla - The Series (Europe) (En,Fr,De) (GB Compatible)" + description "Godzilla - The Series (Europe) (En,Fr,De) (GB Compatible)" + rom ( name "Godzilla - The Series (Europe) (En,Fr,De) (GB Compatible).gbc" size 1048576 crc 2a073369 sha1 05942143ac24489fc61ad9f8385e4d02e216804d ) ) game ( - name "Dawn Will Come (World) (GB Compatible) (Aftermarket) (Unl)" - description "Dawn Will Come (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Dawn Will Come (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc bb64f51c sha1 1611ddfdb9af72f20ddeca4133d8eebd0f14e424 ) + name "Godzilla - The Series (USA) (En,Fr,De) (GB Compatible)" + description "Godzilla - The Series (USA) (En,Fr,De) (GB Compatible)" + rom ( name "Godzilla - The Series (USA) (En,Fr,De) (GB Compatible).gbc" size 1048576 crc dd716efe sha1 56ec20cf1f2613bc2dcdf88d27e8af7378f7d334 ) ) game ( - name "Days Without (World) (Multiple Endings) (Aftermarket) (Unl)" - description "Days Without (World) (Multiple Endings) (Aftermarket) (Unl)" - rom ( name "Days Without (World) (Multiple Endings) (Aftermarket) (Unl).gbc" size 262144 crc 57ca8f69 sha1 8992f14f02bd37e11cb05511c17fff3d253ccf25 ) + name "Godzilla - The Series - Monster Wars (Europe) (En,Fr,De)" + description "Godzilla - The Series - Monster Wars (Europe) (En,Fr,De)" + rom ( name "Godzilla - The Series - Monster Wars (Europe) (En,Fr,De).gbc" size 1048576 crc a6007ce1 sha1 829c7efb45a9e32ee63cd6c9fe5716e457be7222 ) ) game ( - name "Days Without (World) (Aftermarket) (Unl)" - description "Days Without (World) (Aftermarket) (Unl)" - rom ( name "Days Without (World) (Aftermarket) (Unl).gbc" size 262144 crc 437b4921 sha1 cb21c1bca18d750ecde91dc3adb6b599c2ad75fa ) + name "Godzilla - The Series - Monster Wars (USA) (En,Fr,De)" + description "Godzilla - The Series - Monster Wars (USA) (En,Fr,De)" + rom ( name "Godzilla - The Series - Monster Wars (USA) (En,Fr,De).gbc" size 1048576 crc e7ebb394 sha1 4137c24412deb560f2dab36f55c89253ca750b26 ) ) game ( - name "Deadly Skies (Europe) (En,Fr,De)" - description "Deadly Skies (Europe) (En,Fr,De)" - rom ( name "Deadly Skies (Europe) (En,Fr,De).gbc" size 1048576 crc 402de378 sha1 aa9118da41e7d29385352f29593aed8c016329d1 ) + name "Gold and Glory - The Road to El Dorado (Europe) (En,Fr,De,Es,It,Nl)" + description "Gold and Glory - The Road to El Dorado (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Gold and Glory - The Road to El Dorado (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc b16f1752 sha1 89487f0b06a261bb2d3dd64d2a40c42ed9b4f63f ) ) game ( - name "Dear Daniel no Sweet Adventure - Kitty-chan o Sagashite (Japan) (SGB Enhanced) (GB Compatible)" - description "Dear Daniel no Sweet Adventure - Kitty-chan o Sagashite (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Dear Daniel no Sweet Adventure - Kitty-chan o Sagashite (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0fd34427 sha1 8598594285f0342b3d93c447b475fadd4722c6cb ) + name "Gold and Glory - The Road to El Dorado (USA)" + description "Gold and Glory - The Road to El Dorado (USA)" + rom ( name "Gold and Glory - The Road to El Dorado (USA).gbc" size 1048576 crc b7d49490 sha1 d78b266757f8c2f53b0e8679161b1bf7828d9045 ) ) game ( - name "Death Race 16 (World) (Aftermarket) (Unl)" - description "Death Race 16 (World) (Aftermarket) (Unl)" - rom ( name "Death Race 16 (World) (Aftermarket) (Unl).gbc" size 262144 crc 7b9488ec sha1 56b8a2d7117b12ff5e709e6a258f9a0b3b0ebe24 ) + name "Golden Goal (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + description "Golden Goal (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + rom ( name "Golden Goal (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 1048576 crc bb9b597d sha1 1501ea3bb5aa70562306f6df40e5b61cea93de7e ) ) game ( - name "Deer Hunter (USA)" - description "Deer Hunter (USA)" - rom ( name "Deer Hunter (USA).gbc" size 1048576 crc 40a715fb sha1 87a012e82f2361760ae337b30e9d41ef2245419a ) + name "Golden Goal (Germany) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + description "Golden Goal (Germany) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + rom ( name "Golden Goal (Germany) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 1048576 crc 14d1adbe sha1 aba65e7eca59f6fd90d4266df1478bad68d1e74e ) ) game ( - name "Deisanebe (World) (GB Compatible) (Aftermarket) (Unl)" - description "Deisanebe (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Deisanebe (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 7cff943e sha1 065b5325d44cb0e40f7b7803d707b8c1ea9ea5b2 ) + name "Golf Daisuki! (Japan) (SGB Enhanced) (GB Compatible)" + description "Golf Daisuki! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Golf Daisuki! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 80444a86 sha1 d245a267b1b1d056e0f5af4ba732c66c8deadde2 ) ) game ( - name "Deja Vu I & II (Japan)" - description "Deja Vu I & II (Japan)" - rom ( name "Deja Vu I & II (Japan).gbc" size 1048576 crc baf2cc96 sha1 4f3af0a47de674531c0fede3783f8c6cc7f31cca ) + name "Golf de Ohasuta (Japan) (GB Compatible)" + description "Golf de Ohasuta (Japan) (GB Compatible)" + rom ( name "Golf de Ohasuta (Japan) (GB Compatible).gbc" size 524288 crc 38273bdd sha1 8a19713515c4cd6983da57f76924babc090af654 ) ) game ( - name "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (En,Fr)" - description "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (En,Fr)" - rom ( name "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (En,Fr).gbc" size 1048576 crc 71f798b5 sha1 10c2ed4098a07979426d359da57a5289c6bc73fe ) + name "Golf King (Europe) (En,Fr,De) (Proto)" + description "Golf King (Europe) (En,Fr,De) (Proto)" + rom ( name "Golf King (Europe) (En,Fr,De) (Proto).gbc" size 2097152 crc 3019b4e7 sha1 d02e09251e7c5078e4b641e6d334958c2c814285 ) ) game ( - name "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (Fr,De)" - description "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (Fr,De)" - rom ( name "Deja Vu I & II - The Casebooks of Ace Harding (Europe) (Fr,De).gbc" size 1048576 crc c6e7f3c6 sha1 ed1a11e2a02fc11d6b58dedf65ce57eeb430e6e3 ) + name "Golf Ou - The King of Golf (Japan) (SGB Enhanced) (GB Compatible)" + description "Golf Ou - The King of Golf (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Golf Ou - The King of Golf (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 634b2d43 sha1 d196af0aaf77ca67f9784d0ccd1ef4b25abed5c2 ) ) game ( - name "Deja Vu I & II - The Casebooks of Ace Harding (USA)" - description "Deja Vu I & II - The Casebooks of Ace Harding (USA)" - rom ( name "Deja Vu I & II - The Casebooks of Ace Harding (USA).gbc" size 1048576 crc ad0937f4 sha1 63266fc1f0a14678d5cd5dd1c5e3658ef4a944c3 ) + name "Gonta no Okiraku Daibouken (Japan)" + description "Gonta no Okiraku Daibouken (Japan)" + rom ( name "Gonta no Okiraku Daibouken (Japan).gbc" size 1048576 crc e45e99d2 sha1 49e4156716a47d46006ad287ec46c28c573a74a5 ) ) game ( - name "Dejiko no Mahjong Party (Japan)" - description "Dejiko no Mahjong Party (Japan)" - rom ( name "Dejiko no Mahjong Party (Japan).gbc" size 2097152 crc c5501fce sha1 d9dd4196a85bceee6e77a317a357e9e0b14d26eb ) + name "Goraku Ou Tango! (Japan) (GB Compatible)" + description "Goraku Ou Tango! (Japan) (GB Compatible)" + rom ( name "Goraku Ou Tango! (Japan) (GB Compatible).gbc" size 1048576 crc 81fb43e1 sha1 1d49232763c1422a00cbb893d0f900c44a2ccf54 ) ) game ( - name "Dejiko no Mahjong Party (Japan) (Rev 1) (Proto)" - description "Dejiko no Mahjong Party (Japan) (Rev 1) (Proto)" - rom ( name "Dejiko no Mahjong Party (Japan) (Rev 1) (Proto).gbc" size 2097152 crc 7e515a7e sha1 fbc2b66a6595bbb3ed85f35545152442283eaea3 ) + name "Grand Casino (Japan) (Proto)" + description "Grand Casino (Japan) (Proto)" + rom ( name "Grand Casino (Japan) (Proto).gbc" size 1048576 crc 8ba3988b sha1 556e1a6c27c792605925f6f67daa953809f81bfb ) ) game ( - name "Denki Blocks! (USA) (En,Es) (Proto)" - description "Denki Blocks! (USA) (En,Es) (Proto)" - rom ( name "Denki Blocks! (USA) (En,Es) (Proto).gbc" size 1048576 crc aafc35c3 sha1 bca594d5d90219b263638dd86a96e3e9a64ce71e ) + name "Grand Theft Auto (Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "Grand Theft Auto (Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Grand Theft Auto (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 4194304 crc 25ba9231 sha1 b6c1693ba5bf2c914d910e94286bda8f3fbd100e ) ) game ( - name "Denki Blocks! (Europe) (En,Fr,De,Es,It)" - description "Denki Blocks! (Europe) (En,Fr,De,Es,It)" - rom ( name "Denki Blocks! (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 38f00974 sha1 cf4037db23525937e6dceea7343a9ea7a22f928d ) + name "Grand Theft Auto (USA) (GB Compatible)" + description "Grand Theft Auto (USA) (GB Compatible)" + rom ( name "Grand Theft Auto (USA) (GB Compatible).gbc" size 4194304 crc 924de366 sha1 a0c9d9a95bf2cceca7922f4375555b8edee9ea6b ) ) game ( - name "Densha de Go! (Japan)" - description "Densha de Go! (Japan)" - rom ( name "Densha de Go! (Japan).gbc" size 4194304 crc 14375072 sha1 9661a5cfa2dc4fedbca1f15b69cf81a3fc7fc097 ) + name "Grand Theft Auto 2 (Europe) (En,Fr,De,Es,It)" + description "Grand Theft Auto 2 (Europe) (En,Fr,De,Es,It)" + rom ( name "Grand Theft Auto 2 (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc ad563bd9 sha1 a7577d81de3ab03b93b364f9e775c303c842dad2 flags verified ) ) game ( - name "Densha de Go! 2 (Japan)" - description "Densha de Go! 2 (Japan)" - rom ( name "Densha de Go! 2 (Japan).gbc" size 8388608 crc b72603fc sha1 63bcca7177712a9bc6f032c83c2e129d9b9af0fa flags verified ) + name "Grand Theft Auto 2 (USA)" + description "Grand Theft Auto 2 (USA)" + rom ( name "Grand Theft Auto 2 (USA).gbc" size 2097152 crc 68610203 sha1 6fd4b31d410ca98452ada0a1f3c0e2590e7df099 ) ) game ( - name "Dexter's Laboratory - Robot Rampage (USA, Europe)" - description "Dexter's Laboratory - Robot Rampage (USA, Europe)" - rom ( name "Dexter's Laboratory - Robot Rampage (USA, Europe).gbc" size 1048576 crc d24d6601 sha1 db107af55df07fb8c771c712b05d6aebb175e3c5 ) + name "Grandia - Parallel Trippers (Japan)" + description "Grandia - Parallel Trippers (Japan)" + rom ( name "Grandia - Parallel Trippers (Japan).gbc" size 4194304 crc 23223670 sha1 647b7cc5fa415ef7081aa37cd787eb41d2a3e574 flags verified ) ) game ( - name "Dia de Sol Noite de Lua (World) (GB Compatible) (Aftermarket) (Unl)" - description "Dia de Sol Noite de Lua (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Dia de Sol Noite de Lua (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc c6b965b9 sha1 ac43f43bdcfc0347f24a0a70de213a4b701d8155 ) + name "Granduel - Shinki Dungeon no Hihou (Japan)" + description "Granduel - Shinki Dungeon no Hihou (Japan)" + rom ( name "Granduel - Shinki Dungeon no Hihou (Japan).gbc" size 2097152 crc d589c501 sha1 7fe6da989e95a6e228c8d01ad650ed26ee42551b flags verified ) ) game ( - name "Digimon - Yellow Jade (USA) (Unl)" - description "Digimon - Yellow Jade (USA) (Unl)" - rom ( name "Digimon - Yellow Jade (USA) (Unl).gbc" size 2097152 crc 96662e76 sha1 743bf9b07245ae5df98898b7794f304ac09d2ed4 ) + name "Granduel - Shinki Dungeon no Hihou (Japan) (Sample)" + description "Granduel - Shinki Dungeon no Hihou (Japan) (Sample)" + rom ( name "Granduel - Shinki Dungeon no Hihou (Japan) (Sample).gbc" size 2097152 crc 7122136d sha1 534fc9ae5800eb935460f145e1bbc57f77ab2555 ) ) game ( - name "Digimon 02 4 (Taiwan) (En) (Unl)" - description "Digimon 02 4 (Taiwan) (En) (Unl)" - rom ( name "Digimon 02 4 (Taiwan) (En) (Unl).gbc" size 1048576 crc a90061e9 sha1 0c8280e5349dda05fdd27bb1eb68a1be2f3d5c04 ) + name "Great Battle Pocket, The (Japan) (SGB Enhanced) (GB Compatible)" + description "Great Battle Pocket, The (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Great Battle Pocket, The (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b471c095 sha1 617752e18894590b5959f565f1cdbfd218141e7d ) ) game ( - name "Digimon 2 (Taiwan) (En) (Unl)" - description "Digimon 2 (Taiwan) (En) (Unl)" - rom ( name "Digimon 2 (Taiwan) (En) (Unl).gbc" size 1048576 crc a43ab22b sha1 8476385e380bee46f19f874dfed91b3aa61bbf66 ) + name "Green Beret (Unknown) (Proto 1)" + description "Green Beret (Unknown) (Proto 1)" + rom ( name "Green Beret (Unknown) (Proto 1).gbc" size 32768 crc c66c546f sha1 5b92b0db1af9803e27a4ebb23ad9ed8377d6d87b ) ) game ( - name "Digimon 3 Crystal (Taiwan) (En) (Unl)" - description "Digimon 3 Crystal (Taiwan) (En) (Unl)" - rom ( name "Digimon 3 Crystal (Taiwan) (En) (Unl).gbc" size 1048576 crc fe8bf4e8 sha1 b844ee8f803e48ec786bc6f5d2953af22dda45e2 ) + name "Green Beret (Unknown) (Proto 2)" + description "Green Beret (Unknown) (Proto 2)" + rom ( name "Green Beret (Unknown) (Proto 2).gbc" size 65536 crc 702af305 sha1 f8e6ee070147c56e280abf2a31316ee8124b953c ) ) game ( - name "Digimon Adventure 2001 (USA) (Unl)" - description "Digimon Adventure 2001 (USA) (Unl)" - rom ( name "Digimon Adventure 2001 (USA) (Unl).gbc" size 1048576 crc 01f1fcee sha1 cb4327829bc90c7bb448e7591e6ee3729a12a8cd ) + name "Green Beret (Unknown) (Proto 3)" + description "Green Beret (Unknown) (Proto 3)" + rom ( name "Green Beret (Unknown) (Proto 3).gbc" size 262144 crc fac3f4c5 sha1 dd69f3d9ef87198334b4cc0f54c88a29fb353e44 ) ) game ( - name "Digimon Amethyst (USA) (Unl)" - description "Digimon Amethyst (USA) (Unl)" - rom ( name "Digimon Amethyst (USA) (Unl).gbc" size 2097152 crc 726eed2a sha1 0b5f44cc2f583182a91ed8a815a3e7cec3bd1a58 ) + name "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt)" + description "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt)" + rom ( name "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc 053bc315 sha1 d18e30a434262f7bf46a8db2e5f62ce19b7ecfaa ) ) game ( - name "Digimon Crystal II (USA) (Unl)" - description "Digimon Crystal II (USA) (Unl)" - rom ( name "Digimon Crystal II (USA) (Unl).gbc" size 2097152 crc 685e76df sha1 4e981044ac3a40d7a9cd63b79d5982b4b4e670a5 ) + name "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt) (Beta)" + description "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt) (Beta)" + rom ( name "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt) (Beta).gbc" size 1048576 crc c38d52e7 sha1 675623b58fa0d307355c77d7a4783af7927681e9 ) ) game ( - name "Digimon Pocket (Taiwan) (En) (Unl)" - description "Digimon Pocket (Taiwan) (En) (Unl)" - rom ( name "Digimon Pocket (Taiwan) (En) (Unl).gbc" size 524288 crc 6791b106 sha1 87750928d5f005e67e51e4d08a6d82351effc7b2 ) + name "Grinch (Japan)" + description "Grinch (Japan)" + rom ( name "Grinch (Japan).gbc" size 1048576 crc 432dc371 sha1 33412209ef2b952e82f5d0b3f7bb035efebcf480 ) ) game ( - name "Digimon Saphire (USA) (Unl)" - description "Digimon Saphire (USA) (Unl)" - rom ( name "Digimon Saphire (USA) (Unl).gbc" size 1048576 crc be4c1d83 sha1 f5706a80bae20027d7643ab151607adbe13e6b1d ) + name "Grinch, The (Europe) (En,Fr,De)" + description "Grinch, The (Europe) (En,Fr,De)" + rom ( name "Grinch, The (Europe) (En,Fr,De).gbc" size 1048576 crc 9ed6059a sha1 df0ed2c6fad2d511037ab9269571f24146103237 ) ) game ( - name "Digital Monster 2001 (Taiwan) (En) (Unl)" - description "Digital Monster 2001 (Taiwan) (En) (Unl)" - rom ( name "Digital Monster 2001 (Taiwan) (En) (Unl).gbc" size 524288 crc d9eb3f2a sha1 cc7d4a2e5bf1fbee8e0a0e0960f4038fca3e458f ) + name "Grinch, The (USA)" + description "Grinch, The (USA)" + rom ( name "Grinch, The (USA).gbc" size 1048576 crc c5a47896 sha1 84c2397fe07011511225b9d9f442f16c026576d3 ) ) game ( - name "Dino Breeder 3 - Gaia Fukkatsu (Japan) (SGB Enhanced) (GB Compatible)" - description "Dino Breeder 3 - Gaia Fukkatsu (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Dino Breeder 3 - Gaia Fukkatsu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc d9f071bb sha1 f571a591a2f4fc4f70897e380fdbe9011be75f8d ) + name "Guaishou Go! Go! II (Taiwan) (Unl)" + description "Guaishou Go! Go! II (Taiwan) (Unl)" + rom ( name "Guaishou Go! Go! II (Taiwan) (Unl).gbc" size 1048576 crc b0237467 sha1 8ed6f39a9973d634266806455ef845b6bdb5ab95 ) ) game ( - name "Dino Breeder 4 (Japan) (SGB Enhanced) (GB Compatible)" - description "Dino Breeder 4 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Dino Breeder 4 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b0106777 sha1 b25681defda961837a28be1432076b65574fd1be ) + name "Guiwu Zhe 2 (Taiwan) (Unl)" + description "Guiwu Zhe 2 (Taiwan) (Unl)" + rom ( name "Guiwu Zhe 2 (Taiwan) (Unl).gbc" size 2097152 crc 955bc6ad sha1 5fe41ac064f4b4d4476ef4177a2f4d69fae1a933 ) ) game ( - name "Dinosaur (Europe) (En,Fr,De,Es,It)" - description "Dinosaur (Europe) (En,Fr,De,Es,It)" - rom ( name "Dinosaur (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 0aa8d0cc sha1 9123d3528bf295c5cba4284ca276af23a32ec725 ) + name "Guruguru Garakutas (Japan) (SGB Enhanced) (GB Compatible)" + description "Guruguru Garakutas (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Guruguru Garakutas (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 7eaeeeac sha1 86fea7dd8d815a51c1b75b816125ab4ba731dba1 ) ) game ( - name "Dinosaur (USA)" - description "Dinosaur (USA)" - rom ( name "Dinosaur (USA).gbc" size 2097152 crc 276ecaae sha1 f566c37ab95537d88f6d1ab91804f47f7c0b4027 ) + name "Guruguru Town Hanamaru-kun (Japan)" + description "Guruguru Town Hanamaru-kun (Japan)" + rom ( name "Guruguru Town Hanamaru-kun (Japan).gbc" size 1048576 crc 03fbfc9e sha1 d147400bb9831b30a4e75f3570a1844f674e866c ) ) game ( - name "Dinosaur (USA) (Beta)" - description "Dinosaur (USA) (Beta)" - rom ( name "Dinosaur (USA) (Beta).gbc" size 2097152 crc 0b087fe7 sha1 e8042138b56777733e8e9e397ea084cf61383cd9 ) + name "Gute Zeiten Schlechte Zeiten Quiz (Germany) (GB Compatible)" + description "Gute Zeiten Schlechte Zeiten Quiz (Germany) (GB Compatible)" + rom ( name "Gute Zeiten Schlechte Zeiten Quiz (Germany) (GB Compatible).gbc" size 1048576 crc 5f13a2d4 sha1 611d8ab71bdeb6b0fd292118676e85e940d11bd4 ) ) game ( - name "Dinosaur'us (Europe) (En,Fr,De,Es,It,Nl)" - description "Dinosaur'us (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Dinosaur'us (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc f4609fe3 sha1 d0caf4b5172651aee2bbe38efdae084ce3d7a7ff ) + name "Gyouten Ningen Batseelor - Doctor Guy no Yabou (Japan)" + description "Gyouten Ningen Batseelor - Doctor Guy no Yabou (Japan)" + rom ( name "Gyouten Ningen Batseelor - Doctor Guy no Yabou (Japan).gbc" size 4194304 crc b17dc263 sha1 b72e885baeeb27cb32de5b5dcedb632537898c33 flags verified ) ) game ( - name "Disco Elysium - Game Boy Edition (World) (Music) (GB Compatible) (Aftermarket) (Unl)" - description "Disco Elysium - Game Boy Edition (World) (Music) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Disco Elysium - Game Boy Edition (World) (Music) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc ef349515 sha1 06fe25086432c82f1e4b4c44473dd5b487a8af05 ) + name "Haizhan Qibing (Taiwan) (Unl)" + description "Haizhan Qibing (Taiwan) (Unl)" + rom ( name "Haizhan Qibing (Taiwan) (Unl).gbc" size 2097152 crc a962ad73 sha1 36f6454e3e70bb29f27782f2ec4200d5aef5ca98 ) ) game ( - name "Disco Elysium - Game Boy Edition (World) (No Music) (GB Compatible) (Aftermarket) (Unl)" - description "Disco Elysium - Game Boy Edition (World) (No Music) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Disco Elysium - Game Boy Edition (World) (No Music) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 7c0f52cc sha1 8bc16b70838f9245b7e37c6dbe57159b294fbf81 ) + name "Hajimari no Mori (Japan) (Proto)" + description "Hajimari no Mori (Japan) (Proto)" + rom ( name "Hajimari no Mori (Japan) (Proto).gbc" size 2097152 crc fecc8ee8 sha1 75a3e1794fd6bd6d35f0a357a82612c016dfba24 ) ) game ( - name "Diva Starz (Europe)" - description "Diva Starz (Europe)" - rom ( name "Diva Starz (Europe).gbc" size 1048576 crc 4476e79f sha1 9ae754470a116555373a47eae0fe611160219925 ) + name "Hali Xiaozi Dier Bu - Mishi de Mi (Taiwan) (Unl)" + description "Hali Xiaozi Dier Bu - Mishi de Mi (Taiwan) (Unl)" + rom ( name "Hali Xiaozi Dier Bu - Mishi de Mi (Taiwan) (Unl).gbc" size 2097152 crc 859457c8 sha1 3844b61eb455507d634ee7048dc8c9e64216fffe ) ) game ( - name "Diva Starz (France)" - description "Diva Starz (France)" - rom ( name "Diva Starz (France).gbc" size 1048576 crc fc1b36d1 sha1 fcbfbef077feec07f93b867de5b537f45812d5a4 ) + name "Halloween Racer (Europe) (En,Fr,De,Es,It,Pt)" + description "Halloween Racer (Europe) (En,Fr,De,Es,It,Pt)" + rom ( name "Halloween Racer (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc 70f3b431 sha1 15bf27a7847817fbbb9cb7729b8046a6d70164c5 ) ) game ( - name "Diva Starz (Germany)" - description "Diva Starz (Germany)" - rom ( name "Diva Starz (Germany).gbc" size 1048576 crc 56095f86 sha1 286d16d697caa2dfc1ebcad88a9633dd45c20e67 flags verified ) + name "Hamster Club (Japan) (GB Compatible)" + description "Hamster Club (Japan) (GB Compatible)" + rom ( name "Hamster Club (Japan) (GB Compatible).gbc" size 2097152 crc 8a4d86a0 sha1 6ab81c4dec3263502a1781b600218285836c5302 ) ) game ( - name "Diva Starz - Mall Mania (USA)" - description "Diva Starz - Mall Mania (USA)" - rom ( name "Diva Starz - Mall Mania (USA).gbc" size 1048576 crc ebe0ecd6 sha1 1d0edb87404409f1e4c124503be4cc59165c01da ) + name "Hamster Club - Awasete Chuu (Japan)" + description "Hamster Club - Awasete Chuu (Japan)" + rom ( name "Hamster Club - Awasete Chuu (Japan).gbc" size 1048576 crc d56d68ff sha1 ad4148b716f8a379578e6d862b06d435396faccc ) ) game ( - name "Diver 94 (World) (GB Compatible) (Aftermarket) (Unl)" - description "Diver 94 (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Diver 94 (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc f4ff5eb0 sha1 6b421505acc626a34bb9306a3d88e1964a4502f3 ) + name "Hamster Club - Oshiema Chuu (Japan)" + description "Hamster Club - Oshiema Chuu (Japan)" + rom ( name "Hamster Club - Oshiema Chuu (Japan).gbc" size 2097152 crc 79ceef4e sha1 e2739f49ce29d1f7fe1cb94808230e7c2ad781e3 ) ) game ( - name "Dogz (Europe)" - description "Dogz (Europe)" - rom ( name "Dogz (Europe).gbc" size 1048576 crc ce8dd179 sha1 ad1e238f180eaa55b4c76cd39a03a88f28dc9649 ) + name "Hamster Club 2 (Japan) (GB Compatible)" + description "Hamster Club 2 (Japan) (GB Compatible)" + rom ( name "Hamster Club 2 (Japan) (GB Compatible).gbc" size 4194304 crc 2fb398f9 sha1 dcef750a73d813841cfcb871b5bb5f021a7b7285 ) ) game ( - name "Dogz (USA)" - description "Dogz (USA)" - rom ( name "Dogz (USA).gbc" size 1048576 crc a8397183 sha1 d0d4c661e2ced3664ff07b15f2fb2c57a63d2dad ) + name "Hamster Monogatari GB + Magi Ham no Mahou Shoujo (Japan)" + description "Hamster Monogatari GB + Magi Ham no Mahou Shoujo (Japan)" + rom ( name "Hamster Monogatari GB + Magi Ham no Mahou Shoujo (Japan).gbc" size 4194304 crc abd59939 sha1 b3300b1df2cd6a42f112624d5eb2803d45eb3054 ) ) game ( - name "Dokapon! - Millennium Quest (Japan) (SGB Enhanced) (GB Compatible)" - description "Dokapon! - Millennium Quest (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Dokapon! - Millennium Quest (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4fe9e966 sha1 2ac27b1f9b8821fcf1cb4bf347156e29dcde689c ) + name "Hamster Paradise (Japan) (SGB Enhanced) (GB Compatible)" + description "Hamster Paradise (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Hamster Paradise (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f520cb19 sha1 87ebc7e0cfb0803e6e14da7eec1b2fad51c83ba0 ) ) game ( - name "Doki x Doki Sasete!! (Japan)" - description "Doki x Doki Sasete!! (Japan)" - rom ( name "Doki x Doki Sasete!! (Japan).gbc" size 2097152 crc 19a73f60 sha1 d2d424bdd151222aa8316db1fd1df2cafcb3a15d ) + name "Hamster Paradise 2 (Japan)" + description "Hamster Paradise 2 (Japan)" + rom ( name "Hamster Paradise 2 (Japan).gbc" size 2097152 crc 542c78b6 sha1 cf19fd582d8881779e7e34e1d6cd8fd5b7129f53 flags verified ) ) game ( - name "Dokidoki Densetsu - Mahoujin Guruguru (Japan)" - description "Dokidoki Densetsu - Mahoujin Guruguru (Japan)" - rom ( name "Dokidoki Densetsu - Mahoujin Guruguru (Japan).gbc" size 4194304 crc 83e47a1a sha1 1b4627699b45af36a42e75c1a217b40fb5bec4ba ) + name "Hamster Paradise 2 (Japan) (Rev 1)" + description "Hamster Paradise 2 (Japan) (Rev 1)" + rom ( name "Hamster Paradise 2 (Japan) (Rev 1).gbc" size 2097152 crc b9e1f3b0 sha1 140100d96d165ee399f5cd18f5aec962fde714b6 flags verified ) ) game ( - name "Don't Forget About Me (World) (GB Compatible) (Aftermarket) (Unl)" - description "Don't Forget About Me (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Don't Forget About Me (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 52cf7153 sha1 74e6246405dd52d4c5c2eabc417946550c637164 ) + name "Hamster Paradise 3 (Japan)" + description "Hamster Paradise 3 (Japan)" + rom ( name "Hamster Paradise 3 (Japan).gbc" size 4194304 crc 14cac67c sha1 9d8e482afad5b8786bf289640fc275b7787fbea3 ) ) game ( - name "Don't Forget About Me (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "Don't Forget About Me (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Don't Forget About Me (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 8ca9dbe0 sha1 cf6eaac37c4ae1b3cfc4ed8d2ce73a143635b525 ) + name "Hamster Paradise 4 (Japan)" + description "Hamster Paradise 4 (Japan)" + rom ( name "Hamster Paradise 4 (Japan).gbc" size 4194304 crc c460dc88 sha1 177cb46c44346eabbeb06f5d7929c77afc798db9 flags verified ) ) game ( - name "Don't Forget About Me (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" - description "Don't Forget About Me (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Don't Forget About Me (World) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 3d87efd8 sha1 83201c43e9fc89f4393678ade8c6107b4cfdb628 ) + name "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It)" + description "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It)" + rom ( name "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 45be9d9b sha1 047d9dedb77a448d31cd5dce23f4c3dd8714dafe ) ) game ( - name "Donald Duck - Daisy o Sukue! (Japan)" - description "Donald Duck - Daisy o Sukue! (Japan)" - rom ( name "Donald Duck - Daisy o Sukue! (Japan).gbc" size 4194304 crc 333c124c sha1 46ecfe890cb225563bcd45f8607962840b5fd587 ) + name "Hamtaro - Ham-Hams Unite! (USA)" + description "Hamtaro - Ham-Hams Unite! (USA)" + rom ( name "Hamtaro - Ham-Hams Unite! (USA).gbc" size 2097152 crc 1271117f sha1 9770bf59e932b41882839ce9eec033f576094fee flags verified ) ) game ( - name "Donald Duck - Goin' Quackers (USA) (En,Fr,De,Es,It)" - description "Donald Duck - Goin' Quackers (USA) (En,Fr,De,Es,It)" - rom ( name "Donald Duck - Goin' Quackers (USA) (En,Fr,De,Es,It).gbc" size 4194304 crc 4685909b sha1 f2fa670fd20485b3bc1875dc8d31fb40374942bd ) + name "Hamtaro - Ham-Hams Unite! (USA) (2002-08-07) (Beta)" + description "Hamtaro - Ham-Hams Unite! (USA) (2002-08-07) (Beta)" + rom ( name "Hamtaro - Ham-Hams Unite! (USA) (2002-08-07) (Beta).gbc" size 2097152 crc d0cf0d86 sha1 c85ba2da0a652544f938439c8826c5c6754f5e75 ) ) game ( - name "Donald Duck - Quack Attack (Europe) (En,Fr,De,Es,It)" - description "Donald Duck - Quack Attack (Europe) (En,Fr,De,Es,It)" - rom ( name "Donald Duck - Quack Attack (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 07a13b5b sha1 946e473ad7f363295f2c4bb488618f2325f51004 flags verified ) + name "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It) (2002-11-11) (Beta)" + description "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It) (2002-11-11) (Beta)" + rom ( name "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It) (2002-11-11) (Beta).gbc" size 4194304 crc 816b0325 sha1 17c3ff0da5b9733a768ee53eccd13059fda16116 ) ) game ( - name "Donkey Kong 2001 (Japan)" - description "Donkey Kong 2001 (Japan)" - rom ( name "Donkey Kong 2001 (Japan).gbc" size 4194304 crc cb065eba sha1 5be5500d9ff9c4416df77816ebd21cca7a0b19de flags verified ) + name "Hamunaptra - Ushinawareta Sabaku no Miyako (Japan)" + description "Hamunaptra - Ushinawareta Sabaku no Miyako (Japan)" + rom ( name "Hamunaptra - Ushinawareta Sabaku no Miyako (Japan).gbc" size 1048576 crc ff454711 sha1 79c38bc527c9da2c27d1d9dc85924360d7cd66d3 ) ) game ( - name "Donkey Kong 5 - The Journey of Over Time and Space (Taiwan) (En) (Unl)" - description "Donkey Kong 5 - The Journey of Over Time and Space (Taiwan) (En) (Unl)" - rom ( name "Donkey Kong 5 - The Journey of Over Time and Space (Taiwan) (En) (Unl).gbc" size 2097152 crc 1a369dd5 sha1 1ff1ac88dea7431866016970c4f4ae049302201b ) + name "Hana Yori Dango - Another Love Story (Japan)" + description "Hana Yori Dango - Another Love Story (Japan)" + rom ( name "Hana Yori Dango - Another Love Story (Japan).gbc" size 2097152 crc 469f0284 sha1 9a403476fa3325d5d48ad0686727b9c715ebaef9 ) ) game ( - name "Donkey Kong Country (USA) (En,Fr,De,Es,It) (Demo) (Kiosk)" - description "Donkey Kong Country (USA) (En,Fr,De,Es,It) (Demo) (Kiosk)" - rom ( name "Donkey Kong Country (USA) (En,Fr,De,Es,It) (Demo) (Kiosk).gbc" size 4194304 crc 080605a3 sha1 38fedd71736d258e31d3062864d28449e7c3f1c5 ) + name "Hanasaka Tenshi Tenten-kun no Beat Breaker (Japan) (SGB Enhanced) (GB Compatible)" + description "Hanasaka Tenshi Tenten-kun no Beat Breaker (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Hanasaka Tenshi Tenten-kun no Beat Breaker (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6e988c07 sha1 791ea554de774de622bb4fb6bc2bf42955a201b3 ) ) game ( - name "Donkey Kong Country (USA, Europe) (En,Fr,De,Es,It)" - description "Donkey Kong Country (USA, Europe) (En,Fr,De,Es,It)" - rom ( name "Donkey Kong Country (USA, Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc b1743477 sha1 32522dfce902d564e69348541348afc054307f65 flags verified ) + name "Hands of Time (USA, Europe) (En,Fr,De,Es,It,Nl)" + description "Hands of Time (USA, Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Hands of Time (USA, Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc f519f4c3 sha1 ae07e529f1c98432f37fa674ee4de6305807a92b ) ) game ( - name "Donkey Kong GB - Dinky Kong & Dixie Kong (Japan)" - description "Donkey Kong GB - Dinky Kong & Dixie Kong (Japan)" - rom ( name "Donkey Kong GB - Dinky Kong & Dixie Kong (Japan).gbc" size 1048576 crc 28d7e8d3 sha1 55b133b739a5472d477336647cb9ec97b7fa85a2 flags verified ) + name "Hang Time Basketball (Europe) (Unl)" + description "Hang Time Basketball (Europe) (Unl)" + rom ( name "Hang Time Basketball (Europe) (Unl).gbc" size 262144 crc 3207b7d9 sha1 340201c045c020be6de3504fdecbce1ff07a2139 ) ) game ( - name "Doraemon - Aruke Aruke Labyrinth (Japan) (GB Compatible)" - description "Doraemon - Aruke Aruke Labyrinth (Japan) (GB Compatible)" - rom ( name "Doraemon - Aruke Aruke Labyrinth (Japan) (GB Compatible).gbc" size 1048576 crc f6d79a79 sha1 f825279feec357baba2b39423aa596ce02e34921 ) + name "Harley-Davidson Motor Cycles - Race Across America (USA)" + description "Harley-Davidson Motor Cycles - Race Across America (USA)" + rom ( name "Harley-Davidson Motor Cycles - Race Across America (USA).gbc" size 1048576 crc 644bac84 sha1 3777b4f69d6af13b3fd94caadad4661d5904399e ) ) game ( - name "Doraemon - Kimi to Pet no Monogatari (Japan) (GB Compatible)" - description "Doraemon - Kimi to Pet no Monogatari (Japan) (GB Compatible)" - rom ( name "Doraemon - Kimi to Pet no Monogatari (Japan) (GB Compatible).gbc" size 1048576 crc 2fa46211 sha1 1fb01a4a492243c1768bdbf5db88fd95d0cc4f59 ) + name "Harry Potter (Taiwan) (Unl)" + description "Harry Potter (Taiwan) (Unl)" + rom ( name "Harry Potter (Taiwan) (Unl).gbc" size 1048576 crc 5bebe333 sha1 dfd0693315da697240b510776695162880a75a82 ) ) game ( - name "Doraemon Kart 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Doraemon Kart 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Doraemon Kart 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc cf1a2038 sha1 b29695b9944c030c518140341d748d1a1f21f982 ) + name "Harry Potter 2 - The Black Art Wrestle Edition (USA) (Unl)" + description "Harry Potter 2 - The Black Art Wrestle Edition (USA) (Unl)" + rom ( name "Harry Potter 2 - The Black Art Wrestle Edition (USA) (Unl).gbc" size 1048576 crc 772337f4 sha1 d173a8faf3f4045d6cde08b59c2ff1d04eb4f2f1 ) ) game ( - name "Doraemon Memories - Nobita no Omoide Daibouken (Japan) (GB Compatible)" - description "Doraemon Memories - Nobita no Omoide Daibouken (Japan) (GB Compatible)" - rom ( name "Doraemon Memories - Nobita no Omoide Daibouken (Japan) (GB Compatible).gbc" size 1048576 crc d187cec4 sha1 3152a167021ff536186051c42c6e8f131d72ad41 ) + name "Harry Potter 3 (USA) (Unl)" + description "Harry Potter 3 (USA) (Unl)" + rom ( name "Harry Potter 3 (USA) (Unl).gbc" size 1048576 crc d0fece32 sha1 6820d9e05e60a380c52aa8a19a8397ec929a5b49 ) ) game ( - name "Doraemon no Quiz Boy (Japan)" - description "Doraemon no Quiz Boy (Japan)" - rom ( name "Doraemon no Quiz Boy (Japan).gbc" size 1048576 crc 3bbf9ea8 sha1 fd05adb1a6face86ff263883fdf4cebf14e055e9 ) + name "Harry Potter 3 - Shen Qi Zhi Guang Lun (Taiwan) (Unl)" + description "Harry Potter 3 - Shen Qi Zhi Guang Lun (Taiwan) (Unl)" + rom ( name "Harry Potter 3 - Shen Qi Zhi Guang Lun (Taiwan) (Unl).gbc" size 524288 crc aa83a110 sha1 7e572f24a302902cd78b238be5732d838bada7b2 ) ) game ( - name "Doraemon no Quiz Boy (Japan) (Rev 1)" - description "Doraemon no Quiz Boy (Japan) (Rev 1)" - rom ( name "Doraemon no Quiz Boy (Japan) (Rev 1).gbc" size 1048576 crc 915356e3 sha1 ae48f07e608d76143a4a51f18f9454cd990d766a flags verified ) + name "Harry Potter and the Chamber of Secrets (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,Da)" + description "Harry Potter and the Chamber of Secrets (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,Da)" + rom ( name "Harry Potter and the Chamber of Secrets (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,Da).gbc" size 4194304 crc 136e9d0c sha1 e3b9b22e3e528efc41e5b57fc9b3dcfa75dcd443 flags verified ) ) game ( - name "Doraemon no Quiz Boy 2 (Japan)" - description "Doraemon no Quiz Boy 2 (Japan)" - rom ( name "Doraemon no Quiz Boy 2 (Japan).gbc" size 1048576 crc 9e80199a sha1 c6b5ffc4b8f7c106807ed7e2c72e37090d3faa97 flags verified ) + name "Harry Potter and the Sorcerer's Stone (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" + description "Harry Potter and the Sorcerer's Stone (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" + rom ( name "Harry Potter and the Sorcerer's Stone (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi).gbc" size 4194304 crc 4fd8b7c5 sha1 4e6f676ec15e0e6238cb81853b5a74bbb20657a1 flags verified ) ) game ( - name "Doraemon no Study Boy - Gakushuu Kanji Game (Japan)" - description "Doraemon no Study Boy - Gakushuu Kanji Game (Japan)" - rom ( name "Doraemon no Study Boy - Gakushuu Kanji Game (Japan).gbc" size 1048576 crc 67413f65 sha1 1f8aad0fc2a8d03244c69f3a6d80af1a21164ddc flags verified ) + name "Harry Potter II (USA) (Unl)" + description "Harry Potter II (USA) (Unl)" + rom ( name "Harry Potter II (USA) (Unl).gbc" size 1048576 crc 2ff706c0 sha1 e3f21a748d517527218409e35418b23ced8717da ) ) game ( - name "Doraemon no Study Boy - Kanji Yomikaki Master (Japan)" - description "Doraemon no Study Boy - Kanji Yomikaki Master (Japan)" - rom ( name "Doraemon no Study Boy - Kanji Yomikaki Master (Japan).gbc" size 1048576 crc 70156da7 sha1 4b7ec303305daed053243b125a9aebc44f3e221e flags verified ) + name "Harry Potter to Kenja no Ishi (Japan)" + description "Harry Potter to Kenja no Ishi (Japan)" + rom ( name "Harry Potter to Kenja no Ishi (Japan).gbc" size 4194304 crc 2da2686a sha1 a4fb5a1f3cdebd989617a1964ada8df4ab491e36 ) ) game ( - name "Doraemon no Study Boy - Kuku Game (Japan)" - description "Doraemon no Study Boy - Kuku Game (Japan)" - rom ( name "Doraemon no Study Boy - Kuku Game (Japan).gbc" size 1048576 crc a8a353d8 sha1 9b5c8b89b6e69d3803fbd43b2fe5130ad6d2f50b ) + name "Harvest Moon 2 GBC (Europe) (SGB Enhanced) (GB Compatible)" + description "Harvest Moon 2 GBC (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Harvest Moon 2 GBC (Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 160ca990 sha1 4dc14fb6a6057b7fabbcf29bd21f331170f84420 ) ) game ( - name "Dork's Dilemma (World) (Aftermarket) (Unl)" - description "Dork's Dilemma (World) (Aftermarket) (Unl)" - rom ( name "Dork's Dilemma (World) (Aftermarket) (Unl).gbc" size 524288 crc 77b8b43b sha1 bd525f97cc316fed3f6271ed0929414df4c0389c ) + name "Harvest Moon 2 GBC (Germany) (SGB Enhanced) (GB Compatible)" + description "Harvest Moon 2 GBC (Germany) (SGB Enhanced) (GB Compatible)" + rom ( name "Harvest Moon 2 GBC (Germany) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 32a04c29 sha1 697179ecbfb138f1ceff5dd3ff414de06e12ad80 ) ) game ( - name "Doug - La Grande Aventure (France)" - description "Doug - La Grande Aventure (France)" - rom ( name "Doug - La Grande Aventure (France).gbc" size 1048576 crc a9e62f1a sha1 818804e3bc300b0a027a4e34055412c58d73f05e ) + name "Harvest Moon 2 GBC (USA) (SGB Enhanced) (GB Compatible)" + description "Harvest Moon 2 GBC (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Harvest Moon 2 GBC (USA) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 08906220 sha1 da745aa63684f53fb3ee6c19463ed4c132441ccb ) ) game ( - name "Doug's Big Game (Germany)" - description "Doug's Big Game (Germany)" - rom ( name "Doug's Big Game (Germany).gbc" size 1048576 crc 5dc254d1 sha1 df95173e91cd83bf7cb617629541c815e1ad3577 flags verified ) + name "Harvest Moon 3 GBC (USA)" + description "Harvest Moon 3 GBC (USA)" + rom ( name "Harvest Moon 3 GBC (USA).gbc" size 2097152 crc a0d67417 sha1 5313c62c51b9b5417f764fe67b687f403f9765bb ) ) game ( - name "Doug's Big Game (USA)" - description "Doug's Big Game (USA)" - rom ( name "Doug's Big Game (USA).gbc" size 1048576 crc 08e3d065 sha1 be8b0f966a43954084244ccd636ad3bb5a8b721c ) + name "Harvest Moon GB (Europe) (SGB Enhanced) (GB Compatible)" + description "Harvest Moon GB (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Harvest Moon GB (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c8a6f68a sha1 ea464cb16446855ed60cf714ca5b3ded02d82b1e ) ) game ( - name "Doug's Big Game (Europe)" - description "Doug's Big Game (Europe)" - rom ( name "Doug's Big Game (Europe).gbc" size 1048576 crc b6ffbcca sha1 e9c207bb9b03b5762afd53c8f5295703cc1474b1 ) + name "Harvest Moon GB (Germany) (SGB Enhanced) (GB Compatible)" + description "Harvest Moon GB (Germany) (SGB Enhanced) (GB Compatible)" + rom ( name "Harvest Moon GB (Germany) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d3896652 sha1 22e06880afe664051498714b3edb2e18f26f7961 ) ) game ( - name "Downer (World) (GB Compatible) (Aftermarket) (Unl)" - description "Downer (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Downer (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 7a1c9a9f sha1 70044dca1282f4445fe05305586ecc69f4e52304 ) + name "Harvest Moon GBC (USA) (SGB Enhanced) (GB Compatible)" + description "Harvest Moon GBC (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Harvest Moon GBC (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ab5738a1 sha1 d407b9c20c5381f46ec460858539a5b6f559e04f ) ) game ( - name "Dr. Rin ni Kiitemite! - Koi no Rin Fuusui (Japan)" - description "Dr. Rin ni Kiitemite! - Koi no Rin Fuusui (Japan)" - rom ( name "Dr. Rin ni Kiitemite! - Koi no Rin Fuusui (Japan).gbc" size 2097152 crc ec168a61 sha1 7810ea39edd661d2a9e95f57c9847d7e5a172ff6 flags verified ) + name "Hejin Zhuangbei II (Taiwan) (Unl)" + description "Hejin Zhuangbei II (Taiwan) (Unl)" + rom ( name "Hejin Zhuangbei II (Taiwan) (Unl).gbc" size 2097152 crc ef4bbb34 sha1 6a15fc7dbb3b9d7c130b9a25b568d39c655d68ca ) ) game ( - name "Dracula - Crazy Vampire (Europe) (En,Fr,De,Es,It)" - description "Dracula - Crazy Vampire (Europe) (En,Fr,De,Es,It)" - rom ( name "Dracula - Crazy Vampire (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 2f7aef51 sha1 815f252f761e0fd3f29b7acf32b2360264aefab1 ) + name "Hello Kitty no Beads Factory (Japan) (SGB Enhanced) (GB Compatible)" + description "Hello Kitty no Beads Factory (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Hello Kitty no Beads Factory (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 12f74cd4 sha1 539ddbe7f73b33ffb886143dd14869d486f3fecf ) ) game ( - name "Dracula - Crazy Vampire (USA)" - description "Dracula - Crazy Vampire (USA)" - rom ( name "Dracula - Crazy Vampire (USA).gbc" size 1048576 crc 283742e4 sha1 049727b428b01c5309a86039007c97bed7bf856a ) + name "Hello Kitty no Happy House (Japan)" + description "Hello Kitty no Happy House (Japan)" + rom ( name "Hello Kitty no Happy House (Japan).gbc" size 4194304 crc 159fe5e7 sha1 b5cbabec048e1f77fee7830bdb564f21369faeef ) ) game ( - name "Dragon Ball - Final Bout (Taiwan) (Unl)" - description "Dragon Ball - Final Bout (Taiwan) (Unl)" - rom ( name "Dragon Ball - Final Bout (Taiwan) (Unl).gbc" size 1048576 crc d9849157 sha1 51ebe1a27e8295340f996d2841c5cc6e2bc9f548 ) + name "Hello Kitty no Magical Museum (Japan) (SGB Enhanced) (GB Compatible)" + description "Hello Kitty no Magical Museum (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Hello Kitty no Magical Museum (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f6768930 sha1 462e5120831c2298bb5138bf25b4c8c72b372407 flags verified ) ) game ( - name "Dragon Ball Z - 2002 Fighting (Taiwan) (Zh) (Unl)" - description "Dragon Ball Z - 2002 Fighting (Taiwan) (Zh) (Unl)" - rom ( name "Dragon Ball Z - 2002 Fighting (Taiwan) (Zh) (Unl).gbc" size 2097152 crc 8fa35740 sha1 008a559635c9d351d9f68b3a1ac0c687521821cf ) + name "Hello Kitty no Sweet Adventure - Daniel-kun ni Aitai (Japan) (SGB Enhanced) (GB Compatible)" + description "Hello Kitty no Sweet Adventure - Daniel-kun ni Aitai (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Hello Kitty no Sweet Adventure - Daniel-kun ni Aitai (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 45f4159b sha1 c290dbd29a6246eb001f35f973c0e664af2c97b1 ) ) game ( - name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta) (All Unlocked)" - description "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta) (All Unlocked)" - rom ( name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta) (All Unlocked).gbc" size 2097152 crc fb942e08 sha1 075f4a1498d0b5f98f76984aca52ca1f03b1f85d ) + name "Hello Kitty to Dear Daniel no Dream Adventure (Japan)" + description "Hello Kitty to Dear Daniel no Dream Adventure (Japan)" + rom ( name "Hello Kitty to Dear Daniel no Dream Adventure (Japan).gbc" size 1048576 crc 018eed29 sha1 a726c5847112289720d6587bf63778c839245c49 ) ) game ( - name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta)" - description "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta)" - rom ( name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan) (Beta).gbc" size 2097152 crc 3f511f57 sha1 45f5a6fa7eff38b1bb8786472d0eeadf58f692a8 ) + name "Hello Kitty's Cube Frenzy (USA) (GB Compatible)" + description "Hello Kitty's Cube Frenzy (USA) (GB Compatible)" + rom ( name "Hello Kitty's Cube Frenzy (USA) (GB Compatible).gbc" size 1048576 crc 937729f6 sha1 6f15379553a0ec8a8174b85a35eaa4085dec6b43 ) ) game ( - name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan)" - description "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan)" - rom ( name "Dragon Ball Z - Densetsu no Chou Senshi-tachi (Japan).gbc" size 2097152 crc 7d28689a sha1 b094ae04fe665371cf0f5cb6942a67a379e8e645 ) + name "Hello Kitty's Cube Frenzy (Europe) (Proto) (GB Compatible)" + description "Hello Kitty's Cube Frenzy (Europe) (Proto) (GB Compatible)" + rom ( name "Hello Kitty's Cube Frenzy (Europe) (Proto) (GB Compatible).gbc" size 1048576 crc 9606a07f sha1 2225da8a68e489c0f562afcb8e90fc9387321af0 ) ) game ( - name "Dragon Ball Z - Guerreros de Leyenda (Spain)" - description "Dragon Ball Z - Guerreros de Leyenda (Spain)" - rom ( name "Dragon Ball Z - Guerreros de Leyenda (Spain).gbc" size 2097152 crc 9dad6e23 sha1 0318fa8930608cbf4dc69a8b6e2a41c96a51ea04 ) + name "Hercules - The Legendary Journeys (Europe) (En,Fr,De,Es,It,Nl)" + description "Hercules - The Legendary Journeys (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Hercules - The Legendary Journeys (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc c0ede71f sha1 ae521e5011b2b67de489374c3e9c5ec8ad8c0ee6 ) ) game ( - name "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta) (All Unlocked)" - description "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta) (All Unlocked)" - rom ( name "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta) (All Unlocked).gbc" size 2097152 crc d7654e34 sha1 ac3b5f50578210a29ce08e7e89d456cfc16b5ae9 ) + name "Hero Hero-kun (Japan)" + description "Hero Hero-kun (Japan)" + rom ( name "Hero Hero-kun (Japan).gbc" size 2097152 crc 8cabdca4 sha1 e7b0944fc2c9ffb4e7f997357327470e15798d63 ) ) game ( - name "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta)" - description "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta)" - rom ( name "Dragon Ball Z - Guerreros de Leyenda (Spain) (Beta).gbc" size 2097152 crc f017924f sha1 ad8235817bec5165a16478301cbfa7fa7d090ecf ) + name "Heroes of Might and Magic (USA) (En,Fr,De)" + description "Heroes of Might and Magic (USA) (En,Fr,De)" + rom ( name "Heroes of Might and Magic (USA) (En,Fr,De).gbc" size 1048576 crc bb0672a6 sha1 209d8a9cdd240a8c73d03d8575373bfa53948869 ) ) game ( - name "Dragon Ball Z - I Leggendari Super Guerrieri (Italy) (Beta) (All Unlocked)" - description "Dragon Ball Z - I Leggendari Super Guerrieri (Italy) (Beta) (All Unlocked)" - rom ( name "Dragon Ball Z - I Leggendari Super Guerrieri (Italy) (Beta) (All Unlocked).gbc" size 2097152 crc 35790637 sha1 621571759c021b564339efdc969d9bcef4c908dc ) + name "Heroes of Might and Magic (Europe) (En,Fr,De)" + description "Heroes of Might and Magic (Europe) (En,Fr,De)" + rom ( name "Heroes of Might and Magic (Europe) (En,Fr,De).gbc" size 1048576 crc e0b9fd3b sha1 d6471849187edcf68e61ed98558d9326a44cf2dc ) ) game ( - name "Dragon Ball Z - I Leggendari Super Guerrieri (Italy)" - description "Dragon Ball Z - I Leggendari Super Guerrieri (Italy)" - rom ( name "Dragon Ball Z - I Leggendari Super Guerrieri (Italy).gbc" size 2097152 crc a888a049 sha1 56dee34337a8893097cbffd7ea8aff76caef92d0 flags verified ) + name "Heroes of Might and Magic (USA) (En,Fr,De) (Rev 1) (Proto)" + description "Heroes of Might and Magic (USA) (En,Fr,De) (Rev 1) (Proto)" + rom ( name "Heroes of Might and Magic (USA) (En,Fr,De) (Rev 1) (Proto).gbc" size 1048576 crc 0753927e sha1 2ad31a64d113909180fd85dc6707a3c487ec2bfb ) ) game ( - name "Dragon Ball Z - Legendaere Superkaempfer (Germany)" - description "Dragon Ball Z - Legendaere Superkaempfer (Germany)" - rom ( name "Dragon Ball Z - Legendaere Superkaempfer (Germany).gbc" size 2097152 crc ec7dfdc1 sha1 8eb99e87c58a471b9af5f91b2aeab2bf4ec516d9 flags verified ) + name "Heroes of Might and Magic II (USA) (En,Fr,De)" + description "Heroes of Might and Magic II (USA) (En,Fr,De)" + rom ( name "Heroes of Might and Magic II (USA) (En,Fr,De).gbc" size 1048576 crc 53156d4d sha1 1d6ae18073c8b789c288039b0f579ebf15d1f03c ) ) game ( - name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 1)" - description "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 1)" - rom ( name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 1).gbc" size 2097152 crc 276f7895 sha1 3e2ba8228b0e804f2e581af5cc1e4bb95a8c9354 ) + name "Hexcite (Europe) (En,Fr,De) (Proto) (SGB Enhanced) (GB Compatible)" + description "Hexcite (Europe) (En,Fr,De) (Proto) (SGB Enhanced) (GB Compatible)" + rom ( name "Hexcite (Europe) (En,Fr,De) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 2c6bdcfa sha1 9380ad9ccc193682eb98be7d7447dabadd67beae ) ) game ( - name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 2)" - description "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 2)" - rom ( name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 2).gbc" size 2097152 crc 2353bbe4 sha1 b93c142b6da94c7d69956011ccbda9f22e5fae9f ) + name "Hexcite - The Shapes of Victory (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Hexcite - The Shapes of Victory (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Hexcite - The Shapes of Victory (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 84084e5f sha1 bb00ff88af717b45e08ef421ac77e0546870b1f4 flags verified ) ) game ( - name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3) (All Unlocked)" - description "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3) (All Unlocked)" - rom ( name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3) (All Unlocked).gbc" size 2097152 crc f646bd3b sha1 08a947763c36f4ad64f51c388da863d5852540a1 ) + name "Hiryuu no Ken - Retsuden GB (Japan)" + description "Hiryuu no Ken - Retsuden GB (Japan)" + rom ( name "Hiryuu no Ken - Retsuden GB (Japan).gbc" size 1048576 crc bdae91e8 sha1 75db7acdfa206e539c385b928da07c6b0c776308 ) ) game ( - name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3)" - description "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3)" - rom ( name "Dragon Ball Z - Legendaere Superkaempfer (Germany) (Beta 3).gbc" size 2097152 crc 72acbcb4 sha1 4b22b1949aed367036a84e0e7d36dd0a57bdd11f ) + name "Hissatsu Pachinko Boy - CR Monster House (Japan)" + description "Hissatsu Pachinko Boy - CR Monster House (Japan)" + rom ( name "Hissatsu Pachinko Boy - CR Monster House (Japan).gbc" size 1048576 crc 70f10315 sha1 35ee6e33b11ba8c02f1bf2dcdaf96c1e135982ab ) ) game ( - name "Dragon Ball Z - Legendary Super Warriors (Europe) (Beta) (All Unlocked)" - description "Dragon Ball Z - Legendary Super Warriors (Europe) (Beta) (All Unlocked)" - rom ( name "Dragon Ball Z - Legendary Super Warriors (Europe) (Beta) (All Unlocked).gbc" size 2097152 crc 4ec4f8ed sha1 073eb096c0454032d8632549ad4c60adc5b8cf9a ) + name "Hole in One Golf (USA) (Rumble Version) (SGB Enhanced) (GB Compatible)" + description "Hole in One Golf (USA) (Rumble Version) (SGB Enhanced) (GB Compatible)" + rom ( name "Hole in One Golf (USA) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 27a53965 sha1 d0c2fb49177bc1cf145503eb48bde3bd196ea1d9 ) ) game ( - name "Dragon Ball Z - Legendary Super Warriors (Europe)" - description "Dragon Ball Z - Legendary Super Warriors (Europe)" - rom ( name "Dragon Ball Z - Legendary Super Warriors (Europe).gbc" size 2097152 crc 7bf836db sha1 c190d34beac5157e98076d6a94ffa3033579b7a2 ) + name "Hollywood Pinball (Europe) (En,Fr,De,It) (GB Compatible)" + description "Hollywood Pinball (Europe) (En,Fr,De,It) (GB Compatible)" + rom ( name "Hollywood Pinball (Europe) (En,Fr,De,It) (GB Compatible).gbc" size 1048576 crc 8bd1f635 sha1 2d179e034dbd19e48aee31ffdc504305444cc84a ) ) game ( - name "Dragon Ball Z - Legendary Super Warriors (USA)" - description "Dragon Ball Z - Legendary Super Warriors (USA)" - rom ( name "Dragon Ball Z - Legendary Super Warriors (USA).gbc" size 2097152 crc 025aa88a sha1 e8184e1ae44d744aa54a082bd9979a46e144e6fb flags verified ) + name "Hollywood Pinball (Japan) (GB Compatible)" + description "Hollywood Pinball (Japan) (GB Compatible)" + rom ( name "Hollywood Pinball (Japan) (GB Compatible).gbc" size 1048576 crc 77d7e5b7 sha1 ff77ec892f2331e895774555183fb1cffb88ca6e ) ) game ( - name "Dragon Ball Z - Les Guerriers Legendaires (France)" - description "Dragon Ball Z - Les Guerriers Legendaires (France)" - rom ( name "Dragon Ball Z - Les Guerriers Legendaires (France).gbc" size 2097152 crc c07e9438 sha1 f5f0bc375f4559c9a0d62b52afd2eee18273c193 ) + name "Holy Magic Century (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + description "Holy Magic Century (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + rom ( name "Holy Magic Century (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc abd8ceae sha1 01ad2928e923c415671e6306d6d73016a1ca7bb9 ) ) game ( - name "Dragon Ball Z - Les Guerriers Legendaires (France) (Beta) (All Unlocked)" - description "Dragon Ball Z - Les Guerriers Legendaires (France) (Beta) (All Unlocked)" - rom ( name "Dragon Ball Z - Les Guerriers Legendaires (France) (Beta) (All Unlocked).gbc" size 2097152 crc f4041d28 sha1 72e25b25b9f2516879648e0051bb8ad8d4069003 ) + name "Honkaku Hanafuda GB (Japan)" + description "Honkaku Hanafuda GB (Japan)" + rom ( name "Honkaku Hanafuda GB (Japan).gbc" size 1048576 crc 05dcbd55 sha1 24e116249e569d79a280c8f4104934b369c32d79 ) ) game ( - name "Dragon Ball Z 3 - 2002 Fighting (Taiwan) (En) (Unl)" - description "Dragon Ball Z 3 - 2002 Fighting (Taiwan) (En) (Unl)" - rom ( name "Dragon Ball Z 3 - 2002 Fighting (Taiwan) (En) (Unl).gbc" size 2097152 crc dbe0f44e sha1 baea9e5ee1411988039d563ece97d8d7f765396a ) + name "Honkaku Shougi - Shougi Ou (Japan) (SGB Enhanced) (GB Compatible)" + description "Honkaku Shougi - Shougi Ou (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Honkaku Shougi - Shougi Ou (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 3a96e868 sha1 a0e5a6b00cc31670949f7d8cdeec2486d0ec986f ) ) game ( - name "Dragon Ball Z Gedou 2005 (Taiwan) (Unl)" - description "Dragon Ball Z Gedou 2005 (Taiwan) (Unl)" - rom ( name "Dragon Ball Z Gedou 2005 (Taiwan) (Unl).gbc" size 2097152 crc d1c48145 sha1 8637ed614dc94e846c32adbc723e09a06b3da3ce ) + name "Honkaku Taisen Shougi Ayumu (Japan) (GB Compatible)" + description "Honkaku Taisen Shougi Ayumu (Japan) (GB Compatible)" + rom ( name "Honkaku Taisen Shougi Ayumu (Japan) (GB Compatible).gbc" size 1048576 crc 89140949 sha1 5b71c264a69902d77888243df92e8c93ace6732b ) ) game ( - name "Dragon Dance (USA) (SGB Enhanced) (GB Compatible)" - description "Dragon Dance (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Dance (USA) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 0602dbe1 sha1 a28bfabc4db62ad5aa6bfe29114b0878429586cc ) + name "Honkaku Yonin Uchi Mahjong - Mahjong Ou (Japan) (SGB Enhanced) (GB Compatible)" + description "Honkaku Yonin Uchi Mahjong - Mahjong Ou (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Honkaku Yonin Uchi Mahjong - Mahjong Ou (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 8ed4bbba sha1 222487f14aaaa8f0bb536a09238e63ac95636208 ) ) game ( - name "Dragon Dance (Europe) (Proto) (SGB Enhanced) (GB Compatible)" - description "Dragon Dance (Europe) (Proto) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Dance (Europe) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 8b0dd3b2 sha1 76de183317c952276dbdad9d8f0592493652f31e ) + name "Hot Wheels - Stunt Track Driver (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Hot Wheels - Stunt Track Driver (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Hot Wheels - Stunt Track Driver (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 72a5e820 sha1 eabf2bc053ba6a440a834d6bcd0b45a7432a9a20 ) ) game ( - name "Dragon Dance (USA) (Beta 1) (SGB Enhanced) (GB Compatible)" - description "Dragon Dance (USA) (Beta 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Dance (USA) (Beta 1) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc a0cd0ed7 sha1 7df48e776ce2be88f7a9459530b855cef2f012b6 ) + name "Hoyle Card Games (USA)" + description "Hoyle Card Games (USA)" + rom ( name "Hoyle Card Games (USA).gbc" size 1048576 crc dd5d3713 sha1 5eb733fa50e21f124a5362287da439dc199e3773 ) ) game ( - name "Dragon Dance (USA) (Beta 2) (SGB Enhanced) (GB Compatible)" - description "Dragon Dance (USA) (Beta 2) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Dance (USA) (Beta 2) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 9a90adbe sha1 5fc97752a98a18b7e2db238d1ab88c6b09e34602 ) + name "Hoyle Casino (USA)" + description "Hoyle Casino (USA)" + rom ( name "Hoyle Casino (USA).gbc" size 1048576 crc 413473b0 sha1 827efa6d7b56e919b95ae52c451be2a40d870822 ) ) game ( - name "Dragon Quest I & II (Japan) (SGB Enhanced) (GB Compatible)" - description "Dragon Quest I & II (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Quest I & II (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc a053b42e sha1 8cfdfb7a76dd0012af3b441e162fcd37e4370958 flags verified ) + name "Hugo - Black Diamond Fever (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" + description "Hugo - Black Diamond Fever (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" + rom ( name "Hugo - Black Diamond Fever (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi).gbc" size 1048576 crc 685cafcc sha1 bb2721dd0866b9b7f41e590287569fc09339cc6a ) ) game ( - name "Dragon Quest III - Soshite Densetsu e... (Japan)" - description "Dragon Quest III - Soshite Densetsu e... (Japan)" - rom ( name "Dragon Quest III - Soshite Densetsu e... (Japan).gbc" size 4194304 crc 21078c16 sha1 1f30968a5ebd32643acd32351e78e68cfffb8ae9 flags verified ) + name "Hugo - The Evil Mirror (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" + description "Hugo - The Evil Mirror (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" + rom ( name "Hugo - The Evil Mirror (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi).gbc" size 1048576 crc 24b76cd0 sha1 e5f29c654687221c5e4d4bdbc456fd08f32946a6 ) ) game ( - name "Dragon Quest Monsters (Germany) (SGB Enhanced) (GB Compatible)" - description "Dragon Quest Monsters (Germany) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Quest Monsters (Germany) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 2a82b63b sha1 ae8a05d616785391ba4bbdca4c408d4a641c6683 ) + name "Hugo 2 1-2 (Germany) (GB Compatible)" + description "Hugo 2 1-2 (Germany) (GB Compatible)" + rom ( name "Hugo 2 1-2 (Germany) (GB Compatible).gbc" size 1048576 crc fab64b18 sha1 5d89a8b4de6e6b2ba5be3434f0a1eee03077eeda flags verified ) ) game ( - name "Dragon Quest Monsters - Terry no Wonderland (Japan) (SGB Enhanced) (GB Compatible)" - description "Dragon Quest Monsters - Terry no Wonderland (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Quest Monsters - Terry no Wonderland (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4702c4f1 sha1 eebaf3d553bb915340e64cb85022eb8344ddf1b0 flags verified ) + name "Hunter x Hunter - Hunter no Keifu (Japan)" + description "Hunter x Hunter - Hunter no Keifu (Japan)" + rom ( name "Hunter x Hunter - Hunter no Keifu (Japan).gbc" size 4194304 crc a1361642 sha1 cf31b713b6039ba18675fa5d4caa83934ae1f216 ) ) game ( - name "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc d263d88d sha1 a32198d1645741979e24956afd6479b64c258647 flags verified ) + name "Hunter x Hunter - Kindan no Hihou (Japan)" + description "Hunter x Hunter - Kindan no Hihou (Japan)" + rom ( name "Hunter x Hunter - Kindan no Hihou (Japan).gbc" size 1048576 crc d23c6a75 sha1 ef131fb2752b8ff996bf1aaaebd22887e380aa31 ) ) game ( - name "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (Possible Proto) (SGB Enhanced) (GB Compatible) (Alt)" - description "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (Possible Proto) (SGB Enhanced) (GB Compatible) (Alt)" - rom ( name "Dragon Quest Monsters - Terry no Wonderland (Japan) (Rev 1) (Possible Proto) (SGB Enhanced) (GB Compatible) (Alt).gbc" size 2097152 crc 66b83e3a sha1 378794e041f2eb286f2d5243a3cada2faf265bb5 ) + name "Hype - The Time Quest (Europe) (En,Fr,De,Es,It,Nl,Sv,Da)" + description "Hype - The Time Quest (Europe) (En,Fr,De,Es,It,Nl,Sv,Da)" + rom ( name "Hype - The Time Quest (Europe) (En,Fr,De,Es,It,Nl,Sv,Da).gbc" size 1048576 crc 24846d65 sha1 8e26e7e2e64d4bf866b67387586fc5c4a9c56855 ) ) game ( - name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Iru no Bouken (Japan) (SGB Enhanced) (GB Compatible)" - description "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Iru no Bouken (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Iru no Bouken (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 68ba18d7 sha1 9193778b28e2e4a6303e09cb4170ca00d0058ae5 ) + name "Hype - The Time Quest (Brazil) (En)" + description "Hype - The Time Quest (Brazil) (En)" + rom ( name "Hype - The Time Quest (Brazil) (En).gbc" size 1048576 crc cafb8035 sha1 7c7dca7c48dc478d0278c273ba37723b9e9dce5b ) ) game ( - name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (SGB Enhanced) (GB Compatible)" - description "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 2c428a87 sha1 5d2daec53938805236328a0f8a614debffa34048 flags verified ) + name "Hyper Olympic - Winter 2000 (Japan)" + description "Hyper Olympic - Winter 2000 (Japan)" + rom ( name "Hyper Olympic - Winter 2000 (Japan).gbc" size 1048576 crc a9b8f072 sha1 b8b0ea6e8a1093e7171ffe0eff73967a6cc00bce ) ) game ( - name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Quest Monsters 2 - Maruta no Fushigi na Kagi - Ruka no Tabidachi (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 649e8d97 sha1 217faaf8e7d60545bd07f818a3b3373843e6318d flags verified ) + name "Hyper Olympic Series - Track & Field GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Hyper Olympic Series - Track & Field GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Hyper Olympic Series - Track & Field GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 77f76ebc sha1 6dabafe260b53e61a810cbae2f14287adafffd8e ) ) game ( - name "Dragon Tales - Dragon Adventures (USA)" - description "Dragon Tales - Dragon Adventures (USA)" - rom ( name "Dragon Tales - Dragon Adventures (USA).gbc" size 1048576 crc de390609 sha1 3daa96d9d66f686077f03f0820c63f751047e791 ) + name "Ice Age II (Taiwan) (En) (Unl)" + description "Ice Age II (Taiwan) (En) (Unl)" + rom ( name "Ice Age II (Taiwan) (En) (Unl).gbc" size 2097152 crc 50bc8e9d sha1 c57912e67c135c48233f351f68cdc34020de8d01 ) ) game ( - name "Dragon Tales - Dragon Wings (Europe)" - description "Dragon Tales - Dragon Wings (Europe)" - rom ( name "Dragon Tales - Dragon Wings (Europe).gbc" size 1048576 crc 137d7b45 sha1 fa30510eb396143b3b0025005ee82de207562e65 ) + name "Ide Yousuke no Mahjong Kyoushitsu GB (Japan)" + description "Ide Yousuke no Mahjong Kyoushitsu GB (Japan)" + rom ( name "Ide Yousuke no Mahjong Kyoushitsu GB (Japan).gbc" size 2097152 crc 61df88ca sha1 e4138f45980d60700c758babfa1473c03b24d247 ) ) game ( - name "Dragon Tales - Dragon Wings (USA)" - description "Dragon Tales - Dragon Wings (USA)" - rom ( name "Dragon Tales - Dragon Wings (USA).gbc" size 1048576 crc 191d31ec sha1 de220565bfdd27e48de4ba886cd3c135953140e5 ) + name "Indiana Jones and the Infernal Machine (USA, Europe) (En,Fr,De)" + description "Indiana Jones and the Infernal Machine (USA, Europe) (En,Fr,De)" + rom ( name "Indiana Jones and the Infernal Machine (USA, Europe) (En,Fr,De).gbc" size 1048576 crc 7fff1142 sha1 6d568438aa3b9b67c55aded582cec136b15c46d7 flags verified ) ) game ( - name "Dragon Warrior I & II (USA) (SGB Enhanced) (GB Compatible)" - description "Dragon Warrior I & II (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Warrior I & II (USA) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 71d693da sha1 01c4e2145365a12560d162116378f1991807ef95 flags verified ) + name "Infinity (USA) (Proto) (2001-03-22)" + description "Infinity (USA) (Proto) (2001-03-22)" + rom ( name "Infinity (USA) (Proto) (2001-03-22).gbc" size 2097152 crc 4ade94aa sha1 fdfd6d4cbebbf64fc7d1264f0450be270be89823 ) ) game ( - name "Dragon Warrior III (USA)" - description "Dragon Warrior III (USA)" - rom ( name "Dragon Warrior III (USA).gbc" size 4194304 crc 0fd9c59c sha1 581a12695ae42becaa078ac2694a11767a96dc61 flags verified ) + name "Inspector Gadget - Operation Madkactus (Europe) (Fr) (Beta)" + description "Inspector Gadget - Operation Madkactus (Europe) (Fr) (Beta)" + rom ( name "Inspector Gadget - Operation Madkactus (Europe) (Fr) (Beta).gbc" size 1048576 crc 93ec798b sha1 8444ff17aa3f865eec33cc49398b450e345376c3 ) ) game ( - name "Dragon Warrior Monsters (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Dragon Warrior Monsters (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Warrior Monsters (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc e56c35b1 sha1 728e458d4b13cdc8a0026dc28c5a14f1d72d9da4 flags verified ) + name "Inspector Gadget - Operation Madkactus (Europe) (En,Fr,De,Es,It,Nl)" + description "Inspector Gadget - Operation Madkactus (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Inspector Gadget - Operation Madkactus (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 3390b056 sha1 55c02b81fa854938ca3cb3e5b725a6a72f711e7b ) ) game ( - name "Dragon Warrior Monsters 2 - Cobi's Journey (USA) (SGB Enhanced) (GB Compatible)" - description "Dragon Warrior Monsters 2 - Cobi's Journey (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Warrior Monsters 2 - Cobi's Journey (USA) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc ab7bfdd5 sha1 76901b7e5cadf9611dd4fac52e8501155c1e33a2 ) + name "Inspector Gadget - Operation Madkactus (USA)" + description "Inspector Gadget - Operation Madkactus (USA)" + rom ( name "Inspector Gadget - Operation Madkactus (USA).gbc" size 1048576 crc 1af0b489 sha1 b0fa81a35e605948df3b7f1fcb5893bab99d9d6a ) ) game ( - name "Dragon Warrior Monsters 2 - Tara's Adventure (USA) (SGB Enhanced) (GB Compatible)" - description "Dragon Warrior Monsters 2 - Tara's Adventure (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Dragon Warrior Monsters 2 - Tara's Adventure (USA) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 35ec5fb2 sha1 a68451e7d3accd81b240c4b60a1f552e39211ede ) + name "International Karate 2000 (Europe)" + description "International Karate 2000 (Europe)" + rom ( name "International Karate 2000 (Europe).gbc" size 1048576 crc 12e00808 sha1 515477a2695f89827b2dc5495d9d43ec79a6cc09 ) ) game ( - name "Dragon's Lair (USA, Europe) (En,Ja,Fr,De,Es,Zh)" - description "Dragon's Lair (USA, Europe) (En,Ja,Fr,De,Es,Zh)" - rom ( name "Dragon's Lair (USA, Europe) (En,Ja,Fr,De,Es,Zh).gbc" size 4194304 crc bf076ca5 sha1 15fb0865314e43a83910d52cca7307502aab29fc ) + name "International Rally (USA) (SGB Enhanced) (GB Compatible)" + description "International Rally (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "International Rally (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b85fd752 sha1 ac09080efb22ed401ddc827045e72ab054da1763 ) ) game ( - name "Dragonborne DX (World) (v1.0.2) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Dragonborne DX (World) (v1.0.2) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Dragonborne DX (World) (v1.0.2) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 4194304 crc 9f30b891 sha1 9974d28975a2d8e1e41ce8f32351c6eef144919d ) + name "International Superstar Soccer 2000 (Europe)" + description "International Superstar Soccer 2000 (Europe)" + rom ( name "International Superstar Soccer 2000 (Europe).gbc" size 2097152 crc 57ea1ec8 sha1 3ef4adaff3a9d36dc6986a5944280162768c441d ) ) game ( - name "Dragonyhm (World) (v1.0) (Demo) (SGB Enhanced) (GB Compatible) (Aftermarket) (Unl)" - description "Dragonyhm (World) (v1.0) (Demo) (SGB Enhanced) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Dragonyhm (World) (v1.0) (Demo) (SGB Enhanced) (GB Compatible) (Aftermarket) (Unl).gbc" size 4194304 crc 96f9b7c0 sha1 2b74d076cabff92e5935d922e8f37202a723aaf0 flags verified ) + name "International Superstar Soccer 2000 (USA)" + description "International Superstar Soccer 2000 (USA)" + rom ( name "International Superstar Soccer 2000 (USA).gbc" size 2097152 crc e8fa7203 sha1 117415d3620fab07066cd5a3ffb438d05bfd940a ) ) game ( - name "Dragonyhm (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Dragonyhm (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Dragonyhm (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 4194304 crc cad7369d sha1 0058096f8fcbb2774f908811aaa0b1ee54111493 ) + name "International Superstar Soccer 99 (Europe) (SGB Enhanced) (GB Compatible)" + description "International Superstar Soccer 99 (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "International Superstar Soccer 99 (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1b76d115 sha1 d9d9fffb463d4c35f8a1a753908cddfbe17fc671 flags verified ) ) game ( - name "Driver (Europe) (En,Fr,De,Es,It)" - description "Driver (Europe) (En,Fr,De,Es,It)" - rom ( name "Driver (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc e9e67403 sha1 5001f0f4904ca4fb6ab287b52136d00ac94b49d7 ) + name "International Superstar Soccer 99 (USA) (SGB Enhanced) (GB Compatible)" + description "International Superstar Soccer 99 (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "International Superstar Soccer 99 (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 9d0290a7 sha1 6f491e6f919a677627090f949b8e69abb8bfd1db ) ) game ( - name "Driver (Europe) (En,Fr,De,Es,It) (Beta)" - description "Driver (Europe) (En,Fr,De,Es,It) (Beta)" - rom ( name "Driver (Europe) (En,Fr,De,Es,It) (Beta).gbc" size 1048576 crc 33e9d438 sha1 07e25b8c7569e064d060258981814a151202edbb ) + name "International Track & Field (Europe) (En,Fr,De,It) (SGB Enhanced) (GB Compatible)" + description "International Track & Field (Europe) (En,Fr,De,It) (SGB Enhanced) (GB Compatible)" + rom ( name "International Track & Field (Europe) (En,Fr,De,It) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 327ec81f sha1 3aecac0876dac69e9e1fb6f6c311d0af050f1f48 ) ) game ( - name "Driver - You Are the Wheelman (USA) (En,Fr,De,Es,It)" - description "Driver - You Are the Wheelman (USA) (En,Fr,De,Es,It)" - rom ( name "Driver - You Are the Wheelman (USA) (En,Fr,De,Es,It).gbc" size 1048576 crc d4c7f6df sha1 9add1e67f39f900f2c004e4d8bbd1fec368eef4c ) + name "International Track & Field (USA) (SGB Enhanced) (GB Compatible)" + description "International Track & Field (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "International Track & Field (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 803d5d57 sha1 80b7591470d0a26fe7cf5c80c8bff5d34f79f569 ) ) game ( - name "Dropzone (Europe) (GB Compatible)" - description "Dropzone (Europe) (GB Compatible)" - rom ( name "Dropzone (Europe) (GB Compatible).gbc" size 262144 crc 1e71b67e sha1 e5bb7c075c2953e99ca2abe66592810125febf0a flags verified ) + name "International Track & Field - Summer Games (Europe)" + description "International Track & Field - Summer Games (Europe)" + rom ( name "International Track & Field - Summer Games (Europe).gbc" size 1048576 crc d826c75f sha1 53e158cb23fa79026345dae775d9f020218f8bb2 ) ) game ( - name "DryMouth (USA) (Unl)" - description "DryMouth (USA) (Unl)" - rom ( name "DryMouth (USA) (Unl).gbc" size 1048576 crc 6471622c sha1 6bf5cbd0b5d2ce170b0334abafa59cf3aa18adb2 ) + name "It's a World Rally (Japan) (SGB Enhanced) (GB Compatible)" + description "It's a World Rally (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "It's a World Rally (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 39e34650 sha1 31a289823468285ac786afe7de38201235983e35 ) ) game ( - name "DT - Lords of Genomes (Japan) (SGB Enhanced) (GB Compatible)" - description "DT - Lords of Genomes (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "DT - Lords of Genomes (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 42ceb854 sha1 66988a201f77cd4c33fb0a9b3981ff5831206c9d ) + name "Itsudemo Pachinko GB - CR Monster House (Japan)" + description "Itsudemo Pachinko GB - CR Monster House (Japan)" + rom ( name "Itsudemo Pachinko GB - CR Monster House (Japan).gbc" size 1048576 crc 834091ba sha1 c07c9fc27e0c2cab09a55cd7c6a3ecc06da13aec ) ) game ( - name "Duke Nukem (Europe) (En,Fr,De,Es,It)" - description "Duke Nukem (Europe) (En,Fr,De,Es,It)" - rom ( name "Duke Nukem (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc fc3d1bb7 sha1 665961e875350d9335e467c2ad752a4dd3dcaef4 flags verified ) + name "J.League Excite Stage GB (Japan)" + description "J.League Excite Stage GB (Japan)" + rom ( name "J.League Excite Stage GB (Japan).gbc" size 1048576 crc b3f38f16 sha1 76f708659d790e1a2bf3915591499a4a8904974b ) ) game ( - name "Duke Nukem (USA) (En,Fr,De,Es,It)" - description "Duke Nukem (USA) (En,Fr,De,Es,It)" - rom ( name "Duke Nukem (USA) (En,Fr,De,Es,It).gbc" size 1048576 crc 846fc830 sha1 b9bd0cfe64a7f40c243bc65e0489b5187ad11560 ) + name "J.League Excite Stage Tactics (Japan)" + description "J.League Excite Stage Tactics (Japan)" + rom ( name "J.League Excite Stage Tactics (Japan).gbc" size 2097152 crc 558f4631 sha1 7862be5efe19d84b205062a7e77e5a317f7e17fc ) ) game ( - name "Dukes of Hazzard, The - Racing for Home (Europe) (En,Fr,De)" - description "Dukes of Hazzard, The - Racing for Home (Europe) (En,Fr,De)" - rom ( name "Dukes of Hazzard, The - Racing for Home (Europe) (En,Fr,De).gbc" size 2097152 crc 21826adc sha1 782337f5338a242bc8cbaeb69ce7f1e87bb0f6b9 flags verified ) + name "Jack no Daibouken - Daimaou no Gyakushuu (Japan) (SGB Enhanced) (GB Compatible)" + description "Jack no Daibouken - Daimaou no Gyakushuu (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Jack no Daibouken - Daimaou no Gyakushuu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc cff5325a sha1 c2d9548e845ed9a76a0e6dae81bb80023564a9f2 ) ) game ( - name "Dukes of Hazzard, The - Racing for Home (USA)" - description "Dukes of Hazzard, The - Racing for Home (USA)" - rom ( name "Dukes of Hazzard, The - Racing for Home (USA).gbc" size 2097152 crc fb08dceb sha1 6a39dfbce8b86db84615cdb5fb24012cbbac7b36 ) + name "Jagainu-kun (Japan) (GB Compatible)" + description "Jagainu-kun (Japan) (GB Compatible)" + rom ( name "Jagainu-kun (Japan) (GB Compatible).gbc" size 1048576 crc aeb634c5 sha1 c8cf0523c2cf562d2b2e79b2fe8845e6943a0be4 ) ) game ( - name "Dungeon Savior (Japan) (SGB Enhanced) (GB Compatible)" - description "Dungeon Savior (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Dungeon Savior (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 2bcb5f78 sha1 766ab65d9420f361d8d9a4754ea8c6b692e34c36 ) + name "Jaguar Mishin Sashi Senyou Soft - Kirby Family (Japan) (Proto)" + description "Jaguar Mishin Sashi Senyou Soft - Kirby Family (Japan) (Proto)" + rom ( name "Jaguar Mishin Sashi Senyou Soft - Kirby Family (Japan) (Proto).gbc" size 2097152 crc bd65b109 sha1 709c612c13b70226a919a168b03427ec0f33f8f8 ) ) game ( - name "Dungeon Savior (Japan) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible)" - description "Dungeon Savior (Japan) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible)" - rom ( name "Dungeon Savior (Japan) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 0180364b sha1 c5e93f04cc41404320aaf70eb10b55465edb1083 ) + name "Jaguar Mishin Sashi Senyou Soft - Mario Family (Japan)" + description "Jaguar Mishin Sashi Senyou Soft - Mario Family (Japan)" + rom ( name "Jaguar Mishin Sashi Senyou Soft - Mario Family (Japan).gbc" size 2097152 crc ab3f3cef sha1 4a3c1c84a486864b84e110456e4b9a4e582fdbb8 ) ) game ( - name "Dusky Dungeon (World) (v0.1.0) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "Dusky Dungeon (World) (v0.1.0) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Dusky Dungeon (World) (v0.1.0) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 7c41cef6 sha1 e2df238887da0b6cf79513c7799ad707740eae30 ) + name "Jankyuusei - Cosplay Paradise (Japan)" + description "Jankyuusei - Cosplay Paradise (Japan)" + rom ( name "Jankyuusei - Cosplay Paradise (Japan).gbc" size 4194304 crc d60e1c0a sha1 45db3e3c0752c59fc20803945593fd8b9264240e ) ) game ( - name "Dusky Dungeon (World) (v0.2.0) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "Dusky Dungeon (World) (v0.2.0) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Dusky Dungeon (World) (v0.2.0) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc abb154db sha1 f3b456d6318bee05150403efa5a933996e1d744a ) + name "Janosch - Das grosse Panama-Spiel (Germany)" + description "Janosch - Das grosse Panama-Spiel (Germany)" + rom ( name "Janosch - Das grosse Panama-Spiel (Germany).gbc" size 1048576 crc 32c8ee13 sha1 0b514e2b77b9da69d10fa1f3d79c0727f625de82 flags verified ) ) game ( - name "DX Jinsei Game (Japan)" - description "DX Jinsei Game (Japan)" - rom ( name "DX Jinsei Game (Japan).gbc" size 2097152 crc 7e15b3dd sha1 cd14fe4e7c7a8a4c6af76682a954ef24919d89ad flags verified ) + name "Jay und die Spielzeugdiebe (Germany)" + description "Jay und die Spielzeugdiebe (Germany)" + rom ( name "Jay und die Spielzeugdiebe (Germany).gbc" size 1048576 crc 73f4f6da sha1 dd01d68bab2d3615f173e4c9c94da56248fab580 ) ) game ( - name "DX Monopoly GB (Japan) (SGB Enhanced) (GB Compatible)" - description "DX Monopoly GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "DX Monopoly GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 3f1e076c sha1 524d9459d357e209d64a2ef17b4072478f290806 ) + name "Jeff Gordon XS Racing (USA) (GB Compatible)" + description "Jeff Gordon XS Racing (USA) (GB Compatible)" + rom ( name "Jeff Gordon XS Racing (USA) (GB Compatible).gbc" size 1048576 crc a41ed926 sha1 3939bd5c3ba034ebb19395d4292f82b703629468 ) ) game ( - name "DynaMike (Europe) (Proto)" - description "DynaMike (Europe) (Proto)" - rom ( name "DynaMike (Europe) (Proto).gbc" size 1048576 crc 53c069e9 sha1 692a583da5890e83da5a5eac8d0d31315da316df ) + name "Jeremy McGrath Supercross 2000 (USA, Europe)" + description "Jeremy McGrath Supercross 2000 (USA, Europe)" + rom ( name "Jeremy McGrath Supercross 2000 (USA, Europe).gbc" size 1048576 crc f0f9abe6 sha1 5b48252bde9f47d0ffd33f0e84cf30ec769946e7 ) ) game ( - name "E.T. - The Extra-Terrestrial - Digital Companion (USA)" - description "E.T. - The Extra-Terrestrial - Digital Companion (USA)" - rom ( name "E.T. - The Extra-Terrestrial - Digital Companion (USA).gbc" size 1048576 crc 84872999 sha1 7dd940c8044ccc0e18a511fa32c73551ce30463e ) + name "Jeremy McGrath Supercross 2000 (Japan) (En) (Possible Proto) (NP)" + description "Jeremy McGrath Supercross 2000 (Japan) (En) (Possible Proto) (NP)" + rom ( name "Jeremy McGrath Supercross 2000 (Japan) (En) (Possible Proto) (NP).gbc" size 1048576 crc 666d2a75 sha1 dd204c1d47290f52ef264ce32d59cb5f58a2701d ) ) game ( - name "E.T. - The Extra-Terrestrial - Digital Companion (Europe) (Proto)" - description "E.T. - The Extra-Terrestrial - Digital Companion (Europe) (Proto)" - rom ( name "E.T. - The Extra-Terrestrial - Digital Companion (Europe) (Proto).gbc" size 1048576 crc 513f38b7 sha1 14ad36a7939be12d1212c12a59de31d27e4df8f3 ) + name "Jet de Go! - Let's Go by Airliner (Japan)" + description "Jet de Go! - Let's Go by Airliner (Japan)" + rom ( name "Jet de Go! - Let's Go by Airliner (Japan).gbc" size 2097152 crc 20c4ccf6 sha1 97bf75afa0089ddb342ea7046b7cd113ba2c6fec ) ) game ( - name "E.T. - The Extra-Terrestrial - Escape from Planet Earth (Europe) (En,Fr,De,Es,It,Nl)" - description "E.T. - The Extra-Terrestrial - Escape from Planet Earth (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "E.T. - The Extra-Terrestrial - Escape from Planet Earth (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc b25f3db5 sha1 95fd6b8f5b4f550d6e28f21f23e2e0794176d9b7 ) + name "Jibaku-kun - Rei no Itsuki no Kajitsu (Japan) (Proto)" + description "Jibaku-kun - Rei no Itsuki no Kajitsu (Japan) (Proto)" + rom ( name "Jibaku-kun - Rei no Itsuki no Kajitsu (Japan) (Proto).gbc" size 2097152 crc 1900bcc8 sha1 fec43a82916e8504de685b928a0af73c2252b55d ) ) game ( - name "E.T. - The Extra-Terrestrial - Escape from Planet Earth (USA)" - description "E.T. - The Extra-Terrestrial - Escape from Planet Earth (USA)" - rom ( name "E.T. - The Extra-Terrestrial - Escape from Planet Earth (USA).gbc" size 1048576 crc 086106de sha1 d90e6a76a6cadc4b364f36c01345a26e086adb73 ) + name "Jieba Tianwang 4 (Taiwan) (Unl)" + description "Jieba Tianwang 4 (Taiwan) (Unl)" + rom ( name "Jieba Tianwang 4 (Taiwan) (Unl).gbc" size 1048576 crc 1a6fe765 sha1 b0862fc1cc856b904b2febd094d9453a2baacb85 ) ) game ( - name "E.T. - The Extra-Terrestrial and the Cosmic Garden (Europe) (En,Fr,De,Es,It,Nl)" - description "E.T. - The Extra-Terrestrial and the Cosmic Garden (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "E.T. - The Extra-Terrestrial and the Cosmic Garden (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 8321a1b9 sha1 c4f4179f391fc57ea4db3688d95f2d53533db995 flags verified ) + name "Jim Henson's Bear in the Big Blue House (Europe) (En,Fr,De,Es,It,Nl)" + description "Jim Henson's Bear in the Big Blue House (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Jim Henson's Bear in the Big Blue House (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 48c99939 sha1 a5c2bb5244fe0fd6d2710c832f66f8f8b8c2bbab flags verified ) ) game ( - name "E.T. - The Extra-Terrestrial and the Cosmic Garden (USA)" - description "E.T. - The Extra-Terrestrial and the Cosmic Garden (USA)" - rom ( name "E.T. - The Extra-Terrestrial and the Cosmic Garden (USA).gbc" size 1048576 crc 32c87958 sha1 da71b581f7415b6535ac4af2e8fccd2040c54215 ) + name "Jim Henson's Bear in the Big Blue House (USA) (En,Fr,De,Es,It,Nl)" + description "Jim Henson's Bear in the Big Blue House (USA) (En,Fr,De,Es,It,Nl)" + rom ( name "Jim Henson's Bear in the Big Blue House (USA) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 851c8710 sha1 e4c1c58025a083c067f752490c1fbd816c93d072 ) ) game ( - name "Earthworm Jim - Menace 2 the Galaxy (USA, Europe) (GB Compatible)" - description "Earthworm Jim - Menace 2 the Galaxy (USA, Europe) (GB Compatible)" - rom ( name "Earthworm Jim - Menace 2 the Galaxy (USA, Europe) (GB Compatible).gbc" size 1048576 crc 2e65daaf sha1 78f9bd7f8c40274cf7282892a45e814103944060 flags verified ) + name "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv)" + description "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv)" + rom ( name "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv).gbc" size 2097152 crc 0fafa3f2 sha1 dc9288bc4b2a2093ea298514a91c3b2b4101691b ) ) game ( - name "ECW Hardcore Revolution (USA, Europe)" - description "ECW Hardcore Revolution (USA, Europe)" - rom ( name "ECW Hardcore Revolution (USA, Europe).gbc" size 1048576 crc 484eba10 sha1 c337d0480e84f5e2b7e28b13c3667b8cf92d9649 ) + name "Jim Henson's Muppets (USA)" + description "Jim Henson's Muppets (USA)" + rom ( name "Jim Henson's Muppets (USA).gbc" size 2097152 crc 3c476c6f sha1 77ad190ad107c57b167e3837757a4c7f990a867e ) ) game ( - name "Elang Chuanshuo - Shiji Zhi Zhan (Taiwan) (Unl)" - description "Elang Chuanshuo - Shiji Zhi Zhan (Taiwan) (Unl)" - rom ( name "Elang Chuanshuo - Shiji Zhi Zhan (Taiwan) (Unl).gbc" size 1048576 crc 1cb8e67f sha1 334bebed71956822f7cf9af9a2e2be2f1280654c ) + name "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + description "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + rom ( name "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 4194304 crc 3204b92c sha1 6e042fc6029493a429557a6fdce111c03f9ede1b flags verified ) ) game ( - name "Elemental Fighter (USA) (Proto)" - description "Elemental Fighter (USA) (Proto)" - rom ( name "Elemental Fighter (USA) (Proto).gbc" size 262144 crc 03fc3d03 sha1 92cce7614474d3f9ed9e3fdbd2e2bb434e074565 ) + name "Jimmy White's Cueball (USA) (Proto)" + description "Jimmy White's Cueball (USA) (Proto)" + rom ( name "Jimmy White's Cueball (USA) (Proto).gbc" size 1048576 crc 62c49da9 sha1 54a72ed5ef210b947a97e81208752c4431ef715c ) ) game ( - name "Elementaria - Orientational Waltz (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Elementaria - Orientational Waltz (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Elementaria - Orientational Waltz (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc bffec2e1 sha1 a25cc6ee07e524f9a7121786bd0e513a1c6c2a8d ) + name "Jimmy White's Cueball (Europe)" + description "Jimmy White's Cueball (Europe)" + rom ( name "Jimmy White's Cueball (Europe).gbc" size 1048576 crc 27632f4f sha1 ed9a76a235edd862f642b4dc974cd37126a267a8 ) ) game ( - name "Elevator Action EX (Europe) (En,Fr,De,Es,It)" - description "Elevator Action EX (Europe) (En,Fr,De,Es,It)" - rom ( name "Elevator Action EX (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 2154763c sha1 498308efb907c8dc79c9699d27ff349941fac23a ) + name "Jingling Wang III (Taiwan) (Unl)" + description "Jingling Wang III (Taiwan) (Unl)" + rom ( name "Jingling Wang III (Taiwan) (Unl).gbc" size 2097152 crc f19e780c sha1 8ef6ceb1b7894f43caa5f422d62d6c437f81e56d ) ) game ( - name "Elevator Action EX (Japan)" - description "Elevator Action EX (Japan)" - rom ( name "Elevator Action EX (Japan).gbc" size 1048576 crc b70c4ddb sha1 db91028de0a07479f53f7449d0a6794d295e0b97 ) + name "Jinsei Game - Tomodachi Takusan Tsukurou yo! (Japan) (SGB Enhanced) (GB Compatible)" + description "Jinsei Game - Tomodachi Takusan Tsukurou yo! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Jinsei Game - Tomodachi Takusan Tsukurou yo! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c8d46e99 sha1 d2c4ae3808d9a24cbd4c6c8e43184ca0ef2d8373 ) ) game ( - name "Elie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Elie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Elie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 7967320e sha1 95797142058700b13577c21ed118b6508b84c8a6 ) + name "Jisedai Begoma Battle Beyblade (Japan)" + description "Jisedai Begoma Battle Beyblade (Japan)" + rom ( name "Jisedai Begoma Battle Beyblade (Japan).gbc" size 2097152 crc 9c56977e sha1 fc2af4ebd10ca20158d231089a8378f6c4641329 ) ) game ( - name "Emo Cheng 2 - Fengyun Pian (Taiwan) (Unl)" - description "Emo Cheng 2 - Fengyun Pian (Taiwan) (Unl)" - rom ( name "Emo Cheng 2 - Fengyun Pian (Taiwan) (Unl).gbc" size 524288 crc a98eec81 sha1 6da2499578b3cd362a21594034278c3ab2b9b374 ) + name "Jissen ni Yakudatsu Tsumego (Japan) (Rev 1)" + description "Jissen ni Yakudatsu Tsumego (Japan) (Rev 1)" + rom ( name "Jissen ni Yakudatsu Tsumego (Japan) (Rev 1).gbc" size 262144 crc 55efa05e sha1 5ff7f6f2a1911e97eb71a3b3788a89745cfa5d31 flags verified ) ) game ( - name "Emo Cheng DX (Taiwan) (Demo) (Unl)" - description "Emo Cheng DX (Taiwan) (Demo) (Unl)" - rom ( name "Emo Cheng DX (Taiwan) (Demo) (Unl).gbc" size 1048576 crc ebf7bf6e sha1 29b1b595ca8f5ad76ebf4f997d0e4fb8069829f1 ) + name "Jissen ni Yakudatsu Tsumego (Japan) (Possible Proto)" + description "Jissen ni Yakudatsu Tsumego (Japan) (Possible Proto)" + rom ( name "Jissen ni Yakudatsu Tsumego (Japan) (Possible Proto).gbc" size 262144 crc 69c6dbef sha1 f7ed6cdce7637a11d7fa7f5cb59b8f8ce131f9d1 ) ) game ( - name "Emo Cheng DX (Taiwan) (Unl)" - description "Emo Cheng DX (Taiwan) (Unl)" - rom ( name "Emo Cheng DX (Taiwan) (Unl).gbc" size 4194304 crc 5c388c6d sha1 7919fe7b54a5bc53ebacc13dd338be9e841dadf7 ) + name "John Romero's Daikatana (Europe) (En,Fr,It)" + description "John Romero's Daikatana (Europe) (En,Fr,It)" + rom ( name "John Romero's Daikatana (Europe) (En,Fr,It).gbc" size 1048576 crc d9062e49 sha1 a5c5b52247b2ab78cd9cad19aa752e07c3df86ef ) ) game ( - name "Emo Dao (Taiwan) (Unl)" - description "Emo Dao (Taiwan) (Unl)" - rom ( name "Emo Dao (Taiwan) (Unl).gbc" size 524288 crc 2b2acb79 sha1 929784599694efc6db16163f5bf91e49c2e459fc ) + name "John Romero's Daikatana (Europe) (Fr,De,Es)" + description "John Romero's Daikatana (Europe) (Fr,De,Es)" + rom ( name "John Romero's Daikatana (Europe) (Fr,De,Es).gbc" size 1048576 crc f7e83313 sha1 b699fc3bc587e5df25235a6c7f74fec307f476fe ) ) game ( - name "Emperor's New Groove, The (Europe) (En,Fr,De,Es,It)" - description "Emperor's New Groove, The (Europe) (En,Fr,De,Es,It)" - rom ( name "Emperor's New Groove, The (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc eb29c584 sha1 2f53318aa7f1c82df95bf3da6b29701a2c563d13 ) + name "Joryuu Janshi ni Chousen GB - Watashi-tachi ni Chousen Shitene! (Japan) (SGB Enhanced) (GB Compatible)" + description "Joryuu Janshi ni Chousen GB - Watashi-tachi ni Chousen Shitene! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Joryuu Janshi ni Chousen GB - Watashi-tachi ni Chousen Shitene! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 9fa5cdb5 sha1 a332817b9561dcab7d1f3dc0cf300e1656b253c3 ) ) game ( - name "Emperor's New Groove, The (USA)" - description "Emperor's New Groove, The (USA)" - rom ( name "Emperor's New Groove, The (USA).gbc" size 2097152 crc 6ebad539 sha1 ba663289bd5d9d09bc8b9ac2c1d38293dcba9c02 ) + name "Juedui Wuli (Taiwan) (Unl)" + description "Juedui Wuli (Taiwan) (Unl)" + rom ( name "Juedui Wuli (Taiwan) (Unl).gbc" size 2097152 crc f4d63a7e sha1 f0b9f02335ee89aa6189e687e6e759d8c49bc2b3 ) ) game ( - name "Empire of Dreams, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Empire of Dreams, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Empire of Dreams, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 9ca3cf6c sha1 d3f4d21bf543431672268b476802693b2da9b6b9 ) + name "JumpStart Dino Adventure - Field Trip (USA)" + description "JumpStart Dino Adventure - Field Trip (USA)" + rom ( name "JumpStart Dino Adventure - Field Trip (USA).gbc" size 1048576 crc 6d50772d sha1 97d328c36fcb17a65d398f0696c819136d1b03dc ) ) game ( - name "Equestriad 2001 (Europe) (Proto)" - description "Equestriad 2001 (Europe) (Proto)" - rom ( name "Equestriad 2001 (Europe) (Proto).gbc" size 1048576 crc 626f978f sha1 7698801ef38b63d45fdd2110f9b3ea87e59b9476 ) + name "Jungle Book, The - Mowgli's Wild Adventure (Europe) (En,Fr,De,Es,It)" + description "Jungle Book, The - Mowgli's Wild Adventure (Europe) (En,Fr,De,Es,It)" + rom ( name "Jungle Book, The - Mowgli's Wild Adventure (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc b609ecea sha1 960f8e7e7c72f3466eed4ebfa87fbf3b18053745 ) ) game ( - name "ESPN International Track & Field (USA)" - description "ESPN International Track & Field (USA)" - rom ( name "ESPN International Track & Field (USA).gbc" size 1048576 crc 4005d541 sha1 397d76c85859d0fa9b58b49f7eae16f76ad45a17 ) + name "Jungle Book, The - Mowgli's Wild Adventure (USA) (En,Fr,De,Es,It)" + description "Jungle Book, The - Mowgli's Wild Adventure (USA) (En,Fr,De,Es,It)" + rom ( name "Jungle Book, The - Mowgli's Wild Adventure (USA) (En,Fr,De,Es,It).gbc" size 4194304 crc 9b6b755f sha1 a76a8692246893545663be9d1e4a6f2c1370ed09 ) ) game ( - name "ESPN National Hockey Night (USA)" - description "ESPN National Hockey Night (USA)" - rom ( name "ESPN National Hockey Night (USA).gbc" size 2097152 crc 600f61f9 sha1 3ddf8cf9afe08c6079737a232ea071cedafeaa14 ) + name "Jurassic Boy 2 (Taiwan) (En) (Rev 1) (Sachen) (Unl)" + description "Jurassic Boy 2 (Taiwan) (En) (Rev 1) (Sachen) (Unl)" + rom ( name "Jurassic Boy 2 (Taiwan) (En) (Rev 1) (Sachen) (Unl).gbc" size 262144 crc a3ba0db4 sha1 1a2522d29cfbeb195488ed6ea79c36382b3b28be ) ) game ( - name "Estpolis Denki - Yomigaeru Densetsu (Japan)" - description "Estpolis Denki - Yomigaeru Densetsu (Japan)" - rom ( name "Estpolis Denki - Yomigaeru Densetsu (Japan).gbc" size 2097152 crc 54617416 sha1 dde3b4fbbef61b1e20abc1d71408f59e6c90e79a ) + name "Jurassic Boy 2 + Thunder Blast Man (Taiwan) (En) (1B-002, 1B-003, Sachen) (Unl)" + description "Jurassic Boy 2 + Thunder Blast Man (Taiwan) (En) (1B-002, 1B-003, Sachen) (Unl)" + rom ( name "Jurassic Boy 2 + Thunder Blast Man (Taiwan) (En) (1B-002, 1B-003, Sachen) (Unl).gbc" size 524288 crc 497be52b sha1 4d7f15ed30dcc6ddeea1863ee8d786e3933ca92f flags verified ) ) game ( - name "European Super League (Europe) (En,Fr,De,Es,It)" - description "European Super League (Europe) (En,Fr,De,Es,It)" - rom ( name "European Super League (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 5a0b7c72 sha1 2b403fc1c01aa82645960df4fe7e93801ef735a3 ) + name "Juukou Senki Bullet Battlers (Japan) (SGB Enhanced) (GB Compatible)" + description "Juukou Senki Bullet Battlers (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Juukou Senki Bullet Battlers (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4039c187 sha1 a89304600330a62800751f16e231924fa9cf6e4d ) ) game ( - name "EuroSport Pro Champ Fishing (Europe) (Proto) (GB Compatible)" - description "EuroSport Pro Champ Fishing (Europe) (Proto) (GB Compatible)" - rom ( name "EuroSport Pro Champ Fishing (Europe) (Proto) (GB Compatible).gbc" size 1048576 crc 32083abd sha1 565c16da5d2bc5dacffa992ed3f0466ec4888e73 ) + name "K.O. - The Pro Boxing (Japan)" + description "K.O. - The Pro Boxing (Japan)" + rom ( name "K.O. - The Pro Boxing (Japan).gbc" size 1048576 crc 69f08c89 sha1 6fca09dabfcf087156263f656b80ff57065bcbfe ) ) game ( - name "EuroSport XS Racing (Europe) (Proto) (GB Compatible)" - description "EuroSport XS Racing (Europe) (Proto) (GB Compatible)" - rom ( name "EuroSport XS Racing (Europe) (Proto) (GB Compatible).gbc" size 1048576 crc ca0abfca sha1 b3dda41ef755cc78680858103bad07d064e155ac ) + name "Kaept'n Blaubaer - Die verrueckte Schatzsuche (Germany)" + description "Kaept'n Blaubaer - Die verrueckte Schatzsuche (Germany)" + rom ( name "Kaept'n Blaubaer - Die verrueckte Schatzsuche (Germany).gbc" size 1048576 crc 77e13dbe sha1 57c29638d77e8a1589c411085aa2c99108d96bf2 flags verified ) ) game ( - name "Evel Knievel (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - description "Evel Knievel (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - rom ( name "Evel Knievel (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 2097152 crc dfd6a908 sha1 0841f55e18fe6e4a50df826703db22681169f2e7 ) + name "Kaitei Densetsu!! Treasure World (Japan) (GB Compatible)" + description "Kaitei Densetsu!! Treasure World (Japan) (GB Compatible)" + rom ( name "Kaitei Densetsu!! Treasure World (Japan) (GB Compatible).gbc" size 1048576 crc 4c7258d9 sha1 fe1cba586c0ff61628e52890b5ac40d1b7c4cbee ) ) game ( - name "Evel Knievel (USA) (GB Compatible)" - description "Evel Knievel (USA) (GB Compatible)" - rom ( name "Evel Knievel (USA) (GB Compatible).gbc" size 2097152 crc 51e951b5 sha1 24cac6ab0151b33d2b1fd06ee01931802fb98267 flags verified ) + name "Kakurenbo Battle - Monster Tactics (Japan)" + description "Kakurenbo Battle - Monster Tactics (Japan)" + rom ( name "Kakurenbo Battle - Monster Tactics (Japan).gbc" size 2097152 crc 9cfa76c3 sha1 45bf50f9ff80df20d25d40cc8f78d829d6a8fab7 ) ) game ( - name "Expiration Date (World) (v1.5) (GB Compatible) (Aftermarket) (Unl)" - description "Expiration Date (World) (v1.5) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Expiration Date (World) (v1.5) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f222b03b sha1 c14f008cfc182f35fe670e14b57052ae4f8d1c60 ) + name "Kakutou Ryouri Densetsu Bistro Recipe - Gekitou Foodon Battle Hen (Japan) (SGB Enhanced) (GB Compatible)" + description "Kakutou Ryouri Densetsu Bistro Recipe - Gekitou Foodon Battle Hen (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kakutou Ryouri Densetsu Bistro Recipe - Gekitou Foodon Battle Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 459a126b sha1 6a972325c07687b51fe6dbb3813bf54e1721668f ) ) game ( - name "Expiration Date (World) (GB Compatible) (Aftermarket) (Unl)" - description "Expiration Date (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Expiration Date (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 050caa5e sha1 e4b61c220b046e2287272f9b1bef85ad2d835fe3 ) + name "Kakutou Ryouri Densetsu Bistro Recipe - Kettou Bistgarm Hen (Japan) (SGB Enhanced) (GB Compatible)" + description "Kakutou Ryouri Densetsu Bistro Recipe - Kettou Bistgarm Hen (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kakutou Ryouri Densetsu Bistro Recipe - Kettou Bistgarm Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4fbec464 sha1 c9fa1b1a24a0098eadd7e3fa4ee19f1b615a618f ) ) game ( - name "Exploits of Fingers Malone, The (World) (Aftermarket) (Unl)" - description "Exploits of Fingers Malone, The (World) (Aftermarket) (Unl)" - rom ( name "Exploits of Fingers Malone, The (World) (Aftermarket) (Unl).gbc" size 524288 crc 20fe84af sha1 18056b5b032955099c606651f26164de131e54a6 ) + name "Kanji Boy (Japan) (SGB Enhanced) (GB Compatible)" + description "Kanji Boy (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kanji Boy (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 18caa513 sha1 3876d5f64113e5365b42d30945f51f40b1d22d47 ) ) game ( - name "Extreme Ghostbusters (Europe) (En,Fr,De,Es,It,Pt)" - description "Extreme Ghostbusters (Europe) (En,Fr,De,Es,It,Pt)" - rom ( name "Extreme Ghostbusters (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc cc777b98 sha1 01e1bf3cea7ccd7b8853727ac252adddc540fa2f ) + name "Kanji Boy 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Kanji Boy 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kanji Boy 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 81fd8918 sha1 4d382de7fd6912c0cd8ca15032e6f75409d0a97b ) ) game ( - name "Extreme Sports with the Berenstain Bears (USA, Europe) (En,Fr,De,Es,It)" - description "Extreme Sports with the Berenstain Bears (USA, Europe) (En,Fr,De,Es,It)" - rom ( name "Extreme Sports with the Berenstain Bears (USA, Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 5c0e7b44 sha1 ee56328e88729f929da717221d72826c872253c2 flags verified ) + name "Kanji Boy 3 (Japan)" + description "Kanji Boy 3 (Japan)" + rom ( name "Kanji Boy 3 (Japan).gbc" size 4194304 crc 2d4d8597 sha1 ea9064f703354b7fbeef0dd55084b16f2f7797ba ) ) game ( - name "F-1 World Grand Prix (Europe) (En,Fr,De,Es)" - description "F-1 World Grand Prix (Europe) (En,Fr,De,Es)" - rom ( name "F-1 World Grand Prix (Europe) (En,Fr,De,Es).gbc" size 2097152 crc 8d9a9182 sha1 16aa2e02e9b7f236f12a49c3224ca4cc89cdf98c flags verified ) + name "Kanji Boy 3 (Japan) (Beta)" + description "Kanji Boy 3 (Japan) (Beta)" + rom ( name "Kanji Boy 3 (Japan) (Beta).gbc" size 4194304 crc 2ce7d758 sha1 f8b34e0834c7bff5bb06587e932dff2036d86c6e ) ) game ( - name "F-1 World Grand Prix (Europe) (Beta)" - description "F-1 World Grand Prix (Europe) (Beta)" - rom ( name "F-1 World Grand Prix (Europe) (Beta).gbc" size 2097152 crc d6496fe9 sha1 9285bb4fbab8678b65cc8736f43e4ea3895c1cf4 ) + name "Kanji de Puzzle (Japan) (GB Compatible)" + description "Kanji de Puzzle (Japan) (GB Compatible)" + rom ( name "Kanji de Puzzle (Japan) (GB Compatible).gbc" size 1048576 crc 25efa1d7 sha1 a0f108d3838ac820b2ee3167e93886b979115006 ) ) game ( - name "F-1 World Grand Prix (Japan) (En) (Beta 2)" - description "F-1 World Grand Prix (Japan) (En) (Beta 2)" - rom ( name "F-1 World Grand Prix (Japan) (En) (Beta 2).gbc" size 1048576 crc 5e24811e sha1 25c83cb589ce85917b99757090a94e588cb799b9 ) + name "Kanji Shishuu (Japan) (Proto)" + description "Kanji Shishuu (Japan) (Proto)" + rom ( name "Kanji Shishuu (Japan) (Proto).gbc" size 8388608 crc 29a1932f sha1 09d5b0f6e3b17f670820265dcb2477e5c869ed79 ) ) game ( - name "F-1 World Grand Prix (Japan) (En) (Beta 1)" - description "F-1 World Grand Prix (Japan) (En) (Beta 1)" - rom ( name "F-1 World Grand Prix (Japan) (En) (Beta 1).gbc" size 2097152 crc 3122807b sha1 afc4b8f0487b0c6b0ca6470d4002eaca6616a04b ) + name "Kanzume Monsters Parfait (Japan) (SGB Enhanced) (GB Compatible)" + description "Kanzume Monsters Parfait (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kanzume Monsters Parfait (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6d5b59c0 sha1 62f431d8e1efdc93a36751ce5f4740d05d999348 ) ) game ( - name "F-18 Thunder Strike (USA, Europe) (Beta) (Rumble Version)" - description "F-18 Thunder Strike (USA, Europe) (Beta) (Rumble Version)" - rom ( name "F-18 Thunder Strike (USA, Europe) (Beta) (Rumble Version).gbc" size 1048576 crc 9e253e73 sha1 f7ccfc1f0822bdc611751d77b9f164c6aaa64c01 ) + name "Karamuchou wa Oosawagi! - Okawari! (Japan) (SGB Enhanced, GB Compatible) (NP)" + description "Karamuchou wa Oosawagi! - Okawari! (Japan) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Karamuchou wa Oosawagi! - Okawari! (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 1048576 crc 6c568e06 sha1 9217169dc3f42562d71a7edabc3b42e36ec8304b ) ) game ( - name "F-18 Thunder Strike (USA, Europe)" - description "F-18 Thunder Strike (USA, Europe)" - rom ( name "F-18 Thunder Strike (USA, Europe).gbc" size 1048576 crc 410fa858 sha1 530aecae5b89e580be8a8d4827be95522d8319c4 ) + name "Karamuchou wa Oosawagi! - Polinkies to Okashina Nakama-tachi (Japan) (SGB Enhanced) (GB Compatible)" + description "Karamuchou wa Oosawagi! - Polinkies to Okashina Nakama-tachi (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Karamuchou wa Oosawagi! - Polinkies to Okashina Nakama-tachi (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc dd948071 sha1 cb6079dc290ace0daafdd40353e4477e4a37c8f7 ) ) game ( - name "F.A. Premier League Stars 2001, The (Europe)" - description "F.A. Premier League Stars 2001, The (Europe)" - rom ( name "F.A. Premier League Stars 2001, The (Europe).gbc" size 1048576 crc 5e3844fb sha1 9fee426307ebfc373ab60a17f8f2f08d2ff8661c ) + name "Karate Joe (Europe) (Unl)" + description "Karate Joe (Europe) (Unl)" + rom ( name "Karate Joe (Europe) (Unl).gbc" size 262144 crc b8a54e29 sha1 bc9e760dcc851a01240b49b28cde8fe5ab18df91 ) ) game ( - name "F1 Championship Season 2000 (Europe) (En,Fr,De,Es,It)" - description "F1 Championship Season 2000 (Europe) (En,Fr,De,Es,It)" - rom ( name "F1 Championship Season 2000 (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 5c10315e sha1 dc566028e0e86f32d99d5b0846d4b113525be0a2 ) + name "Kaseki Sousei Reborn II - Monster Digger (Japan) (SGB Enhanced) (GB Compatible)" + description "Kaseki Sousei Reborn II - Monster Digger (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kaseki Sousei Reborn II - Monster Digger (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc bf80c897 sha1 857fb62dc310268e0b92e9383c6b6fd61aa33fa0 flags verified ) ) game ( - name "F1 Championship Season 2000 (Brazil) (En,Fr,De,Es,It)" - description "F1 Championship Season 2000 (Brazil) (En,Fr,De,Es,It)" - rom ( name "F1 Championship Season 2000 (Brazil) (En,Fr,De,Es,It).gbc" size 2097152 crc f4f5ed18 sha1 4731a7442bbff31c6d470b84938a3f148a4f1f6c ) + name "Katakis 3D (Europe) (Proto)" + description "Katakis 3D (Europe) (Proto)" + rom ( name "Katakis 3D (Europe) (Proto).gbc" size 2097152 crc 7c4b3795 sha1 8cd4be6772c592bbc2908fa826c090ec122e384c ) ) game ( - name "F1 Racing Championship (USA) (En,Fr,De,Es,It) (Proto)" - description "F1 Racing Championship (USA) (En,Fr,De,Es,It) (Proto)" - rom ( name "F1 Racing Championship (USA) (En,Fr,De,Es,It) (Proto).gbc" size 4194304 crc 9ec98cab sha1 83f1791b5fc7d7e589c105d87a14abb8087edaed ) + name "Katou Hifumi Kudan - Shougi Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible)" + description "Katou Hifumi Kudan - Shougi Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Katou Hifumi Kudan - Shougi Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a262269f sha1 c3ba0d2b82d66ef1b5c0dee8813a5f965631ed75 ) ) game ( - name "F1 Racing Championship (Europe) (En,Fr,De,Es,It) (Beta)" - description "F1 Racing Championship (Europe) (En,Fr,De,Es,It) (Beta)" - rom ( name "F1 Racing Championship (Europe) (En,Fr,De,Es,It) (Beta).gbc" size 4194304 crc e115ddb1 sha1 e9616a53ab9474c0bb85451ff19b62bed9e7f1a4 ) + name "Kawa no Nushi Tsuri 4 (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" + description "Kawa no Nushi Tsuri 4 (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" + rom ( name "Kawa no Nushi Tsuri 4 (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f0b09ddb sha1 dbdac654d4056ade51a139614192742ce8800d7e ) ) game ( - name "F1 Racing Championship (Europe) (En,Fr,De,Es,It)" - description "F1 Racing Championship (Europe) (En,Fr,De,Es,It)" - rom ( name "F1 Racing Championship (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 93a9789f sha1 ea844051c0b5c6f9a6a8c472f4f67ee6b9b3d8e7 ) + name "Kawa no Nushi Tsuri 4 (Japan) (Rev 1) (Possible Proto) (Rumble Version) (SGB Enhanced, GB Compatible) (NP)" + description "Kawa no Nushi Tsuri 4 (Japan) (Rev 1) (Possible Proto) (Rumble Version) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Kawa no Nushi Tsuri 4 (Japan) (Rev 1) (Possible Proto) (Rumble Version) (SGB Enhanced, GB Compatible) (NP).gbc" size 1048576 crc 456d4dfc sha1 69e56fd73eb365dba87713c2a3ea2e74bd63f63c ) ) game ( - name "F1 World Grand Prix II for Game Boy Color (Europe) (En,Fr,De,Es)" - description "F1 World Grand Prix II for Game Boy Color (Europe) (En,Fr,De,Es)" - rom ( name "F1 World Grand Prix II for Game Boy Color (Europe) (En,Fr,De,Es).gbc" size 1048576 crc eef4a20b sha1 ce114896da10c8a0a14164cd9958922523491a59 ) + name "Kawaii Pet Shop Monogatari (Japan) (SGB Enhanced) (GB Compatible)" + description "Kawaii Pet Shop Monogatari (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kawaii Pet Shop Monogatari (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 44767443 sha1 8392eccbac1d8ae23782c6d29d3ee604a03b5c05 ) ) game ( - name "F1 World Grand Prix II for Game Boy Color (Japan) (En,Ja)" - description "F1 World Grand Prix II for Game Boy Color (Japan) (En,Ja)" - rom ( name "F1 World Grand Prix II for Game Boy Color (Japan) (En,Ja).gbc" size 1048576 crc 28453467 sha1 b4d5e42c10c2bcd9204d282e9d91312f34ff768a ) + name "Kawaii Pet Shop Monogatari 2 (Japan) (GB Compatible)" + description "Kawaii Pet Shop Monogatari 2 (Japan) (GB Compatible)" + rom ( name "Kawaii Pet Shop Monogatari 2 (Japan) (GB Compatible).gbc" size 2097152 crc 3791dca1 sha1 76dc291937adbe7ebab4c1681ecf1fc7ea3a6074 ) ) game ( - name "F1 World Grand Prix II for Game Boy Color (USA) (En,Fr,De,Es)" - description "F1 World Grand Prix II for Game Boy Color (USA) (En,Fr,De,Es)" - rom ( name "F1 World Grand Prix II for Game Boy Color (USA) (En,Fr,De,Es).gbc" size 1048576 crc 482e10c5 sha1 c39e33fd9d5f06bc8f0f74eafb45fa0c254f9c84 ) + name "Kawaii Pet Shop Monogatari 2 (Japan) (Rev 1) (GB Compatible)" + description "Kawaii Pet Shop Monogatari 2 (Japan) (Rev 1) (GB Compatible)" + rom ( name "Kawaii Pet Shop Monogatari 2 (Japan) (Rev 1) (GB Compatible).gbc" size 2097152 crc 6fce1ad0 sha1 58ea410ebbee5edc18644c0467fe9ea03d179b1c flags verified ) ) game ( - name "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (SGB Enhanced) (GB Compatible)" - description "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b59a51c4 sha1 a27b498c6170b4136d2ca8a75c3d529dd6c06639 ) + name "Keep the Balance (Europe) (En,Fr,De,Es,It)" + description "Keep the Balance (Europe) (En,Fr,De,Es,It)" + rom ( name "Keep the Balance (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc b868e846 sha1 a0bbbb00f0ad1c62ad766b378c9a6c15fbd54991 ) ) game ( - name "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Fairy Kitty no Kaiun Jiten - Yousei no Kuni no Uranai Shugyou (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c4d3628f sha1 d07b600cc9af8cadc2581a6ac19aadea79313d69 flags verified ) + name "Keibajou e Ikou! Wide (Japan) (GB Compatible)" + description "Keibajou e Ikou! Wide (Japan) (GB Compatible)" + rom ( name "Keibajou e Ikou! Wide (Japan) (GB Compatible).gbc" size 1048576 crc 710286ea sha1 120c3888f7206ac8b06cea5e9b81dbcd87109ebf ) ) game ( - name "Far After (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Far After (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Far After (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc bdaf8f3f sha1 d1ed0fb4d926f4c337399ca342644f89cf00790a ) + name "Keitai Denjuu Telefang - Power Version (Japan) (GB Compatible)" + description "Keitai Denjuu Telefang - Power Version (Japan) (GB Compatible)" + rom ( name "Keitai Denjuu Telefang - Power Version (Japan) (GB Compatible).gbc" size 2097152 crc 8b61cfcc sha1 baaf7fb9f9958ca22982ba0600bc0cb8a7fc4764 ) ) game ( - name "Far After (World) (v1.01) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Far After (World) (v1.01) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Far After (World) (v1.01) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc e61c1dc2 sha1 d7a88a68ec65d9cf3f9521fc9ad9d3f4b51bac5d ) + name "Keitai Denjuu Telefang - Speed Version (Japan) (GB Compatible)" + description "Keitai Denjuu Telefang - Speed Version (Japan) (GB Compatible)" + rom ( name "Keitai Denjuu Telefang - Speed Version (Japan) (GB Compatible).gbc" size 2097152 crc fb528f66 sha1 1c273f9078c580e85e5c49e7114058f3e0fe5cca flags verified ) ) game ( - name "Featherless Cake Delivery (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" - description "Featherless Cake Delivery (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Featherless Cake Delivery (World) (v2.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 63c6c960 sha1 b62ec7a341ea9a0bfe8f0b014da971b73606a86e ) + name "Kelly Club (USA)" + description "Kelly Club (USA)" + rom ( name "Kelly Club (USA).gbc" size 1048576 crc 6e39ebc4 sha1 d47519a0295c3a76bc68c54ae94ccce039bcd3ee ) ) game ( - name "Featherless Cake Delivery (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" - description "Featherless Cake Delivery (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Featherless Cake Delivery (World) (v1.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc de373eba sha1 dbf2228017515b407ed9f4a9b3bf01bc2a5f7b0f ) + name "Ken Griffey Jr.'s Slugfest (USA)" + description "Ken Griffey Jr.'s Slugfest (USA)" + rom ( name "Ken Griffey Jr.'s Slugfest (USA).gbc" size 1048576 crc 1e64d19c sha1 2362bdd8c26f30adb871259ce2d909ac6d505e36 ) ) game ( - name "Feed IT Souls (World) (v1.3) (Aftermarket) (Unl)" - description "Feed IT Souls (World) (v1.3) (Aftermarket) (Unl)" - rom ( name "Feed IT Souls (World) (v1.3) (Aftermarket) (Unl).gbc" size 1048576 crc 701847f5 sha1 aba3fecd55c0cee7fbe49506b367b7e94b56b81c ) + name "Kettou Transformers Beast Wars - Beast Senshi Saikyou Ketteisen (Japan) (SGB Enhanced) (GB Compatible)" + description "Kettou Transformers Beast Wars - Beast Senshi Saikyou Ketteisen (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kettou Transformers Beast Wars - Beast Senshi Saikyou Ketteisen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 72895639 sha1 db690f46d37e0273c69f24badbb44588a363a84f ) ) game ( - name "Feed IT Souls (World) (v1.4) (Aftermarket) (Unl)" - description "Feed IT Souls (World) (v1.4) (Aftermarket) (Unl)" - rom ( name "Feed IT Souls (World) (v1.4) (Aftermarket) (Unl).gbc" size 1048576 crc f87760b3 sha1 ea0dd170812d1bcc38de1cabe12a372cd2178c95 ) + name "Kidou Senkan Nadesico - Ruri Ruri Mahjong (Japan)" + description "Kidou Senkan Nadesico - Ruri Ruri Mahjong (Japan)" + rom ( name "Kidou Senkan Nadesico - Ruri Ruri Mahjong (Japan).gbc" size 2097152 crc 6427cd7a sha1 7f3f408f3835bc8aa9312ba76374436bfbe136fe ) ) game ( - name "Feed The Monster (World) (GB Compatible) (Aftermarket) (Pirate)" - description "Feed The Monster (World) (GB Compatible) (Aftermarket) (Pirate)" - rom ( name "Feed The Monster (World) (GB Compatible) (Aftermarket) (Pirate).gbc" size 524288 crc 7bec6553 sha1 bdcadc0f98d8c9061cbe83c53a047719280b6e09 ) + name "Kikansha Thomas - Sodor-tou no Nakama-tachi (Japan)" + description "Kikansha Thomas - Sodor-tou no Nakama-tachi (Japan)" + rom ( name "Kikansha Thomas - Sodor-tou no Nakama-tachi (Japan).gbc" size 1048576 crc 223bb19c sha1 8abd4406ec19bfecd6d675285fa73ef2d5ea622e ) ) game ( - name "Fellowship of the Rings (Taiwan) (En) (Unl)" - description "Fellowship of the Rings (Taiwan) (En) (Unl)" - rom ( name "Fellowship of the Rings (Taiwan) (En) (Unl).gbc" size 524288 crc 4bcc59dc sha1 837232bd2eeb50b276049d0908f8ed4dc7efbcfe ) + name "Kindaichi Shounen no Jikenbo - 10 Nenme no Shoutaijou (Japan) (SGB Enhanced) (GB Compatible)" + description "Kindaichi Shounen no Jikenbo - 10 Nenme no Shoutaijou (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kindaichi Shounen no Jikenbo - 10 Nenme no Shoutaijou (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc de52ffdc sha1 468ea148eb15eac3b771a2520e0b5248ea5085a1 ) ) game ( - name "Feng Kuang A Gei III - Chaoji Zhadan Ren (Taiwan) (Unl)" - description "Feng Kuang A Gei III - Chaoji Zhadan Ren (Taiwan) (Unl)" - rom ( name "Feng Kuang A Gei III - Chaoji Zhadan Ren (Taiwan) (Unl).gbc" size 2097152 crc 8059e009 sha1 84011e3ae407613cfd7b6b1fe85f3812097afc66 flags verified ) + name "King of Fighters R2 (Taiwan) (Unl)" + description "King of Fighters R2 (Taiwan) (Unl)" + rom ( name "King of Fighters R2 (Taiwan) (Unl).gbc" size 1048576 crc 9913e18b sha1 43c2b6f0c3559ed90032cba6569811047f9e20d0 ) ) game ( - name "Feng Zhi Gou II (Taiwan) (Unl)" - description "Feng Zhi Gou II (Taiwan) (Unl)" - rom ( name "Feng Zhi Gou II (Taiwan) (Unl).gbc" size 2097152 crc 842cb4fe sha1 4322980e5b21332a71fb7fcadbf57a79aad6346b ) + name "Kinniku Banzuke GB - Chousensha wa Kimida! (Japan) (SGB Enhanced) (GB Compatible)" + description "Kinniku Banzuke GB - Chousensha wa Kimida! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kinniku Banzuke GB - Chousensha wa Kimida! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e2e4328b sha1 75d7e35fea257d8da4c1efcdd6ebdca020c648a6 flags verified ) ) game ( - name "Fengkuang Dafuweng (Taiwan) (Unl)" - description "Fengkuang Dafuweng (Taiwan) (Unl)" - rom ( name "Fengkuang Dafuweng (Taiwan) (Unl).gbc" size 2097152 crc fbf62c35 sha1 7128a6ddbb44ba5ba226516996eb9a6077d365a9 ) + name "Kinniku Banzuke GB 2 - Mezase! Muscle Champion (Japan) (SGB Enhanced) (GB Compatible)" + description "Kinniku Banzuke GB 2 - Mezase! Muscle Champion (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Kinniku Banzuke GB 2 - Mezase! Muscle Champion (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 42de9092 sha1 5ea803b820ff865a4470d7f82b36da6b82f3caec ) ) game ( - name "Fengkuang Dafuweng (Taiwan) (Unl) (Alt)" - description "Fengkuang Dafuweng (Taiwan) (Unl) (Alt)" - rom ( name "Fengkuang Dafuweng (Taiwan) (Unl) (Alt).gbc" size 2097152 crc 45b79edc sha1 cc86e1247a352a7c7134db927cc41a1e9950fb96 ) + name "Kinniku Banzuke GB 3 - Shinseiki Survival Retsuden! (Japan)" + description "Kinniku Banzuke GB 3 - Shinseiki Survival Retsuden! (Japan)" + rom ( name "Kinniku Banzuke GB 3 - Shinseiki Survival Retsuden! (Japan).gbc" size 4194304 crc e2f6253e sha1 2e5d5adcdbedf45c6ebda0f90ccfa787a24c24d0 ) ) game ( - name "Ferret Monogatari (Japan)" - description "Ferret Monogatari (Japan)" - rom ( name "Ferret Monogatari (Japan).gbc" size 1048576 crc 8b742fb5 sha1 9a35dbd3d474f838e21584c249232ff8905b14c0 ) + name "Kirby - Tilt 'n' Tumble (USA)" + description "Kirby - Tilt 'n' Tumble (USA)" + rom ( name "Kirby - Tilt 'n' Tumble (USA).gbc" size 1048576 crc e541acf1 sha1 6ab8d666e2bebbb3fee7796c8968aab2ea21b8f9 flags verified ) ) game ( - name "FGB (USA) (Proto) (2001-05-15)" - description "FGB (USA) (Proto) (2001-05-15)" - rom ( name "FGB (USA) (Proto) (2001-05-15).gbc" size 1048576 crc 800c74b6 sha1 dc41aa4e29ad4c0ba0bb1dee1e90c7bfb9506a46 ) + name "Kirikou (Europe) (En,Fr,De,Es,It,Pt)" + description "Kirikou (Europe) (En,Fr,De,Es,It,Pt)" + rom ( name "Kirikou (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc 783bc02d sha1 b047db711bbef8f8d32fb64aa8e120fc01d1fb76 ) ) game ( - name "FIFA 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "FIFA 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "FIFA 2000 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e6bc2e8c sha1 c40dd26a6d600818eca960bade3afa374a19bc12 ) + name "Kisekae Series 2 - Oshare Nikki (Japan)" + description "Kisekae Series 2 - Oshare Nikki (Japan)" + rom ( name "Kisekae Series 2 - Oshare Nikki (Japan).gbc" size 2097152 crc 948f4a96 sha1 054065759ff04c508378796ca12a4b578e1c174c ) ) game ( - name "Fillo - Crystal Version (World) (Aftermarket) (Unl)" - description "Fillo - Crystal Version (World) (Aftermarket) (Unl)" - rom ( name "Fillo - Crystal Version (World) (Aftermarket) (Unl).gbc" size 524288 crc 88bb855c sha1 2ffc4199d94f8b29b3f84b7bdb2694154a0bd285 ) + name "Kisekae Series 2 - Oshare Nikki (Japan) (Rev 1)" + description "Kisekae Series 2 - Oshare Nikki (Japan) (Rev 1)" + rom ( name "Kisekae Series 2 - Oshare Nikki (Japan) (Rev 1).gbc" size 2097152 crc e915337c sha1 1896ec1aa7edb56774afa5d8b93e941aa1e838eb flags verified ) ) game ( - name "Find Out (World) (GB Compatible) (Aftermarket) (Unl)" - description "Find Out (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Find Out (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 5f8b660e sha1 3605a96f6713157a88e4d88989d2e2f11b9db42f ) + name "Kisekae Series 3 - Kisekae Hamster (Japan)" + description "Kisekae Series 3 - Kisekae Hamster (Japan)" + rom ( name "Kisekae Series 3 - Kisekae Hamster (Japan).gbc" size 2097152 crc a29d862f sha1 76c0f2e1559ffec3c77043a6df08b6e7240854e2 flags verified ) ) game ( - name "Finders Keepers (World) (Aftermarket) (Unl)" - description "Finders Keepers (World) (Aftermarket) (Unl)" - rom ( name "Finders Keepers (World) (Aftermarket) (Unl).gbc" size 524288 crc 4cfa0cfd sha1 db002f4a2500a9dc98a9ac7c263293d6e4a72cf1 ) + name "Klax (USA, Europe)" + description "Klax (USA, Europe)" + rom ( name "Klax (USA, Europe).gbc" size 1048576 crc 7181cbd0 sha1 23b5601748bda8e0dba69e589fa2b6d2d79781b3 flags verified ) ) game ( - name "Fire Ant (World) (Aftermarket) (Unl)" - description "Fire Ant (World) (Aftermarket) (Unl)" - rom ( name "Fire Ant (World) (Aftermarket) (Unl).gbc" size 262144 crc 154cc020 sha1 b58ed66838db34fc7f8475ccb670267119d623a5 ) + name "Klustar (Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "Klustar (Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Klustar (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 262144 crc 577e1521 sha1 b78d832e5d39180d84bf13dde81b923717cb35aa ) ) game ( - name "Fireman Fred (World) (Aftermarket) (Unl)" - description "Fireman Fred (World) (Aftermarket) (Unl)" - rom ( name "Fireman Fred (World) (Aftermarket) (Unl).gbc" size 524288 crc 563d9ca7 sha1 e62a9c6b6a39f0cb662fdb07b72669355b706f57 ) + name "Klustar (USA) (GB Compatible)" + description "Klustar (USA) (GB Compatible)" + rom ( name "Klustar (USA) (GB Compatible).gbc" size 262144 crc 3f8d6041 sha1 096748f23f61e83837568c4070a34572d11ff48e ) ) game ( - name "Firemen (World) (Aftermarket) (Unl)" - description "Firemen (World) (Aftermarket) (Unl)" - rom ( name "Firemen (World) (Aftermarket) (Unl).gbc" size 262144 crc 7299401f sha1 84c68614334578f866cfa929df736377f04f5d04 ) + name "Klustar (Japan) (Proto 2) (1999-09-28) (GB Compatible)" + description "Klustar (Japan) (Proto 2) (1999-09-28) (GB Compatible)" + rom ( name "Klustar (Japan) (Proto 2) (1999-09-28) (GB Compatible).gbc" size 262144 crc 65da9075 sha1 9c60c858f647b42007fc27c5d21f3f57923c4cda ) ) game ( - name "Fish Files, The (Europe) (En,Fr,De,Es,It)" - description "Fish Files, The (Europe) (En,Fr,De,Es,It)" - rom ( name "Fish Files, The (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc d6abc1f8 sha1 07b071cbbca12234d9ee9bfb0a3f3a47aa2b0bfa ) + name "Klustar (Europe) (En,Fr,De,Es,It) (Beta) (1998-10-01) (GB Compatible)" + description "Klustar (Europe) (En,Fr,De,Es,It) (Beta) (1998-10-01) (GB Compatible)" + rom ( name "Klustar (Europe) (En,Fr,De,Es,It) (Beta) (1998-10-01) (GB Compatible).gbc" size 131072 crc fc56bb35 sha1 7512484c9c84592e65f19f135cbe629f5a1ee84e ) ) game ( - name "Fix & Foxi - Episode 1 - Lupo (Europe) (En,Fr,De)" - description "Fix & Foxi - Episode 1 - Lupo (Europe) (En,Fr,De)" - rom ( name "Fix & Foxi - Episode 1 - Lupo (Europe) (En,Fr,De).gbc" size 1048576 crc 5dfc61e8 sha1 6d14bf255eb042e7185da32137f679f4e2c24ce5 ) + name "Klustar (Japan) (Proto 1) (1998-10-01) (GB Compatible)" + description "Klustar (Japan) (Proto 1) (1998-10-01) (GB Compatible)" + rom ( name "Klustar (Japan) (Proto 1) (1998-10-01) (GB Compatible).gbc" size 131072 crc f9c6e0a5 sha1 4990b427f1b85ceca9646b3edfa921ed160a55a9 ) ) game ( - name "Fix It Felix Jr. (World) (GB Compatible) (Aftermarket) (Unl)" - description "Fix It Felix Jr. (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Fix It Felix Jr. (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc c8014615 sha1 7221f5e53f6027183301d06e258c6cb417007b8c ) + name "Knockout Kings (USA, Europe)" + description "Knockout Kings (USA, Europe)" + rom ( name "Knockout Kings (USA, Europe).gbc" size 1048576 crc a0d64934 sha1 a04d86a384c5c417bf9f1219eb14829d0459f469 flags verified ) ) game ( - name "Fix My Heart (World) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl)" - description "Fix My Heart (World) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Fix My Heart (World) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 507f9ea2 sha1 28ad64e379dc60d6e1c2617e073f6361c0feb475 flags verified ) + name "Koenig der Loewen, Der - Simbas grosses Abenteuer (Germany)" + description "Koenig der Loewen, Der - Simbas grosses Abenteuer (Germany)" + rom ( name "Koenig der Loewen, Der - Simbas grosses Abenteuer (Germany).gbc" size 1048576 crc ea11e39c sha1 e04daabfdb6c9147a030ffb892bf77eafb1b0ba2 ) ) game ( - name "Flashin' (World) (v3.0) (GB Compatible) (Aftermarket) (Unl)" - description "Flashin' (World) (v3.0) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Flashin' (World) (v3.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc fcc05ec4 sha1 64d31f34e189b3af08bf0c659a93f71dbf83ef71 ) + name "Koguru Guruguru - Guruguru to Nakayoshi (Japan) (SGB Enhanced, GB Compatible) (NP)" + description "Koguru Guruguru - Guruguru to Nakayoshi (Japan) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Koguru Guruguru - Guruguru to Nakayoshi (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 1048576 crc d6050f64 sha1 6bf1d7517c762a8b692e149529d826504b8f483e ) ) game ( - name "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It) (Beta)" - description "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It) (Beta)" - rom ( name "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It) (Beta).gbc" size 1048576 crc ecccd908 sha1 80ec102f3cf45602c6facffcdd44232650897dab ) + name "Konami GB Collection Vol.1 (Europe) (GB Compatible)" + description "Konami GB Collection Vol.1 (Europe) (GB Compatible)" + rom ( name "Konami GB Collection Vol.1 (Europe) (GB Compatible).gbc" size 1048576 crc 203f8727 sha1 760abb9e3950f39bf01320e414a4f4d516e04c83 ) ) game ( - name "Flintstones, The - Burgertime in Bedrock (USA)" - description "Flintstones, The - Burgertime in Bedrock (USA)" - rom ( name "Flintstones, The - Burgertime in Bedrock (USA).gbc" size 1048576 crc 14d8cc5d sha1 065851358f6720d4926faa42b015da68cafa6c28 ) + name "Konami GB Collection Vol.2 (Europe) (GB Compatible)" + description "Konami GB Collection Vol.2 (Europe) (GB Compatible)" + rom ( name "Konami GB Collection Vol.2 (Europe) (GB Compatible).gbc" size 1048576 crc a6499792 sha1 7a726cac1d459986edebd2cc8f4a84d7369353dd ) ) game ( - name "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It)" - description "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It)" - rom ( name "Flintstones, The - Burgertime in Bedrock (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc a5b09726 sha1 2f7fb1afedd6c9657715b45397dc5492e40dfe45 flags verified ) + name "Konami GB Collection Vol.3 (Europe) (GB Compatible)" + description "Konami GB Collection Vol.3 (Europe) (GB Compatible)" + rom ( name "Konami GB Collection Vol.3 (Europe) (GB Compatible).gbc" size 1048576 crc d4d6243d sha1 748248b0f837b89f00a8af868f2262d27302eb5c ) ) game ( - name "Flipper & Lopaka (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - description "Flipper & Lopaka (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - rom ( name "Flipper & Lopaka (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gbc" size 1048576 crc 08b9e4aa sha1 3d538b78ef5f1238f47531c069921056b00e33b3 ) + name "Konami GB Collection Vol.4 (Europe) (GB Compatible)" + description "Konami GB Collection Vol.4 (Europe) (GB Compatible)" + rom ( name "Konami GB Collection Vol.4 (Europe) (GB Compatible).gbc" size 1048576 crc 8800f1c9 sha1 4c0c9e9cba36bfe5588e2a2dc799d207afd1321e ) ) game ( - name "Flooder (World) (Aftermarket) (Unl)" - description "Flooder (World) (Aftermarket) (Unl)" - rom ( name "Flooder (World) (Aftermarket) (Unl).gbc" size 32768 crc 253dcbe0 sha1 8fdcd8b02604ac5259fb6aa80e5ba67a03c861fb ) + name "Konami Winter Games (Europe)" + description "Konami Winter Games (Europe)" + rom ( name "Konami Winter Games (Europe).gbc" size 1048576 crc 1c644040 sha1 2b51f52560226dec0467e5bf4897cd12e8453888 ) ) game ( - name "Flooder (World) (Anniversary Edition) (Aftermarket) (Unl)" - description "Flooder (World) (Anniversary Edition) (Aftermarket) (Unl)" - rom ( name "Flooder (World) (Anniversary Edition) (Aftermarket) (Unl).gbc" size 32768 crc cdda76f8 sha1 e5eec8efc032aa5bce1826f7b6b8790c61c96e06 ) + name "Konchuu Fighters (Japan)" + description "Konchuu Fighters (Japan)" + rom ( name "Konchuu Fighters (Japan).gbc" size 2097152 crc c6758b0b sha1 8bb171b72c3bb761de07954299b5aa379145e8f1 ) ) game ( - name "Floracy (Europe) (Proto) (2000-10-10)" - description "Floracy (Europe) (Proto) (2000-10-10)" - rom ( name "Floracy (Europe) (Proto) (2000-10-10).gbc" size 524288 crc d760ccff sha1 bb24ea021d873990d2e381d711376ba1d300b81f ) + name "Konchuu Hakase 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Konchuu Hakase 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Konchuu Hakase 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b6381744 sha1 e4bcfb94aa1c09a013a03f26f978b32e74f70d23 ) ) game ( - name "Force 21 (USA) (En,Fr,De)" - description "Force 21 (USA) (En,Fr,De)" - rom ( name "Force 21 (USA) (En,Fr,De).gbc" size 1048576 crc 2dcd0a0a sha1 a1a912851bf265d6228dc807c58339cd51ec9d44 ) + name "Konchuu Hakase 2 (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Konchuu Hakase 2 (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Konchuu Hakase 2 (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc d390430e sha1 59fa1707247f12b0c48eeb2e8fec274b9231d968 ) ) game ( - name "Forest of Fallen Knights (World) (GB Compatible) (Aftermarket) (Unl)" - description "Forest of Fallen Knights (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Forest of Fallen Knights (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc fa2d92a1 sha1 24f02d116aafb7b55d6cfd6d263b7595986af843 ) + name "Konchuu Hakase 3 (Japan)" + description "Konchuu Hakase 3 (Japan)" + rom ( name "Konchuu Hakase 3 (Japan).gbc" size 2097152 crc 380f19ed sha1 4066434fe741a071e2072aee44fdf1b5eecde258 ) ) game ( - name "Forest of Fallen Knights (World) (Beta) (GB Compatible) (Aftermarket) (Unl)" - description "Forest of Fallen Knights (World) (Beta) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Forest of Fallen Knights (World) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 4c21e563 sha1 f6f84f1a44d41fa7d26a9195ddf791fae53dfcdf ) + name "Korokoro Kirby (Japan)" + description "Korokoro Kirby (Japan)" + rom ( name "Korokoro Kirby (Japan).gbc" size 1048576 crc c0face3d sha1 8dd46f6d34c831c910c4574f252fa47ce6f67261 flags verified ) ) game ( - name "Formula One 2000 (Europe) (En,Fr,De,Es,It) (Proto)" - description "Formula One 2000 (Europe) (En,Fr,De,Es,It) (Proto)" - rom ( name "Formula One 2000 (Europe) (En,Fr,De,Es,It) (Proto).gbc" size 1048576 crc e689bf16 sha1 7aa7073b7b494522f7cfcd268aa066b7fe52c671 ) + name "Koto Battle - Tengai no Moribito (Japan)" + description "Koto Battle - Tengai no Moribito (Japan)" + rom ( name "Koto Battle - Tengai no Moribito (Japan).gbc" size 2097152 crc 430eb1e1 sha1 ac30025352026b34a0d9ccede82862f6e04aaf00 ) ) game ( - name "Formula One 2000 (USA)" - description "Formula One 2000 (USA)" - rom ( name "Formula One 2000 (USA).gbc" size 1048576 crc 703c057f sha1 7a38195842e536581fdcea42e4ebe50967581736 ) + name "Koudai Guaishou - Da Jihe (Taiwan) (Ja) (Pirate)" + description "Koudai Guaishou - Da Jihe (Taiwan) (Ja) (Pirate)" + rom ( name "Koudai Guaishou - Da Jihe (Taiwan) (Ja) (Pirate).gbc" size 2097152 crc a96e26c4 sha1 69d345f0da430d0b1c5f4edd086f244ddcf49c78 ) ) game ( - name "Fort Boyard (Europe) (En,Fr,De,Es,It,Nl,Pt)" - description "Fort Boyard (Europe) (En,Fr,De,Es,It,Nl,Pt)" - rom ( name "Fort Boyard (Europe) (En,Fr,De,Es,It,Nl,Pt).gbc" size 1048576 crc 06c8e50a sha1 a5b2d892568bc44424577f0a62228d05aa355efd ) + name "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl)" + description "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl)" + rom ( name "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl).gbc" size 1048576 crc 14355371 sha1 f398086d1f8cb435a632e5ea45fb19e980b0568d ) ) game ( - name "Freestyle Scooter (Europe)" - description "Freestyle Scooter (Europe)" - rom ( name "Freestyle Scooter (Europe).gbc" size 1048576 crc ee79117d sha1 cf6ae174584bbfb5ae30478841114443adc00245 ) + name "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl) (Alt)" + description "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl) (Alt)" + rom ( name "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl) (Alt).gbc" size 1048576 crc ec2fbdfd sha1 c7a1020797b57d292e16c5297199d977e025256b ) ) game ( - name "Friday the 13th - The GB Game (World) (GB Compatible) (Aftermarket) (Unl)" - description "Friday the 13th - The GB Game (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Friday the 13th - The GB Game (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 7543586a sha1 397821751ac6464582f61566f3a7c731a46b24ba ) + name "Koudai Guaishou - Feicui Ban (Taiwan) (Unl)" + description "Koudai Guaishou - Feicui Ban (Taiwan) (Unl)" + rom ( name "Koudai Guaishou - Feicui Ban (Taiwan) (Unl).gbc" size 2097152 crc 8494465f sha1 a3b2818c778fe6b5811841a9f28a1a06334216ea ) ) game ( - name "Friendly Fire (World) (Aftermarket) (Unl)" - description "Friendly Fire (World) (Aftermarket) (Unl)" - rom ( name "Friendly Fire (World) (Aftermarket) (Unl).gbc" size 262144 crc 5c6dca2b sha1 8f8085010e28aa8bdb312d086b0002b706742282 ) + name "Koudai Guaishou - Sheng Bianshi (China) (Unl)" + description "Koudai Guaishou - Sheng Bianshi (China) (Unl)" + rom ( name "Koudai Guaishou - Sheng Bianshi (China) (Unl).gbc" size 2097152 crc 0791c3a7 sha1 8a61c2dc4d1acf96d8ae871b0f371c7f8a17e9f1 ) ) game ( - name "Friendly Fire (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" - description "Friendly Fire (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Friendly Fire (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc d8be10d6 sha1 d09f4d2f799ac2e2731be0171625846d28d0f57e ) + name "Koudai Yaoguai - Baijin Ban (Taiwan) (Unl)" + description "Koudai Yaoguai - Baijin Ban (Taiwan) (Unl)" + rom ( name "Koudai Yaoguai - Baijin Ban (Taiwan) (Unl).gbc" size 2097152 crc 998ad382 sha1 f9013985d7c40eccfa863e2ba808e64deaa4b384 ) ) game ( - name "Frogger (USA) (Rev 2) (GB Compatible)" - description "Frogger (USA) (Rev 2) (GB Compatible)" - rom ( name "Frogger (USA) (Rev 2) (GB Compatible).gbc" size 1048576 crc d9a22e5d sha1 cf4801c7f82519344a50a25e35b1f5c7ee45c9a6 flags verified ) + name "Koudai Yaoguai Lu Baoshi (Taiwan) (Unl)" + description "Koudai Yaoguai Lu Baoshi (Taiwan) (Unl)" + rom ( name "Koudai Yaoguai Lu Baoshi (Taiwan) (Unl).gbc" size 2097152 crc ee74e4a2 sha1 59e4550bd3958464188fd9b8c11b2dc1c9ad7d06 ) ) game ( - name "Frogger (USA) (Rev 1) (GB Compatible)" - description "Frogger (USA) (Rev 1) (GB Compatible)" - rom ( name "Frogger (USA) (Rev 1) (GB Compatible).gbc" size 1048576 crc ba907064 sha1 db3d21977c17a505936d1e2fc3626a0b43addf16 ) + name "Koushien Pocket (Japan) (SGB Enhanced) (GB Compatible)" + description "Koushien Pocket (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Koushien Pocket (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6910ff3a sha1 a677bf07c67925ded32799d6a8eb63ec99c01bb7 flags verified ) ) game ( - name "Frogger (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - description "Frogger (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - rom ( name "Frogger (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 524288 crc b6bf0672 sha1 538d2fa68e2e877a80bbdf4d58b2b4dcf051c17c ) + name "Land Before Time, The (Europe) (En,Fr,De,Es,It)" + description "Land Before Time, The (Europe) (En,Fr,De,Es,It)" + rom ( name "Land Before Time, The (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc f253e082 sha1 9d7a8b923116093b9ee9415603a4ac9d15dcf8e3 ) ) game ( - name "Frogger (USA) (GB Compatible)" - description "Frogger (USA) (GB Compatible)" - rom ( name "Frogger (USA) (GB Compatible).gbc" size 1048576 crc af46ea77 sha1 5b7c097a12a8408fd20b81289e03ad9ea2fd2691 ) + name "Land Before Time, The (USA)" + description "Land Before Time, The (USA)" + rom ( name "Land Before Time, The (USA).gbc" size 1048576 crc bce9cb16 sha1 320524e7ee7061af3bb6e89a0c4b68c517a75752 ) ) game ( - name "Frogger 2 (USA)" - description "Frogger 2 (USA)" - rom ( name "Frogger 2 (USA).gbc" size 1048576 crc 6a2666aa sha1 566e0afb3a6f25342399a3e39f3fbcacef68eb72 ) + name "Langrsr II (Taiwan) (En) (Unl)" + description "Langrsr II (Taiwan) (En) (Unl)" + rom ( name "Langrsr II (Taiwan) (En) (Unl).gbc" size 2097152 crc 34c1a63a sha1 747707afd771d73dbbdeeeaec1c1201f2729fb8a ) ) game ( - name "Frogger 2 (USA) (Rev 1)" - description "Frogger 2 (USA) (Rev 1)" - rom ( name "Frogger 2 (USA) (Rev 1).gbc" size 1048576 crc e3227b7d sha1 0d5028ca6fcc10df46d11cd4b56e5add1dc5e63e ) + name "Laofuzi Chuanqi (Taiwan) (Unl)" + description "Laofuzi Chuanqi (Taiwan) (Unl)" + rom ( name "Laofuzi Chuanqi (Taiwan) (Unl).gbc" size 2097152 crc aeca45be sha1 b7193fcb8b9b8958a2522be0d1a3874cffc1e1db ) ) game ( - name "From Below Pocket (World) (Aftermarket) (Unl)" - description "From Below Pocket (World) (Aftermarket) (Unl)" - rom ( name "From Below Pocket (World) (Aftermarket) (Unl).gbc" size 131072 crc 35ad9b5a sha1 c0e072bfb88c84dc68b2eded1f9c088d75ffa5ed ) + name "Las Vegas Cool Hand (USA) (GB Compatible)" + description "Las Vegas Cool Hand (USA) (GB Compatible)" + rom ( name "Las Vegas Cool Hand (USA) (GB Compatible).gbc" size 524288 crc bef1cde4 sha1 c7423c03e5976f85de361fe1b83dfee11e75a60f flags verified ) ) - -game ( - name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 1) (SGB Enhanced) (GB Compatible)" - description "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 1) (SGB Enhanced) (GB Compatible)" - rom ( name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 1) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc a86de7b7 sha1 f2c04440f5d668b14623c924faec460f63158a29 ) + +game ( + name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Beta)" + description "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Beta)" + rom ( name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Beta).gbc" size 1048576 crc f90a3dae sha1 772539821e4b703259b2e2ad535d74a03fa22760 ) ) game ( - name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 2) (SGB Enhanced) (GB Compatible)" - description "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 2) (SGB Enhanced) (GB Compatible)" - rom ( name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (Beta 2) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 419befcc sha1 e11809babdca45527b81d7db02741263407aeb46 ) + name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Rev 1) (Proto)" + description "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Rev 1) (Proto)" + rom ( name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Rev 1) (Proto).gbc" size 1048576 crc cf8e2371 sha1 f7b19c1501d325dd8ee219ccae2eaca130a5a21b ) ) game ( - name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (SGB Enhanced) (GB Compatible)" - description "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "From TV Animation One Piece - Maboroshi no Grand Line Boukenki! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc a7317bb8 sha1 7fa5fbb94390876dee807216c2097cdb42510efe flags verified ) + name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da)" + description "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da)" + rom ( name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da).gbc" size 1048576 crc a58c8282 sha1 47e5c4c7fa447efc8a0abf019e8d2cd227c5e0e3 ) ) game ( - name "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (SGB Enhanced) (GB Compatible)" - description "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc c693aa37 sha1 459f1ae41f6c5c6464745a23ea42bbba5385a83b flags verified ) + name "Laura (USA)" + description "Laura (USA)" + rom ( name "Laura (USA).gbc" size 1048576 crc e2bff286 sha1 3fe3eb99ee818c94e9a07e19640af6a2aad33903 ) ) game ( - name "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "From TV Animation One Piece - Yume no Luffy Kaizokudan Tanjou! (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc a4dde805 sha1 53da28b16a4bf0efab1f65c21f7931ce4948865b flags verified ) + name "Le Mans 24 Hours (Europe) (En,Fr,De,Es,It)" + description "Le Mans 24 Hours (Europe) (En,Fr,De,Es,It)" + rom ( name "Le Mans 24 Hours (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 1b49d07d sha1 cb4847cd63c8cc52f04bf4d86d54954be3d8fc1a ) ) game ( - name "Front Line - The Next Mission (Japan)" - description "Front Line - The Next Mission (Japan)" - rom ( name "Front Line - The Next Mission (Japan).gbc" size 1048576 crc f48e1643 sha1 7456b221f95a64f36a70d024477032a4b6615948 ) + name "Legend of the River King 2 (Europe) (SGB Enhanced) (GB Compatible)" + description "Legend of the River King 2 (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of the River King 2 (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f24d010a sha1 ae8ee704b968576cf2cd0a93dc5b42f8f63c48eb ) ) game ( - name "Front Row (Japan)" - description "Front Row (Japan)" - rom ( name "Front Row (Japan).gbc" size 1048576 crc 6eea9243 sha1 64c8a9459d7c80e297774dab7775b5edf59432cc ) + name "Legend of the River King 2 (USA) (SGB Enhanced) (GB Compatible)" + description "Legend of the River King 2 (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of the River King 2 (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 840fd525 sha1 1155f2d5cc56c8275855b02a8b3826648cc5e904 ) ) game ( - name "Fugazim (World) (Pt) (GB Compatible) (Aftermarket) (Unl)" - description "Fugazim (World) (Pt) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Fugazim (World) (Pt) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 85edfba4 sha1 8a95571a32c5a23bd6be4edf6429f630d7a1a15a ) + name "Legend of the River King GB (Europe) (SGB Enhanced) (GB Compatible)" + description "Legend of the River King GB (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of the River King GB (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 87ef9530 sha1 31a5a32625532ded19d6eccfc283c4f049ae31b5 ) ) game ( - name "Full Time Soccer (Europe) (Unl)" - description "Full Time Soccer (Europe) (Unl)" - rom ( name "Full Time Soccer (Europe) (Unl).gbc" size 262144 crc b99beda2 sha1 a2b1268df08b583d033999b894638dadf32e37f4 ) + name "Legend of the River King GB (Germany) (SGB Enhanced) (GB Compatible)" + description "Legend of the River King GB (Germany) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of the River King GB (Germany) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1241f3f5 sha1 e0e0522ba283df632adbf2fe6f9aba85e1a7efec ) ) game ( - name "Full Time Soccer & Hang Time Basketball (Europe) (Unl)" - description "Full Time Soccer & Hang Time Basketball (Europe) (Unl)" - rom ( name "Full Time Soccer & Hang Time Basketball (Europe) (Unl).gbc" size 524288 crc 0634c196 sha1 aefb746984b3450b90bbfaa5de21a252685ddabb ) + name "Legend of the River King GBC (USA) (SGB Enhanced) (GB Compatible)" + description "Legend of the River King GBC (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of the River King GBC (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 7e821f47 sha1 1773c4719c3134845a91fef3a897034d5a70825e ) ) game ( - name "Fury (World) (Aftermarket) (Unl)" - description "Fury (World) (Aftermarket) (Unl)" - rom ( name "Fury (World) (Aftermarket) (Unl).gbc" size 262144 crc 7217c41d sha1 ef532b587eb438f1a39a77086ac0b8bbae23a16d ) + name "Legend of Zelda, The - Link's Awakening DX (France) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (France) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f48824fe sha1 9a679e30b03e119a21ae7daac65e73e0ef4e0894 flags verified ) ) game ( - name "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (AFMJ)" - description "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (AFMJ)" - rom ( name "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (AFMJ).gbc" size 4194304 crc 2c97e90f sha1 5264f6d0c4f12c9144de1d12fddadbadd82b3e33 ) + name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4e2b75e7 sha1 b5e4df1a67432c609fa0f23519315297c6dcdc1d ) ) game ( - name "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (BFWJ)" - description "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (BFWJ)" - rom ( name "Fushigi no Dungeon - Fuurai no Shiren GB 2 - Sabaku no Majou (Japan) (BFWJ).gbc" size 4194304 crc f3c20fbe sha1 d9c490af97c08ac7053bbb9f7ae06d3501035127 flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (Germany) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (Germany) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc fed5959b sha1 8cd9d786547bfb3ddbe16ad2a84a36cf895ac16e ) ) game ( - name "G-Man (World) (Aftermarket) (Unl)" - description "G-Man (World) (Aftermarket) (Unl)" - rom ( name "G-Man (World) (Aftermarket) (Unl).gbc" size 524288 crc ff3beab1 sha1 cb9486ca9a6ad3903662963aa966145257ef92a6 ) + name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc efb76777 sha1 7f5c39fa297cb17abf51c6f91fbdebc9f07e3de8 flags verified ) ) game ( - name "G.B Corp. (World) (Beta) (GB Compatible) (Aftermarket) (Unl)" - description "G.B Corp. (World) (Beta) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "G.B Corp. (World) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc fd2e40f4 sha1 e442316132506ff223a9e5f33d874b71ec09d71a flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 97822948 sha1 d90ac17e9bf17b6c61624ad9f05447bdb5efc01a flags verified ) ) game ( - name "Gaiamaster Duel - Card Attackers (Japan)" - description "Gaiamaster Duel - Card Attackers (Japan)" - rom ( name "Gaiamaster Duel - Card Attackers (Japan).gbc" size 2097152 crc 78206460 sha1 26601cd806c588b232ea1275b2bcb434ccd81e6d ) + name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b38eb9de sha1 363d184d9b1e9faa5a2facd80897b7e118446164 ) ) game ( - name "Gakkyuu Ou Yamazaki (Japan) (Rev 1) (GB Compatible)" - description "Gakkyuu Ou Yamazaki (Japan) (Rev 1) (GB Compatible)" - rom ( name "Gakkyuu Ou Yamazaki (Japan) (Rev 1) (GB Compatible).gbc" size 1048576 crc ef2cfd99 sha1 3a2718efa3d1cac7345fbbcddb7c3f666fc6c70c flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 06887a34 sha1 1c091225688d966928cc74336dbef2e07d12a47c flags verified ) ) game ( - name "Gakkyuu Ou Yamazaki (Japan) (Possible Proto) (GB Compatible)" - description "Gakkyuu Ou Yamazaki (Japan) (Possible Proto) (GB Compatible)" - rom ( name "Gakkyuu Ou Yamazaki (Japan) (Possible Proto) (GB Compatible).gbc" size 1048576 crc b8147b5c sha1 132b872391565d418ccc9d0e1c643510d778c066 ) + name "Legend of Zelda, The - Link's Awakening DX (France) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (France) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible).gbc" size 1015808 crc c17259db sha1 a5a6f0251e8eafd0a02b1eeceaa5b51705c12f0d ) ) game ( - name "Galaga - Destination Earth (USA)" - description "Galaga - Destination Earth (USA)" - rom ( name "Galaga - Destination Earth (USA).gbc" size 1048576 crc e3c4abc6 sha1 e2d16612c7cbeb3da07be696d154e366cbb3fcdd ) + name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible).gbc" size 1015808 crc 8afd751e sha1 797925a26eb39656aea60e10c8e9dd986b515b53 ) ) game ( - name "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan)" - description "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan)" - rom ( name "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan).gbc" size 1048576 crc 28356950 sha1 8ba0973997bdaeecdf23c45a4fb7e18e06132dfb ) + name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-23) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-23) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-23) (SGB Enhanced) (GB Compatible).gbc" size 1015808 crc 0559bc89 sha1 dbe7a909c71d407f01af2cdb0aaf7d164ac7a9bd ) ) game ( - name "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan) (Rev 1)" - description "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan) (Rev 1)" - rom ( name "Gambler Densetsu Tetsuya - Shinjuku Tenun Hen (Japan) (Rev 1).gbc" size 1048576 crc 91739def sha1 b62f8e56b995874c0e1a2533df5a37f6996df12e flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (Germany) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (Germany) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc be5e366e sha1 6bcd23a3a8afde7c220bc1da4e32d47749139305 ) ) game ( - name "Game & Watch Gallery 2 (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Game & Watch Gallery 2 (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Game & Watch Gallery 2 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 969c8961 sha1 ce81d3260e8c5e1dd241caf6de315eb3e63dbc15 flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 84415b28 sha1 95417ae15e0b89c918d97e2e658056a6869eb0ef ) ) game ( - name "Game & Watch Gallery 3 (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Game & Watch Gallery 3 (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Game & Watch Gallery 3 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1ac625da sha1 64ccb3b41715080a9aa13970678aa9047fc7a9fd flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 33c65722 sha1 b76adb353acf520084529c4f9c9cd137b07016c5 ) ) game ( - name "Game Boy Camera Gallery 2022, The (World) (GB Compatible) (Aftermarket) (Unl)" - description "Game Boy Camera Gallery 2022, The (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Game Boy Camera Gallery 2022, The (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc f1948966 sha1 14849ab5831c71949ec3a1fe7657050057d2cf29 ) + name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc fdccc2bd sha1 6daa7e77b0f329da5641e61bcdb0fecf941437f0 ) ) game ( - name "Game Boy Color (World) (Demo) (Kiosk)" - description "Game Boy Color (World) (Demo) (Kiosk)" - rom ( name "Game Boy Color (World) (Demo) (Kiosk).gbc" size 524288 crc f5e9aa8c sha1 bcbc9ede4a06e52e5dea809e20e0b34901b6ae91 flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 865cc1ed sha1 7d78f4bda653ff76618a38f33444602d1b54b206 ) ) game ( - name "Game Boy Gallery 2 (Japan) (Possible Proto) (SGB Enhanced, GB Compatible) (NP)" - description "Game Boy Gallery 2 (Japan) (Possible Proto) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Game Boy Gallery 2 (Japan) (Possible Proto) (SGB Enhanced, GB Compatible) (NP).gbc" size 1048576 crc e99beba5 sha1 90a9b368bca0f47fe72028ff4d50fb3d3060c32f ) + name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 05f23861 sha1 a3f5445fcb463e801b70466e736fe2d495581289 ) ) game ( - name "Game Boy Gallery 3 (Australia) (SGB Enhanced) (GB Compatible)" - description "Game Boy Gallery 3 (Australia) (SGB Enhanced) (GB Compatible)" - rom ( name "Game Boy Gallery 3 (Australia) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6935fea1 sha1 fde6a70e7ad6a3a116d918435f7efbc1fd95b4cc flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-07) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-07) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-07) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 5715d896 sha1 8b8eeb368dfadc73e4f051fb53134974d688491d ) ) game ( - name "Game Boy Gallery 3 (Japan) (SGB Enhanced) (GB Compatible)" - description "Game Boy Gallery 3 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Game Boy Gallery 3 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 149f807e sha1 18c3e0a015fa79c8694b8554e3c46fd67f034c71 flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (Europe) (Rev 2) (Beta) (1999-09-19) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (Europe) (Rev 2) (Beta) (1999-09-19) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (Europe) (Rev 2) (Beta) (1999-09-19) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f9a66cda sha1 eb862e0ab4d0456d98187ddfb4948cd45d923f6d ) ) game ( - name "Game Boy Gallery 4 (Australia) (SGB Enhanced) (GB Compatible)" - description "Game Boy Gallery 4 (Australia) (SGB Enhanced) (GB Compatible)" - rom ( name "Game Boy Gallery 4 (Australia) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 2549fdde sha1 fb8b98ae16f79fd70d2c0f0911dfcb2fdf1e7149 flags verified ) + name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a8855c67 sha1 a86161ca5ce9e1e8c7a6ab0931edb12a1ace5f39 ) ) game ( - name "Game Boy Wars 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Game Boy Wars 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Game Boy Wars 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c69dc37b sha1 db511650fdc9a6c130add7eada9562b6443b565d ) + name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" + description "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" + rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 3e88a24a sha1 1cbca5313b1c0163620d7d81b649f158ba59e6b3 ) ) game ( - name "Game Boy Wars 3 (Japan)" - description "Game Boy Wars 3 (Japan)" - rom ( name "Game Boy Wars 3 (Japan).gbc" size 1048576 crc 30c26262 sha1 61e08f96261b5f85c65c70db5464b4298f9f2cf8 flags verified ) + name "Legend of Zelda, The - Oracle of Ages (Europe) (En,Fr,De,Es,It)" + description "Legend of Zelda, The - Oracle of Ages (Europe) (En,Fr,De,Es,It)" + rom ( name "Legend of Zelda, The - Oracle of Ages (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 5933e3fa sha1 9f2dff3c46406839f839a8d535353dfc1e3e8670 flags verified ) ) game ( - name "Game Boy Wars Pocket Tactics (Japan) (Beta)" - description "Game Boy Wars Pocket Tactics (Japan) (Beta)" - rom ( name "Game Boy Wars Pocket Tactics (Japan) (Beta).gbc" size 1048576 crc 7e8ea9a5 sha1 a729d9ecd2b2abcd04b11122183f48c303d227b1 ) + name "Legend of Zelda, The - Oracle of Ages (USA, Australia)" + description "Legend of Zelda, The - Oracle of Ages (USA, Australia)" + rom ( name "Legend of Zelda, The - Oracle of Ages (USA, Australia).gbc" size 1048576 crc 3800a387 sha1 880374fb978b18af4aa529e2e32f7ffb4d7dd2f4 flags verified ) ) game ( - name "Game Conveni 21 (Japan) (GB Compatible)" - description "Game Conveni 21 (Japan) (GB Compatible)" - rom ( name "Game Conveni 21 (Japan) (GB Compatible).gbc" size 1048576 crc 994314b3 sha1 6803617abc46db83dbec08d10e03b9f9297f260e ) + name "Legend of Zelda, The - Oracle of Seasons (Europe) (En,Fr,De,Es,It)" + description "Legend of Zelda, The - Oracle of Seasons (Europe) (En,Fr,De,Es,It)" + rom ( name "Legend of Zelda, The - Oracle of Seasons (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc dbac1357 sha1 360b9408e569ba826212eac1ebea1b09573cb48c flags verified ) ) game ( - name "Gamer Boy Mission (World) (GB Compatible) (Aftermarket) (Unl)" - description "Gamer Boy Mission (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Gamer Boy Mission (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 96721e5d sha1 90fad94433a5b0dbcf73f4a2d4ebb75d7ab065c4 ) + name "Legend of Zelda, The - Oracle of Seasons (USA, Australia)" + description "Legend of Zelda, The - Oracle of Seasons (USA, Australia)" + rom ( name "Legend of Zelda, The - Oracle of Seasons (USA, Australia).gbc" size 1048576 crc d7e9f5d7 sha1 ba1268290fb2b1b70505d2d7b5825fc8a4816a4b flags verified ) ) game ( - name "Gamer Boy Mission (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Gamer Boy Mission (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Gamer Boy Mission (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc a02d2ae2 sha1 7eb6865c5c265193763ec0bf751d26964e870120 ) + name "LEGO Alpha Team (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" + description "LEGO Alpha Team (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" + rom ( name "LEGO Alpha Team (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gbc" size 1048576 crc 690c0373 sha1 4bd3bf401e861fe9991a58b523622c68138274e6 ) ) game ( - name "Games Frenzy (Europe) (En,Fr,De)" - description "Games Frenzy (Europe) (En,Fr,De)" - rom ( name "Games Frenzy (Europe) (En,Fr,De).gbc" size 1048576 crc 308a4ccb sha1 fd3c38d61b723e12614fa5e0b809d083827b9ae5 ) + name "LEGO Alpha Team (USA)" + description "LEGO Alpha Team (USA)" + rom ( name "LEGO Alpha Team (USA).gbc" size 1048576 crc 6d7ec41b sha1 b5d521d5b7504442c886944a6fb7dd830a28b496 flags verified ) ) game ( - name "GameShark MX (USA) (v1.02) (Unl)" - description "GameShark MX (USA) (v1.02) (Unl)" - rom ( name "GameShark MX (USA) (v1.02) (Unl).gbc" size 262144 crc 300e03ba sha1 d3eb3e7bc9042a3a9bdc6017620842c52d07cb07 ) + name "LEGO Island 2 - The Brickster's Revenge (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" + description "LEGO Island 2 - The Brickster's Revenge (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" + rom ( name "LEGO Island 2 - The Brickster's Revenge (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gbc" size 1048576 crc 921abb21 sha1 b70a22669256735abae16a32bb5f8944cff4a37c ) ) game ( - name "GameShark Online (USA) (Unl)" - description "GameShark Online (USA) (Unl)" - rom ( name "GameShark Online (USA) (Unl).gbc" size 81920 crc c37d21d9 sha1 22f00e604acb827a48d4c9e109ba622f59a9d0a9 ) + name "LEGO Island 2 - The Brickster's Revenge (USA) (En,Fr,Es)" + description "LEGO Island 2 - The Brickster's Revenge (USA) (En,Fr,Es)" + rom ( name "LEGO Island 2 - The Brickster's Revenge (USA) (En,Fr,Es).gbc" size 1048576 crc b14fa7e7 sha1 cd49bde3c3641e34cfbc1d55fd08d54ccc5b099b ) ) game ( - name "Ganbare Goemon - Mononoke Douchuu Tobidase Nabebugyou! (Japan) (SGB Enhanced) (GB Compatible)" - description "Ganbare Goemon - Mononoke Douchuu Tobidase Nabebugyou! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Ganbare Goemon - Mononoke Douchuu Tobidase Nabebugyou! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 73311cfa sha1 4bc3928f3528a2c566b09613e538253dd128864c ) + name "LEGO Racers (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" + description "LEGO Racers (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" + rom ( name "LEGO Racers (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gbc" size 1048576 crc 0a109f13 sha1 25877740f157db965a2caf30f081a89b6c13df23 ) ) game ( - name "Ganbare Goemon - Seikuushi Dynamites Arawaru!! (Japan)" - description "Ganbare Goemon - Seikuushi Dynamites Arawaru!! (Japan)" - rom ( name "Ganbare Goemon - Seikuushi Dynamites Arawaru!! (Japan).gbc" size 1048576 crc 2ea8d9d4 sha1 fc44dd6ac4a91ab32dc7096a364406433b48b7d8 ) + name "LEGO Racers (USA) (En,Fr,Es)" + description "LEGO Racers (USA) (En,Fr,Es)" + rom ( name "LEGO Racers (USA) (En,Fr,Es).gbc" size 1048576 crc f6865b09 sha1 8e46d2920bccc9a67fcfed404d0f8dd1bd9cb807 ) ) game ( - name "Ganbare Goemon - Tengutou no Gyakushuu (Japan) (GB Compatible)" - description "Ganbare Goemon - Tengutou no Gyakushuu (Japan) (GB Compatible)" - rom ( name "Ganbare Goemon - Tengutou no Gyakushuu (Japan) (GB Compatible).gbc" size 1048576 crc d829eb2f sha1 337cbcbd185a74c6fd5b10823fda3dcf8dca30e4 ) + name "LEGO Stunt Rally (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" + description "LEGO Stunt Rally (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" + rom ( name "LEGO Stunt Rally (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gbc" size 1048576 crc 05cc01fb sha1 32dc01db6a5af637e96a6d83895c352d920fba04 ) ) game ( - name "Ganbare! Nippon! Olympic 2000 (Japan)" - description "Ganbare! Nippon! Olympic 2000 (Japan)" - rom ( name "Ganbare! Nippon! Olympic 2000 (Japan).gbc" size 1048576 crc ffd919a7 sha1 5abaac9c4cb3d06e20fcb4c9985a6c4b52e62871 ) + name "LEGO Stunt Rally (USA)" + description "LEGO Stunt Rally (USA)" + rom ( name "LEGO Stunt Rally (USA).gbc" size 1048576 crc da084760 sha1 106cb59ac42c3573dcf27b448503ab4d3029d90a ) ) game ( - name "Gangdan Wuyu 2 (Taiwan) (Unl)" - description "Gangdan Wuyu 2 (Taiwan) (Unl)" - rom ( name "Gangdan Wuyu 2 (Taiwan) (Unl).gbc" size 2097152 crc 09dee8cb sha1 6753a7a34f057f952172dff5ef9e8961d3af6649 ) + name "Lemmings (Europe) (Proto)" + description "Lemmings (Europe) (Proto)" + rom ( name "Lemmings (Europe) (Proto).gbc" size 4194304 crc 5ea0796b sha1 f1f9ab3878c606b488e89c24068af10060b1640f ) ) game ( - name "Ganso! Doubutsu Uranai (Japan) (Proto)" - description "Ganso! Doubutsu Uranai (Japan) (Proto)" - rom ( name "Ganso! Doubutsu Uranai (Japan) (Proto).gbc" size 1048576 crc 58421179 sha1 d2512b7bb05771deac7b732cce17671d7807273d ) + name "Lemmings & Oh No! More Lemmings (USA)" + description "Lemmings & Oh No! More Lemmings (USA)" + rom ( name "Lemmings & Oh No! More Lemmings (USA).gbc" size 4194304 crc 97e5ce2f sha1 2662b9fdfb243392ec1268feea993ed36ac840b1 ) ) game ( - name "GB Harobots (Japan)" - description "GB Harobots (Japan)" - rom ( name "GB Harobots (Japan).gbc" size 2097152 crc 1c0368fa sha1 0fc2198938fcd259c525591f74c8aae4b048f298 ) + name "Lemmings VS (Japan)" + description "Lemmings VS (Japan)" + rom ( name "Lemmings VS (Japan).gbc" size 4194304 crc 947d45ae sha1 2ebb428a53acbcbc215f37bb263e44d94f547473 ) ) game ( - name "GB Karan Koron Gakuen - Hanafuda Mahjong (Japan)" - description "GB Karan Koron Gakuen - Hanafuda Mahjong (Japan)" - rom ( name "GB Karan Koron Gakuen - Hanafuda Mahjong (Japan).gbc" size 2097152 crc aaba1ea4 sha1 8e84f233279c543799663bd7c62b4f2fb84e5dff ) + name "Lil' Monster (USA) (SGB Enhanced) (GB Compatible)" + description "Lil' Monster (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Lil' Monster (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c6859b34 sha1 cb812599f23f8812ff756e269a621de39b1b1def ) ) game ( - name "GB Memory Multi Menu (Japan) (SGB Enhanced, GB Compatible) (NP)" - description "GB Memory Multi Menu (Japan) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "GB Memory Multi Menu (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 131072 crc ec823cc1 sha1 0781eaecb7fd25c068e396b5eb02c6231baf6ea3 ) + name "Lion King, The - Simba's Mighty Adventure (USA, Europe)" + description "Lion King, The - Simba's Mighty Adventure (USA, Europe)" + rom ( name "Lion King, The - Simba's Mighty Adventure (USA, Europe).gbc" size 1048576 crc d5b4b7bb sha1 4fcb6698e4fd6bb03812a35ed545ec68b7c11fa7 ) ) game ( - name "GB-Wordyl (World) (Pt-BR) (GB Compatible) (Aftermarket) (Unl)" - description "GB-Wordyl (World) (Pt-BR) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "GB-Wordyl (World) (Pt-BR) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc f20c0097 sha1 691af25434a09931a302ced52c757d28b9b06619 ) + name "Little Magic (Japan)" + description "Little Magic (Japan)" + rom ( name "Little Magic (Japan).gbc" size 1048576 crc ca38283d sha1 4cd610be44a9fbfde9de81167f1e4051a62b01a9 ) ) game ( - name "GB-Wordyl (World) (Ca) (GB Compatible) (Aftermarket) (Unl)" - description "GB-Wordyl (World) (Ca) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "GB-Wordyl (World) (Ca) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 164999eb sha1 197d3d194d4cb6cae9a358f7fb53d6de649e7c5f ) + name "Little Mermaid II, The - Pinball Frenzy (Europe) (En,Fr,De,Es,It)" + description "Little Mermaid II, The - Pinball Frenzy (Europe) (En,Fr,De,Es,It)" + rom ( name "Little Mermaid II, The - Pinball Frenzy (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 9fec297e sha1 c84c653eada20161c8d0aa966303b378fe5feef1 ) ) game ( - name "GB-Wordyl (World) (De) (GB Compatible) (Aftermarket) (Unl)" - description "GB-Wordyl (World) (De) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "GB-Wordyl (World) (De) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 60b075d1 sha1 0a66254b2327b48657de64d6102ac05f1e8700e7 ) + name "Little Mermaid II, The - Pinball Frenzy (USA) (En,Fr,De,Es,It) (Rumble Version)" + description "Little Mermaid II, The - Pinball Frenzy (USA) (En,Fr,De,Es,It) (Rumble Version)" + rom ( name "Little Mermaid II, The - Pinball Frenzy (USA) (En,Fr,De,Es,It) (Rumble Version).gbc" size 1048576 crc 364f9ccd sha1 0940a1a86127cf8228a6a015035d8189218f57db flags verified ) ) game ( - name "GB-Wordyl (World) (Es) (GB Compatible) (Aftermarket) (Unl)" - description "GB-Wordyl (World) (Es) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "GB-Wordyl (World) (Es) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 1a169897 sha1 0636b968e8e24fe7c1910f61db6e94fa84824494 ) + name "Little Mermaid II, The - Pinball Frenzy (Japan) (Proto)" + description "Little Mermaid II, The - Pinball Frenzy (Japan) (Proto)" + rom ( name "Little Mermaid II, The - Pinball Frenzy (Japan) (Proto).gbc" size 1048576 crc 6b974b2d sha1 ed001b5792e1afb35178e22d3adf45bbf0c4d721 ) ) game ( - name "GB-Wordyl (World) (Fr) (GB Compatible) (Aftermarket) (Unl)" - description "GB-Wordyl (World) (Fr) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "GB-Wordyl (World) (Fr) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 593965ff sha1 75d566045a680aaed4d40b83b6418cbfab5b4422 ) + name "Little Nicky (USA)" + description "Little Nicky (USA)" + rom ( name "Little Nicky (USA).gbc" size 2097152 crc 27310900 sha1 f2fa3ae6bb82ebf31c4863b64b330716bd839362 flags verified ) ) game ( - name "GB-Wordyl (World) (It) (GB Compatible) (Aftermarket) (Unl)" - description "GB-Wordyl (World) (It) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "GB-Wordyl (World) (It) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc d81ab567 sha1 1dfd3c4508ffb6598662bcf1b16ec109a9282dd5 ) + name "LNF Stars 2001 (France)" + description "LNF Stars 2001 (France)" + rom ( name "LNF Stars 2001 (France).gbc" size 1048576 crc f8bf3ee7 sha1 07a0e1c0ddde6371dbaf25fd016bdc77c0eca090 ) ) game ( - name "GB-Wordyl (World) (Kw) (GB Compatible) (Aftermarket) (Unl)" - description "GB-Wordyl (World) (Kw) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "GB-Wordyl (World) (Kw) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc f795689c sha1 9a332127182e8155d1a3dc53e1382a6c9dde6aeb ) + name "Lode Runner - Domudomu Dan no Yabou (Japan) (GB Compatible)" + description "Lode Runner - Domudomu Dan no Yabou (Japan) (GB Compatible)" + rom ( name "Lode Runner - Domudomu Dan no Yabou (Japan) (GB Compatible).gbc" size 1048576 crc eceab84e sha1 c49569e4453f18b00bcf5ea3de43dee9ba3b4499 ) ) game ( - name "GB-Wordyl (World) (Es-XL) (GB Compatible) (Aftermarket) (Unl)" - description "GB-Wordyl (World) (Es-XL) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "GB-Wordyl (World) (Es-XL) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 660ed37b sha1 0792fbef010cac21c12cbcb8b3c85b3af30faec4 ) + name "Lodoss-tou Senki - Eiyuu Kishiden GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Lodoss-tou Senki - Eiyuu Kishiden GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Lodoss-tou Senki - Eiyuu Kishiden GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 66e166bb sha1 3431247ffae511b6c2a836759e5ed0545d11ba05 ) ) game ( - name "GB-Wordyl (World) (Nl) (GB Compatible) (Aftermarket) (Unl)" - description "GB-Wordyl (World) (Nl) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "GB-Wordyl (World) (Nl) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 6dc4faaa sha1 7617083f9b13b2f95bdf1b0b327ffb4f8ccbe3c9 ) + name "Logical (Europe)" + description "Logical (Europe)" + rom ( name "Logical (Europe).gbc" size 1048576 crc 5eee76c4 sha1 bfcc97d28a0fe90521258de9cdf75a8abb5fbd0b ) ) game ( - name "GB-Wordyl (World) (En) (GB Compatible) (Aftermarket) (Unl)" - description "GB-Wordyl (World) (En) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "GB-Wordyl (World) (En) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 8780e125 sha1 7163bfbaa2cae2f9d41c472128f69a4fa5879180 ) + name "Logical (USA)" + description "Logical (USA)" + rom ( name "Logical (USA).gbc" size 1048576 crc d67275f7 sha1 3163071800753f29f2ce6142931356d8d6dfbe68 ) ) game ( - name "Gedou Jian Shen - Soul Falchion (Taiwan) (Unl) (Alt)" - description "Gedou Jian Shen - Soul Falchion (Taiwan) (Unl) (Alt)" - rom ( name "Gedou Jian Shen - Soul Falchion (Taiwan) (Unl) (Alt).gbc" size 1048576 crc c0ac1b50 sha1 4dcef6fcfe009e17da0bb13e50e7410a3f586e23 ) + name "Looney Tunes (Europe) (GB Compatible)" + description "Looney Tunes (Europe) (GB Compatible)" + rom ( name "Looney Tunes (Europe) (GB Compatible).gbc" size 1048576 crc 76cf3e3a sha1 e631eaa8f7be44a1f41e06878ca81bd3fa779f6b flags verified ) ) game ( - name "Gedou Jian Shen - Soul Falchion (Taiwan) (Unl)" - description "Gedou Jian Shen - Soul Falchion (Taiwan) (Unl)" - rom ( name "Gedou Jian Shen - Soul Falchion (Taiwan) (Unl).gbc" size 1048576 crc 1b1c6f68 sha1 fd06c62b42878e8094e610b180c1848c785f67e9 ) + name "Looney Tunes (USA) (GB Compatible)" + description "Looney Tunes (USA) (GB Compatible)" + rom ( name "Looney Tunes (USA) (GB Compatible).gbc" size 1048576 crc 4ef3ddd7 sha1 80a0e66754ce81a01385941459b9ea15a450b2b6 ) ) game ( - name "Gedou Zhizun 2003 (Taiwan) (Unl)" - description "Gedou Zhizun 2003 (Taiwan) (Unl)" - rom ( name "Gedou Zhizun 2003 (Taiwan) (Unl).gbc" size 1048576 crc f7630d88 sha1 f43c4055f69a1ff6b325494b5b34c8043914cd9d ) + name "Looney Tunes - Carrot Crazy (USA) (En,Fr,Es) (GB Compatible)" + description "Looney Tunes - Carrot Crazy (USA) (En,Fr,Es) (GB Compatible)" + rom ( name "Looney Tunes - Carrot Crazy (USA) (En,Fr,Es) (GB Compatible).gbc" size 1048576 crc 11fb5617 sha1 4d8fa4d930f7f2ba7d674eed1c5a284f20c434ca ) ) game ( - name "Geheimnis der Happy Hippo-Insel, Das (Germany)" - description "Geheimnis der Happy Hippo-Insel, Das (Germany)" - rom ( name "Geheimnis der Happy Hippo-Insel, Das (Germany).gbc" size 1048576 crc 25b480c3 sha1 f2ab35743f477a98007665f2a5686ab4da2b9049 flags verified ) + name "Looney Tunes - Twouble! (USA) (En,Fr,Es) (GB Compatible)" + description "Looney Tunes - Twouble! (USA) (En,Fr,Es) (GB Compatible)" + rom ( name "Looney Tunes - Twouble! (USA) (En,Fr,Es) (GB Compatible).gbc" size 1048576 crc 698d7be4 sha1 f08bd36a0933ac56eeed2dd235d476d3b80a1f50 ) ) game ( - name "Gekido (Europe) (Proto) (2000-09-04)" - description "Gekido (Europe) (Proto) (2000-09-04)" - rom ( name "Gekido (Europe) (Proto) (2000-09-04).gbc" size 262144 crc 4869c684 sha1 41b65a1399f92162f06423cb27d6ee25d3fcfa8d ) + name "Looney Tunes Collector - Alert! (USA) (En,Fr,Es)" + description "Looney Tunes Collector - Alert! (USA) (En,Fr,Es)" + rom ( name "Looney Tunes Collector - Alert! (USA) (En,Fr,Es).gbc" size 2097152 crc 54509d24 sha1 54c4f732a8c328a9331a8a500438b1b1e9472b39 ) ) game ( - name "Gekisou Dangun Racer - Onsoku Buster Dangun Dan (Japan)" - description "Gekisou Dangun Racer - Onsoku Buster Dangun Dan (Japan)" - rom ( name "Gekisou Dangun Racer - Onsoku Buster Dangun Dan (Japan).gbc" size 2097152 crc 06fccefc sha1 0b9c99a614d31cc0cb4047deeee6de76b64a5f8b ) + name "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl)" + description "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl).gbc" size 2097152 crc 5d85dfad sha1 645c4cf67faf33248d2102f137a605de94305796 flags verified ) ) game ( - name "Gem Gem Monster (Japan) (SGB Enhanced) (GB Compatible)" - description "Gem Gem Monster (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Gem Gem Monster (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc de7505c0 sha1 8b1396cf9dbc77246b3443810282b8b9bcb65a67 ) + name "Looney Tunes Collector - Martian Alert! (Europe) (Fr) (Beta 1) (1999-10-28)" + description "Looney Tunes Collector - Martian Alert! (Europe) (Fr) (Beta 1) (1999-10-28)" + rom ( name "Looney Tunes Collector - Martian Alert! (Europe) (Fr) (Beta 1) (1999-10-28).gbc" size 2097152 crc 3acb4840 sha1 4c05c1a15bb90feb09fbc2d8dfbfb42794313936 ) ) game ( - name "Gensou Maden Saiyuuki - Sabaku no Shijin (Japan)" - description "Gensou Maden Saiyuuki - Sabaku no Shijin (Japan)" - rom ( name "Gensou Maden Saiyuuki - Sabaku no Shijin (Japan).gbc" size 1048576 crc 918a40e7 sha1 9226b76621495ae0fc893c0a835973605414638f ) + name "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl) (Beta 2)" + description "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl) (Beta 2)" + rom ( name "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl) (Beta 2).gbc" size 2097152 crc 9058eae3 sha1 601236c323f4adbe5bd6091fac8871e11d71f105 ) ) game ( - name "Get Chuu Club - Minna no Konchuu Daizukan (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" - description "Get Chuu Club - Minna no Konchuu Daizukan (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" - rom ( name "Get Chuu Club - Minna no Konchuu Daizukan (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 9ebdb6c6 sha1 8a04a1c6374df1d6393a8af395422b63aad2e3d1 ) + name "Looney Tunes Collector - Martian Quest! (Japan)" + description "Looney Tunes Collector - Martian Quest! (Japan)" + rom ( name "Looney Tunes Collector - Martian Quest! (Japan).gbc" size 2097152 crc bc46a2d2 sha1 450e43cf2d9cfa18856b3f3312e2194f132dbb1b ) ) game ( - name "Gex - Enter the Gecko (USA, Europe) (GB Compatible)" - description "Gex - Enter the Gecko (USA, Europe) (GB Compatible)" - rom ( name "Gex - Enter the Gecko (USA, Europe) (GB Compatible).gbc" size 1048576 crc dccc7514 sha1 a05a530b3272634c8d3fedb6fd6eaf8b00b5cf9c ) + name "Looney Tunes Collector - Martian Revenge! (Europe) (En,Fr,De,Es,It,Nl)" + description "Looney Tunes Collector - Martian Revenge! (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Looney Tunes Collector - Martian Revenge! (Europe) (En,Fr,De,Es,It,Nl).gbc" size 2097152 crc 22952662 sha1 9e17af53ef89e2d436096c88dd293b838026b75f ) ) game ( - name "Gex 3 - Deep Cover Gecko (Europe) (En,Fr,De,Es,It)" - description "Gex 3 - Deep Cover Gecko (Europe) (En,Fr,De,Es,It)" - rom ( name "Gex 3 - Deep Cover Gecko (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 025f305d sha1 176ec4347ce08b15214e68fcec39c9c4c57ad773 ) + name "Looney Tunes Racing (Europe) (En,Fr,De,Es,It,Nl)" + description "Looney Tunes Racing (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Looney Tunes Racing (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 7efdca8a sha1 2552c1f0e864e1689e59f8d80837bffdffa211fa ) ) game ( - name "Gex 3 - Deep Pocket Gecko (USA)" - description "Gex 3 - Deep Pocket Gecko (USA)" - rom ( name "Gex 3 - Deep Pocket Gecko (USA).gbc" size 2097152 crc 85a98c7d sha1 0da71536a3e92dd537c7067ec1014a262dbc3837 ) + name "Looney Tunes Racing (USA) (En,Fr,De,Es,It,Nl)" + description "Looney Tunes Racing (USA) (En,Fr,De,Es,It,Nl)" + rom ( name "Looney Tunes Racing (USA) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 66792cde sha1 249759398fb9e484b00e0d5416da2411c79d2d39 ) ) game ( - name "Ghost of the Arcade (World) (v1.7) (Aftermarket) (Unl)" - description "Ghost of the Arcade (World) (v1.7) (Aftermarket) (Unl)" - rom ( name "Ghost of the Arcade (World) (v1.7) (Aftermarket) (Unl).gbc" size 1048576 crc 4aa9a9c2 sha1 ac697bc27a126c1389e6bef94a2c83404e8819f2 ) + name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 29e193c5 sha1 8cc512784d323f7c0bfe36848c5f7fdc49257285 ) ) game ( - name "Ghost of the Arcade (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" - description "Ghost of the Arcade (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Ghost of the Arcade (World) (v1.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 32e2ea48 sha1 ee11d5397316b69eee5ae3023de08c3b919c93df ) + name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc d54d5836 sha1 c88ae04f7adbec5ad40edec650198cbe58a561bd ) ) game ( - name "Ghost of the Arcade (World) (GB Compo 2023) (GB Compatible) (Aftermarket) (Unl)" - description "Ghost of the Arcade (World) (GB Compo 2023) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Ghost of the Arcade (World) (GB Compo 2023) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc ea87ad5d sha1 433e25df1421e77cdc807296e1ed662d9e43d685 ) + name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc e078d9f8 sha1 a7faa970e71d38c68948b646d3dcb9cbea1df995 ) ) game ( - name "Ghost Town (World) (Aftermarket) (Unl)" - description "Ghost Town (World) (Aftermarket) (Unl)" - rom ( name "Ghost Town (World) (Aftermarket) (Unl).gbc" size 262144 crc 52efcc35 sha1 1a4a7846d6c87f0bd8b267aa6a8aa98e797fedf8 ) + name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 065a3bf5 sha1 42721b99b427e51f7e815c852bf53e807c52dd65 ) ) game ( - name "Ghosts'n Goblins (USA, Europe) (GB Compatible)" - description "Ghosts'n Goblins (USA, Europe) (GB Compatible)" - rom ( name "Ghosts'n Goblins (USA, Europe) (GB Compatible).gbc" size 1048576 crc ae024c23 sha1 af9e69fc65fbe0d4fabe145472c1340e9f541a7b ) + name "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc c0287cf2 sha1 7425bd94790866bf716fd3c23886a5cdc06f1aad ) ) game ( - name "Gift (Europe)" - description "Gift (Europe)" - rom ( name "Gift (Europe).gbc" size 1048576 crc 1b0034e8 sha1 a8c6b7ca2e4ed75cf037625b603cfc8ab67c0aef flags verified ) + name "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 267b5253 sha1 f977d3dd6395066bbea729ea547c7a81e1c4464d ) ) game ( - name "Gift (Europe) (Sample)" - description "Gift (Europe) (Sample)" - rom ( name "Gift (Europe) (Sample).gbc" size 1048576 crc d8e357ba sha1 a9e2d5e1fd5d3993acb87888d287612a09ecaa8b ) + name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc d457cc6c sha1 cb14866337caecd5458edc72f2d56f2c8c028411 ) ) game ( - name "Gift (Europe) (Rev 1) (Proto)" - description "Gift (Europe) (Rev 1) (Proto)" - rom ( name "Gift (Europe) (Rev 1) (Proto).gbc" size 1048576 crc 19681ac2 sha1 12561be4c0979b9dc8ba22caff8ac3513e1611a6 ) + name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 27ab2187 sha1 49a63339bc253d1bd55f6db75f7324980572925a ) ) game ( - name "Gifty (Germany) (En) (Rev 1) (Proto)" - description "Gifty (Germany) (En) (Rev 1) (Proto)" - rom ( name "Gifty (Germany) (En) (Rev 1) (Proto).gbc" size 1048576 crc 96b929e8 sha1 b0c9eb2ad7a41f17d8621c40a5c0ae3e53166253 ) + name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 3ef25533 sha1 9822fecf183d3d0a6e9af80696463b09e1f31a60 ) ) game ( - name "Gifty (Germany) (En)" - description "Gifty (Germany) (En)" - rom ( name "Gifty (Germany) (En).gbc" size 1048576 crc b97a8cb8 sha1 f92997128f6bce74f5e5c0787f98fa3d2b6c3133 ) + name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 62d3f1e5 sha1 a3ddd9794e05f2962481b802f84e783495e853b2 ) ) game ( - name "Gimmick Land (Japan) (Proto)" - description "Gimmick Land (Japan) (Proto)" - rom ( name "Gimmick Land (Japan) (Proto).gbc" size 2097152 crc 228d0b0c sha1 f63adff202d7351c61411766c5b57efefac58bcd ) + name "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 094ffd1e sha1 5a476f79db61aa8c6f32bbabd82fade5cde811d2 ) ) game ( - name "Glocal Hexcite (Japan) (SGB Enhanced) (GB Compatible)" - description "Glocal Hexcite (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Glocal Hexcite (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f1908391 sha1 7d13220593c8d89af1b4cae955caacff7df3817a ) + name "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + description "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 88ce5c13 sha1 7e493878e0b755df3c6d6ab93c7b15b4b10a0896 ) ) game ( - name "Gobs of Games (USA) (En,Fr,De)" - description "Gobs of Games (USA) (En,Fr,De)" - rom ( name "Gobs of Games (USA) (En,Fr,De).gbc" size 1048576 crc 2e61c391 sha1 89695361ccbca372662f6634678a40ea676076a7 ) + name "Lord of the Rings, The - The Fellowship of the Ring (Taiwan) (En) (Unl)" + description "Lord of the Rings, The - The Fellowship of the Ring (Taiwan) (En) (Unl)" + rom ( name "Lord of the Rings, The - The Fellowship of the Ring (Taiwan) (En) (Unl).gbc" size 2097152 crc c01bbc48 sha1 3ecb3ae13e0934ed94dbb8621e62820a07fdffb0 ) ) game ( - name "Gods of the Universe (World) (Aftermarket) (Unl)" - description "Gods of the Universe (World) (Aftermarket) (Unl)" - rom ( name "Gods of the Universe (World) (Aftermarket) (Unl).gbc" size 262144 crc 27b87354 sha1 74eb8cd698097290b93fb08d9b19486d05411877 ) + name "Love Hina Party (Japan)" + description "Love Hina Party (Japan)" + rom ( name "Love Hina Party (Japan).gbc" size 2097152 crc 034d2686 sha1 d3551d99bb03e7945862cc8f1c3c095477119cf2 ) ) game ( - name "Godzilla - The Series (Europe) (En,Fr,De) (GB Compatible)" - description "Godzilla - The Series (Europe) (En,Fr,De) (GB Compatible)" - rom ( name "Godzilla - The Series (Europe) (En,Fr,De) (GB Compatible).gbc" size 1048576 crc 2a073369 sha1 05942143ac24489fc61ad9f8385e4d02e216804d ) + name "Love Hina Pocket (Japan)" + description "Love Hina Pocket (Japan)" + rom ( name "Love Hina Pocket (Japan).gbc" size 4194304 crc 1c877abd sha1 912c09f99bdae6e7fcd62d0c6f727e5fff93db70 ) ) game ( - name "Godzilla - The Series (USA) (En,Fr,De) (GB Compatible)" - description "Godzilla - The Series (USA) (En,Fr,De) (GB Compatible)" - rom ( name "Godzilla - The Series (USA) (En,Fr,De) (GB Compatible).gbc" size 1048576 crc dd716efe sha1 56ec20cf1f2613bc2dcdf88d27e8af7378f7d334 ) + name "Love Hina Pocket (Japan) (Rev 1)" + description "Love Hina Pocket (Japan) (Rev 1)" + rom ( name "Love Hina Pocket (Japan) (Rev 1).gbc" size 4194304 crc 55dd0ba6 sha1 b29abee319ccb223e5d1a4f88982fb53e538d527 ) ) game ( - name "Godzilla - The Series - Monster Wars (Europe) (En,Fr,De)" - description "Godzilla - The Series - Monster Wars (Europe) (En,Fr,De)" - rom ( name "Godzilla - The Series - Monster Wars (Europe) (En,Fr,De).gbc" size 1048576 crc a6007ce1 sha1 829c7efb45a9e32ee63cd6c9fe5716e457be7222 ) + name "Luca no Puzzle de Daibouken! (Japan) (SGB Enhanced) (GB Compatible)" + description "Luca no Puzzle de Daibouken! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Luca no Puzzle de Daibouken! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc 3aebfad8 sha1 3c06fe05909ad632b761c6a1c00bc69da81aa358 ) ) game ( - name "Godzilla - The Series - Monster Wars (USA) (En,Fr,De)" - description "Godzilla - The Series - Monster Wars (USA) (En,Fr,De)" - rom ( name "Godzilla - The Series - Monster Wars (USA) (En,Fr,De).gbc" size 1048576 crc e7ebb394 sha1 4137c24412deb560f2dab36f55c89253ca750b26 ) + name "Lucky Luke (Europe) (En,Fr,De,Es)" + description "Lucky Luke (Europe) (En,Fr,De,Es)" + rom ( name "Lucky Luke (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 412fb57c sha1 36b59251751a55285dbedc3bd4b33b2c73b811c9 flags verified ) ) game ( - name "Gold and Glory - The Road to El Dorado (Europe) (En,Fr,De,Es,It,Nl)" - description "Gold and Glory - The Road to El Dorado (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Gold and Glory - The Road to El Dorado (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc b16f1752 sha1 89487f0b06a261bb2d3dd64d2a40c42ed9b4f63f ) + name "Lucky Luke (USA) (En,Fr,De,Es)" + description "Lucky Luke (USA) (En,Fr,De,Es)" + rom ( name "Lucky Luke (USA) (En,Fr,De,Es).gbc" size 1048576 crc a5e29f34 sha1 ebf61143a16be4bfc0c99a7feb9455685f86acfa ) ) game ( - name "Gold and Glory - The Road to El Dorado (USA)" - description "Gold and Glory - The Road to El Dorado (USA)" - rom ( name "Gold and Glory - The Road to El Dorado (USA).gbc" size 1048576 crc b7d49490 sha1 d78b266757f8c2f53b0e8679161b1bf7828d9045 ) + name "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl)" + description "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc ce7f108a sha1 857dda99bdb15c49918c633dbcb73bd96ef7bae9 ) ) game ( - name "Golden Goal (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - description "Golden Goal (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - rom ( name "Golden Goal (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 1048576 crc bb9b597d sha1 1501ea3bb5aa70562306f6df40e5b61cea93de7e ) + name "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + description "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + rom ( name "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 1048576 crc b558c401 sha1 ab9b610f2858fec8bd4542731f6fbfd4b7faf9e1 ) ) game ( - name "Golden Goal (Germany) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - description "Golden Goal (Germany) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - rom ( name "Golden Goal (Germany) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 1048576 crc 14d1adbe sha1 aba65e7eca59f6fd90d4266df1478bad68d1e74e ) + name "Lufia - The Legend Returns (Europe) (En,De)" + description "Lufia - The Legend Returns (Europe) (En,De)" + rom ( name "Lufia - The Legend Returns (Europe) (En,De).gbc" size 2097152 crc 470dcb1d sha1 10faaefba4c97d8392bb0231cf898a77db4f73f2 flags verified ) ) game ( - name "Golf Daisuki! (Japan) (SGB Enhanced) (GB Compatible)" - description "Golf Daisuki! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Golf Daisuki! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 80444a86 sha1 d245a267b1b1d056e0f5af4ba732c66c8deadde2 ) + name "Lufia - The Legend Returns (USA)" + description "Lufia - The Legend Returns (USA)" + rom ( name "Lufia - The Legend Returns (USA).gbc" size 2097152 crc 5bae3c04 sha1 9eb52c525620e7bda619f2161961071e8996c0db ) ) game ( - name "Golf de Ohasuta (Japan) (GB Compatible)" - description "Golf de Ohasuta (Japan) (GB Compatible)" - rom ( name "Golf de Ohasuta (Japan) (GB Compatible).gbc" size 524288 crc 38273bdd sha1 8a19713515c4cd6983da57f76924babc090af654 ) + name "Luke Yingxiong 2 - Zook Hero 2 (Taiwan) (Unl)" + description "Luke Yingxiong 2 - Zook Hero 2 (Taiwan) (Unl)" + rom ( name "Luke Yingxiong 2 - Zook Hero 2 (Taiwan) (Unl).gbc" size 524288 crc 59822b31 sha1 4bf85d9641e3b842a917474dcb49a8b7f282711b ) ) game ( - name "Golf King (Europe) (En,Fr,De) (Proto)" - description "Golf King (Europe) (En,Fr,De) (Proto)" - rom ( name "Golf King (Europe) (En,Fr,De) (Proto).gbc" size 2097152 crc 3019b4e7 sha1 d02e09251e7c5078e4b641e6d334958c2c814285 ) + name "Luke Yingxiong Chuan 3 (Taiwan) (Unl)" + description "Luke Yingxiong Chuan 3 (Taiwan) (Unl)" + rom ( name "Luke Yingxiong Chuan 3 (Taiwan) (Unl).gbc" size 4194304 crc bd0e7c73 sha1 a095388a2ba13f0f846bbf4ee86ef25e49327c67 ) ) game ( - name "Golf Ou - The King of Golf (Japan) (SGB Enhanced) (GB Compatible)" - description "Golf Ou - The King of Golf (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Golf Ou - The King of Golf (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 634b2d43 sha1 d196af0aaf77ca67f9784d0ccd1ef4b25abed5c2 ) + name "Luke Yingxiong Z (Taiwan) (Unl)" + description "Luke Yingxiong Z (Taiwan) (Unl)" + rom ( name "Luke Yingxiong Z (Taiwan) (Unl).gbc" size 1048576 crc 8ced0c21 sha1 271097c99be5f60fbdb561875d006a622093fe70 ) ) game ( - name "Gonta no Okiraku Daibouken (Japan)" - description "Gonta no Okiraku Daibouken (Japan)" - rom ( name "Gonta no Okiraku Daibouken (Japan).gbc" size 1048576 crc e45e99d2 sha1 49e4156716a47d46006ad287ec46c28c573a74a5 ) + name "Luoke Yingxiong EXE5 (Taiwan) (Unl)" + description "Luoke Yingxiong EXE5 (Taiwan) (Unl)" + rom ( name "Luoke Yingxiong EXE5 (Taiwan) (Unl).gbc" size 2097152 crc 51f92403 sha1 c498a5fb261e921828831bff5c2c705453ea314e ) ) game ( - name "Goraku Ou Tango! (Japan) (GB Compatible)" - description "Goraku Ou Tango! (Japan) (GB Compatible)" - rom ( name "Goraku Ou Tango! (Japan) (GB Compatible).gbc" size 1048576 crc 81fb43e1 sha1 1d49232763c1422a00cbb893d0f900c44a2ccf54 ) + name "M&M's Minis Madness (Europe)" + description "M&M's Minis Madness (Europe)" + rom ( name "M&M's Minis Madness (Europe).gbc" size 1048576 crc 60683bc4 sha1 d0b18a3acf9495db5af52b5c28df4129f48010bf ) ) game ( - name "Gorf the Ghost Saves Halloween (World) (GB Compatible) (Aftermarket) (Unl)" - description "Gorf the Ghost Saves Halloween (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Gorf the Ghost Saves Halloween (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ab10cec6 sha1 9dcaa6824fab806683737bdf1c76609c68c451a5 ) + name "M&M's Minis Madness (Germany)" + description "M&M's Minis Madness (Germany)" + rom ( name "M&M's Minis Madness (Germany).gbc" size 1048576 crc a666f54d sha1 9ccc1f1f0b6bd65913e60e2f9b7d5f9859b46535 ) ) game ( - name "Grand Casino (Japan) (Proto)" - description "Grand Casino (Japan) (Proto)" - rom ( name "Grand Casino (Japan) (Proto).gbc" size 1048576 crc 8ba3988b sha1 556e1a6c27c792605925f6f67daa953809f81bfb ) + name "M&M's Minis Madness (USA)" + description "M&M's Minis Madness (USA)" + rom ( name "M&M's Minis Madness (USA).gbc" size 1048576 crc 8649d7a0 sha1 7cc20e133a66163c6dec140e960b5be3848ccd44 ) ) game ( - name "Grand Theft Auto (Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "Grand Theft Auto (Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Grand Theft Auto (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 4194304 crc 25ba9231 sha1 b6c1693ba5bf2c914d910e94286bda8f3fbd100e ) + name "M&M's Minis Madness (USA) (Sample)" + description "M&M's Minis Madness (USA) (Sample)" + rom ( name "M&M's Minis Madness (USA) (Sample).gbc" size 1048576 crc 83293b1b sha1 2a0d0b7aa3b96b05bc020da496f2ce08e8fac190 ) ) game ( - name "Grand Theft Auto (USA) (GB Compatible)" - description "Grand Theft Auto (USA) (GB Compatible)" - rom ( name "Grand Theft Auto (USA) (GB Compatible).gbc" size 4194304 crc 924de366 sha1 a0c9d9a95bf2cceca7922f4375555b8edee9ea6b ) + name "Macross 7 - Ginga no Heart o Furuwasero!! (Japan)" + description "Macross 7 - Ginga no Heart o Furuwasero!! (Japan)" + rom ( name "Macross 7 - Ginga no Heart o Furuwasero!! (Japan).gbc" size 2097152 crc 2b7abba4 sha1 88746c361cfbdac49e5d72807b396a6667c42229 ) ) game ( - name "Grand Theft Auto 2 (Europe) (En,Fr,De,Es,It)" - description "Grand Theft Auto 2 (Europe) (En,Fr,De,Es,It)" - rom ( name "Grand Theft Auto 2 (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc ad563bd9 sha1 a7577d81de3ab03b93b364f9e775c303c842dad2 flags verified ) + name "Madden NFL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Madden NFL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Madden NFL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 482944aa sha1 df03f3e5e3f6fd3905dc332b307b5566f0f35252 flags verified ) ) game ( - name "Grand Theft Auto 2 (USA)" - description "Grand Theft Auto 2 (USA)" - rom ( name "Grand Theft Auto 2 (USA).gbc" size 2097152 crc 68610203 sha1 6fd4b31d410ca98452ada0a1f3c0e2590e7df099 ) + name "Madden NFL 2000 (USA, Europe) (Beta) (SGB Enhanced) (GB Compatible)" + description "Madden NFL 2000 (USA, Europe) (Beta) (SGB Enhanced) (GB Compatible)" + rom ( name "Madden NFL 2000 (USA, Europe) (Beta) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b3fead85 sha1 09bf3dea1dc01b018ba86e3affbcbab7b9d2eb63 ) ) game ( - name "Grandia - Parallel Trippers (Japan)" - description "Grandia - Parallel Trippers (Japan)" - rom ( name "Grandia - Parallel Trippers (Japan).gbc" size 4194304 crc 23223670 sha1 647b7cc5fa415ef7081aa37cd787eb41d2a3e574 flags verified ) + name "Madden NFL 2001 (USA)" + description "Madden NFL 2001 (USA)" + rom ( name "Madden NFL 2001 (USA).gbc" size 1048576 crc 160e9e3c sha1 5f7c156b7a141a8f373d626f53c9ce8b95cec880 ) ) game ( - name "Granduel - Shinki Dungeon no Hihou (Japan)" - description "Granduel - Shinki Dungeon no Hihou (Japan)" - rom ( name "Granduel - Shinki Dungeon no Hihou (Japan).gbc" size 2097152 crc d589c501 sha1 7fe6da989e95a6e228c8d01ad650ed26ee42551b flags verified ) + name "Madden NFL 2002 (USA)" + description "Madden NFL 2002 (USA)" + rom ( name "Madden NFL 2002 (USA).gbc" size 1048576 crc de1338d2 sha1 f32926053b8e565c2a3634c68a456d459e1f01a0 ) ) game ( - name "Granduel - Shinki Dungeon no Hihou (Japan) (Sample)" - description "Granduel - Shinki Dungeon no Hihou (Japan) (Sample)" - rom ( name "Granduel - Shinki Dungeon no Hihou (Japan) (Sample).gbc" size 2097152 crc 7122136d sha1 534fc9ae5800eb935460f145e1bbc57f77ab2555 ) + name "Magi Nation (USA)" + description "Magi Nation (USA)" + rom ( name "Magi Nation (USA).gbc" size 2097152 crc 5042450b sha1 9972a7bca43210b4b6c0b3f6ee5d1957a865e12d ) ) game ( - name "Grave Encounter, A (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" - description "Grave Encounter, A (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Grave Encounter, A (World) (v1.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc a5ad3c0b sha1 1cf0cf6d1da5c5337856ecc0a60d2e9fb3c98f58 ) + name "Magi-Nation - Keeper's Quest (USA) (Proto)" + description "Magi-Nation - Keeper's Quest (USA) (Proto)" + rom ( name "Magi-Nation - Keeper's Quest (USA) (Proto).gbc" size 1048576 crc 89de57b7 sha1 7c6b427810be2f0d7496ccb5eff2226d3ed1194e ) ) game ( - name "Grave Encounter, A (World) (v1.21) (GB Compatible) (Aftermarket) (Unl)" - description "Grave Encounter, A (World) (v1.21) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Grave Encounter, A (World) (v1.21) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc b29fc03f sha1 2f979202a4bf4f98f3026a7548a8b6c7008806bf ) + name "Magical Chase GB - Minarai Mahoutsukai Kenja no Tani e (Japan)" + description "Magical Chase GB - Minarai Mahoutsukai Kenja no Tani e (Japan)" + rom ( name "Magical Chase GB - Minarai Mahoutsukai Kenja no Tani e (Japan).gbc" size 1048576 crc 15e5d499 sha1 3b13fc974d68a8b057ab8133a0ba7e3fbac23f11 ) ) game ( - name "Gravitorque (World) (GB Compatible) (Aftermarket) (Unl)" - description "Gravitorque (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Gravitorque (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc a0e998e1 sha1 ab656383e9aaaa2991aa344bdc8f21370f0eda36 ) + name "Magical Drop (Europe) (En,Fr,De)" + description "Magical Drop (Europe) (En,Fr,De)" + rom ( name "Magical Drop (Europe) (En,Fr,De).gbc" size 1048576 crc ea9ee203 sha1 8ef276f9c6a64d7cec527bcba8d1b7223de0e01c flags verified ) ) game ( - name "Great Battle Pocket, The (Japan) (SGB Enhanced) (GB Compatible)" - description "Great Battle Pocket, The (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Great Battle Pocket, The (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b471c095 sha1 617752e18894590b5959f565f1cdbfd218141e7d ) + name "Magical Drop (USA)" + description "Magical Drop (USA)" + rom ( name "Magical Drop (USA).gbc" size 1048576 crc e4188a79 sha1 2106b22776a87825d3edb408503e719f4927c3e6 ) ) game ( - name "Green Beret (Unknown) (Proto 1)" - description "Green Beret (Unknown) (Proto 1)" - rom ( name "Green Beret (Unknown) (Proto 1).gbc" size 32768 crc c66c546f sha1 5b92b0db1af9803e27a4ebb23ad9ed8377d6d87b ) + name "Magical Drop (Europe) (En,Fr,De) (Beta)" + description "Magical Drop (Europe) (En,Fr,De) (Beta)" + rom ( name "Magical Drop (Europe) (En,Fr,De) (Beta).gbc" size 1048576 crc 799e2020 sha1 99fbf24ca924acf5a4ea64817fb29d6e408cb722 ) ) game ( - name "Green Beret (Unknown) (Proto 2)" - description "Green Beret (Unknown) (Proto 2)" - rom ( name "Green Beret (Unknown) (Proto 2).gbc" size 65536 crc 702af305 sha1 f8e6ee070147c56e280abf2a31316ee8124b953c ) + name "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv)" + description "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv)" + rom ( name "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv).gbc" size 1048576 crc 0a421839 sha1 3c315f3f77002456f09df9643be323608ae72088 ) ) game ( - name "Green Beret (Unknown) (Proto 3)" - description "Green Beret (Unknown) (Proto 3)" - rom ( name "Green Beret (Unknown) (Proto 3).gbc" size 262144 crc fac3f4c5 sha1 dd69f3d9ef87198334b4cc0f54c88a29fb353e44 ) + name "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1)" + description "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1)" + rom ( name "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1).gbc" size 1048576 crc c82be2f4 sha1 950b30b267b0f0b79d7e85e91b8536b096b6a1b2 ) ) game ( - name "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt)" - description "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt)" - rom ( name "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc 053bc315 sha1 d18e30a434262f7bf46a8db2e5f62ce19b7ecfaa ) + name "Magical Tetris Challenge (USA)" + description "Magical Tetris Challenge (USA)" + rom ( name "Magical Tetris Challenge (USA).gbc" size 1048576 crc f53cf66c sha1 7cdb0bf463ad87ec8a68a564c3f03dbc890edd7e ) ) game ( - name "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt) (Beta)" - description "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt) (Beta)" - rom ( name "Gremlins - Unleashed (Europe) (En,Fr,De,Es,It,Pt) (Beta).gbc" size 1048576 crc c38d52e7 sha1 675623b58fa0d307355c77d7a4783af7927681e9 ) + name "Mahjong Joou (Japan) (SGB Enhanced) (GB Compatible)" + description "Mahjong Joou (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Mahjong Joou (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 7d83a5e8 sha1 68f2326f7fa70d0ed0207bd087c6fe26ec6f9a53 ) ) game ( - name "Grimace's Birthday (World) (Aftermarket) (Unl)" - description "Grimace's Birthday (World) (Aftermarket) (Unl)" - rom ( name "Grimace's Birthday (World) (Aftermarket) (Unl).gbc" size 1048576 crc 7f4386e9 sha1 d6358d100ea65d34d95588f800635b64927baf82 ) + name "Mahjong Quest (Japan) (SGB Enhanced) (GB Compatible)" + description "Mahjong Quest (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Mahjong Quest (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c870b88f sha1 3ab49ce8aa69013c1b2d9427926513e21d5efe1d ) ) game ( - name "Grimace's Birthday (World) (v1.1) (Aftermarket) (Unl)" - description "Grimace's Birthday (World) (v1.1) (Aftermarket) (Unl)" - rom ( name "Grimace's Birthday (World) (v1.1) (Aftermarket) (Unl).gbc" size 1048576 crc 7744f551 sha1 035b7417e03c4e264a90212f2a3811012f03c2a2 flags verified ) + name "Mail Junkies World Port (United Kingdom) (v1.01) (Unl)" + description "Mail Junkies World Port (United Kingdom) (v1.01) (Unl)" + rom ( name "Mail Junkies World Port (United Kingdom) (v1.01) (Unl).gbc" size 262144 crc d4df856f sha1 004deb1e75ffa08080028cb4c08a7c981c313eb8 ) ) game ( - name "Grimace's Birthday (World) (v1.2) (Aftermarket) (Unl)" - description "Grimace's Birthday (World) (v1.2) (Aftermarket) (Unl)" - rom ( name "Grimace's Birthday (World) (v1.2) (Aftermarket) (Unl).gbc" size 1048576 crc 9dee42fe sha1 071fa179df96950c3c92b0abbe32092b1816ec40 flags verified ) + name "Majokko Mari-chan no Kisekae Monogatari (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Majokko Mari-chan no Kisekae Monogatari (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Majokko Mari-chan no Kisekae Monogatari (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 0d16a545 sha1 a56e2a42d4a0b21e656bc928e4451cf0623486cf flags verified ) ) game ( - name "Grimace's Birthday (World) (v1.4) (Aftermarket) (Unl)" - description "Grimace's Birthday (World) (v1.4) (Aftermarket) (Unl)" - rom ( name "Grimace's Birthday (World) (v1.4) (Aftermarket) (Unl).gbc" size 1048576 crc 9baa5f46 sha1 d247c03119ac14f97fdeeaa6bf0defa98e35fa17 flags verified ) + name "Majokko Mari-chan no Kisekae Monogatari (Japan) (SGB Enhanced) (GB Compatible)" + description "Majokko Mari-chan no Kisekae Monogatari (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Majokko Mari-chan no Kisekae Monogatari (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 934f4b0a sha1 8bdd3bd414da91c6ea05bc29435e09b0b72e3790 ) ) game ( - name "Grimace's Birthday (World) (v1.3) (Aftermarket) (Unl)" - description "Grimace's Birthday (World) (v1.3) (Aftermarket) (Unl)" - rom ( name "Grimace's Birthday (World) (v1.3) (Aftermarket) (Unl).gbc" size 1048576 crc ab41a9ef sha1 d8e727745e285f5e467f5eccbfd30ee175bafc2e flags verified ) + name "Marble Madness (USA, Europe)" + description "Marble Madness (USA, Europe)" + rom ( name "Marble Madness (USA, Europe).gbc" size 1048576 crc 4ec78785 sha1 32c84b75b10bd00812589f3c8cfd537518f021c6 flags verified ) ) game ( - name "Grimace's Birthday (World) (v1.5) (Aftermarket) (Unl)" - description "Grimace's Birthday (World) (v1.5) (Aftermarket) (Unl)" - rom ( name "Grimace's Birthday (World) (v1.5) (Aftermarket) (Unl).gbc" size 1048576 crc f8e8e1f3 sha1 a3fdfe3981e800fa7c73ff989bc06426f668c331 flags verified ) + name "Marie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Marie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Marie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 6144fc66 sha1 f2b175da93054372531bc7d839bdbf3192c6a5eb ) ) game ( - name "Grimace's Birthday (World) (v1.6) (Aftermarket) (Unl)" - description "Grimace's Birthday (World) (v1.6) (Aftermarket) (Unl)" - rom ( name "Grimace's Birthday (World) (v1.6) (Aftermarket) (Unl).gbc" size 1048576 crc a7b59d7b sha1 295fdc3218d1699dea6d5832d068b721fccf9bd4 flags verified ) + name "Mario Golf (Europe)" + description "Mario Golf (Europe)" + rom ( name "Mario Golf (Europe).gbc" size 2097152 crc a132417d sha1 ae3aec0d376c1bc5b83ae4c4c1e245c3ab2b9392 ) ) game ( - name "Grimace's Birthday (World) (v1.7) (Aftermarket) (Unl)" - description "Grimace's Birthday (World) (v1.7) (Aftermarket) (Unl)" - rom ( name "Grimace's Birthday (World) (v1.7) (Aftermarket) (Unl).gbc" size 1048576 crc f3879ef0 sha1 27d7ee2f31bf575185711217c3cc9e08cbc5928a flags verified ) + name "Mario Golf (USA)" + description "Mario Golf (USA)" + rom ( name "Mario Golf (USA).gbc" size 2097152 crc 905ad0cb sha1 7f2062e51b4fc87378c1d5e6b9578c9277b94e0b ) ) game ( - name "Grinch (Japan)" - description "Grinch (Japan)" - rom ( name "Grinch (Japan).gbc" size 1048576 crc 432dc371 sha1 33412209ef2b952e82f5d0b3f7bb035efebcf480 ) + name "Mario Golf GB (Japan)" + description "Mario Golf GB (Japan)" + rom ( name "Mario Golf GB (Japan).gbc" size 2097152 crc 4ca2191a sha1 5658666a30288c6104f01985018a213e851067de ) ) game ( - name "Grinch, The (Europe) (En,Fr,De)" - description "Grinch, The (Europe) (En,Fr,De)" - rom ( name "Grinch, The (Europe) (En,Fr,De).gbc" size 1048576 crc 9ed6059a sha1 df0ed2c6fad2d511037ab9269571f24146103237 ) + name "Mario Tennis (Europe)" + description "Mario Tennis (Europe)" + rom ( name "Mario Tennis (Europe).gbc" size 2097152 crc 0510d601 sha1 550dcc99d0a56bbb13ae3abb2a4193b830e54970 ) ) game ( - name "Grinch, The (USA)" - description "Grinch, The (USA)" - rom ( name "Grinch, The (USA).gbc" size 1048576 crc c5a47896 sha1 84c2397fe07011511225b9d9f442f16c026576d3 ) + name "Mario Tennis (USA)" + description "Mario Tennis (USA)" + rom ( name "Mario Tennis (USA).gbc" size 2097152 crc a781c63c sha1 414ba58340a27fc27b127bc01455b32764151ff0 ) ) game ( - name "Guaishou Go! Go! II (Taiwan) (Unl)" - description "Guaishou Go! Go! II (Taiwan) (Unl)" - rom ( name "Guaishou Go! Go! II (Taiwan) (Unl).gbc" size 1048576 crc b0237467 sha1 8ed6f39a9973d634266806455ef845b6bdb5ab95 ) + name "Mario Tennis GB (Japan)" + description "Mario Tennis GB (Japan)" + rom ( name "Mario Tennis GB (Japan).gbc" size 2097152 crc 19070962 sha1 ad003d51b5a7adb7beb8b946cdf467db6d940204 flags verified ) ) game ( - name "Guiwu Zhe 2 (Taiwan) (Unl)" - description "Guiwu Zhe 2 (Taiwan) (Unl)" - rom ( name "Guiwu Zhe 2 (Taiwan) (Unl).gbc" size 2097152 crc 955bc6ad sha1 5fe41ac064f4b4d4476ef4177a2f4d69fae1a933 ) + name "Marvin Strikes Back! (USA) (En,Fr,Es)" + description "Marvin Strikes Back! (USA) (En,Fr,Es)" + rom ( name "Marvin Strikes Back! (USA) (En,Fr,Es).gbc" size 2097152 crc 11b4788c sha1 6e420ef902a52a5a932e0932d0aeb11c3d71fda2 ) ) game ( - name "Gun Law (World) (Aftermarket) (Unl)" - description "Gun Law (World) (Aftermarket) (Unl)" - rom ( name "Gun Law (World) (Aftermarket) (Unl).gbc" size 262144 crc 3a0b6823 sha1 c49f7e0a5055f836528a7bc0cb6f45f221c76475 ) + name "Mary-Kate & Ashley - Get a Clue! (USA, Europe) (GB Compatible)" + description "Mary-Kate & Ashley - Get a Clue! (USA, Europe) (GB Compatible)" + rom ( name "Mary-Kate & Ashley - Get a Clue! (USA, Europe) (GB Compatible).gbc" size 1048576 crc 46faa730 sha1 4d7884e985a07ac640c3ddd1b9b482c205c5a709 flags verified ) ) game ( - name "Gunslinger (World) (Aftermarket) (Unl)" - description "Gunslinger (World) (Aftermarket) (Unl)" - rom ( name "Gunslinger (World) (Aftermarket) (Unl).gbc" size 262144 crc 0dfd765f sha1 8410ef1558649f9badc71629827ba1500510d221 ) + name "Mary-Kate and Ashley - Crush Course (USA, Europe)" + description "Mary-Kate and Ashley - Crush Course (USA, Europe)" + rom ( name "Mary-Kate and Ashley - Crush Course (USA, Europe).gbc" size 1048576 crc 69db3cd8 sha1 11b2a52e19862a907d340a35a49d206059f21369 ) ) game ( - name "Gunther the Monster and His Friends (World) (Aftermarket) (Unl)" - description "Gunther the Monster and His Friends (World) (Aftermarket) (Unl)" - rom ( name "Gunther the Monster and His Friends (World) (Aftermarket) (Unl).gbc" size 524288 crc 2d9b59bf sha1 d89fe1cd97d1ef2c457aa90b1c00e7b473c57270 ) + name "Mary-Kate and Ashley - Pocket Planner (USA, Europe) (GB Compatible)" + description "Mary-Kate and Ashley - Pocket Planner (USA, Europe) (GB Compatible)" + rom ( name "Mary-Kate and Ashley - Pocket Planner (USA, Europe) (GB Compatible).gbc" size 1048576 crc 84a880b9 sha1 138472b98387169425b6a652be6cc8594e031bbe flags verified ) ) game ( - name "Guruguru Garakutas (Japan) (SGB Enhanced) (GB Compatible)" - description "Guruguru Garakutas (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Guruguru Garakutas (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 7eaeeeac sha1 86fea7dd8d815a51c1b75b816125ab4ba731dba1 ) + name "Mary-Kate and Ashley - Winners Circle (USA, Europe)" + description "Mary-Kate and Ashley - Winners Circle (USA, Europe)" + rom ( name "Mary-Kate and Ashley - Winners Circle (USA, Europe).gbc" size 1048576 crc 35d6ddcc sha1 b12133af5ea63d05c2625cc46d1ffa55d19054fc flags verified ) ) game ( - name "Guruguru Town Hanamaru-kun (Japan)" - description "Guruguru Town Hanamaru-kun (Japan)" - rom ( name "Guruguru Town Hanamaru-kun (Japan).gbc" size 1048576 crc 03fbfc9e sha1 d147400bb9831b30a4e75f3570a1844f674e866c ) + name "Mask of Zorro, The (Europe)" + description "Mask of Zorro, The (Europe)" + rom ( name "Mask of Zorro, The (Europe).gbc" size 1048576 crc 909c870f sha1 20fd1b3ed55a21fd6bf62a29ef8b57ddf1c0c73e ) ) game ( - name "Gute Zeiten Schlechte Zeiten Quiz (Germany) (GB Compatible)" - description "Gute Zeiten Schlechte Zeiten Quiz (Germany) (GB Compatible)" - rom ( name "Gute Zeiten Schlechte Zeiten Quiz (Germany) (GB Compatible).gbc" size 1048576 crc 5f13a2d4 sha1 611d8ab71bdeb6b0fd292118676e85e940d11bd4 ) + name "Mask of Zorro, The (USA)" + description "Mask of Zorro, The (USA)" + rom ( name "Mask of Zorro, The (USA).gbc" size 1048576 crc 2c92ad12 sha1 134c03f90b21facf8720783c5dcefb182e3839ec ) ) game ( - name "Guzzler (World) (Aftermarket) (Unl)" - description "Guzzler (World) (Aftermarket) (Unl)" - rom ( name "Guzzler (World) (Aftermarket) (Unl).gbc" size 524288 crc 3684abd0 sha1 e36cd02fe2b697901843c4cbf6d83da8a9b7b923 ) + name "Mat Hoffman's Pro BMX (USA, Europe)" + description "Mat Hoffman's Pro BMX (USA, Europe)" + rom ( name "Mat Hoffman's Pro BMX (USA, Europe).gbc" size 1048576 crc 515c1459 sha1 15f58d2647fd772c8d08e6c0a23911f1f486aee2 flags verified ) ) game ( - name "Gyouten Ningen Batseelor - Doctor Guy no Yabou (Japan)" - description "Gyouten Ningen Batseelor - Doctor Guy no Yabou (Japan)" - rom ( name "Gyouten Ningen Batseelor - Doctor Guy no Yabou (Japan).gbc" size 4194304 crc b17dc263 sha1 b72e885baeeb27cb32de5b5dcedb632537898c33 flags verified ) + name "Matchbox Emergency Patrol (USA, Europe)" + description "Matchbox Emergency Patrol (USA, Europe)" + rom ( name "Matchbox Emergency Patrol (USA, Europe).gbc" size 2097152 crc a3f23d7e sha1 8697a1a2d3575527c06114b422bd855384cf8905 flags verified ) ) game ( - name "Haizhan Qibing (Taiwan) (Unl)" - description "Haizhan Qibing (Taiwan) (Unl)" - rom ( name "Haizhan Qibing (Taiwan) (Unl).gbc" size 2097152 crc a962ad73 sha1 36f6454e3e70bb29f27782f2ec4200d5aef5ca98 ) + name "Matel Gear II (Taiwan) (En) (Unl)" + description "Matel Gear II (Taiwan) (En) (Unl)" + rom ( name "Matel Gear II (Taiwan) (En) (Unl).gbc" size 2097152 crc 55494332 sha1 64da797bb0b6fe97b1956443f7bed4555436af46 ) ) game ( - name "Hajimari no Mori (Japan) (Proto)" - description "Hajimari no Mori (Japan) (Proto)" - rom ( name "Hajimari no Mori (Japan) (Proto).gbc" size 2097152 crc fecc8ee8 sha1 75a3e1794fd6bd6d35f0a357a82612c016dfba24 ) + name "Maus, Die (Europe) (En,Fr,De,Es) (Beta)" + description "Maus, Die (Europe) (En,Fr,De,Es) (Beta)" + rom ( name "Maus, Die (Europe) (En,Fr,De,Es) (Beta).gbc" size 1048576 crc d6e8f27e sha1 5c60b47701329e0d3ed9a1a4c929255f0fe360d9 ) ) game ( - name "Hali Xiaozi Dier Bu - Mishi de Mi (Taiwan) (Unl)" - description "Hali Xiaozi Dier Bu - Mishi de Mi (Taiwan) (Unl)" - rom ( name "Hali Xiaozi Dier Bu - Mishi de Mi (Taiwan) (Unl).gbc" size 2097152 crc 859457c8 sha1 3844b61eb455507d634ee7048dc8c9e64216fffe ) + name "Maus, Die (Europe) (En,Fr,De,Es)" + description "Maus, Die (Europe) (En,Fr,De,Es)" + rom ( name "Maus, Die (Europe) (En,Fr,De,Es).gbc" size 1048576 crc e7bd4a49 sha1 23b612ab97b9d5e0454f9ae91b7bdbd50df91131 ) ) game ( - name "Halloween Racer (Europe) (En,Fr,De,Es,It,Pt)" - description "Halloween Racer (Europe) (En,Fr,De,Es,It,Pt)" - rom ( name "Halloween Racer (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc 70f3b431 sha1 15bf27a7847817fbbb9cb7729b8046a6d70164c5 ) + name "Maus, Die - Verrueckte Olympiade (Germany)" + description "Maus, Die - Verrueckte Olympiade (Germany)" + rom ( name "Maus, Die - Verrueckte Olympiade (Germany).gbc" size 1048576 crc fd11138e sha1 861f53ec6d5981b5f5237777fd776299d90f4cc0 ) ) game ( - name "Halo - Combat Devolved (World) (GB Compatible) (Aftermarket) (Unl)" - description "Halo - Combat Devolved (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Halo - Combat Devolved (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c7297c31 sha1 c38cc0e80a2e04693e3a86574c03f23f3e472c88 flags verified ) + name "Maus, Die - Verrueckte Olympiade (Germany) (Beta)" + description "Maus, Die - Verrueckte Olympiade (Germany) (Beta)" + rom ( name "Maus, Die - Verrueckte Olympiade (Germany) (Beta).gbc" size 2097152 crc 39671abc sha1 ee110f4db4e2776198894baba00941e75696bc29 ) ) game ( - name "Hamster Club (Japan) (GB Compatible)" - description "Hamster Club (Japan) (GB Compatible)" - rom ( name "Hamster Club (Japan) (GB Compatible).gbc" size 2097152 crc 8a4d86a0 sha1 6ab81c4dec3263502a1781b600218285836c5302 ) + name "Max Steel - Covert Missions (USA) (En,Fr,De,Es) (Proto)" + description "Max Steel - Covert Missions (USA) (En,Fr,De,Es) (Proto)" + rom ( name "Max Steel - Covert Missions (USA) (En,Fr,De,Es) (Proto).gbc" size 1048576 crc 57b1e978 sha1 050a3f041328016c433d923b213674014546db6e ) ) game ( - name "Hamster Club - Awasete Chuu (Japan)" - description "Hamster Club - Awasete Chuu (Japan)" - rom ( name "Hamster Club - Awasete Chuu (Japan).gbc" size 1048576 crc d56d68ff sha1 ad4148b716f8a379578e6d862b06d435396faccc ) + name "Maya the Bee - Garden Adventures (Europe) (En,Fr,De,Es)" + description "Maya the Bee - Garden Adventures (Europe) (En,Fr,De,Es)" + rom ( name "Maya the Bee - Garden Adventures (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 142b6efb sha1 e46ea15b4c780a49e29e86516cb1ec5a03bdddce ) ) game ( - name "Hamster Club - Oshiema Chuu (Japan)" - description "Hamster Club - Oshiema Chuu (Japan)" - rom ( name "Hamster Club - Oshiema Chuu (Japan).gbc" size 2097152 crc 79ceef4e sha1 e2739f49ce29d1f7fe1cb94808230e7c2ad781e3 ) + name "Maya the Bee & Her Friends (Europe) (En,Fr,De) (GB Compatible)" + description "Maya the Bee & Her Friends (Europe) (En,Fr,De) (GB Compatible)" + rom ( name "Maya the Bee & Her Friends (Europe) (En,Fr,De) (GB Compatible).gbc" size 1048576 crc 983b1d26 sha1 522d7f33fd39bd00f48208743fb2246ef0bd3ff1 ) ) game ( - name "Hamster Club 2 (Japan) (GB Compatible)" - description "Hamster Club 2 (Japan) (GB Compatible)" - rom ( name "Hamster Club 2 (Japan) (GB Compatible).gbc" size 4194304 crc 2fb398f9 sha1 dcef750a73d813841cfcb871b5bb5f021a7b7285 ) + name "McDonald's Monogatari - Honobono Tenchou Ikusei Game (Japan)" + description "McDonald's Monogatari - Honobono Tenchou Ikusei Game (Japan)" + rom ( name "McDonald's Monogatari - Honobono Tenchou Ikusei Game (Japan).gbc" size 2097152 crc 66328695 sha1 5198a1c3a2bb2cfd6d5986a71e322cb6f43609bb ) ) game ( - name "Hamster Monogatari GB + Magi Ham no Mahou Shoujo (Japan)" - description "Hamster Monogatari GB + Magi Ham no Mahou Shoujo (Japan)" - rom ( name "Hamster Monogatari GB + Magi Ham no Mahou Shoujo (Japan).gbc" size 4194304 crc abd59939 sha1 b3300b1df2cd6a42f112624d5eb2803d45eb3054 ) + name "Medarot 2 - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible)" + description "Medarot 2 - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Medarot 2 - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc bf6bd446 sha1 01adf621d6e2cbfec46306d69882fc2eb3d92de5 ) ) game ( - name "Hamster Paradise (Japan) (SGB Enhanced) (GB Compatible)" - description "Hamster Paradise (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Hamster Paradise (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f520cb19 sha1 87ebc7e0cfb0803e6e14da7eec1b2fad51c83ba0 ) + name "Medarot 2 - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible)" + description "Medarot 2 - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Medarot 2 - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 5b8ffd37 sha1 48fc8c6e84c63ee47f5a2c5e99dc1666d6e9f496 flags verified ) ) game ( - name "Hamster Paradise 2 (Japan)" - description "Hamster Paradise 2 (Japan)" - rom ( name "Hamster Paradise 2 (Japan).gbc" size 2097152 crc 542c78b6 sha1 cf19fd582d8881779e7e34e1d6cd8fd5b7129f53 flags verified ) + name "Medarot 2 - Parts Collection (Japan) (SGB Enhanced) (GB Compatible)" + description "Medarot 2 - Parts Collection (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Medarot 2 - Parts Collection (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 159673db sha1 62e6e2800025918a0df9ceb31418dcbfe9e64289 ) ) game ( - name "Hamster Paradise 2 (Japan) (Rev 1)" - description "Hamster Paradise 2 (Japan) (Rev 1)" - rom ( name "Hamster Paradise 2 (Japan) (Rev 1).gbc" size 2097152 crc b9e1f3b0 sha1 140100d96d165ee399f5cd18f5aec962fde714b6 flags verified ) + name "Medarot 3 - Kabuto Version (Japan)" + description "Medarot 3 - Kabuto Version (Japan)" + rom ( name "Medarot 3 - Kabuto Version (Japan).gbc" size 4194304 crc e655632c sha1 5478069c840b5b13e2413771f35fdc844d1974f1 ) ) game ( - name "Hamster Paradise 3 (Japan)" - description "Hamster Paradise 3 (Japan)" - rom ( name "Hamster Paradise 3 (Japan).gbc" size 4194304 crc 14cac67c sha1 9d8e482afad5b8786bf289640fc275b7787fbea3 ) + name "Medarot 3 - Kuwagata Version (Japan)" + description "Medarot 3 - Kuwagata Version (Japan)" + rom ( name "Medarot 3 - Kuwagata Version (Japan).gbc" size 4194304 crc bc617834 sha1 5207698702d206046dd105b07e0c0bbdbc6ed39c ) ) game ( - name "Hamster Paradise 4 (Japan)" - description "Hamster Paradise 4 (Japan)" - rom ( name "Hamster Paradise 4 (Japan).gbc" size 4194304 crc c460dc88 sha1 177cb46c44346eabbeb06f5d7929c77afc798db9 flags verified ) + name "Medarot 3 - Parts Collection - Z kara no Chousenjou (Japan)" + description "Medarot 3 - Parts Collection - Z kara no Chousenjou (Japan)" + rom ( name "Medarot 3 - Parts Collection - Z kara no Chousenjou (Japan).gbc" size 2097152 crc ee2d977f sha1 3f13ced98ee7edf3504559c111825c6f0997f3d9 ) ) game ( - name "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It)" - description "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It)" - rom ( name "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 45be9d9b sha1 047d9dedb77a448d31cd5dce23f4c3dd8714dafe ) + name "Medarot 4 - Kabuto Version (Japan)" + description "Medarot 4 - Kabuto Version (Japan)" + rom ( name "Medarot 4 - Kabuto Version (Japan).gbc" size 4194304 crc c192a368 sha1 a62a00ee6095b3dcdf347fbb7c536b51976a109f ) ) game ( - name "Hamtaro - Ham-Hams Unite! (USA)" - description "Hamtaro - Ham-Hams Unite! (USA)" - rom ( name "Hamtaro - Ham-Hams Unite! (USA).gbc" size 2097152 crc 1271117f sha1 9770bf59e932b41882839ce9eec033f576094fee flags verified ) + name "Medarot 4 - Kuwagata Version (Japan)" + description "Medarot 4 - Kuwagata Version (Japan)" + rom ( name "Medarot 4 - Kuwagata Version (Japan).gbc" size 4194304 crc 6a29b9d8 sha1 10b3e69d19897fd233915e3949d02be71af0e521 ) ) game ( - name "Hamtaro - Ham-Hams Unite! (USA) (2002-08-07) (Beta)" - description "Hamtaro - Ham-Hams Unite! (USA) (2002-08-07) (Beta)" - rom ( name "Hamtaro - Ham-Hams Unite! (USA) (2002-08-07) (Beta).gbc" size 2097152 crc d0cf0d86 sha1 c85ba2da0a652544f938439c8826c5c6754f5e75 ) + name "Medarot 5 - Susutake Mura no Tenkousei - Kabuto (Japan)" + description "Medarot 5 - Susutake Mura no Tenkousei - Kabuto (Japan)" + rom ( name "Medarot 5 - Susutake Mura no Tenkousei - Kabuto (Japan).gbc" size 4194304 crc a3c1756e sha1 7f52ecb2a057d99b0448d82e3b5263eb92c2396c ) ) game ( - name "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It) (2002-11-11) (Beta)" - description "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It) (2002-11-11) (Beta)" - rom ( name "Hamtaro - Ham-Hams Unite! (Europe) (En,Fr,De,Es,It) (2002-11-11) (Beta).gbc" size 4194304 crc 816b0325 sha1 17c3ff0da5b9733a768ee53eccd13059fda16116 ) + name "Medarot 5 - Susutake Mura no Tenkousei - Kuwagata (Japan)" + description "Medarot 5 - Susutake Mura no Tenkousei - Kuwagata (Japan)" + rom ( name "Medarot 5 - Susutake Mura no Tenkousei - Kuwagata (Japan).gbc" size 4194304 crc 014083a8 sha1 3fcc292449da992f04c61d9117f3d5cc1bef446f ) ) game ( - name "Hamunaptra - Ushinawareta Sabaku no Miyako (Japan)" - description "Hamunaptra - Ushinawareta Sabaku no Miyako (Japan)" - rom ( name "Hamunaptra - Ushinawareta Sabaku no Miyako (Japan).gbc" size 1048576 crc ff454711 sha1 79c38bc527c9da2c27d1d9dc85924360d7cd66d3 ) + name "Medarot Cardrobottle - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible)" + description "Medarot Cardrobottle - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Medarot Cardrobottle - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4f03d80a sha1 b7a02cee93169f73675b562d09d10175684ec77f flags verified ) ) game ( - name "Hana Yori Dango - Another Love Story (Japan)" - description "Hana Yori Dango - Another Love Story (Japan)" - rom ( name "Hana Yori Dango - Another Love Story (Japan).gbc" size 2097152 crc 469f0284 sha1 9a403476fa3325d5d48ad0686727b9c715ebaef9 ) + name "Medarot Cardrobottle - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible)" + description "Medarot Cardrobottle - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Medarot Cardrobottle - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc a3735f81 sha1 26b5516170ea0fa1669cafb9484e1aeb5d2cae6c ) ) game ( - name "Hanasaka Tenshi Tenten-kun no Beat Breaker (Japan) (SGB Enhanced) (GB Compatible)" - description "Hanasaka Tenshi Tenten-kun no Beat Breaker (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Hanasaka Tenshi Tenten-kun no Beat Breaker (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6e988c07 sha1 791ea554de774de622bb4fb6bc2bf42955a201b3 ) + name "Mega Man Xtreme (USA, Europe) (GB Compatible)" + description "Mega Man Xtreme (USA, Europe) (GB Compatible)" + rom ( name "Mega Man Xtreme (USA, Europe) (GB Compatible).gbc" size 1048576 crc 3a4d94d5 sha1 c877449ba0889fdcacf23c49b0611d0ca57283c5 flags verified ) ) game ( - name "Hands of Time (USA, Europe) (En,Fr,De,Es,It,Nl)" - description "Hands of Time (USA, Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Hands of Time (USA, Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc f519f4c3 sha1 ae07e529f1c98432f37fa674ee4de6305807a92b ) + name "Mega Man Xtreme 2 (USA, Europe)" + description "Mega Man Xtreme 2 (USA, Europe)" + rom ( name "Mega Man Xtreme 2 (USA, Europe).gbc" size 1048576 crc 8fedb6d8 sha1 cb1811ac8969f6b683df954b57138dd28ebb40ff flags verified ) ) game ( - name "Hang Time Basketball (Europe) (Unl)" - description "Hang Time Basketball (Europe) (Unl)" - rom ( name "Hang Time Basketball (Europe) (Unl).gbc" size 262144 crc 3207b7d9 sha1 340201c045c020be6de3504fdecbce1ff07a2139 ) + name "Mega Memory Card (USA) (GB Compatible) (Unl)" + description "Mega Memory Card (USA) (GB Compatible) (Unl)" + rom ( name "Mega Memory Card (USA) (GB Compatible) (Unl).gbc" size 32768 crc 69e35940 sha1 06803c6342b6b5aa2d4b85ef096e11241bf5c90d ) ) game ( - name "Harbour Attack (World) (Aftermarket) (Unl)" - description "Harbour Attack (World) (Aftermarket) (Unl)" - rom ( name "Harbour Attack (World) (Aftermarket) (Unl).gbc" size 262144 crc 7455782e sha1 1d0b3779007ba8f34e11b189552955dbf5c75a28 ) + name "Megaman X4 (Taiwan) (En) (Rumble Version) (Unl)" + description "Megaman X4 (Taiwan) (En) (Rumble Version) (Unl)" + rom ( name "Megaman X4 (Taiwan) (En) (Rumble Version) (Unl).gbc" size 524288 crc 043a17b3 sha1 64a2ca35c2fa8a8db8604f167652b1ae2148ac0b ) ) game ( - name "Harley-Davidson Motor Cycles - Race Across America (USA)" - description "Harley-Davidson Motor Cycles - Race Across America (USA)" - rom ( name "Harley-Davidson Motor Cycles - Race Across America (USA).gbc" size 1048576 crc 644bac84 sha1 3777b4f69d6af13b3fd94caadad4661d5904399e ) + name "Megami Tensei Gaiden - Last Bible (Japan) (SGB Enhanced) (GB Compatible)" + description "Megami Tensei Gaiden - Last Bible (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Megami Tensei Gaiden - Last Bible (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc bd9ba639 sha1 419c5afdbc9b59e05e7861de8cc59ee367cd29f0 ) ) game ( - name "Harry Potter (Taiwan) (Unl)" - description "Harry Potter (Taiwan) (Unl)" - rom ( name "Harry Potter (Taiwan) (Unl).gbc" size 1048576 crc 5bebe333 sha1 dfd0693315da697240b510776695162880a75a82 ) + name "Megami Tensei Gaiden - Last Bible II (Japan) (SGB Enhanced) (GB Compatible)" + description "Megami Tensei Gaiden - Last Bible II (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Megami Tensei Gaiden - Last Bible II (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 9caa00b5 sha1 84df9508bdd8b24dfb19a74744fec492fffee56d ) ) game ( - name "Harry Potter 2 - The Black Art Wrestle Edition (USA) (Unl)" - description "Harry Potter 2 - The Black Art Wrestle Edition (USA) (Unl)" - rom ( name "Harry Potter 2 - The Black Art Wrestle Edition (USA) (Unl).gbc" size 1048576 crc 772337f4 sha1 d173a8faf3f4045d6cde08b59c2ff1d04eb4f2f1 ) + name "Meitantei Conan - Karakuri Jiin Satsujin Jiken (Japan) (SGB Enhanced) (GB Compatible)" + description "Meitantei Conan - Karakuri Jiin Satsujin Jiken (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Meitantei Conan - Karakuri Jiin Satsujin Jiken (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 3b5f24fc sha1 a418ff2f97536e105b4f0a1bd4bb3fa31f911a7d flags verified ) ) game ( - name "Harry Potter 3 (USA) (Unl)" - description "Harry Potter 3 (USA) (Unl)" - rom ( name "Harry Potter 3 (USA) (Unl).gbc" size 1048576 crc d0fece32 sha1 6820d9e05e60a380c52aa8a19a8397ec929a5b49 ) + name "Meitantei Conan - Kigantou Hihou Densetsu (Japan) (SGB Enhanced) (GB Compatible)" + description "Meitantei Conan - Kigantou Hihou Densetsu (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Meitantei Conan - Kigantou Hihou Densetsu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e620fae2 sha1 cd3f8015e5b708f1eb14c374042a1701eeaafc4f flags verified ) ) game ( - name "Harry Potter 3 - Shen Qi Zhi Guang Lun (Taiwan) (Unl)" - description "Harry Potter 3 - Shen Qi Zhi Guang Lun (Taiwan) (Unl)" - rom ( name "Harry Potter 3 - Shen Qi Zhi Guang Lun (Taiwan) (Unl).gbc" size 524288 crc aa83a110 sha1 7e572f24a302902cd78b238be5732d838bada7b2 ) + name "Meitantei Conan - Norowareta Kouro (Japan) (SGB Enhanced) (GB Compatible)" + description "Meitantei Conan - Norowareta Kouro (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Meitantei Conan - Norowareta Kouro (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc cabdd802 sha1 0858a619d716b0191713734d506d9f113f0d1c62 ) ) game ( - name "Harry Potter and the Chamber of Secrets (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,Da)" - description "Harry Potter and the Chamber of Secrets (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,Da)" - rom ( name "Harry Potter and the Chamber of Secrets (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,Da).gbc" size 4194304 crc 136e9d0c sha1 e3b9b22e3e528efc41e5b57fc9b3dcfa75dcd443 flags verified ) + name "Men in Black - The Series (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Men in Black - The Series (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Men in Black - The Series (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 65b8b343 sha1 7ceb1c82bdd185546c3dd5d2653788d74d811f7a flags verified ) ) game ( - name "Harry Potter and the Sorcerer's Stone (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" - description "Harry Potter and the Sorcerer's Stone (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" - rom ( name "Harry Potter and the Sorcerer's Stone (USA, Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi).gbc" size 4194304 crc 4fd8b7c5 sha1 4e6f676ec15e0e6238cb81853b5a74bbb20657a1 flags verified ) + name "Men in Black 2 - The Series (Europe) (En,Fr,De)" + description "Men in Black 2 - The Series (Europe) (En,Fr,De)" + rom ( name "Men in Black 2 - The Series (Europe) (En,Fr,De).gbc" size 1048576 crc ca675933 sha1 f1527fd7f82329ef676a6d475596e7d91c4065cc ) ) game ( - name "Harry Potter II (USA) (Unl)" - description "Harry Potter II (USA) (Unl)" - rom ( name "Harry Potter II (USA) (Unl).gbc" size 1048576 crc 2ff706c0 sha1 e3f21a748d517527218409e35418b23ced8717da ) + name "Men in Black 2 - The Series (USA) (En,Fr,De)" + description "Men in Black 2 - The Series (USA) (En,Fr,De)" + rom ( name "Men in Black 2 - The Series (USA) (En,Fr,De).gbc" size 1048576 crc 8b63f36f sha1 ccfb89824e81d128a26a38f3e2c49aae1e9752ed ) ) game ( - name "Harry Potter to Kenja no Ishi (Japan)" - description "Harry Potter to Kenja no Ishi (Japan)" - rom ( name "Harry Potter to Kenja no Ishi (Japan).gbc" size 4194304 crc 2da2686a sha1 a4fb5a1f3cdebd989617a1964ada8df4ab491e36 ) + name "Menghuan Moni Zhan II (Taiwan) (Zh) (Unl)" + description "Menghuan Moni Zhan II (Taiwan) (Zh) (Unl)" + rom ( name "Menghuan Moni Zhan II (Taiwan) (Zh) (Unl).gbc" size 2097152 crc 366067e8 sha1 745e43cba91ed6f2af0bdedf136f4247d690aa1a ) ) game ( - name "Harvest Moon 2 GBC (Europe) (SGB Enhanced) (GB Compatible)" - description "Harvest Moon 2 GBC (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Harvest Moon 2 GBC (Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 160ca990 sha1 4dc14fb6a6057b7fabbcf29bd21f331170f84420 ) + name "Merlin (Europe) (En,Fr,De,Es,It,Nl)" + description "Merlin (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Merlin (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc c5290cee sha1 96ee6a40abf4bcbb90f3ea7c232fb3866333a202 ) ) game ( - name "Harvest Moon 2 GBC (Germany) (SGB Enhanced) (GB Compatible)" - description "Harvest Moon 2 GBC (Germany) (SGB Enhanced) (GB Compatible)" - rom ( name "Harvest Moon 2 GBC (Germany) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 32a04c29 sha1 697179ecbfb138f1ceff5dd3ff414de06e12ad80 ) + name "MetaFight EX (Japan)" + description "MetaFight EX (Japan)" + rom ( name "MetaFight EX (Japan).gbc" size 1048576 crc 00733c77 sha1 95057addec90061cfab3e5c5c56d4f87ffc9d00e ) ) game ( - name "Harvest Moon 2 GBC (USA) (SGB Enhanced) (GB Compatible)" - description "Harvest Moon 2 GBC (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Harvest Moon 2 GBC (USA) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 08906220 sha1 da745aa63684f53fb3ee6c19463ed4c132441ccb ) + name "Metal Gear - Ghost Babel (Japan)" + description "Metal Gear - Ghost Babel (Japan)" + rom ( name "Metal Gear - Ghost Babel (Japan).gbc" size 2097152 crc 7831f84d sha1 ca9c35b578171f7ac4957ebb838195e806b5c1e8 ) ) game ( - name "Harvest Moon 3 GBC (USA)" - description "Harvest Moon 3 GBC (USA)" - rom ( name "Harvest Moon 3 GBC (USA).gbc" size 2097152 crc a0d67417 sha1 5313c62c51b9b5417f764fe67b687f403f9765bb ) + name "Metal Gear Solid (Europe) (En,Fr,De,Es,It)" + description "Metal Gear Solid (Europe) (En,Fr,De,Es,It)" + rom ( name "Metal Gear Solid (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 16796957 sha1 488bff9c4cee9e692a05b3938fd7b2014e743eac flags verified ) ) game ( - name "Harvest Moon GB (Europe) (SGB Enhanced) (GB Compatible)" - description "Harvest Moon GB (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Harvest Moon GB (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c8a6f68a sha1 ea464cb16446855ed60cf714ca5b3ded02d82b1e ) + name "Metal Gear Solid (USA)" + description "Metal Gear Solid (USA)" + rom ( name "Metal Gear Solid (USA).gbc" size 2097152 crc 04b0c5d6 sha1 2266499cfa10351b23fefd2216308867d1f1558b ) ) game ( - name "Harvest Moon GB (Germany) (SGB Enhanced) (GB Compatible)" - description "Harvest Moon GB (Germany) (SGB Enhanced) (GB Compatible)" - rom ( name "Harvest Moon GB (Germany) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d3896652 sha1 22e06880afe664051498714b3edb2e18f26f7961 ) + name "Metal Walker (USA) (GB Compatible)" + description "Metal Walker (USA) (GB Compatible)" + rom ( name "Metal Walker (USA) (GB Compatible).gbc" size 1048576 crc 3be68391 sha1 1ccb07d705ef68e078440118c178b87646e9b724 ) ) game ( - name "Harvest Moon GBC (USA) (SGB Enhanced) (GB Compatible)" - description "Harvest Moon GBC (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Harvest Moon GBC (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ab5738a1 sha1 d407b9c20c5381f46ec460858539a5b6f559e04f ) + name "Metamode (Japan)" + description "Metamode (Japan)" + rom ( name "Metamode (Japan).gbc" size 2097152 crc a76eed5b sha1 1c1d74c810b90cf4d2ee32859eaea569a5b45c3f ) ) game ( - name "Haunted (World) (GB Compatible) (Aftermarket) (Unl)" - description "Haunted (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Haunted (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 4b3670bd sha1 f245b8e21716a400769488b852f15d276f3549a6 ) + name "Mia Hamm Soccer Shootout (USA)" + description "Mia Hamm Soccer Shootout (USA)" + rom ( name "Mia Hamm Soccer Shootout (USA).gbc" size 1048576 crc d77971c0 sha1 82e7c25bdee895a6dfdc01ad3e94138bf7b98e59 ) ) game ( - name "Hauntsfield (World) (GB Compatible) (Aftermarket) (Unl)" - description "Hauntsfield (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Hauntsfield (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 287afc75 sha1 42ccc76883c041bc5c6c25a2e61ccc939c14811f ) + name "Mickey's Racing Adventure (USA, Europe) (En,Fr,De,Es,It)" + description "Mickey's Racing Adventure (USA, Europe) (En,Fr,De,Es,It)" + rom ( name "Mickey's Racing Adventure (USA, Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc d5e845f4 sha1 e93e8cde531dbca8a5cc40a8a4e3936f13541f01 flags verified ) ) game ( - name "Hauntsfield (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" - description "Hauntsfield (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Hauntsfield (World) (v2.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 6e484d6a sha1 7282ef5cc2354345c8832b4dde66a559de74f73f ) + name "Mickey's Speedway USA (USA, Europe) (En,Fr,De,Es)" + description "Mickey's Speedway USA (USA, Europe) (En,Fr,De,Es)" + rom ( name "Mickey's Speedway USA (USA, Europe) (En,Fr,De,Es).gbc" size 4194304 crc 11763934 sha1 edd7f3fecfef81bcd5445b6b5df89ca2be897d2f flags verified ) ) game ( - name "Heebie Jeebies (World) (Aftermarket) (Unl)" - description "Heebie Jeebies (World) (Aftermarket) (Unl)" - rom ( name "Heebie Jeebies (World) (Aftermarket) (Unl).gbc" size 262144 crc 73762d53 sha1 d427f18cb854e1387d93c19b88cb7193975e6472 ) + name "Micro Machines 1 and 2 - Twin Turbo (USA, Europe)" + description "Micro Machines 1 and 2 - Twin Turbo (USA, Europe)" + rom ( name "Micro Machines 1 and 2 - Twin Turbo (USA, Europe).gbc" size 2097152 crc 5dd337eb sha1 18b5c14ee3b3f3c16b9d641c3b3824b15c0a0c78 ) ) game ( - name "Hejin Zhuangbei II (Taiwan) (Unl)" - description "Hejin Zhuangbei II (Taiwan) (Unl)" - rom ( name "Hejin Zhuangbei II (Taiwan) (Unl).gbc" size 2097152 crc ef4bbb34 sha1 6a15fc7dbb3b9d7c130b9a25b568d39c655d68ca ) + name "Micro Machines 2 - Turbo Tournament (Europe) (Proto)" + description "Micro Machines 2 - Turbo Tournament (Europe) (Proto)" + rom ( name "Micro Machines 2 - Turbo Tournament (Europe) (Proto).gbc" size 2097152 crc e932c818 sha1 cbdefc7f63bf9a6c0fc15d7ab72b4b532b0d2422 ) ) game ( - name "Hello Kitty no Beads Factory (Japan) (SGB Enhanced) (GB Compatible)" - description "Hello Kitty no Beads Factory (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Hello Kitty no Beads Factory (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 12f74cd4 sha1 539ddbe7f73b33ffb886143dd14869d486f3fecf ) + name "Micro Machines V3 (USA, Europe)" + description "Micro Machines V3 (USA, Europe)" + rom ( name "Micro Machines V3 (USA, Europe).gbc" size 2097152 crc b8064453 sha1 8e9efbe195bcecfec4b233921b22b2e7fce38d3a flags verified ) ) game ( - name "Hello Kitty no Happy House (Japan)" - description "Hello Kitty no Happy House (Japan)" - rom ( name "Hello Kitty no Happy House (Japan).gbc" size 4194304 crc 159fe5e7 sha1 b5cbabec048e1f77fee7830bdb564f21369faeef ) + name "Micro Maniacs (Europe)" + description "Micro Maniacs (Europe)" + rom ( name "Micro Maniacs (Europe).gbc" size 2097152 crc e66e093b sha1 53773090e44e0a24a4481249541d48ea1432e83d ) ) game ( - name "Hello Kitty no Magical Museum (Japan) (SGB Enhanced) (GB Compatible)" - description "Hello Kitty no Magical Museum (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Hello Kitty no Magical Museum (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f6768930 sha1 462e5120831c2298bb5138bf25b4c8c72b372407 flags verified ) + name "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (Europe) (En,Fr,De,Es,It)" + description "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (Europe) (En,Fr,De,Es,It)" + rom ( name "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc ee4cba24 sha1 0af8ea56fcbf49c49d6815d316b1cd80cd8e1538 ) ) game ( - name "Hello Kitty no Sweet Adventure - Daniel-kun ni Aitai (Japan) (SGB Enhanced) (GB Compatible)" - description "Hello Kitty no Sweet Adventure - Daniel-kun ni Aitai (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Hello Kitty no Sweet Adventure - Daniel-kun ni Aitai (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 45f4159b sha1 c290dbd29a6246eb001f35f973c0e664af2c97b1 ) + name "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (USA)" + description "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (USA)" + rom ( name "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (USA).gbc" size 1048576 crc 0777b8d7 sha1 edf2b960209d8763a330c72fcfd890b360864aeb ) ) game ( - name "Hello Kitty to Dear Daniel no Dream Adventure (Japan)" - description "Hello Kitty to Dear Daniel no Dream Adventure (Japan)" - rom ( name "Hello Kitty to Dear Daniel no Dream Adventure (Japan).gbc" size 1048576 crc 018eed29 sha1 a726c5847112289720d6587bf63778c839245c49 ) + name "Microsoft - The Best of Entertainment Pack (Europe)" + description "Microsoft - The Best of Entertainment Pack (Europe)" + rom ( name "Microsoft - The Best of Entertainment Pack (Europe).gbc" size 1048576 crc 0f02d708 sha1 be52fa14e66f4b35c66f434db61da4cfcec71762 ) ) game ( - name "Hello Kitty's Cube Frenzy (USA) (GB Compatible)" - description "Hello Kitty's Cube Frenzy (USA) (GB Compatible)" - rom ( name "Hello Kitty's Cube Frenzy (USA) (GB Compatible).gbc" size 1048576 crc 937729f6 sha1 6f15379553a0ec8a8174b85a35eaa4085dec6b43 ) + name "Microsoft - The Best of Entertainment Pack (USA)" + description "Microsoft - The Best of Entertainment Pack (USA)" + rom ( name "Microsoft - The Best of Entertainment Pack (USA).gbc" size 1048576 crc d2d88cfa sha1 38b4814afd24bf1fffa382ed3396b6413abc5616 ) ) game ( - name "Hello Kitty's Cube Frenzy (Europe) (Proto) (GB Compatible)" - description "Hello Kitty's Cube Frenzy (Europe) (Proto) (GB Compatible)" - rom ( name "Hello Kitty's Cube Frenzy (Europe) (Proto) (GB Compatible).gbc" size 1048576 crc 9606a07f sha1 2225da8a68e489c0f562afcb8e90fc9387321af0 ) + name "Microsoft Pinball Arcade (USA)" + description "Microsoft Pinball Arcade (USA)" + rom ( name "Microsoft Pinball Arcade (USA).gbc" size 1048576 crc 504f55c5 sha1 da4593edb37be892374e00d0174e45ff6301c907 ) ) game ( - name "Hercules - The Legendary Journeys (Europe) (En,Fr,De,Es,It,Nl)" - description "Hercules - The Legendary Journeys (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Hercules - The Legendary Journeys (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc c0ede71f sha1 ae521e5011b2b67de489374c3e9c5ec8ad8c0ee6 ) + name "Microsoft Pinball Arcade (Europe)" + description "Microsoft Pinball Arcade (Europe)" + rom ( name "Microsoft Pinball Arcade (Europe).gbc" size 1048576 crc 4eb7db14 sha1 f2874f0f3023d96edbdb94e5c0dc181d8baa3efb flags verified ) ) game ( - name "Hero Hero-kun (Japan)" - description "Hero Hero-kun (Japan)" - rom ( name "Hero Hero-kun (Japan).gbc" size 2097152 crc 8cabdca4 sha1 e7b0944fc2c9ffb4e7f997357327470e15798d63 ) + name "Midway Presents Arcade Hits - Joust & Defender (USA, Europe) (GB Compatible)" + description "Midway Presents Arcade Hits - Joust & Defender (USA, Europe) (GB Compatible)" + rom ( name "Midway Presents Arcade Hits - Joust & Defender (USA, Europe) (GB Compatible).gbc" size 1048576 crc 4c1ececb sha1 f0f35970517090165797568448b5ef5cad8e4952 ) ) game ( - name "Heroes of Might and Magic (USA) (En,Fr,De)" - description "Heroes of Might and Magic (USA) (En,Fr,De)" - rom ( name "Heroes of Might and Magic (USA) (En,Fr,De).gbc" size 1048576 crc bb0672a6 sha1 209d8a9cdd240a8c73d03d8575373bfa53948869 ) + name "Midway Presents Arcade Hits - Moon Patrol & Spy Hunter (USA, Europe) (GB Compatible)" + description "Midway Presents Arcade Hits - Moon Patrol & Spy Hunter (USA, Europe) (GB Compatible)" + rom ( name "Midway Presents Arcade Hits - Moon Patrol & Spy Hunter (USA, Europe) (GB Compatible).gbc" size 1048576 crc f40199c9 sha1 8dc667e7d44b46ad42ec7e465091cfacc0009974 flags verified ) ) game ( - name "Heroes of Might and Magic (Europe) (En,Fr,De)" - description "Heroes of Might and Magic (Europe) (En,Fr,De)" - rom ( name "Heroes of Might and Magic (Europe) (En,Fr,De).gbc" size 1048576 crc e0b9fd3b sha1 d6471849187edcf68e61ed98558d9326a44cf2dc ) + name "Millennium Winter Sports (USA)" + description "Millennium Winter Sports (USA)" + rom ( name "Millennium Winter Sports (USA).gbc" size 1048576 crc b57dabae sha1 f47321c3c1217467dc48240bf53b50ed9630b28a ) ) game ( - name "Heroes of Might and Magic (USA) (En,Fr,De) (Rev 1) (Proto)" - description "Heroes of Might and Magic (USA) (En,Fr,De) (Rev 1) (Proto)" - rom ( name "Heroes of Might and Magic (USA) (En,Fr,De) (Rev 1) (Proto).gbc" size 1048576 crc 0753927e sha1 2ad31a64d113909180fd85dc6707a3c487ec2bfb ) + name "Mingzhu Koudai Guaishou 2 (Taiwan) (Unl)" + description "Mingzhu Koudai Guaishou 2 (Taiwan) (Unl)" + rom ( name "Mingzhu Koudai Guaishou 2 (Taiwan) (Unl).gbc" size 2097152 crc 31f14d99 sha1 0ea3390e4479acf96d65791dd9ab08464753d48a ) ) game ( - name "Heroes of Might and Magic II (USA) (En,Fr,De)" - description "Heroes of Might and Magic II (USA) (En,Fr,De)" - rom ( name "Heroes of Might and Magic II (USA) (En,Fr,De).gbc" size 1048576 crc 53156d4d sha1 1d6ae18073c8b789c288039b0f579ebf15d1f03c ) + name "Mingzhu Koudai Guaishou 3 (Taiwan) (En,Es,Zh) (Unl)" + description "Mingzhu Koudai Guaishou 3 (Taiwan) (En,Es,Zh) (Unl)" + rom ( name "Mingzhu Koudai Guaishou 3 (Taiwan) (En,Es,Zh) (Unl).gbc" size 4194304 crc a477c7ce sha1 0e1b3e60d4a982538d4645c36693d5fd548cb641 ) ) game ( - name "Hexcite (Europe) (En,Fr,De) (Proto) (SGB Enhanced) (GB Compatible)" - description "Hexcite (Europe) (En,Fr,De) (Proto) (SGB Enhanced) (GB Compatible)" - rom ( name "Hexcite (Europe) (En,Fr,De) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 2c6bdcfa sha1 9380ad9ccc193682eb98be7d7447dabadd67beae ) + name "Minna no Shougi - Shokyuu Hen (Japan) (Rev 1) (GB Compatible)" + description "Minna no Shougi - Shokyuu Hen (Japan) (Rev 1) (GB Compatible)" + rom ( name "Minna no Shougi - Shokyuu Hen (Japan) (Rev 1) (GB Compatible).gbc" size 1048576 crc f766015a sha1 948d2015c29342fdb6052940a5d65e771b0a81d0 flags verified ) ) game ( - name "Hexcite - The Shapes of Victory (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Hexcite - The Shapes of Victory (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Hexcite - The Shapes of Victory (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 84084e5f sha1 bb00ff88af717b45e08ef421ac77e0546870b1f4 flags verified ) + name "Minna no Shougi - Shokyuu Hen (Japan) (GB Compatible)" + description "Minna no Shougi - Shokyuu Hen (Japan) (GB Compatible)" + rom ( name "Minna no Shougi - Shokyuu Hen (Japan) (GB Compatible).gbc" size 1048576 crc 5cb4fc8a sha1 777088b9a3963e55dd6f90a523a84ed58a008149 ) ) game ( - name "Hidden Gems (World) (GB Compatible) (Aftermarket) (Unl)" - description "Hidden Gems (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Hidden Gems (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 6f430dda sha1 e0cfe038063b1cd601a5f1b5af047efc705a7aaa ) + name "Minnie & Friends - Yume no Kuni o Sagashite (Japan)" + description "Minnie & Friends - Yume no Kuni o Sagashite (Japan)" + rom ( name "Minnie & Friends - Yume no Kuni o Sagashite (Japan).gbc" size 2097152 crc d47ae577 sha1 146f336d16d165590d09f41f44ba52a81816a033 flags verified ) ) game ( - name "High Noon (World) (Aftermarket) (Unl)" - description "High Noon (World) (Aftermarket) (Unl)" - rom ( name "High Noon (World) (Aftermarket) (Unl).gbc" size 262144 crc 1d00e48d sha1 21d5e871ed009a674659344d3d768fb2389c0d04 ) + name "Missile Command (Europe)" + description "Missile Command (Europe)" + rom ( name "Missile Command (Europe).gbc" size 1048576 crc 18216e26 sha1 ba4c1c10cfeb74584338d49a64f835995af734fd ) ) game ( - name "Hime's Quest (World) (Digital) (Aftermarket) (Unl)" - description "Hime's Quest (World) (Digital) (Aftermarket) (Unl)" - rom ( name "Hime's Quest (World) (Digital) (Aftermarket) (Unl).gbc" size 2097152 crc de5c21c2 sha1 7b6672c46c23aaa282bd4fded0713c6dfae2eb66 ) + name "Missile Command (USA) (Rumble Version)" + description "Missile Command (USA) (Rumble Version)" + rom ( name "Missile Command (USA) (Rumble Version).gbc" size 1048576 crc 47543c51 sha1 7bd68586df8754cbc81b2dcbb6e2b5de43f812e8 flags verified ) ) game ( - name "Hime's Quest (World) (Cart) (Aftermarket) (Unl)" - description "Hime's Quest (World) (Cart) (Aftermarket) (Unl)" - rom ( name "Hime's Quest (World) (Cart) (Aftermarket) (Unl).gbc" size 2097152 crc 546f578a sha1 ff90ca3ec7fb5d02865ae3cfd807ad3541dd21fc ) - rom ( name "Hime's Quest (World) (Cart) (Aftermarket) (Unl) (Factory Save).sav" size 32768 crc d5ed60c7 sha1 8d6c2e9da87837ba16bbd07247a91a0c3050d2fe ) + name "Mission - Impossible (Europe) (En,Fr,De,Es,It)" + description "Mission - Impossible (Europe) (En,Fr,De,Es,It)" + rom ( name "Mission - Impossible (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 0af32baa sha1 5eb8dad248ff23809016a2515657089116e8df33 flags verified ) ) game ( - name "Hiryuu no Ken - Retsuden GB (Japan)" - description "Hiryuu no Ken - Retsuden GB (Japan)" - rom ( name "Hiryuu no Ken - Retsuden GB (Japan).gbc" size 1048576 crc bdae91e8 sha1 75db7acdfa206e539c385b928da07c6b0c776308 ) + name "Mission - Impossible (USA) (En,Fr,Es)" + description "Mission - Impossible (USA) (En,Fr,Es)" + rom ( name "Mission - Impossible (USA) (En,Fr,Es).gbc" size 1048576 crc 41230d11 sha1 a987998cf57d2eb2275de94cd0e81254b711ccac ) ) game ( - name "Hissatsu Pachinko Boy - CR Monster House (Japan)" - description "Hissatsu Pachinko Boy - CR Monster House (Japan)" - rom ( name "Hissatsu Pachinko Boy - CR Monster House (Japan).gbc" size 1048576 crc 70f10315 sha1 35ee6e33b11ba8c02f1bf2dcdaf96c1e135982ab ) + name "Mission - Impossible (Europe) (En,Fr,De,Es,It) (Rev 1) (Possible Proto)" + description "Mission - Impossible (Europe) (En,Fr,De,Es,It) (Rev 1) (Possible Proto)" + rom ( name "Mission - Impossible (Europe) (En,Fr,De,Es,It) (Rev 1) (Possible Proto).gbc" size 1048576 crc 9c51f4c7 sha1 f822bda01d881f34d1e17664465faf6a3ff64356 ) ) game ( - name "Hole in One Golf (USA) (Rumble Version) (SGB Enhanced) (GB Compatible)" - description "Hole in One Golf (USA) (Rumble Version) (SGB Enhanced) (GB Compatible)" - rom ( name "Hole in One Golf (USA) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 27a53965 sha1 d0c2fb49177bc1cf145503eb48bde3bd196ea1d9 ) + name "Mission Bravo (USA) (Proto)" + description "Mission Bravo (USA) (Proto)" + rom ( name "Mission Bravo (USA) (Proto).gbc" size 1048576 crc b8fc72b6 sha1 2833855bb2b9fde988f8efcac3e357ef9f0f4f50 ) ) game ( - name "Hollywood Pinball (Europe) (En,Fr,De,It) (GB Compatible)" - description "Hollywood Pinball (Europe) (En,Fr,De,It) (GB Compatible)" - rom ( name "Hollywood Pinball (Europe) (En,Fr,De,It) (GB Compatible).gbc" size 1048576 crc 8bd1f635 sha1 2d179e034dbd19e48aee31ffdc504305444cc84a ) + name "Mizuki Shigeru no Shin Youkaiden (Japan)" + description "Mizuki Shigeru no Shin Youkaiden (Japan)" + rom ( name "Mizuki Shigeru no Shin Youkaiden (Japan).gbc" size 4194304 crc fc1f100f sha1 ab12770558fb95434bba0da0d3b8a91e2d9179fb ) ) game ( - name "Hollywood Pinball (Japan) (GB Compatible)" - description "Hollywood Pinball (Japan) (GB Compatible)" - rom ( name "Hollywood Pinball (Japan) (GB Compatible).gbc" size 1048576 crc 77d7e5b7 sha1 ff77ec892f2331e895774555183fb1cffb88ca6e ) + name "Mobile Golf (Japan)" + description "Mobile Golf (Japan)" + rom ( name "Mobile Golf (Japan).gbc" size 4194304 crc 35fc5b32 sha1 fde414fc9efef2c30d1a9e0a2ed35ad2efc0edee flags verified ) ) game ( - name "Holy Magic Century (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - description "Holy Magic Century (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - rom ( name "Holy Magic Century (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc abd8ceae sha1 01ad2928e923c415671e6306d6d73016a1ca7bb9 ) + name "Mobile Trainer (Japan)" + description "Mobile Trainer (Japan)" + rom ( name "Mobile Trainer (Japan).gbc" size 2097152 crc 7226ead0 sha1 ecc0579edeaf9eccd722d605cc288cd023c8576a flags verified ) ) game ( - name "Honkaku Hanafuda GB (Japan)" - description "Honkaku Hanafuda GB (Japan)" - rom ( name "Honkaku Hanafuda GB (Japan).gbc" size 1048576 crc 05dcbd55 sha1 24e116249e569d79a280c8f4104934b369c32d79 ) + name "Mojie 3-bu Wanme de Shijie (Taiwan) (Zh) (Unl)" + description "Mojie 3-bu Wanme de Shijie (Taiwan) (Zh) (Unl)" + rom ( name "Mojie 3-bu Wanme de Shijie (Taiwan) (Zh) (Unl).gbc" size 524288 crc d91e3f98 sha1 556913f2687a49034e1229ef1e375f6036ec5719 ) ) game ( - name "Honkaku Shougi - Shougi Ou (Japan) (SGB Enhanced) (GB Compatible)" - description "Honkaku Shougi - Shougi Ou (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Honkaku Shougi - Shougi Ou (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 3a96e868 sha1 a0e5a6b00cc31670949f7d8cdeec2486d0ec986f ) + name "Mojie Chuanshuo (Taiwan) (Unl)" + description "Mojie Chuanshuo (Taiwan) (Unl)" + rom ( name "Mojie Chuanshuo (Taiwan) (Unl).gbc" size 524288 crc 7aa7eea5 sha1 109e4ba61b04afe15cc5a5ee994f56405938cee3 ) ) game ( - name "Honkaku Taisen Shougi Ayumu (Japan) (GB Compatible)" - description "Honkaku Taisen Shougi Ayumu (Japan) (GB Compatible)" - rom ( name "Honkaku Taisen Shougi Ayumu (Japan) (GB Compatible).gbc" size 1048576 crc 89140949 sha1 5b71c264a69902d77888243df92e8c93ace6732b ) + name "Mojie Zhanshi Chuanshuo (Taiwan) (Unl)" + description "Mojie Zhanshi Chuanshuo (Taiwan) (Unl)" + rom ( name "Mojie Zhanshi Chuanshuo (Taiwan) (Unl).gbc" size 2097152 crc 620c56b8 sha1 25fd8c132601cd9f74784a010141572505a2ef66 ) ) game ( - name "Honkaku Yonin Uchi Mahjong - Mahjong Ou (Japan) (SGB Enhanced) (GB Compatible)" - description "Honkaku Yonin Uchi Mahjong - Mahjong Ou (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Honkaku Yonin Uchi Mahjong - Mahjong Ou (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 8ed4bbba sha1 222487f14aaaa8f0bb536a09238e63ac95636208 ) + name "Momotarou Densetsu 1-2 (Japan)" + description "Momotarou Densetsu 1-2 (Japan)" + rom ( name "Momotarou Densetsu 1-2 (Japan).gbc" size 2097152 crc da7fb08f sha1 acffa3417c85be574aa28432e29e1d40f28a565b flags verified ) ) game ( - name "Host, The (World) (Aftermarket) (Unl)" - description "Host, The (World) (Aftermarket) (Unl)" - rom ( name "Host, The (World) (Aftermarket) (Unl).gbc" size 524288 crc 5f783000 sha1 05cc1f1e52167c6985ebb0a3e67af1fc2fbff93c ) + name "Monkey Puncher (Europe) (SGB Enhanced) (GB Compatible)" + description "Monkey Puncher (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Monkey Puncher (Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc bc1809ce sha1 87f08f8adc8db96ce396bd21f33a804f63826bf3 ) ) game ( - name "Hot Wheels - Stunt Track Driver (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Hot Wheels - Stunt Track Driver (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Hot Wheels - Stunt Track Driver (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 72a5e820 sha1 eabf2bc053ba6a440a834d6bcd0b45a7432a9a20 ) + name "Monopoly (Japan) (SGB Enhanced) (GB Compatible)" + description "Monopoly (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Monopoly (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0503e567 sha1 3f42d9b423c15b4c1b997c7a2292ab2cba1ab23f ) ) game ( - name "Hoyle Card Games (USA)" - description "Hoyle Card Games (USA)" - rom ( name "Hoyle Card Games (USA).gbc" size 1048576 crc dd5d3713 sha1 5eb733fa50e21f124a5362287da439dc199e3773 ) + name "Monopoly (USA) (GB Compatible)" + description "Monopoly (USA) (GB Compatible)" + rom ( name "Monopoly (USA) (GB Compatible).gbc" size 1048576 crc e559a717 sha1 058c34bc2d86cc7d6a3f5263a21946661662f893 ) ) game ( - name "Hoyle Casino (USA)" - description "Hoyle Casino (USA)" - rom ( name "Hoyle Casino (USA).gbc" size 1048576 crc 413473b0 sha1 827efa6d7b56e919b95ae52c451be2a40d870822 ) + name "Monster AG, Die (Germany)" + description "Monster AG, Die (Germany)" + rom ( name "Monster AG, Die (Germany).gbc" size 1048576 crc 3a9602e8 sha1 afe20aa46ff136c0ddf6f2692b1bbde9c30e71f6 ) ) game ( - name "Hugo (World) (Aftermarket) (Unl)" - description "Hugo (World) (Aftermarket) (Unl)" - rom ( name "Hugo (World) (Aftermarket) (Unl).gbc" size 524288 crc 6581c78a sha1 390d2665f34ceaa5e34cc9f8f7c26d9e7583a92b ) + name "Monster Farm Battle Card GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Monster Farm Battle Card GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Monster Farm Battle Card GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 69b88f1e sha1 7e036e175c9e865572ab613ae0f8e6d3642ffb0e flags verified ) ) game ( - name "Hugo - Black Diamond Fever (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" - description "Hugo - Black Diamond Fever (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" - rom ( name "Hugo - Black Diamond Fever (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi).gbc" size 1048576 crc 685cafcc sha1 bb2721dd0866b9b7f41e590287569fc09339cc6a ) + name "Monster Go! Go! Go!! (Taiwan) (En) (Unl)" + description "Monster Go! Go! Go!! (Taiwan) (En) (Unl)" + rom ( name "Monster Go! Go! Go!! (Taiwan) (En) (Unl).gbc" size 524288 crc dd13f234 sha1 8e687d6b2439db522b238361bc2d7458296c9b62 ) ) game ( - name "Hugo - The Evil Mirror (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" - description "Hugo - The Evil Mirror (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi)" - rom ( name "Hugo - The Evil Mirror (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da,Fi).gbc" size 1048576 crc 24b76cd0 sha1 e5f29c654687221c5e4d4bdbc456fd08f32946a6 ) + name "Monster Race 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Monster Race 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Monster Race 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b985f0d8 sha1 8d4a6b4cdaa37b9daaff5a05ac5926a407bacce3 ) ) game ( - name "Hugo 2 1-2 (Germany) (GB Compatible)" - description "Hugo 2 1-2 (Germany) (GB Compatible)" - rom ( name "Hugo 2 1-2 (Germany) (GB Compatible).gbc" size 1048576 crc fab64b18 sha1 5d89a8b4de6e6b2ba5be3434f0a1eee03077eeda flags verified ) + name "Monster Rancher Battle Card GB (USA) (SGB Enhanced) (GB Compatible)" + description "Monster Rancher Battle Card GB (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Monster Rancher Battle Card GB (USA) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 50ddf120 sha1 f94dc1dbdf25d9ab7f7abd3d7878209d404b206d ) ) game ( - name "Hunter x Hunter - Hunter no Keifu (Japan)" - description "Hunter x Hunter - Hunter no Keifu (Japan)" - rom ( name "Hunter x Hunter - Hunter no Keifu (Japan).gbc" size 4194304 crc a1361642 sha1 cf31b713b6039ba18675fa5d4caa83934ae1f216 ) + name "Monster Rancher Explorer (USA)" + description "Monster Rancher Explorer (USA)" + rom ( name "Monster Rancher Explorer (USA).gbc" size 1048576 crc 6c35e8f0 sha1 649fec320d3bafd7a03670ee435a419d2a86c12b ) ) game ( - name "Hunter x Hunter - Kindan no Hihou (Japan)" - description "Hunter x Hunter - Kindan no Hihou (Japan)" - rom ( name "Hunter x Hunter - Kindan no Hihou (Japan).gbc" size 1048576 crc d23c6a75 sha1 ef131fb2752b8ff996bf1aaaebd22887e380aa31 ) + name "Monster Traveler (Japan) (Rev 1)" + description "Monster Traveler (Japan) (Rev 1)" + rom ( name "Monster Traveler (Japan) (Rev 1).gbc" size 4194304 crc f60a376e sha1 23842b7ad88a051b14c1676b1f561b933177f150 flags verified ) ) game ( - name "Hype - The Time Quest (Europe) (En,Fr,De,Es,It,Nl,Sv,Da)" - description "Hype - The Time Quest (Europe) (En,Fr,De,Es,It,Nl,Sv,Da)" - rom ( name "Hype - The Time Quest (Europe) (En,Fr,De,Es,It,Nl,Sv,Da).gbc" size 1048576 crc 24846d65 sha1 8e26e7e2e64d4bf866b67387586fc5c4a9c56855 ) + name "Monster Traveler (Japan) (Possible Proto)" + description "Monster Traveler (Japan) (Possible Proto)" + rom ( name "Monster Traveler (Japan) (Possible Proto).gbc" size 4194304 crc 5d596cf6 sha1 5195f55ad6aaa302c0a0e11c0ec6ecad4efe0e27 ) ) game ( - name "Hype - The Time Quest (Brazil) (En)" - description "Hype - The Time Quest (Brazil) (En)" - rom ( name "Hype - The Time Quest (Brazil) (En).gbc" size 1048576 crc cafb8035 sha1 7c7dca7c48dc478d0278c273ba37723b9e9dce5b ) + name "Monsters, Inc. (Europe) (Rev 1)" + description "Monsters, Inc. (Europe) (Rev 1)" + rom ( name "Monsters, Inc. (Europe) (Rev 1).gbc" size 1048576 crc 3726858a sha1 31e64a1cdd25cdc4413e0a1bc15dc22017e881e4 ) ) game ( - name "Hyper Olympic - Winter 2000 (Japan)" - description "Hyper Olympic - Winter 2000 (Japan)" - rom ( name "Hyper Olympic - Winter 2000 (Japan).gbc" size 1048576 crc a9b8f072 sha1 b8b0ea6e8a1093e7171ffe0eff73967a6cc00bce ) + name "Monsters, Inc. (Europe) (En,Es,Nl)" + description "Monsters, Inc. (Europe) (En,Es,Nl)" + rom ( name "Monsters, Inc. (Europe) (En,Es,Nl).gbc" size 1048576 crc 63e3bbb4 sha1 8713b1d51ce33a761f64455b59cd49952b7f7cd1 ) ) game ( - name "Hyper Olympic Series - Track & Field GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Hyper Olympic Series - Track & Field GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Hyper Olympic Series - Track & Field GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 77f76ebc sha1 6dabafe260b53e61a810cbae2f14287adafffd8e ) + name "Monsters, Inc. (Europe) (En,Fr,It)" + description "Monsters, Inc. (Europe) (En,Fr,It)" + rom ( name "Monsters, Inc. (Europe) (En,Fr,It).gbc" size 1048576 crc 712d40a5 sha1 34ab1e38f34287f022c871b6ed2116ded6d4b60d ) ) game ( - name "Ice Age II (Taiwan) (En) (Unl)" - description "Ice Age II (Taiwan) (En) (Unl)" - rom ( name "Ice Age II (Taiwan) (En) (Unl).gbc" size 2097152 crc 50bc8e9d sha1 c57912e67c135c48233f351f68cdc34020de8d01 ) + name "Monsters, Inc. (USA, Europe)" + description "Monsters, Inc. (USA, Europe)" + rom ( name "Monsters, Inc. (USA, Europe).gbc" size 1048576 crc 183dbb31 sha1 58befa4dbe7dac79bfadcaf259999cdcddf4f2c8 flags verified ) ) game ( - name "Ide Yousuke no Mahjong Kyoushitsu GB (Japan)" - description "Ide Yousuke no Mahjong Kyoushitsu GB (Japan)" - rom ( name "Ide Yousuke no Mahjong Kyoushitsu GB (Japan).gbc" size 2097152 crc 61df88ca sha1 e4138f45980d60700c758babfa1473c03b24d247 ) + name "Montezuma's Return! (Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "Montezuma's Return! (Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Montezuma's Return! (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 524288 crc 659693de sha1 014b174f569984360442fb2142a0e4ae09366dc4 flags verified ) ) game ( - name "Indiana Jones and the Infernal Machine (USA, Europe) (En,Fr,De)" - description "Indiana Jones and the Infernal Machine (USA, Europe) (En,Fr,De)" - rom ( name "Indiana Jones and the Infernal Machine (USA, Europe) (En,Fr,De).gbc" size 1048576 crc 7fff1142 sha1 6d568438aa3b9b67c55aded582cec136b15c46d7 flags verified ) + name "Montezuma's Return! (USA) (En,Es) (GB Compatible)" + description "Montezuma's Return! (USA) (En,Es) (GB Compatible)" + rom ( name "Montezuma's Return! (USA) (En,Es) (GB Compatible).gbc" size 524288 crc de04772f sha1 616bb04e0254ef2ba9e1ea629493efdcc37d807c ) ) game ( - name "Infall (World) (Aftermarket) (Unl)" - description "Infall (World) (Aftermarket) (Unl)" - rom ( name "Infall (World) (Aftermarket) (Unl).gbc" size 131072 crc d9d90319 sha1 aafaf33fa43c7f0fd65cc8af03a42df25361fc74 ) + name "Moomin no Daibouken (Japan) (Beta)" + description "Moomin no Daibouken (Japan) (Beta)" + rom ( name "Moomin no Daibouken (Japan) (Beta).gbc" size 2097152 crc 3c193973 sha1 b60e7896fa4ceca42530f1de01e4691ee9590a7f ) ) game ( - name "Infinity (USA) (Proto) (2001-03-22)" - description "Infinity (USA) (Proto) (2001-03-22)" - rom ( name "Infinity (USA) (Proto) (2001-03-22).gbc" size 2097152 crc 4ade94aa sha1 fdfd6d4cbebbf64fc7d1264f0450be270be89823 ) + name "Moomin no Daibouken (Japan)" + description "Moomin no Daibouken (Japan)" + rom ( name "Moomin no Daibouken (Japan).gbc" size 2097152 crc bd29ee6f sha1 0846545cebec8b376db9bdb0d3744c7d157ee980 ) ) game ( - name "Inspector Gadget - Operation Madkactus (Europe) (Fr) (Beta)" - description "Inspector Gadget - Operation Madkactus (Europe) (Fr) (Beta)" - rom ( name "Inspector Gadget - Operation Madkactus (Europe) (Fr) (Beta).gbc" size 1048576 crc 93ec798b sha1 8444ff17aa3f865eec33cc49398b450e345376c3 ) + name "Moomin's Tale (Europe) (En,Fr,De)" + description "Moomin's Tale (Europe) (En,Fr,De)" + rom ( name "Moomin's Tale (Europe) (En,Fr,De).gbc" size 1048576 crc 45543ba2 sha1 06e57b38b7f9ec71809f309aa7d220af48ca96b6 ) ) game ( - name "Inspector Gadget - Operation Madkactus (Europe) (En,Fr,De,Es,It,Nl)" - description "Inspector Gadget - Operation Madkactus (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Inspector Gadget - Operation Madkactus (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 3390b056 sha1 55c02b81fa854938ca3cb3e5b725a6a72f711e7b ) + name "Moorhuhn 2 - Die Jagd geht weiter (Germany)" + description "Moorhuhn 2 - Die Jagd geht weiter (Germany)" + rom ( name "Moorhuhn 2 - Die Jagd geht weiter (Germany).gbc" size 1048576 crc ed52ceaf sha1 1de0fa5b1dcac8c8b188fd141e889461317dc28d flags verified ) ) game ( - name "Inspector Gadget - Operation Madkactus (USA)" - description "Inspector Gadget - Operation Madkactus (USA)" - rom ( name "Inspector Gadget - Operation Madkactus (USA).gbc" size 1048576 crc 1af0b489 sha1 b0fa81a35e605948df3b7f1fcb5893bab99d9d6a ) + name "Moorhuhn 3 - ...Es Gibt Huhn! (Europe) (En,Fr,De,Es,It)" + description "Moorhuhn 3 - ...Es Gibt Huhn! (Europe) (En,Fr,De,Es,It)" + rom ( name "Moorhuhn 3 - ...Es Gibt Huhn! (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc b7c1025b sha1 154db731f5e1cda137eb0faf55a8e4458387485f ) ) game ( - name "Inspector Waffles Early Days (World) (v1.0.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Inspector Waffles Early Days (World) (v1.0.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Inspector Waffles Early Days (World) (v1.0.1) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc fea1cdb9 sha1 ac10ca63f15ca78af9f7d0eabb85eef8733aef50 ) + name "Mortal Kombat 4 (Germany) (En) (SGB Enhanced) (GB Compatible)" + description "Mortal Kombat 4 (Germany) (En) (SGB Enhanced) (GB Compatible)" + rom ( name "Mortal Kombat 4 (Germany) (En) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 87588725 sha1 1006b279eab113afe50f84e714a93c63de8cbfcf flags verified ) ) game ( - name "International Karate 2000 (Europe)" - description "International Karate 2000 (Europe)" - rom ( name "International Karate 2000 (Europe).gbc" size 1048576 crc 12e00808 sha1 515477a2695f89827b2dc5495d9d43ec79a6cc09 ) + name "Mortal Kombat 4 (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Mortal Kombat 4 (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Mortal Kombat 4 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4eb71448 sha1 ea54fb35cd8c4d4cea234423a81f8f953b1d33e4 ) ) game ( - name "International Rally (USA) (SGB Enhanced) (GB Compatible)" - description "International Rally (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "International Rally (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b85fd752 sha1 ac09080efb22ed401ddc827045e72ab054da1763 ) + name "Moshou Shiji - Zhanshen (Taiwan) (Unl)" + description "Moshou Shiji - Zhanshen (Taiwan) (Unl)" + rom ( name "Moshou Shiji - Zhanshen (Taiwan) (Unl).gbc" size 2097152 crc 80c4fd52 sha1 d2569f8176164cef1cc2a8bd94949ea9cd7dbbea ) ) game ( - name "International Superstar Soccer 2000 (Europe)" - description "International Superstar Soccer 2000 (Europe)" - rom ( name "International Superstar Soccer 2000 (Europe).gbc" size 2097152 crc 57ea1ec8 sha1 3ef4adaff3a9d36dc6986a5944280162768c441d ) + name "Motocross Maniacs 2 (USA)" + description "Motocross Maniacs 2 (USA)" + rom ( name "Motocross Maniacs 2 (USA).gbc" size 1048576 crc 17d27fa9 sha1 5a0e7a9a71a88ee79529531274eb3696cf0fa42c ) ) game ( - name "International Superstar Soccer 2000 (USA)" - description "International Superstar Soccer 2000 (USA)" - rom ( name "International Superstar Soccer 2000 (USA).gbc" size 2097152 crc e8fa7203 sha1 117415d3620fab07066cd5a3ffb438d05bfd940a ) + name "Mr. Driller (Europe)" + description "Mr. Driller (Europe)" + rom ( name "Mr. Driller (Europe).gbc" size 1048576 crc bdf9b05c sha1 6163cc65e7697ef77075a3665a234ce5d720ad9c ) ) game ( - name "International Superstar Soccer 99 (Europe) (SGB Enhanced) (GB Compatible)" - description "International Superstar Soccer 99 (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "International Superstar Soccer 99 (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1b76d115 sha1 d9d9fffb463d4c35f8a1a753908cddfbe17fc671 flags verified ) + name "Mr. Driller (Japan) (NP)" + description "Mr. Driller (Japan) (NP)" + rom ( name "Mr. Driller (Japan) (NP).gbc" size 524288 crc 35fd440d sha1 fb64fa7da6a0fec3e358bb3357e66d68473ada67 flags verified ) ) game ( - name "International Superstar Soccer 99 (USA) (SGB Enhanced) (GB Compatible)" - description "International Superstar Soccer 99 (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "International Superstar Soccer 99 (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 9d0290a7 sha1 6f491e6f919a677627090f949b8e69abb8bfd1db ) + name "Mr. Driller (Japan)" + description "Mr. Driller (Japan)" + rom ( name "Mr. Driller (Japan).gbc" size 1048576 crc 773729af sha1 b0d725dacea717be7109bd6a81817e717641da86 flags verified ) ) game ( - name "International Track & Field (Europe) (En,Fr,De,It) (SGB Enhanced) (GB Compatible)" - description "International Track & Field (Europe) (En,Fr,De,It) (SGB Enhanced) (GB Compatible)" - rom ( name "International Track & Field (Europe) (En,Fr,De,It) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 327ec81f sha1 3aecac0876dac69e9e1fb6f6c311d0af050f1f48 ) + name "Mr. Driller (USA)" + description "Mr. Driller (USA)" + rom ( name "Mr. Driller (USA).gbc" size 1048576 crc 492c0ebf sha1 3bfda5edb7d125ee99b9235434488876dc6d8245 ) ) game ( - name "International Track & Field (USA) (SGB Enhanced) (GB Compatible)" - description "International Track & Field (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "International Track & Field (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 803d5d57 sha1 80b7591470d0a26fe7cf5c80c8bff5d34f79f569 ) + name "Mr. Nutz (Europe) (En,Fr,De,Es,It,Nl)" + description "Mr. Nutz (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Mr. Nutz (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 4e37c741 sha1 d60dffc330f25a61ac1b0b4ba078178585da6fc6 ) ) game ( - name "International Track & Field - Summer Games (Europe)" - description "International Track & Field - Summer Games (Europe)" - rom ( name "International Track & Field - Summer Games (Europe).gbc" size 1048576 crc d826c75f sha1 53e158cb23fa79026345dae775d9f020218f8bb2 ) + name "Mr. Nutz (USA) (En,Fr,Es)" + description "Mr. Nutz (USA) (En,Fr,Es)" + rom ( name "Mr. Nutz (USA) (En,Fr,Es).gbc" size 1048576 crc 59f67529 sha1 43bb8621e3d05e81a7faa63cd76b0757f3954ba1 ) ) game ( - name "Iron Cor - Stainless (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" - description "Iron Cor - Stainless (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Iron Cor - Stainless (World) (v2.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc d6c1c1ac sha1 d722e95155455cf146a97222ccbc2237bea86509 ) + name "Ms. Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible)" + description "Ms. Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Ms. Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc 103e212d sha1 a468f7ad011c1b42ea3144e65607694493e7e4a7 flags verified ) ) game ( - name "It's a World Rally (Japan) (SGB Enhanced) (GB Compatible)" - description "It's a World Rally (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "It's a World Rally (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 39e34650 sha1 31a289823468285ac786afe7de38201235983e35 ) + name "Ms. Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible)" + description "Ms. Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Ms. Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f2335da9 sha1 d0f831165dc9a24e46fed26f90507dadeb5f1e0e ) ) game ( - name "Itsudemo Pachinko GB - CR Monster House (Japan)" - description "Itsudemo Pachinko GB - CR Monster House (Japan)" - rom ( name "Itsudemo Pachinko GB - CR Monster House (Japan).gbc" size 1048576 crc 834091ba sha1 c07c9fc27e0c2cab09a55cd7c6a3ecc06da13aec ) + name "MTV Sports - Pure Ride (USA, Europe)" + description "MTV Sports - Pure Ride (USA, Europe)" + rom ( name "MTV Sports - Pure Ride (USA, Europe).gbc" size 1048576 crc b7b2354b sha1 539772ed4ed2a579453dc57ba06e5aaeda1b4981 flags verified ) ) game ( - name "J.League Excite Stage GB (Japan)" - description "J.League Excite Stage GB (Japan)" - rom ( name "J.League Excite Stage GB (Japan).gbc" size 1048576 crc b3f38f16 sha1 76f708659d790e1a2bf3915591499a4a8904974b ) + name "MTV Sports - Skateboarding Featuring Andy MacDonald (USA, Europe)" + description "MTV Sports - Skateboarding Featuring Andy MacDonald (USA, Europe)" + rom ( name "MTV Sports - Skateboarding Featuring Andy MacDonald (USA, Europe).gbc" size 1048576 crc 744561f3 sha1 91b6e99a68293d72df74528e8077fae58d9c33c3 ) ) game ( - name "J.League Excite Stage Tactics (Japan)" - description "J.League Excite Stage Tactics (Japan)" - rom ( name "J.League Excite Stage Tactics (Japan).gbc" size 2097152 crc 558f4631 sha1 7862be5efe19d84b205062a7e77e5a317f7e17fc ) + name "MTV Sports - T.J. Lavin's Ultimate BMX (USA, Europe)" + description "MTV Sports - T.J. Lavin's Ultimate BMX (USA, Europe)" + rom ( name "MTV Sports - T.J. Lavin's Ultimate BMX (USA, Europe).gbc" size 1048576 crc 904663af sha1 2922d99b87497d1519fb4fde707b4dfd0b2e24e3 ) ) game ( - name "Jack no Daibouken - Daimaou no Gyakushuu (Japan) (SGB Enhanced) (GB Compatible)" - description "Jack no Daibouken - Daimaou no Gyakushuu (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Jack no Daibouken - Daimaou no Gyakushuu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc cff5325a sha1 c2d9548e845ed9a76a0e6dae81bb80023564a9f2 ) + name "Muchang Wuyu GB 6 (Taiwan) (Unl)" + description "Muchang Wuyu GB 6 (Taiwan) (Unl)" + rom ( name "Muchang Wuyu GB 6 (Taiwan) (Unl).gbc" size 2097152 crc 416e6efa sha1 86b2de0fc2806f3d13145e2c0296389ec0897a6a ) ) game ( - name "Jagainu-kun (Japan) (GB Compatible)" - description "Jagainu-kun (Japan) (GB Compatible)" - rom ( name "Jagainu-kun (Japan) (GB Compatible).gbc" size 1048576 crc aeb634c5 sha1 c8cf0523c2cf562d2b2e79b2fe8845e6943a0be4 ) + name "Mummy Returns, The (Europe) (En,Fr,De,Es,It)" + description "Mummy Returns, The (Europe) (En,Fr,De,Es,It)" + rom ( name "Mummy Returns, The (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 64052b9b sha1 186f541e046c6223ef07defb3ba4e065262249b7 ) ) game ( - name "Jaguar Mishin Sashi Senyou Soft - Kirby Family (Japan) (Proto)" - description "Jaguar Mishin Sashi Senyou Soft - Kirby Family (Japan) (Proto)" - rom ( name "Jaguar Mishin Sashi Senyou Soft - Kirby Family (Japan) (Proto).gbc" size 2097152 crc bd65b109 sha1 709c612c13b70226a919a168b03427ec0f33f8f8 ) + name "Mummy Returns, The (USA)" + description "Mummy Returns, The (USA)" + rom ( name "Mummy Returns, The (USA).gbc" size 1048576 crc c997f45b sha1 6dfd1724110f1abff48ab349f89ae11fd201609a ) ) game ( - name "Jaguar Mishin Sashi Senyou Soft - Mario Family (Japan)" - description "Jaguar Mishin Sashi Senyou Soft - Mario Family (Japan)" - rom ( name "Jaguar Mishin Sashi Senyou Soft - Mario Family (Japan).gbc" size 2097152 crc ab3f3cef sha1 4a3c1c84a486864b84e110456e4b9a4e582fdbb8 ) + name "Mummy, The (Europe) (En,Fr,De)" + description "Mummy, The (Europe) (En,Fr,De)" + rom ( name "Mummy, The (Europe) (En,Fr,De).gbc" size 1048576 crc 84fc838a sha1 e1f312f6499229bdcc11c90306c321eadcdb78ca ) ) game ( - name "Jankyuusei - Cosplay Paradise (Japan)" - description "Jankyuusei - Cosplay Paradise (Japan)" - rom ( name "Jankyuusei - Cosplay Paradise (Japan).gbc" size 4194304 crc d60e1c0a sha1 45db3e3c0752c59fc20803945593fd8b9264240e ) + name "Mummy, The (USA)" + description "Mummy, The (USA)" + rom ( name "Mummy, The (USA).gbc" size 1048576 crc c6ba9f27 sha1 35b10f392d514bce858c8c64f9c489500466d0ff ) ) game ( - name "Janosch - Das grosse Panama-Spiel (Germany)" - description "Janosch - Das grosse Panama-Spiel (Germany)" - rom ( name "Janosch - Das grosse Panama-Spiel (Germany).gbc" size 1048576 crc 32c8ee13 sha1 0b514e2b77b9da69d10fa1f3d79c0727f625de82 flags verified ) + name "Muteki Ou Tri-Zenon (Japan)" + description "Muteki Ou Tri-Zenon (Japan)" + rom ( name "Muteki Ou Tri-Zenon (Japan).gbc" size 2097152 crc 0bab7a61 sha1 2a7f422bf9af9aff126e47ede8b5ceec0630eb08 ) ) game ( - name "Jay und die Spielzeugdiebe (Germany)" - description "Jay und die Spielzeugdiebe (Germany)" - rom ( name "Jay und die Spielzeugdiebe (Germany).gbc" size 1048576 crc 73f4f6da sha1 dd01d68bab2d3615f173e4c9c94da56248fab580 ) + name "Mythri (USA) (Proto 1) (2000-08-02)" + description "Mythri (USA) (Proto 1) (2000-08-02)" + rom ( name "Mythri (USA) (Proto 1) (2000-08-02).gbc" size 524288 crc 664882ac sha1 d79650a853fffcef878fedc690d5e3a607b5b9df ) ) game ( - name "Jayro's Game Boy Test Cartridge (World) (v1.18) (GB Compatible) (Aftermarket) (Unl)" - description "Jayro's Game Boy Test Cartridge (World) (v1.18) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Jayro's Game Boy Test Cartridge (World) (v1.18) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 9e97ac30 sha1 c07237d0f9c13b36ac2fcc5324b6e81122b0e189 ) + name "Mythri (USA) (Proto 2) (2001-03-31)" + description "Mythri (USA) (Proto 2) (2001-03-31)" + rom ( name "Mythri (USA) (Proto 2) (2001-03-31).gbc" size 524288 crc d4149106 sha1 d5b5880ab12939065abfb377dc35fbc39d9922ac ) ) game ( - name "Jeff Gordon XS Racing (USA) (GB Compatible)" - description "Jeff Gordon XS Racing (USA) (GB Compatible)" - rom ( name "Jeff Gordon XS Racing (USA) (GB Compatible).gbc" size 1048576 crc a41ed926 sha1 3939bd5c3ba034ebb19395d4292f82b703629468 ) + name "Nakayoshi Cooking Series 1 - Oishii Cake-ya-san (Japan)" + description "Nakayoshi Cooking Series 1 - Oishii Cake-ya-san (Japan)" + rom ( name "Nakayoshi Cooking Series 1 - Oishii Cake-ya-san (Japan).gbc" size 1048576 crc e5c9569a sha1 f98c3209fe712e5696648d946bd63fbca16b0ed3 ) ) game ( - name "Jeremy McGrath Supercross 2000 (USA, Europe)" - description "Jeremy McGrath Supercross 2000 (USA, Europe)" - rom ( name "Jeremy McGrath Supercross 2000 (USA, Europe).gbc" size 1048576 crc f0f9abe6 sha1 5b48252bde9f47d0ffd33f0e84cf30ec769946e7 ) + name "Nakayoshi Cooking Series 2 - Oishii Panya-san (Japan)" + description "Nakayoshi Cooking Series 2 - Oishii Panya-san (Japan)" + rom ( name "Nakayoshi Cooking Series 2 - Oishii Panya-san (Japan).gbc" size 1048576 crc b9fa3ce4 sha1 cf1b69a198c8d95f95bc99eb9fb1f3caed4b961d ) ) game ( - name "Jeremy McGrath Supercross 2000 (Japan) (En) (Possible Proto) (NP)" - description "Jeremy McGrath Supercross 2000 (Japan) (En) (Possible Proto) (NP)" - rom ( name "Jeremy McGrath Supercross 2000 (Japan) (En) (Possible Proto) (NP).gbc" size 1048576 crc 666d2a75 sha1 dd204c1d47290f52ef264ce32d59cb5f58a2701d ) + name "Nakayoshi Cooking Series 3 - Tanoshii Obentou (Japan)" + description "Nakayoshi Cooking Series 3 - Tanoshii Obentou (Japan)" + rom ( name "Nakayoshi Cooking Series 3 - Tanoshii Obentou (Japan).gbc" size 1048576 crc dd7666ce sha1 eb56e8a2a2d77141104cdbdd2ad6d0924ae10e88 ) ) game ( - name "Jet de Go! - Let's Go by Airliner (Japan)" - description "Jet de Go! - Let's Go by Airliner (Japan)" - rom ( name "Jet de Go! - Let's Go by Airliner (Japan).gbc" size 2097152 crc 20c4ccf6 sha1 97bf75afa0089ddb342ea7046b7cd113ba2c6fec ) + name "Nakayoshi Cooking Series 4 - Tanoshii Dessert (Japan)" + description "Nakayoshi Cooking Series 4 - Tanoshii Dessert (Japan)" + rom ( name "Nakayoshi Cooking Series 4 - Tanoshii Dessert (Japan).gbc" size 1048576 crc 7e5c8542 sha1 c86420aba490db1e0bfdda7a4b5db7f5777c509b flags verified ) ) game ( - name "Jet Set Willy (World) (Aftermarket) (Unl)" - description "Jet Set Willy (World) (Aftermarket) (Unl)" - rom ( name "Jet Set Willy (World) (Aftermarket) (Unl).gbc" size 262144 crc 659295ee sha1 bcb5a0e4566572aeb6cddea0897903ba207dc54f ) + name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan)" + description "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan)" + rom ( name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan).gbc" size 4194304 crc c04539f8 sha1 f1b845d5508da37f3600437609d8cc8743799918 flags verified ) ) game ( - name "Jibaku-kun - Rei no Itsuki no Kajitsu (Japan) (Proto)" - description "Jibaku-kun - Rei no Itsuki no Kajitsu (Japan) (Proto)" - rom ( name "Jibaku-kun - Rei no Itsuki no Kajitsu (Japan) (Proto).gbc" size 2097152 crc 1900bcc8 sha1 fec43a82916e8504de685b928a0af73c2252b55d ) + name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 1)" + description "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 1)" + rom ( name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 1).gbc" size 4194304 crc b65a9fb6 sha1 df98eed187a3691ff7fe07619bab1d01072daec6 ) ) game ( - name "Jieba Tianwang 4 (Taiwan) (Unl)" - description "Jieba Tianwang 4 (Taiwan) (Unl)" - rom ( name "Jieba Tianwang 4 (Taiwan) (Unl).gbc" size 1048576 crc 1a6fe765 sha1 b0862fc1cc856b904b2febd094d9453a2baacb85 ) + name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 2)" + description "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 2)" + rom ( name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 2).gbc" size 4194304 crc f4e674be sha1 aa5e2dd4590bbe9d20c76d8fb1ed408cfdc7350b ) ) game ( - name "Jim Henson's Bear in the Big Blue House (Europe) (En,Fr,De,Es,It,Nl)" - description "Jim Henson's Bear in the Big Blue House (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Jim Henson's Bear in the Big Blue House (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 48c99939 sha1 a5c2bb5244fe0fd6d2710c832f66f8f8b8c2bbab flags verified ) + name "Nakayoshi Pet Series 1 - Kawaii Hamster (Japan) (GB Compatible)" + description "Nakayoshi Pet Series 1 - Kawaii Hamster (Japan) (GB Compatible)" + rom ( name "Nakayoshi Pet Series 1 - Kawaii Hamster (Japan) (GB Compatible).gbc" size 1048576 crc 98d0fcb0 sha1 aaa59f2500aa82454cb74aeafa342f8907c82aaf flags verified ) ) game ( - name "Jim Henson's Bear in the Big Blue House (USA) (En,Fr,De,Es,It,Nl)" - description "Jim Henson's Bear in the Big Blue House (USA) (En,Fr,De,Es,It,Nl)" - rom ( name "Jim Henson's Bear in the Big Blue House (USA) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 851c8710 sha1 e4c1c58025a083c067f752490c1fbd816c93d072 ) + name "Nakayoshi Pet Series 2 - Kawaii Usagi (Japan) (GB Compatible)" + description "Nakayoshi Pet Series 2 - Kawaii Usagi (Japan) (GB Compatible)" + rom ( name "Nakayoshi Pet Series 2 - Kawaii Usagi (Japan) (GB Compatible).gbc" size 1048576 crc 866095c2 sha1 9d155a4dd73785c2cc725184954fc2d44b4d6f34 flags verified ) ) game ( - name "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv)" - description "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv)" - rom ( name "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv).gbc" size 2097152 crc 0fafa3f2 sha1 dc9288bc4b2a2093ea298514a91c3b2b4101691b ) + name "Nakayoshi Pet Series 3 - Kawaii Koinu (Japan)" + description "Nakayoshi Pet Series 3 - Kawaii Koinu (Japan)" + rom ( name "Nakayoshi Pet Series 3 - Kawaii Koinu (Japan).gbc" size 1048576 crc fa4e9896 sha1 2e6f44bddfffad5defbcf45cf489151ffe43bcdb ) ) game ( - name "Jim Henson's Muppets (USA)" - description "Jim Henson's Muppets (USA)" - rom ( name "Jim Henson's Muppets (USA).gbc" size 2097152 crc 3c476c6f sha1 77ad190ad107c57b167e3837757a4c7f990a867e ) + name "Nakayoshi Pet Series 4 - Kawaii Koneko (Japan)" + description "Nakayoshi Pet Series 4 - Kawaii Koneko (Japan)" + rom ( name "Nakayoshi Pet Series 4 - Kawaii Koneko (Japan).gbc" size 1048576 crc 1a382367 sha1 e5d5f1092e991a7538b9d24a12de35da21e23edd flags verified ) ) game ( - name "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - description "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - rom ( name "Jim Henson's Muppets (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 4194304 crc 3204b92c sha1 6e042fc6029493a429557a6fdce111c03f9ede1b flags verified ) + name "Nakayoshi Pet Series 5 - Kawaii Hamster 2 (Japan)" + description "Nakayoshi Pet Series 5 - Kawaii Hamster 2 (Japan)" + rom ( name "Nakayoshi Pet Series 5 - Kawaii Hamster 2 (Japan).gbc" size 1048576 crc e5ec7be5 sha1 8465423089e87bc5a8f3485403c1b8a9b32915a1 ) ) game ( - name "Jimmy White's Cueball (USA) (Proto)" - description "Jimmy White's Cueball (USA) (Proto)" - rom ( name "Jimmy White's Cueball (USA) (Proto).gbc" size 1048576 crc 62c49da9 sha1 54a72ed5ef210b947a97e81208752c4431ef715c ) + name "Naminori Yarou! (Japan) (NP)" + description "Naminori Yarou! (Japan) (NP)" + rom ( name "Naminori Yarou! (Japan) (NP).gbc" size 1048576 crc ac5e477d sha1 d305a76307bf05f4d31d395785784ba317a9689f ) ) game ( - name "Jimmy White's Cueball (Europe)" - description "Jimmy White's Cueball (Europe)" - rom ( name "Jimmy White's Cueball (Europe).gbc" size 1048576 crc 27632f4f sha1 ed9a76a235edd862f642b4dc974cd37126a267a8 ) + name "NASCAR 2000 (USA, Europe)" + description "NASCAR 2000 (USA, Europe)" + rom ( name "NASCAR 2000 (USA, Europe).gbc" size 1048576 crc 54d90a4c sha1 37d3ffb5ae9bcf4c1cab7cece0a19d6b0b45c3a2 flags verified ) ) game ( - name "Jingling Wang III (Taiwan) (Unl)" - description "Jingling Wang III (Taiwan) (Unl)" - rom ( name "Jingling Wang III (Taiwan) (Unl).gbc" size 2097152 crc f19e780c sha1 8ef6ceb1b7894f43caa5f422d62d6c437f81e56d ) + name "NASCAR Challenge (USA) (Rumble Version)" + description "NASCAR Challenge (USA) (Rumble Version)" + rom ( name "NASCAR Challenge (USA) (Rumble Version).gbc" size 1048576 crc 39c6b868 sha1 4282d0d76af3d022f9e76082be17522ce5699e54 ) ) game ( - name "Jinsei Game - Tomodachi Takusan Tsukurou yo! (Japan) (SGB Enhanced) (GB Compatible)" - description "Jinsei Game - Tomodachi Takusan Tsukurou yo! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Jinsei Game - Tomodachi Takusan Tsukurou yo! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c8d46e99 sha1 d2c4ae3808d9a24cbd4c6c8e43184ca0ef2d8373 ) + name "NASCAR Heat (USA)" + description "NASCAR Heat (USA)" + rom ( name "NASCAR Heat (USA).gbc" size 1048576 crc fa83b37c sha1 059411b2c51fbc0c79d2b8911cbf313f14f15738 ) ) game ( - name "Jisedai Begoma Battle Beyblade (Japan)" - description "Jisedai Begoma Battle Beyblade (Japan)" - rom ( name "Jisedai Begoma Battle Beyblade (Japan).gbc" size 2097152 crc 9c56977e sha1 fc2af4ebd10ca20158d231089a8378f6c4641329 ) + name "NASCAR Racers (USA)" + description "NASCAR Racers (USA)" + rom ( name "NASCAR Racers (USA).gbc" size 1048576 crc f39a5c4f sha1 2e1b822afa8537cd7b2be8d608c4c000b5b59d46 ) ) game ( - name "Jissen ni Yakudatsu Tsumego (Japan) (Rev 1)" - description "Jissen ni Yakudatsu Tsumego (Japan) (Rev 1)" - rom ( name "Jissen ni Yakudatsu Tsumego (Japan) (Rev 1).gbc" size 262144 crc 55efa05e sha1 5ff7f6f2a1911e97eb71a3b3788a89745cfa5d31 flags verified ) + name "Nations, The - Land of Legends (Europe) (En,De)" + description "Nations, The - Land of Legends (Europe) (En,De)" + rom ( name "Nations, The - Land of Legends (Europe) (En,De).gbc" size 1048576 crc 8c195f49 sha1 2fa6767632e37dc70d97061cbece2cdbace7ab1c ) ) game ( - name "Jissen ni Yakudatsu Tsumego (Japan) (Possible Proto)" - description "Jissen ni Yakudatsu Tsumego (Japan) (Possible Proto)" - rom ( name "Jissen ni Yakudatsu Tsumego (Japan) (Possible Proto).gbc" size 262144 crc 69c6dbef sha1 f7ed6cdce7637a11d7fa7f5cb59b8f8ce131f9d1 ) + name "NBA 3 on 3 Featuring Kobe Bryant (USA) (SGB Enhanced) (GB Compatible)" + description "NBA 3 on 3 Featuring Kobe Bryant (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "NBA 3 on 3 Featuring Kobe Bryant (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 001f4754 sha1 8f8d1a33a71b22c9359ddc1aae0bd9cad4cc7456 ) ) game ( - name "John Romero's Daikatana (Europe) (En,Fr,It)" - description "John Romero's Daikatana (Europe) (En,Fr,It)" - rom ( name "John Romero's Daikatana (Europe) (En,Fr,It).gbc" size 1048576 crc d9062e49 sha1 a5c5b52247b2ab78cd9cad19aa752e07c3df86ef ) + name "NBA Hoopz (USA)" + description "NBA Hoopz (USA)" + rom ( name "NBA Hoopz (USA).gbc" size 1048576 crc 5011a419 sha1 c23d8276c3766d4265ac017bfada04a664ee4e8f ) ) game ( - name "John Romero's Daikatana (Europe) (Fr,De,Es)" - description "John Romero's Daikatana (Europe) (Fr,De,Es)" - rom ( name "John Romero's Daikatana (Europe) (Fr,De,Es).gbc" size 1048576 crc f7e83313 sha1 b699fc3bc587e5df25235a6c7f74fec307f476fe ) + name "NBA in the Zone (USA) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "NBA in the Zone (USA) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "NBA in the Zone (USA) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc be949f74 sha1 f4ba926ad640d7b3e9d175fb58c90347dafcbef4 ) ) game ( - name "Joryuu Janshi ni Chousen GB - Watashi-tachi ni Chousen Shitene! (Japan) (SGB Enhanced) (GB Compatible)" - description "Joryuu Janshi ni Chousen GB - Watashi-tachi ni Chousen Shitene! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Joryuu Janshi ni Chousen GB - Watashi-tachi ni Chousen Shitene! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 9fa5cdb5 sha1 a332817b9561dcab7d1f3dc0cf300e1656b253c3 ) + name "NBA in the Zone (USA) (Possible Proto) (SGB Enhanced) (GB Compatible)" + description "NBA in the Zone (USA) (Possible Proto) (SGB Enhanced) (GB Compatible)" + rom ( name "NBA in the Zone (USA) (Possible Proto) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f6bae9a0 sha1 7f0d5a37956ae58077656a42b26629784c203038 ) ) game ( - name "Judy's Adventure (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Judy's Adventure (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Judy's Adventure (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 8884d532 sha1 a41195443613fb4414d8536b1f3494677f6f253d ) + name "NBA in the Zone 2000 (Europe)" + description "NBA in the Zone 2000 (Europe)" + rom ( name "NBA in the Zone 2000 (Europe).gbc" size 2097152 crc e6af6d07 sha1 773a303c25bc907476bee20064f2c1f154361d82 ) ) game ( - name "Judy's Adventure (World) (v11.3) (GB Compatible) (Aftermarket) (Unl)" - description "Judy's Adventure (World) (v11.3) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Judy's Adventure (World) (v11.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 570a8043 sha1 1ccbf555412a417135acea0b7b185a7f795a89da ) + name "NBA in the Zone 2000 (USA)" + description "NBA in the Zone 2000 (USA)" + rom ( name "NBA in the Zone 2000 (USA).gbc" size 2097152 crc fdb38c49 sha1 57cd13938fb394752f1e070026df716771561cc2 ) ) game ( - name "Juedui Wuli (Taiwan) (Unl)" - description "Juedui Wuli (Taiwan) (Unl)" - rom ( name "Juedui Wuli (Taiwan) (Unl).gbc" size 2097152 crc f4d63a7e sha1 f0b9f02335ee89aa6189e687e6e759d8c49bc2b3 ) + name "NBA Jam 2001 (USA, Europe)" + description "NBA Jam 2001 (USA, Europe)" + rom ( name "NBA Jam 2001 (USA, Europe).gbc" size 1048576 crc 3aa75f1c sha1 b1f7230dcccaecb7ae9b2a0e786effac2fc24497 flags verified ) ) game ( - name "JumpStart Dino Adventure - Field Trip (USA)" - description "JumpStart Dino Adventure - Field Trip (USA)" - rom ( name "JumpStart Dino Adventure - Field Trip (USA).gbc" size 1048576 crc 6d50772d sha1 97d328c36fcb17a65d398f0696c819136d1b03dc ) + name "NBA Jam 2001 (USA, Europe) (Beta) (2000-02-07)" + description "NBA Jam 2001 (USA, Europe) (Beta) (2000-02-07)" + rom ( name "NBA Jam 2001 (USA, Europe) (Beta) (2000-02-07).gbc" size 131072 crc 594ee678 sha1 5d8ae5937a374fe4e36fe5303e3ad3757ee9675c ) ) game ( - name "Jungle Book, The - Mowgli's Wild Adventure (Europe) (En,Fr,De,Es,It)" - description "Jungle Book, The - Mowgli's Wild Adventure (Europe) (En,Fr,De,Es,It)" - rom ( name "Jungle Book, The - Mowgli's Wild Adventure (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc b609ecea sha1 960f8e7e7c72f3466eed4ebfa87fbf3b18053745 ) + name "NBA Jam 2001 (USA, Europe) (Beta) (2000-05-05)" + description "NBA Jam 2001 (USA, Europe) (Beta) (2000-05-05)" + rom ( name "NBA Jam 2001 (USA, Europe) (Beta) (2000-05-05).gbc" size 1048576 crc 926b47d1 sha1 ddbb720be9dd573728f897abe77569d42dae7baf ) ) game ( - name "Jungle Book, The - Mowgli's Wild Adventure (USA) (En,Fr,De,Es,It)" - description "Jungle Book, The - Mowgli's Wild Adventure (USA) (En,Fr,De,Es,It)" - rom ( name "Jungle Book, The - Mowgli's Wild Adventure (USA) (En,Fr,De,Es,It).gbc" size 4194304 crc 9b6b755f sha1 a76a8692246893545663be9d1e4a6f2c1370ed09 ) + name "NBA Jam 2001 (USA, Europe) (Beta) (2000-09-26)" + description "NBA Jam 2001 (USA, Europe) (Beta) (2000-09-26)" + rom ( name "NBA Jam 2001 (USA, Europe) (Beta) (2000-09-26).gbc" size 1048576 crc 0d5506ae sha1 2859d6ad2af7ff3333ad0d3750a1fd4b3088d47d ) ) game ( - name "Jurassic Boy 2 (Taiwan) (En) (Rev 1) (Sachen) (Unl)" - description "Jurassic Boy 2 (Taiwan) (En) (Rev 1) (Sachen) (Unl)" - rom ( name "Jurassic Boy 2 (Taiwan) (En) (Rev 1) (Sachen) (Unl).gbc" size 262144 crc a3ba0db4 sha1 1a2522d29cfbeb195488ed6ea79c36382b3b28be ) + name "NBA Jam 99 (USA, Europe) (GB Compatible)" + description "NBA Jam 99 (USA, Europe) (GB Compatible)" + rom ( name "NBA Jam 99 (USA, Europe) (GB Compatible).gbc" size 1048576 crc 84be0eed sha1 f34d0ac01f14c7c2671b6097c2ef891e70826d72 ) ) game ( - name "Jurassic Boy 2 + Thunder Blast Man (Taiwan) (En) (1B-002, 1B-003, Sachen) (Unl)" - description "Jurassic Boy 2 + Thunder Blast Man (Taiwan) (En) (1B-002, 1B-003, Sachen) (Unl)" - rom ( name "Jurassic Boy 2 + Thunder Blast Man (Taiwan) (En) (1B-002, 1B-003, Sachen) (Unl).gbc" size 524288 crc 497be52b sha1 4d7f15ed30dcc6ddeea1863ee8d786e3933ca92f flags verified ) + name "NBA Pro 99 (Europe) (SGB Enhanced) (GB Compatible)" + description "NBA Pro 99 (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "NBA Pro 99 (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 748564ae sha1 6eb56b61b8a77ce1060343f2c99f18c3271fa5f5 flags verified ) ) game ( - name "Juukou Senki Bullet Battlers (Japan) (SGB Enhanced) (GB Compatible)" - description "Juukou Senki Bullet Battlers (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Juukou Senki Bullet Battlers (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4039c187 sha1 a89304600330a62800751f16e231924fa9cf6e4d ) + name "NBA Show Time - NBA on NBC (USA)" + description "NBA Show Time - NBA on NBC (USA)" + rom ( name "NBA Show Time - NBA on NBC (USA).gbc" size 1048576 crc 7ae23888 sha1 a72cd784883f2299b8b51d763ff4f8cf99a103bd ) ) game ( - name "K.O. - The Pro Boxing (Japan)" - description "K.O. - The Pro Boxing (Japan)" - rom ( name "K.O. - The Pro Boxing (Japan).gbc" size 1048576 crc 69f08c89 sha1 6fca09dabfcf087156263f656b80ff57065bcbfe ) + name "NBA Show Time - NBA on NBC (USA) (Rev 1) (Proto)" + description "NBA Show Time - NBA on NBC (USA) (Rev 1) (Proto)" + rom ( name "NBA Show Time - NBA on NBC (USA) (Rev 1) (Proto).gbc" size 1048576 crc 8bc9be45 sha1 fd4bb16f306e309834e276ed768e8e2ed402e138 ) ) game ( - name "Kaept'n Blaubaer - Die verrueckte Schatzsuche (Germany)" - description "Kaept'n Blaubaer - Die verrueckte Schatzsuche (Germany)" - rom ( name "Kaept'n Blaubaer - Die verrueckte Schatzsuche (Germany).gbc" size 1048576 crc 77e13dbe sha1 57c29638d77e8a1589c411085aa2c99108d96bf2 flags verified ) + name "Net de Get - Minigame @ 100 (Japan)" + description "Net de Get - Minigame @ 100 (Japan)" + rom ( name "Net de Get - Minigame @ 100 (Japan).gbc" size 1048576 crc 6e33d509 sha1 819efde3ebd0f52b080a8307979803914d029035 flags verified ) ) game ( - name "Kaitei Densetsu!! Treasure World (Japan) (GB Compatible)" - description "Kaitei Densetsu!! Treasure World (Japan) (GB Compatible)" - rom ( name "Kaitei Densetsu!! Treasure World (Japan) (GB Compatible).gbc" size 1048576 crc 4c7258d9 sha1 fe1cba586c0ff61628e52890b5ac40d1b7c4cbee ) + name "Network Boukenki Bugsite - Alpha Version (Japan)" + description "Network Boukenki Bugsite - Alpha Version (Japan)" + rom ( name "Network Boukenki Bugsite - Alpha Version (Japan).gbc" size 2097152 crc d65c8ba1 sha1 a5be33b3cefa2af0865caddb287814c8cca19edd flags verified ) ) game ( - name "Kakurenbo Battle - Monster Tactics (Japan)" - description "Kakurenbo Battle - Monster Tactics (Japan)" - rom ( name "Kakurenbo Battle - Monster Tactics (Japan).gbc" size 2097152 crc 9cfa76c3 sha1 45bf50f9ff80df20d25d40cc8f78d829d6a8fab7 ) + name "Network Boukenki Bugsite - Beta Version (Japan)" + description "Network Boukenki Bugsite - Beta Version (Japan)" + rom ( name "Network Boukenki Bugsite - Beta Version (Japan).gbc" size 2097152 crc 56f52663 sha1 0c03e241e2931a0e2e54de30678334999beacb48 ) ) game ( - name "Kakutou Ryouri Densetsu Bistro Recipe - Gekitou Foodon Battle Hen (Japan) (SGB Enhanced) (GB Compatible)" - description "Kakutou Ryouri Densetsu Bistro Recipe - Gekitou Foodon Battle Hen (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kakutou Ryouri Densetsu Bistro Recipe - Gekitou Foodon Battle Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 459a126b sha1 6a972325c07687b51fe6dbb3813bf54e1721668f ) + name "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt)" + description "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt)" + rom ( name "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt).gbc" size 2097152 crc fbb97680 sha1 87af7b26281adc9efb8b5b5e31a13b8f6be16042 ) ) game ( - name "Kakutou Ryouri Densetsu Bistro Recipe - Kettou Bistgarm Hen (Japan) (SGB Enhanced) (GB Compatible)" - description "Kakutou Ryouri Densetsu Bistro Recipe - Kettou Bistgarm Hen (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kakutou Ryouri Densetsu Bistro Recipe - Kettou Bistgarm Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4fbec464 sha1 c9fa1b1a24a0098eadd7e3fa4ee19f1b615a618f ) + name "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt) (Rev 1) (Proto)" + description "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt) (Rev 1) (Proto)" + rom ( name "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt) (Rev 1) (Proto).gbc" size 2097152 crc 910df34b sha1 c0582e350ade53908a9f091a4796d58b3c1806f8 ) ) game ( - name "Kanji Boy (Japan) (SGB Enhanced) (GB Compatible)" - description "Kanji Boy (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kanji Boy (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 18caa513 sha1 3876d5f64113e5365b42d30945f51f40b1d22d47 ) + name "New Adventures of Mary-Kate & Ashley, The (USA, Europe) (GB Compatible)" + description "New Adventures of Mary-Kate & Ashley, The (USA, Europe) (GB Compatible)" + rom ( name "New Adventures of Mary-Kate & Ashley, The (USA, Europe) (GB Compatible).gbc" size 1048576 crc dca4474e sha1 d42515a16143319afac0d980e9cb080103085f5c flags verified ) ) game ( - name "Kanji Boy 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Kanji Boy 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kanji Boy 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 81fd8918 sha1 4d382de7fd6912c0cd8ca15032e6f75409d0a97b ) + name "New Super Color 145 in 1 (Taiwan) (Unl)" + description "New Super Color 145 in 1 (Taiwan) (Unl)" + rom ( name "New Super Color 145 in 1 (Taiwan) (Unl).gbc" size 16777216 crc b087710c sha1 cbeb1745d68163978a422a8d7260a6a0f2693b85 ) ) game ( - name "Kanji Boy 3 (Japan)" - description "Kanji Boy 3 (Japan)" - rom ( name "Kanji Boy 3 (Japan).gbc" size 4194304 crc 2d4d8597 sha1 ea9064f703354b7fbeef0dd55084b16f2f7797ba ) + name "NFL Blitz (USA, Europe) (GB Compatible)" + description "NFL Blitz (USA, Europe) (GB Compatible)" + rom ( name "NFL Blitz (USA, Europe) (GB Compatible).gbc" size 524288 crc d731ded7 sha1 14649b51e40aeea24cb4d9cbc41b847cadf68067 ) ) game ( - name "Kanji Boy 3 (Japan) (Beta)" - description "Kanji Boy 3 (Japan) (Beta)" - rom ( name "Kanji Boy 3 (Japan) (Beta).gbc" size 4194304 crc 2ce7d758 sha1 f8b34e0834c7bff5bb06587e932dff2036d86c6e ) + name "NFL Blitz (USA, Europe) (Rev 1) (GB Compatible)" + description "NFL Blitz (USA, Europe) (Rev 1) (GB Compatible)" + rom ( name "NFL Blitz (USA, Europe) (Rev 1) (GB Compatible).gbc" size 524288 crc 107d734b sha1 66b69cba0705f0670759f01cfd586a50c47c7c89 flags verified ) ) game ( - name "Kanji de Puzzle (Japan) (GB Compatible)" - description "Kanji de Puzzle (Japan) (GB Compatible)" - rom ( name "Kanji de Puzzle (Japan) (GB Compatible).gbc" size 1048576 crc 25efa1d7 sha1 a0f108d3838ac820b2ee3167e93886b979115006 ) + name "NFL Blitz 2000 (USA)" + description "NFL Blitz 2000 (USA)" + rom ( name "NFL Blitz 2000 (USA).gbc" size 1048576 crc 090c7dac sha1 26e60d551b71ac65feef7882062a61c0bad03664 flags verified ) ) game ( - name "Kanji Shishuu (Japan) (Proto)" - description "Kanji Shishuu (Japan) (Proto)" - rom ( name "Kanji Shishuu (Japan) (Proto).gbc" size 8388608 crc 29a1932f sha1 09d5b0f6e3b17f670820265dcb2477e5c869ed79 ) + name "NFL Blitz 2001 (USA)" + description "NFL Blitz 2001 (USA)" + rom ( name "NFL Blitz 2001 (USA).gbc" size 1048576 crc 61c653ae sha1 51da92005e63c427f5edf030c8a35b33b5e07cfc ) ) game ( - name "Kanzume Monsters Parfait (Japan) (SGB Enhanced) (GB Compatible)" - description "Kanzume Monsters Parfait (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kanzume Monsters Parfait (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6d5b59c0 sha1 62f431d8e1efdc93a36751ce5f4740d05d999348 ) + name "NHL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "NHL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "NHL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc bb625129 sha1 8f7cb463a1438c70310f319e602df4b13530d96f ) ) game ( - name "Karamuchou wa Oosawagi! - Okawari! (Japan) (SGB Enhanced, GB Compatible) (NP)" - description "Karamuchou wa Oosawagi! - Okawari! (Japan) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Karamuchou wa Oosawagi! - Okawari! (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 1048576 crc 6c568e06 sha1 9217169dc3f42562d71a7edabc3b42e36ec8304b ) + name "NHL Blades of Steel (USA)" + description "NHL Blades of Steel (USA)" + rom ( name "NHL Blades of Steel (USA).gbc" size 1048576 crc a890adb2 sha1 9a93f90645b929ff0344fd256815f02b3bf33a99 ) ) game ( - name "Karamuchou wa Oosawagi! - Polinkies to Okashina Nakama-tachi (Japan) (SGB Enhanced) (GB Compatible)" - description "Karamuchou wa Oosawagi! - Polinkies to Okashina Nakama-tachi (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Karamuchou wa Oosawagi! - Polinkies to Okashina Nakama-tachi (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc dd948071 sha1 cb6079dc290ace0daafdd40353e4477e4a37c8f7 ) + name "NHL Blades of Steel 2000 (USA)" + description "NHL Blades of Steel 2000 (USA)" + rom ( name "NHL Blades of Steel 2000 (USA).gbc" size 1048576 crc 8bc5b62a sha1 271782de2566fb0c36c96d7def5f439009371870 ) ) game ( - name "Karate Joe (Europe) (Unl)" - description "Karate Joe (Europe) (Unl)" - rom ( name "Karate Joe (Europe) (Unl).gbc" size 262144 crc b8a54e29 sha1 bc9e760dcc851a01240b49b28cde8fe5ab18df91 ) + name "Nicktoons Racing (USA)" + description "Nicktoons Racing (USA)" + rom ( name "Nicktoons Racing (USA).gbc" size 1048576 crc a3f079d4 sha1 8b023f596d9b37ae442578c02c6ba859bc81c5c6 ) ) game ( - name "Kaseki Sousei Reborn II - Monster Digger (Japan) (SGB Enhanced) (GB Compatible)" - description "Kaseki Sousei Reborn II - Monster Digger (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kaseki Sousei Reborn II - Monster Digger (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc bf80c897 sha1 857fb62dc310268e0b92e9383c6b6fd61aa33fa0 flags verified ) + name "Ninja JaJaMaru - The Great World Adventure DX (USA, Europe) (Ninja JaJaMaru Retro Collection) (Switch)" + description "Ninja JaJaMaru - The Great World Adventure DX (USA, Europe) (Ninja JaJaMaru Retro Collection) (Switch)" + rom ( name "Ninja JaJaMaru - The Great World Adventure DX (USA, Europe) (Ninja JaJaMaru Retro Collection) (Switch).gbc" size 262144 crc b5af4ca5 sha1 73efaca14c998dd6790e08f2ce2b6f73e7909ce4 flags verified ) ) game ( - name "Katakis 3D (Europe) (Proto)" - description "Katakis 3D (Europe) (Proto)" - rom ( name "Katakis 3D (Europe) (Proto).gbc" size 2097152 crc 7c4b3795 sha1 8cd4be6772c592bbc2908fa826c090ec122e384c ) + name "Nintama Rantarou - Ninjutsu Gakuen ni Nyuugaku Shiyou no Dan (Japan)" + description "Nintama Rantarou - Ninjutsu Gakuen ni Nyuugaku Shiyou no Dan (Japan)" + rom ( name "Nintama Rantarou - Ninjutsu Gakuen ni Nyuugaku Shiyou no Dan (Japan).gbc" size 1048576 crc 4631d8bf sha1 916bb8c06539cfcf6b4499a2046ea89e17a8874c ) ) game ( - name "Katou Hifumi Kudan - Shougi Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible)" - description "Katou Hifumi Kudan - Shougi Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Katou Hifumi Kudan - Shougi Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a262269f sha1 c3ba0d2b82d66ef1b5c0dee8813a5f965631ed75 ) + name "Nisemon Puzzle da Mon! - Feromon Kyuushutsu Daisakusen! (Japan)" + description "Nisemon Puzzle da Mon! - Feromon Kyuushutsu Daisakusen! (Japan)" + rom ( name "Nisemon Puzzle da Mon! - Feromon Kyuushutsu Daisakusen! (Japan).gbc" size 2097152 crc 2f7d62f3 sha1 8d60e4af5504fe68277e1da162e6352d8438900e ) ) game ( - name "Kawa no Nushi Tsuri 4 (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" - description "Kawa no Nushi Tsuri 4 (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" - rom ( name "Kawa no Nushi Tsuri 4 (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f0b09ddb sha1 dbdac654d4056ade51a139614192742ce8800d7e ) + name "No Fear - Downhill Mountain Biking (Europe)" + description "No Fear - Downhill Mountain Biking (Europe)" + rom ( name "No Fear - Downhill Mountain Biking (Europe).gbc" size 1048576 crc 0f69f574 sha1 d04c3578f3abed229c9bc44f55fc3a2154e15429 ) ) game ( - name "Kawa no Nushi Tsuri 4 (Japan) (Rev 1) (Possible Proto) (Rumble Version) (SGB Enhanced, GB Compatible) (NP)" - description "Kawa no Nushi Tsuri 4 (Japan) (Rev 1) (Possible Proto) (Rumble Version) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Kawa no Nushi Tsuri 4 (Japan) (Rev 1) (Possible Proto) (Rumble Version) (SGB Enhanced, GB Compatible) (NP).gbc" size 1048576 crc 456d4dfc sha1 69e56fd73eb365dba87713c2a3ea2e74bd63f63c ) + name "Nobunaga no Yabou - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Nobunaga no Yabou - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Nobunaga no Yabou - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 233862d0 sha1 a61e35306405e41c03b98b162ee14442e77c0da1 flags verified ) ) game ( - name "Kawaii Pet Shop Monogatari (Japan) (SGB Enhanced) (GB Compatible)" - description "Kawaii Pet Shop Monogatari (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kawaii Pet Shop Monogatari (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 44767443 sha1 8392eccbac1d8ae23782c6d29d3ee604a03b5c05 ) + name "Noddy and the Birthday Party (Europe) (En,Fr,De,Es)" + description "Noddy and the Birthday Party (Europe) (En,Fr,De,Es)" + rom ( name "Noddy and the Birthday Party (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 845b4e44 sha1 9db01baf9aec2dd3df8ddc583694b1b7aa85ac2c ) ) game ( - name "Kawaii Pet Shop Monogatari 2 (Japan) (GB Compatible)" - description "Kawaii Pet Shop Monogatari 2 (Japan) (GB Compatible)" - rom ( name "Kawaii Pet Shop Monogatari 2 (Japan) (GB Compatible).gbc" size 2097152 crc 3791dca1 sha1 76dc291937adbe7ebab4c1681ecf1fc7ea3a6074 ) + name "NSYNC - Get to the Show (USA)" + description "NSYNC - Get to the Show (USA)" + rom ( name "NSYNC - Get to the Show (USA).gbc" size 1048576 crc f770878b sha1 23b031d03a139c4d963099070b0b290f5f806a6d ) ) game ( - name "Kawaii Pet Shop Monogatari 2 (Japan) (Rev 1) (GB Compatible)" - description "Kawaii Pet Shop Monogatari 2 (Japan) (Rev 1) (GB Compatible)" - rom ( name "Kawaii Pet Shop Monogatari 2 (Japan) (Rev 1) (GB Compatible).gbc" size 2097152 crc 6fce1ad0 sha1 58ea410ebbee5edc18644c0467fe9ea03d179b1c flags verified ) + name "Nushi Tsuri Adventure - Kite no Bouken (Japan) (Rumble Version)" + description "Nushi Tsuri Adventure - Kite no Bouken (Japan) (Rumble Version)" + rom ( name "Nushi Tsuri Adventure - Kite no Bouken (Japan) (Rumble Version).gbc" size 2097152 crc ac52f6ef sha1 2c72cfaa3cb1080ed4393e961bf2990a7df79cbe ) ) game ( - name "Keep the Balance (Europe) (En,Fr,De,Es,It)" - description "Keep the Balance (Europe) (En,Fr,De,Es,It)" - rom ( name "Keep the Balance (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc b868e846 sha1 a0bbbb00f0ad1c62ad766b378c9a6c15fbd54991 ) + name "Nv Wang Gedou 2000 (Taiwan) (Unl)" + description "Nv Wang Gedou 2000 (Taiwan) (Unl)" + rom ( name "Nv Wang Gedou 2000 (Taiwan) (Unl).gbc" size 2097152 crc e1668b49 sha1 37516139aa317a16440379c1dc00bdfc4c1e607a flags verified ) ) game ( - name "Keibajou e Ikou! Wide (Japan) (GB Compatible)" - description "Keibajou e Ikou! Wide (Japan) (GB Compatible)" - rom ( name "Keibajou e Ikou! Wide (Japan) (GB Compatible).gbc" size 1048576 crc 710286ea sha1 120c3888f7206ac8b06cea5e9b81dbcd87109ebf ) + name "NYR - New York Race (Europe) (En,Fr,De,Es,It,Pt)" + description "NYR - New York Race (Europe) (En,Fr,De,Es,It,Pt)" + rom ( name "NYR - New York Race (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc 62f560d8 sha1 001decc8331b4beb94a01a1b6ef08e1bf2920ece ) ) game ( - name "Keitai Denjuu Telefang - Power Version (Japan) (GB Compatible)" - description "Keitai Denjuu Telefang - Power Version (Japan) (GB Compatible)" - rom ( name "Keitai Denjuu Telefang - Power Version (Japan) (GB Compatible).gbc" size 2097152 crc 8b61cfcc sha1 baaf7fb9f9958ca22982ba0600bc0cb8a7fc4764 ) + name "O'Leary Manager 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca)" + description "O'Leary Manager 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca)" + rom ( name "O'Leary Manager 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca).gbc" size 1048576 crc 3485761a sha1 724aa0f905d7a6e7b9b2b01a477f424ac95eadf9 ) ) game ( - name "Keitai Denjuu Telefang - Speed Version (Japan) (GB Compatible)" - description "Keitai Denjuu Telefang - Speed Version (Japan) (GB Compatible)" - rom ( name "Keitai Denjuu Telefang - Speed Version (Japan) (GB Compatible).gbc" size 2097152 crc fb528f66 sha1 1c273f9078c580e85e5c49e7114058f3e0fe5cca flags verified ) + name "Oddworld Adventures 2 (USA) (En,Fr,De,Es,It) (GB Compatible)" + description "Oddworld Adventures 2 (USA) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Oddworld Adventures 2 (USA) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc 5c260d5a sha1 a35ccdf0789ce84df3c12cfe7c4b9b98af08ca9a ) ) game ( - name "Kelly Club (USA)" - description "Kelly Club (USA)" - rom ( name "Kelly Club (USA).gbc" size 1048576 crc 6e39ebc4 sha1 d47519a0295c3a76bc68c54ae94ccce039bcd3ee ) + name "Oddworld Adventures 2 (Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "Oddworld Adventures 2 (Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Oddworld Adventures 2 (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc 4b83b14f sha1 c9d4d1dd1c33a9fa9b54e9f2a7a5f6dd90069b91 flags verified ) ) game ( - name "Ken Griffey Jr.'s Slugfest (USA)" - description "Ken Griffey Jr.'s Slugfest (USA)" - rom ( name "Ken Griffey Jr.'s Slugfest (USA).gbc" size 1048576 crc 1e64d19c sha1 2362bdd8c26f30adb871259ce2d909ac6d505e36 ) + name "Ohasuta Dance Dance Revolution GB (Japan)" + description "Ohasuta Dance Dance Revolution GB (Japan)" + rom ( name "Ohasuta Dance Dance Revolution GB (Japan).gbc" size 2097152 crc e338c118 sha1 bec623a9f0d4ca75905bb23595b17d9c33ff0775 ) ) game ( - name "Kero Kero Cowboy (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Kero Kero Cowboy (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Kero Kero Cowboy (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 6a5abba1 sha1 0b3deef7a27201e81b4d39bc0bd10ff7ec73e380 ) + name "Ohasuta Yama-chan & Raymond (Japan) (SGB Enhanced) (GB Compatible)" + description "Ohasuta Yama-chan & Raymond (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Ohasuta Yama-chan & Raymond (Japan) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 840ef32f sha1 373166bc65dd9b6c5734add30a8d278986fc9c98 flags verified ) ) game ( - name "Kettou Transformers Beast Wars - Beast Senshi Saikyou Ketteisen (Japan) (SGB Enhanced) (GB Compatible)" - description "Kettou Transformers Beast Wars - Beast Senshi Saikyou Ketteisen (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kettou Transformers Beast Wars - Beast Senshi Saikyou Ketteisen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 72895639 sha1 db690f46d37e0273c69f24badbb44588a363a84f ) + name "Oide Rascal (Japan)" + description "Oide Rascal (Japan)" + rom ( name "Oide Rascal (Japan).gbc" size 1048576 crc 9e0799f4 sha1 9b73a9dc4424029261579193fdbd5a30ca84052b ) ) game ( - name "Kidou Senkan Nadesico - Ruri Ruri Mahjong (Japan)" - description "Kidou Senkan Nadesico - Ruri Ruri Mahjong (Japan)" - rom ( name "Kidou Senkan Nadesico - Ruri Ruri Mahjong (Japan).gbc" size 2097152 crc 6427cd7a sha1 7f3f408f3835bc8aa9312ba76374436bfbe136fe ) + name "Ojarumaru - Mangan Jinja no Ennichi de Ojaru! (Japan) (GB Compatible)" + description "Ojarumaru - Mangan Jinja no Ennichi de Ojaru! (Japan) (GB Compatible)" + rom ( name "Ojarumaru - Mangan Jinja no Ennichi de Ojaru! (Japan) (GB Compatible).gbc" size 1048576 crc d86507c9 sha1 f17175f7744f97ad4f9943c5dadd4776ad85e5cb ) ) game ( - name "Kikansha Thomas - Sodor-tou no Nakama-tachi (Japan)" - description "Kikansha Thomas - Sodor-tou no Nakama-tachi (Japan)" - rom ( name "Kikansha Thomas - Sodor-tou no Nakama-tachi (Japan).gbc" size 1048576 crc 223bb19c sha1 8abd4406ec19bfecd6d675285fa73ef2d5ea622e ) + name "Ojarumaru - Tsukiyo ga Ike no Takaramono (Japan) (GB Compatible)" + description "Ojarumaru - Tsukiyo ga Ike no Takaramono (Japan) (GB Compatible)" + rom ( name "Ojarumaru - Tsukiyo ga Ike no Takaramono (Japan) (GB Compatible).gbc" size 2097152 crc ed7461d2 sha1 66d87a06d4d951e7695df73f53793a462509e4d0 ) ) game ( - name "Kikstart (World) (Aftermarket) (Unl)" - description "Kikstart (World) (Aftermarket) (Unl)" - rom ( name "Kikstart (World) (Aftermarket) (Unl).gbc" size 524288 crc 9a9f483b sha1 bc472506f73f0c1a3f0a610c0136b324b7635c7f ) + name "Original Moorhuhn Jagd, Die (Germany)" + description "Original Moorhuhn Jagd, Die (Germany)" + rom ( name "Original Moorhuhn Jagd, Die (Germany).gbc" size 1048576 crc 714ec204 sha1 d4f3fe5bdeed4bbf40d3f1eb6eab7a69676c6138 flags verified ) ) game ( - name "Kindaichi Shounen no Jikenbo - 10 Nenme no Shoutaijou (Japan) (SGB Enhanced) (GB Compatible)" - description "Kindaichi Shounen no Jikenbo - 10 Nenme no Shoutaijou (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kindaichi Shounen no Jikenbo - 10 Nenme no Shoutaijou (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc de52ffdc sha1 468ea148eb15eac3b771a2520e0b5248ea5085a1 ) + name "Othello Millennium (Japan) (GB Compatible)" + description "Othello Millennium (Japan) (GB Compatible)" + rom ( name "Othello Millennium (Japan) (GB Compatible).gbc" size 1048576 crc c7800576 sha1 1546e2b676931c87b4a48e77c761f49a8e39b9e7 ) ) game ( - name "King of Fighters R2 (Taiwan) (Unl)" - description "King of Fighters R2 (Taiwan) (Unl)" - rom ( name "King of Fighters R2 (Taiwan) (Unl).gbc" size 1048576 crc 9913e18b sha1 43c2b6f0c3559ed90032cba6569811047f9e20d0 ) + name "Other Life - Azure Dreams GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Other Life - Azure Dreams GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Other Life - Azure Dreams GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c6f1abd4 sha1 9e473df09e962a9accc3f6446140b0333f6a088e ) ) game ( - name "Kinniku Banzuke GB - Chousensha wa Kimida! (Japan) (SGB Enhanced) (GB Compatible)" - description "Kinniku Banzuke GB - Chousensha wa Kimida! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kinniku Banzuke GB - Chousensha wa Kimida! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e2e4328b sha1 75d7e35fea257d8da4c1efcdd6ebdca020c648a6 flags verified ) + name "Ottifanten - Kommando Stoertebeker (Germany)" + description "Ottifanten - Kommando Stoertebeker (Germany)" + rom ( name "Ottifanten - Kommando Stoertebeker (Germany).gbc" size 1048576 crc 3eac3d1c sha1 79c774ab9999cec95087ebe0982b6abba8f4ab91 ) ) game ( - name "Kinniku Banzuke GB 2 - Mezase! Muscle Champion (Japan) (SGB Enhanced) (GB Compatible)" - description "Kinniku Banzuke GB 2 - Mezase! Muscle Champion (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Kinniku Banzuke GB 2 - Mezase! Muscle Champion (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 42de9092 sha1 5ea803b820ff865a4470d7f82b36da6b82f3caec ) + name "Ou Dorobou Jing - Angel Version (Japan) (SGB Enhanced) (GB Compatible)" + description "Ou Dorobou Jing - Angel Version (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Ou Dorobou Jing - Angel Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d47c0dcf sha1 493e37dac6d8b037e44e64f9f31dba7f08a89e08 ) ) game ( - name "Kinniku Banzuke GB 3 - Shinseiki Survival Retsuden! (Japan)" - description "Kinniku Banzuke GB 3 - Shinseiki Survival Retsuden! (Japan)" - rom ( name "Kinniku Banzuke GB 3 - Shinseiki Survival Retsuden! (Japan).gbc" size 4194304 crc e2f6253e sha1 2e5d5adcdbedf45c6ebda0f90ccfa787a24c24d0 ) + name "Ou Dorobou Jing - Devil Version (Japan) (SGB Enhanced) (GB Compatible)" + description "Ou Dorobou Jing - Devil Version (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Ou Dorobou Jing - Devil Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 2a39a874 sha1 71797aa125b88614182ce3d0f8252d6ed8cfa08e ) ) game ( - name "Kirby - Tilt 'n' Tumble (USA)" - description "Kirby - Tilt 'n' Tumble (USA)" - rom ( name "Kirby - Tilt 'n' Tumble (USA).gbc" size 1048576 crc e541acf1 sha1 6ab8d666e2bebbb3fee7796c8968aab2ea21b8f9 flags verified ) + name "Owarai Yoiko no Geemumichi - Oyaji Sagashite 3 Choume (Japan) (SGB Enhanced) (GB Compatible)" + description "Owarai Yoiko no Geemumichi - Oyaji Sagashite 3 Choume (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Owarai Yoiko no Geemumichi - Oyaji Sagashite 3 Choume (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 3f635a4f sha1 21644c1ef67bdd6038686d8522e957e3de803237 ) ) game ( - name "Kirikou (Europe) (En,Fr,De,Es,It,Pt)" - description "Kirikou (Europe) (En,Fr,De,Es,It,Pt)" - rom ( name "Kirikou (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc 783bc02d sha1 b047db711bbef8f8d32fb64aa8e120fc01d1fb76 ) + name "Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible)" + description "Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 3485ef86 sha1 a0a6f55c15dca60350b3a74b1973cc13ff328730 flags verified ) ) game ( - name "Kisekae Series 2 - Oshare Nikki (Japan)" - description "Kisekae Series 2 - Oshare Nikki (Japan)" - rom ( name "Kisekae Series 2 - Oshare Nikki (Japan).gbc" size 2097152 crc 948f4a96 sha1 054065759ff04c508378796ca12a4b578e1c174c ) + name "Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible)" + description "Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f565647f sha1 d80a9d8ba18d5cecff332bab48afdd00bf30df25 ) ) game ( - name "Kisekae Series 2 - Oshare Nikki (Japan) (Rev 1)" - description "Kisekae Series 2 - Oshare Nikki (Japan) (Rev 1)" - rom ( name "Kisekae Series 2 - Oshare Nikki (Japan) (Rev 1).gbc" size 2097152 crc e915337c sha1 1896ec1aa7edb56774afa5d8b93e941aa1e838eb flags verified ) + name "Pachinko CR Mouretsu Genshijin T (Japan) (GB Compatible)" + description "Pachinko CR Mouretsu Genshijin T (Japan) (GB Compatible)" + rom ( name "Pachinko CR Mouretsu Genshijin T (Japan) (GB Compatible).gbc" size 1048576 crc f75e269e sha1 3c473f1e5e849d42e5412dc968d0514f1d85855f ) ) game ( - name "Kisekae Series 3 - Kisekae Hamster (Japan)" - description "Kisekae Series 3 - Kisekae Hamster (Japan)" - rom ( name "Kisekae Series 3 - Kisekae Hamster (Japan).gbc" size 2097152 crc a29d862f sha1 76c0f2e1559ffec3c77043a6df08b6e7240854e2 flags verified ) + name "Pachinko Hisshou Guide - Data no Ousama (Japan) (GB Compatible)" + description "Pachinko Hisshou Guide - Data no Ousama (Japan) (GB Compatible)" + rom ( name "Pachinko Hisshou Guide - Data no Ousama (Japan) (GB Compatible).gbc" size 1048576 crc 1a631bab sha1 9ba368431d307ff4c4455f9befee2ac9b1efb64a ) ) game ( - name "Klax (USA, Europe)" - description "Klax (USA, Europe)" - rom ( name "Klax (USA, Europe).gbc" size 1048576 crc 7181cbd0 sha1 23b5601748bda8e0dba69e589fa2b6d2d79781b3 flags verified ) + name "Pachipachi Pachisurou - New Pulsar Hen (Japan) (SGB Enhanced) (GB Compatible)" + description "Pachipachi Pachisurou - New Pulsar Hen (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pachipachi Pachisurou - New Pulsar Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1e443d1b sha1 969d5352c15e3e5daa891edcda91bd48a8380308 ) ) game ( - name "Klustar (Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "Klustar (Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Klustar (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 262144 crc 577e1521 sha1 b78d832e5d39180d84bf13dde81b923717cb35aa ) + name "Painter (Europe) (Unl)" + description "Painter (Europe) (Unl)" + rom ( name "Painter (Europe) (Unl).gbc" size 262144 crc f4801f21 sha1 78db482d1d12b4556b6a5b995ce37a2435236a06 ) ) game ( - name "Klustar (USA) (GB Compatible)" - description "Klustar (USA) (GB Compatible)" - rom ( name "Klustar (USA) (GB Compatible).gbc" size 262144 crc 3f8d6041 sha1 096748f23f61e83837568c4070a34572d11ff48e ) + name "Paperboy (USA, Europe)" + description "Paperboy (USA, Europe)" + rom ( name "Paperboy (USA, Europe).gbc" size 1048576 crc c0a98305 sha1 b96acf81c82286148c3a2154715aa043e2612a36 ) ) game ( - name "Klustar (Japan) (Proto 2) (1999-09-28) (GB Compatible)" - description "Klustar (Japan) (Proto 2) (1999-09-28) (GB Compatible)" - rom ( name "Klustar (Japan) (Proto 2) (1999-09-28) (GB Compatible).gbc" size 262144 crc 65da9075 sha1 9c60c858f647b42007fc27c5d21f3f57923c4cda ) + name "Papyrus (Europe) (En,Fr,De,Es,It,Nl)" + description "Papyrus (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Papyrus (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc da3a3278 sha1 422c5f48f307820ee7c610e761a30a8cab85aed9 ) ) game ( - name "Klustar (Europe) (En,Fr,De,Es,It) (Beta) (1998-10-01) (GB Compatible)" - description "Klustar (Europe) (En,Fr,De,Es,It) (Beta) (1998-10-01) (GB Compatible)" - rom ( name "Klustar (Europe) (En,Fr,De,Es,It) (Beta) (1998-10-01) (GB Compatible).gbc" size 131072 crc fc56bb35 sha1 7512484c9c84592e65f19f135cbe629f5a1ee84e ) + name "PaZeek (USA) (Proto)" + description "PaZeek (USA) (Proto)" + rom ( name "PaZeek (USA) (Proto).gbc" size 262144 crc 952b0028 sha1 590dc27682dacb8a044b68d76ad3a0548973c390 ) ) game ( - name "Klustar (Japan) (Proto 1) (1998-10-01) (GB Compatible)" - description "Klustar (Japan) (Proto 1) (1998-10-01) (GB Compatible)" - rom ( name "Klustar (Japan) (Proto 1) (1998-10-01) (GB Compatible).gbc" size 131072 crc f9c6e0a5 sha1 4990b427f1b85ceca9646b3edfa921ed160a55a9 ) + name "Perfect Choro Q (Japan)" + description "Perfect Choro Q (Japan)" + rom ( name "Perfect Choro Q (Japan).gbc" size 2097152 crc afa1aac3 sha1 3c7024086f9bedc223c7d482c309336c250ed039 ) ) game ( - name "Knit-Wit (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "Knit-Wit (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Knit-Wit (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f19d5e86 sha1 0f0e01a143182a9784c80a882ac206d02d8679d7 ) + name "Perfect Dark (USA, Europe) (En,Fr,De,Es,It) (Rumble Version)" + description "Perfect Dark (USA, Europe) (En,Fr,De,Es,It) (Rumble Version)" + rom ( name "Perfect Dark (USA, Europe) (En,Fr,De,Es,It) (Rumble Version).gbc" size 4194304 crc 0601bef6 sha1 2d1e47bf3fb4a28ffb82a4fd2ae779ec99aaa87d flags verified ) ) game ( - name "Knockout Kings (USA, Europe)" - description "Knockout Kings (USA, Europe)" - rom ( name "Knockout Kings (USA, Europe).gbc" size 1048576 crc a0d64934 sha1 a04d86a384c5c417bf9f1219eb14829d0459f469 flags verified ) + name "Peugeot - Orbital Diagnostic System (Unknown) (Unl) [b]" + description "Peugeot - Orbital Diagnostic System (Unknown) (Unl) [b]" + rom ( name "Peugeot - Orbital Diagnostic System (Unknown) (Unl) [b].gbc" size 1048576 crc f971fce9 sha1 6bc140722fad759830fd6e4b6ac0b41443795fb2 flags baddump ) ) game ( - name "Koenig der Loewen, Der - Simbas grosses Abenteuer (Germany)" - description "Koenig der Loewen, Der - Simbas grosses Abenteuer (Germany)" - rom ( name "Koenig der Loewen, Der - Simbas grosses Abenteuer (Germany).gbc" size 1048576 crc ea11e39c sha1 e04daabfdb6c9147a030ffb892bf77eafb1b0ba2 ) + name "Peugeot - Orbital Diagnostic System (Unknown) (Alt) (Unl) [b]" + description "Peugeot - Orbital Diagnostic System (Unknown) (Alt) (Unl) [b]" + rom ( name "Peugeot - Orbital Diagnostic System (Unknown) (Alt) (Unl) [b].gbc" size 32768 crc 424912fe sha1 bd5735021e4593ec07082e6197e683496d0ecf0b flags baddump ) ) game ( - name "Koguru Guruguru - Guruguru to Nakayoshi (Japan) (SGB Enhanced, GB Compatible) (NP)" - description "Koguru Guruguru - Guruguru to Nakayoshi (Japan) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Koguru Guruguru - Guruguru to Nakayoshi (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 1048576 crc d6050f64 sha1 6bf1d7517c762a8b692e149529d826504b8f483e ) + name "Phantom Zona (Japan) (SGB Enhanced) (GB Compatible)" + description "Phantom Zona (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Phantom Zona (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 3e43f25f sha1 bf2162f970a9dbb658afbdd7354155768daa96b1 flags verified ) ) game ( - name "Konami GB Collection Vol.1 (Europe) (GB Compatible)" - description "Konami GB Collection Vol.1 (Europe) (GB Compatible)" - rom ( name "Konami GB Collection Vol.1 (Europe) (GB Compatible).gbc" size 1048576 crc 203f8727 sha1 760abb9e3950f39bf01320e414a4f4d516e04c83 ) + name "Pia Carrot e Youkoso!! 2.2 (Japan)" + description "Pia Carrot e Youkoso!! 2.2 (Japan)" + rom ( name "Pia Carrot e Youkoso!! 2.2 (Japan).gbc" size 4194304 crc 2267360b sha1 e18cd437c52ca37c6c13ba71e0bd50f1b517a8d6 ) ) game ( - name "Konami GB Collection Vol.2 (Europe) (GB Compatible)" - description "Konami GB Collection Vol.2 (Europe) (GB Compatible)" - rom ( name "Konami GB Collection Vol.2 (Europe) (GB Compatible).gbc" size 1048576 crc a6499792 sha1 7a726cac1d459986edebd2cc8f4a84d7369353dd ) + name "Pian Wai Zhang - Huangjin Taiyang - Fengyin de Yuangu Lianjin Shu (Taiwan) (Unl)" + description "Pian Wai Zhang - Huangjin Taiyang - Fengyin de Yuangu Lianjin Shu (Taiwan) (Unl)" + rom ( name "Pian Wai Zhang - Huangjin Taiyang - Fengyin de Yuangu Lianjin Shu (Taiwan) (Unl).gbc" size 2097152 crc 0db9fdfa sha1 6d2acdca141001bfefdcbf0076702fec6619e368 ) ) game ( - name "Konami GB Collection Vol.3 (Europe) (GB Compatible)" - description "Konami GB Collection Vol.3 (Europe) (GB Compatible)" - rom ( name "Konami GB Collection Vol.3 (Europe) (GB Compatible).gbc" size 1048576 crc d4d6243d sha1 748248b0f837b89f00a8af868f2262d27302eb5c ) + name "Piecrust (World) (Unl)" + description "Piecrust (World) (Unl)" + rom ( name "Piecrust (World) (Unl).gbc" size 32768 crc f39c8119 sha1 b01cad9652bf1c65151dd8d2bd21251a9cf44d43 ) ) game ( - name "Konami GB Collection Vol.4 (Europe) (GB Compatible)" - description "Konami GB Collection Vol.4 (Europe) (GB Compatible)" - rom ( name "Konami GB Collection Vol.4 (Europe) (GB Compatible).gbc" size 1048576 crc 8800f1c9 sha1 4c0c9e9cba36bfe5588e2a2dc799d207afd1321e ) + name "Pitfall - Beyond the Jungle (USA, Europe) (GB Compatible)" + description "Pitfall - Beyond the Jungle (USA, Europe) (GB Compatible)" + rom ( name "Pitfall - Beyond the Jungle (USA, Europe) (GB Compatible).gbc" size 1048576 crc f911bb5d sha1 249e4c0370961eaff6bdcff20a0bd8e42aba2393 ) ) game ( - name "Konami Winter Games (Europe)" - description "Konami Winter Games (Europe)" - rom ( name "Konami Winter Games (Europe).gbc" size 1048576 crc 1c644040 sha1 2b51f52560226dec0467e5bf4897cd12e8453888 ) + name "Pitfall GB (Japan) (GB Compatible)" + description "Pitfall GB (Japan) (GB Compatible)" + rom ( name "Pitfall GB (Japan) (GB Compatible).gbc" size 1048576 crc fa09cebe sha1 5b8ed6b038084890ce198133a7ae8ca93257d0f8 ) ) game ( - name "Konchuu Fighters (Japan)" - description "Konchuu Fighters (Japan)" - rom ( name "Konchuu Fighters (Japan).gbc" size 2097152 crc c6758b0b sha1 8bb171b72c3bb761de07954299b5aa379145e8f1 ) + name "Planet of the Apes (Europe) (En,Fr,De,Es,It,Nl)" + description "Planet of the Apes (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Planet of the Apes (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc a92dcb79 sha1 fa8ca9a374fa3151ae912c7210b116d9fe0fce2b ) ) game ( - name "Konchuu Hakase 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Konchuu Hakase 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Konchuu Hakase 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b6381744 sha1 e4bcfb94aa1c09a013a03f26f978b32e74f70d23 ) + name "Planet of the Apes (USA) (En,Fr,De,Es,It,Nl)" + description "Planet of the Apes (USA) (En,Fr,De,Es,It,Nl)" + rom ( name "Planet of the Apes (USA) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 91d7ccca sha1 84b616c937b9dcc7cdcb05f583a4d60467ede385 ) ) game ( - name "Konchuu Hakase 2 (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Konchuu Hakase 2 (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Konchuu Hakase 2 (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc d390430e sha1 59fa1707247f12b0c48eeb2e8fec274b9231d968 ) + name "Player Manager 2001 (Europe) (En,Fr)" + description "Player Manager 2001 (Europe) (En,Fr)" + rom ( name "Player Manager 2001 (Europe) (En,Fr).gbc" size 1048576 crc 375c35e0 sha1 6e21a85257361be76914f418409124c5bc315429 ) ) game ( - name "Konchuu Hakase 3 (Japan)" - description "Konchuu Hakase 3 (Japan)" - rom ( name "Konchuu Hakase 3 (Japan).gbc" size 2097152 crc 380f19ed sha1 4066434fe741a071e2072aee44fdf1b5eecde258 ) + name "Pocket Billiards - Funk the 9 Ball (Japan)" + description "Pocket Billiards - Funk the 9 Ball (Japan)" + rom ( name "Pocket Billiards - Funk the 9 Ball (Japan).gbc" size 1048576 crc 3b46e7c9 sha1 24673a0d0c274d8eda3b3952d63772c65778b8c3 ) ) game ( - name "Korokoro Kirby (Japan)" - description "Korokoro Kirby (Japan)" - rom ( name "Korokoro Kirby (Japan).gbc" size 1048576 crc c0face3d sha1 8dd46f6d34c831c910c4574f252fa47ce6f67261 flags verified ) + name "Pocket Bomberman (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Pocket Bomberman (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket Bomberman (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc fa2a66e9 sha1 b0ae803600e06cd1cc9a0d801f2511c9ecc50584 flags verified ) ) game ( - name "Koto Battle - Tengai no Moribito (Japan)" - description "Koto Battle - Tengai no Moribito (Japan)" - rom ( name "Koto Battle - Tengai no Moribito (Japan).gbc" size 2097152 crc 430eb1e1 sha1 ac30025352026b34a0d9ccede82862f6e04aaf00 ) + name "Pocket Bowling (Japan) (GB Compatible)" + description "Pocket Bowling (Japan) (GB Compatible)" + rom ( name "Pocket Bowling (Japan) (GB Compatible).gbc" size 524288 crc 26589b79 sha1 8a29e82be027a82030c1dc7f7cf9bc9ecf010e64 ) ) game ( - name "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl)" - description "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl)" - rom ( name "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl).gbc" size 1048576 crc 14355371 sha1 f398086d1f8cb435a632e5ea45fb19e980b0568d ) + name "Pocket Bowling (USA) (GB Compatible)" + description "Pocket Bowling (USA) (GB Compatible)" + rom ( name "Pocket Bowling (USA) (GB Compatible).gbc" size 524288 crc 3ed30908 sha1 5435ccec39ef27d9cab626425671bd81e7fa4d55 ) ) game ( - name "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl) (Alt)" - description "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl) (Alt)" - rom ( name "Koudai Guaishou - Dongzuo Pian (Taiwan) (En) (Unl) (Alt).gbc" size 1048576 crc ec2fbdfd sha1 c7a1020797b57d292e16c5297199d977e025256b ) + name "Pocket Color Billiards (Japan)" + description "Pocket Color Billiards (Japan)" + rom ( name "Pocket Color Billiards (Japan).gbc" size 1048576 crc 911007e1 sha1 7d2f568887449d7d34e82022007568c035949539 ) ) game ( - name "Koudai Guaishou - Feicui Ban (Taiwan) (Unl)" - description "Koudai Guaishou - Feicui Ban (Taiwan) (Unl)" - rom ( name "Koudai Guaishou - Feicui Ban (Taiwan) (Unl).gbc" size 2097152 crc 8494465f sha1 a3b2818c778fe6b5811841a9f28a1a06334216ea ) + name "Pocket Color Block (Japan) (SGB Enhanced) (GB Compatible)" + description "Pocket Color Block (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket Color Block (Japan) (SGB Enhanced) (GB Compatible).gbc" size 131072 crc 389cf56f sha1 84d243c64f98731965ca78b75ad48f8787d3c907 ) ) game ( - name "Koudai Guaishou - Sheng Bianshi (China) (Unl)" - description "Koudai Guaishou - Sheng Bianshi (China) (Unl)" - rom ( name "Koudai Guaishou - Sheng Bianshi (China) (Unl).gbc" size 2097152 crc 0791c3a7 sha1 8a61c2dc4d1acf96d8ae871b0f371c7f8a17e9f1 ) + name "Pocket Color Mahjong (Japan) (GB Compatible)" + description "Pocket Color Mahjong (Japan) (GB Compatible)" + rom ( name "Pocket Color Mahjong (Japan) (GB Compatible).gbc" size 1048576 crc 08dc0af4 sha1 23067c8b37f283facc5c3a8e96c804ddd53aeaf4 ) ) game ( - name "Koudai Yaoguai - Baijin Ban (Taiwan) (Unl)" - description "Koudai Yaoguai - Baijin Ban (Taiwan) (Unl)" - rom ( name "Koudai Yaoguai - Baijin Ban (Taiwan) (Unl).gbc" size 2097152 crc 998ad382 sha1 f9013985d7c40eccfa863e2ba808e64deaa4b384 ) + name "Pocket Color Trump (Japan) (GB Compatible)" + description "Pocket Color Trump (Japan) (GB Compatible)" + rom ( name "Pocket Color Trump (Japan) (GB Compatible).gbc" size 1048576 crc c73eb10e sha1 ddc9846964a19e8702f226ffd9060b94a60011c3 ) ) game ( - name "Koudai Yaoguai Lu Baoshi (Taiwan) (Unl)" - description "Koudai Yaoguai Lu Baoshi (Taiwan) (Unl)" - rom ( name "Koudai Yaoguai Lu Baoshi (Taiwan) (Unl).gbc" size 2097152 crc ee74e4a2 sha1 59e4550bd3958464188fd9b8c11b2dc1c9ad7d06 ) + name "Pocket Cooking (Japan)" + description "Pocket Cooking (Japan)" + rom ( name "Pocket Cooking (Japan).gbc" size 4194304 crc f5ab554d sha1 60a13fc904100655a52dfb61d9abe77cc126e58c flags verified ) ) game ( - name "Koushien Pocket (Japan) (SGB Enhanced) (GB Compatible)" - description "Koushien Pocket (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Koushien Pocket (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6910ff3a sha1 a677bf07c67925ded32799d6a8eb63ec99c01bb7 flags verified ) + name "Pocket Densha 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Pocket Densha 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket Densha 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4d26e880 sha1 859331f57a964197f271acafa7e8dc586e598cf5 ) ) game ( - name "Land Before Time, The (Europe) (En,Fr,De,Es,It)" - description "Land Before Time, The (Europe) (En,Fr,De,Es,It)" - rom ( name "Land Before Time, The (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc f253e082 sha1 9d7a8b923116093b9ee9415603a4ac9d15dcf8e3 ) + name "Pocket Family GB 2 (Japan)" + description "Pocket Family GB 2 (Japan)" + rom ( name "Pocket Family GB 2 (Japan).gbc" size 2097152 crc 2a273244 sha1 fc88fcf5aab548936cd6617c4e2ea07b77ee43c8 flags verified ) ) game ( - name "Land Before Time, The (USA)" - description "Land Before Time, The (USA)" - rom ( name "Land Before Time, The (USA).gbc" size 1048576 crc bce9cb16 sha1 320524e7ee7061af3bb6e89a0c4b68c517a75752 ) + name "Pocket GI Stable (Japan) (SGB Enhanced) (GB Compatible)" + description "Pocket GI Stable (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket GI Stable (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc c424874e sha1 f818e6284d198f4b394f79cb8511c9b906d69f03 ) ) game ( - name "Langrsr II (Taiwan) (En) (Unl)" - description "Langrsr II (Taiwan) (En) (Unl)" - rom ( name "Langrsr II (Taiwan) (En) (Unl).gbc" size 2097152 crc 34c1a63a sha1 747707afd771d73dbbdeeeaec1c1201f2729fb8a ) + name "Pocket Golf! (USA) (Proto) (SGB Enhanced) (GB Compatible)" + description "Pocket Golf! (USA) (Proto) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket Golf! (USA) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc d06ecb1f sha1 bbe2651547c1f3c79bbf822b41ddbb54133a489f ) ) game ( - name "Laofuzi Chuanqi (Taiwan) (Unl)" - description "Laofuzi Chuanqi (Taiwan) (Unl)" - rom ( name "Laofuzi Chuanqi (Taiwan) (Unl).gbc" size 2097152 crc aeca45be sha1 b7193fcb8b9b8958a2522be0d1a3874cffc1e1db ) + name "Pocket GT (USA) (Proto)" + description "Pocket GT (USA) (Proto)" + rom ( name "Pocket GT (USA) (Proto).gbc" size 1048576 crc 9e120d94 sha1 c48f302009c405aa379ebf048bc46a284a74c84c ) ) game ( - name "Las Vegas Cool Hand (USA) (GB Compatible)" - description "Las Vegas Cool Hand (USA) (GB Compatible)" - rom ( name "Las Vegas Cool Hand (USA) (GB Compatible).gbc" size 524288 crc bef1cde4 sha1 c7423c03e5976f85de361fe1b83dfee11e75a60f flags verified ) + name "Pocket GT (Japan)" + description "Pocket GT (Japan)" + rom ( name "Pocket GT (Japan).gbc" size 1048576 crc 2ac77c5a sha1 035e2284654751491fafb9d752740eefc2aa80cd ) ) game ( - name "Laser Squad Alter (World) (Aftermarket) (Unl)" - description "Laser Squad Alter (World) (Aftermarket) (Unl)" - rom ( name "Laser Squad Alter (World) (Aftermarket) (Unl).gbc" size 1048576 crc 32f24248 sha1 26f4efe636214e72ec724f8887ca79fbc8abad80 ) + name "Pocket Hanafuda (Japan)" + description "Pocket Hanafuda (Japan)" + rom ( name "Pocket Hanafuda (Japan).gbc" size 262144 crc af0c51b8 sha1 339e97a223da844efe889e18eaced20756b0ba28 ) ) game ( - name "Last Crown Warriors (World) (v1.0.1) (Demo) (Kickstarter) (GB Compatible) (Aftermarket) (Unl)" - description "Last Crown Warriors (World) (v1.0.1) (Demo) (Kickstarter) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Last Crown Warriors (World) (v1.0.1) (Demo) (Kickstarter) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 4a58315b sha1 5a234e33f7429b48f4374b5989e6df4d20352b4c ) + name "Pocket King (Japan) (SGB Enhanced) (GB Compatible)" + description "Pocket King (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket King (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc dee71d44 sha1 ceb6679568dca09212e758cbf76a170c4719aae1 ) ) game ( - name "Last Crown Warriors (World) (v2.1.0) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Last Crown Warriors (World) (v2.1.0) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Last Crown Warriors (World) (v2.1.0) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 5c405584 sha1 3ee043ba17f46a6afbbba8ac05f35d093b817fbc ) + name "Pocket Lure Boy (Japan)" + description "Pocket Lure Boy (Japan)" + rom ( name "Pocket Lure Boy (Japan).gbc" size 1048576 crc 35a29628 sha1 2cc7337a2b6ac37238ac1cdaf8e7966bd9493295 ) ) game ( - name "Last Crown Warriors (World) (v2.1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Last Crown Warriors (World) (v2.1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Last Crown Warriors (World) (v2.1.1) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 9a134100 sha1 75b5188a5b8a720ff08894379147c7870ac8825d ) + name "Pocket Monsters - Crystal Version (Japan)" + description "Pocket Monsters - Crystal Version (Japan)" + rom ( name "Pocket Monsters - Crystal Version (Japan).gbc" size 2097152 crc 270c4ecc sha1 95127b901bbce2407daf43cce9f45d4c27ef635d flags verified ) ) game ( - name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da)" - description "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da)" - rom ( name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da).gbc" size 1048576 crc a58c8282 sha1 47e5c4c7fa447efc8a0abf019e8d2cd227c5e0e3 ) + name "Pocket Monsters - Crystal Version (Taiwan) (Unl)" + description "Pocket Monsters - Crystal Version (Taiwan) (Unl)" + rom ( name "Pocket Monsters - Crystal Version (Taiwan) (Unl).gbc" size 2097152 crc 4b2b8b57 sha1 9a2b381a134bb7ed1b566bb6f94596b57e690a4e ) ) game ( - name "Laura (USA)" - description "Laura (USA)" - rom ( name "Laura (USA).gbc" size 1048576 crc e2bff286 sha1 3fe3eb99ee818c94e9a07e19640af6a2aad33903 ) + name "Pocket Monsters Diamond (Taiwan) (En) (Unl)" + description "Pocket Monsters Diamond (Taiwan) (En) (Unl)" + rom ( name "Pocket Monsters Diamond (Taiwan) (En) (Unl).gbc" size 2097152 crc 41e3723c sha1 47391ca3d68c41a627e1bb5cf987425ce391abf0 ) ) game ( - name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Beta)" - description "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Beta)" - rom ( name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Beta).gbc" size 1048576 crc f90a3dae sha1 772539821e4b703259b2e2ad535d74a03fa22760 ) + name "Pocket Monsters Eun (Korea)" + description "Pocket Monsters Eun (Korea)" + rom ( name "Pocket Monsters Eun (Korea).gbc" size 2097152 crc 9cc1f90f sha1 cb22d7e03a74dc3a563fde6be8626626b2b392e7 flags verified ) ) game ( - name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Rev 1) (Proto)" - description "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Rev 1) (Proto)" - rom ( name "Laura (Europe) (En,Fr,De,Es,It,Nl,Sv,Da) (Rev 1) (Proto).gbc" size 1048576 crc cf8e2371 sha1 f7b19c1501d325dd8ee219ccae2eaca130a5a21b ) + name "Pocket Monsters Geum (Korea)" + description "Pocket Monsters Geum (Korea)" + rom ( name "Pocket Monsters Geum (Korea).gbc" size 2097152 crc 249a7a66 sha1 c0ff3999e1093e1af59ef3eea3f1bfd7c1f18a65 ) ) game ( - name "Le Mans 24 Hours (Europe) (En,Fr,De,Es,It)" - description "Le Mans 24 Hours (Europe) (En,Fr,De,Es,It)" - rom ( name "Le Mans 24 Hours (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 1b49d07d sha1 cb4847cd63c8cc52f04bf4d86d54954be3d8fc1a ) + name "Pocket Monsters Gin (Japan) (SGB Enhanced) (GB Compatible)" + description "Pocket Monsters Gin (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket Monsters Gin (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc be1b928a sha1 fa8c51059c1642faa570db56ef089f54d1d2011f ) ) game ( - name "Leaper (World) (Aftermarket) (Unl)" - description "Leaper (World) (Aftermarket) (Unl)" - rom ( name "Leaper (World) (Aftermarket) (Unl).gbc" size 524288 crc ed8cd385 sha1 425db2916263121f4aee91a8cab6286e39364f87 ) + name "Pocket Monsters Gin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Pocket Monsters Gin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket Monsters Gin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0aea5383 sha1 a11d5ddc26eb826086593f82370b15d16404d33e flags verified ) ) game ( - name "Legacy of Verintia (World) (2023-05-15) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Legacy of Verintia (World) (2023-05-15) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Legacy of Verintia (World) (2023-05-15) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 953e25d1 sha1 018c7cada41e693a02b9c596d307b0aa9207eef4 ) + name "Pocket Monsters Kin (Japan) (SGB Enhanced) (GB Compatible)" + description "Pocket Monsters Kin (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket Monsters Kin (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 524478d4 sha1 8814f1039450a5d3684b1389f588ccd7ee7c3436 flags verified ) ) game ( - name "Legacy of Verintia (World) (2023-05-31) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Legacy of Verintia (World) (2023-05-31) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Legacy of Verintia (World) (2023-05-31) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 1096252a sha1 c22cc79b25a05afad66e769dc0365b7c25f1bb85 ) + name "Pocket Monsters Kin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Pocket Monsters Kin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket Monsters Kin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4ef7f2a5 sha1 a222402235d484ee8e39f3f31bae57cf13daf585 flags verified ) ) game ( - name "Legend of the River King 2 (Europe) (SGB Enhanced) (GB Compatible)" - description "Legend of the River King 2 (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of the River King 2 (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f24d010a sha1 ae8ee704b968576cf2cd0a93dc5b42f8f63c48eb ) + name "Pocket Music (Europe) (En,Fr,De,Es,It)" + description "Pocket Music (Europe) (En,Fr,De,Es,It)" + rom ( name "Pocket Music (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 1bfb531e sha1 74dc5efab773fde400304d3df8034a095af8a742 ) ) game ( - name "Legend of the River King 2 (USA) (SGB Enhanced) (GB Compatible)" - description "Legend of the River King 2 (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of the River King 2 (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 840fd525 sha1 1155f2d5cc56c8275855b02a8b3826648cc5e904 ) + name "Pocket Music (USA) (En,Es) (Proto)" + description "Pocket Music (USA) (En,Es) (Proto)" + rom ( name "Pocket Music (USA) (En,Es) (Proto).gbc" size 1048576 crc c4387812 sha1 ad547a79af864eb56a18e1c2ad4346eb35df41ed ) ) game ( - name "Legend of the River King GB (Europe) (SGB Enhanced) (GB Compatible)" - description "Legend of the River King GB (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of the River King GB (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 87ef9530 sha1 31a5a32625532ded19d6eccfc283c4f049ae31b5 ) + name "Pocket no Naka no Oukoku (Japan) (Proto)" + description "Pocket no Naka no Oukoku (Japan) (Proto)" + rom ( name "Pocket no Naka no Oukoku (Japan) (Proto).gbc" size 2097152 crc 1eed33c6 sha1 b91750cc805beb753e3c61a99c256d9cc006d3b8 ) ) game ( - name "Legend of the River King GB (Germany) (SGB Enhanced) (GB Compatible)" - description "Legend of the River King GB (Germany) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of the River King GB (Germany) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1241f3f5 sha1 e0e0522ba283df632adbf2fe6f9aba85e1a7efec ) + name "Pocket Pro Wrestling - Perfect Wrestler (Japan)" + description "Pocket Pro Wrestling - Perfect Wrestler (Japan)" + rom ( name "Pocket Pro Wrestling - Perfect Wrestler (Japan).gbc" size 2097152 crc d4ebba41 sha1 1b029aa7097672c469e48179d45534ab33fcca1d ) ) game ( - name "Legend of the River King GBC (USA) (SGB Enhanced) (GB Compatible)" - description "Legend of the River King GBC (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of the River King GBC (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 7e821f47 sha1 1773c4719c3134845a91fef3a897034d5a70825e ) + name "Pocket Pro Yakyuu (Japan)" + description "Pocket Pro Yakyuu (Japan)" + rom ( name "Pocket Pro Yakyuu (Japan).gbc" size 1048576 crc 2a6ef6a8 sha1 4fbbc6bd6a1631b92218632540e242820ec889ca ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (France) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (France) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f48824fe sha1 9a679e30b03e119a21ae7daac65e73e0ef4e0894 ) + name "Pocket Puyo Puyo Sun (Japan) (SGB Enhanced) (GB Compatible)" + description "Pocket Puyo Puyo Sun (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pocket Puyo Puyo Sun (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 45661ec3 sha1 c2f72fad1a26ad765eb3036f0c9e9e8945133d3a flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4e2b75e7 sha1 b5e4df1a67432c609fa0f23519315297c6dcdc1d ) + name "Pocket Puyo Puyo-n (Japan)" + description "Pocket Puyo Puyo-n (Japan)" + rom ( name "Pocket Puyo Puyo-n (Japan).gbc" size 1048576 crc 870db337 sha1 a86d4a24b5da3444b1967362b13d321b5c4f7a64 ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (Germany) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (Germany) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc fed5959b sha1 8cd9d786547bfb3ddbe16ad2a84a36cf895ac16e ) + name "Pocket Puyo Puyo-n (Japan) (Rev 1)" + description "Pocket Puyo Puyo-n (Japan) (Rev 1)" + rom ( name "Pocket Puyo Puyo-n (Japan) (Rev 1).gbc" size 1048576 crc c884037a sha1 3d52805f712e6d1ce22b88dfebfcac2a31743ff3 flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc efb76777 sha1 7f5c39fa297cb17abf51c6f91fbdebc9f07e3de8 flags verified ) + name "Pocket Puyo Puyo-n (Japan) (Rev 2)" + description "Pocket Puyo Puyo-n (Japan) (Rev 2)" + rom ( name "Pocket Puyo Puyo-n (Japan) (Rev 2).gbc" size 1048576 crc 573613d7 sha1 09b217161ac326da63887693281b60751ca2dfcf flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 97822948 sha1 d90ac17e9bf17b6c61624ad9f05447bdb5efc01a flags verified ) + name "Pocket Racing (Europe)" + description "Pocket Racing (Europe)" + rom ( name "Pocket Racing (Europe).gbc" size 1048576 crc fbf97372 sha1 76cdbd2fe7a2ad49c22083cd49f444ee51c4d140 ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b38eb9de sha1 363d184d9b1e9faa5a2facd80897b7e118446164 ) + name "Pocket Smash Out (Europe) (Unl)" + description "Pocket Smash Out (Europe) (Unl)" + rom ( name "Pocket Smash Out (Europe) (Unl).gbc" size 262144 crc cbd14276 sha1 0a721164053a8b2765ea9826a0958415701ca6f5 ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 06887a34 sha1 1c091225688d966928cc74336dbef2e07d12a47c flags verified ) + name "Pocket Smash Out & Race Time (Europe) (Unl)" + description "Pocket Smash Out & Race Time (Europe) (Unl)" + rom ( name "Pocket Smash Out & Race Time (Europe) (Unl).gbc" size 524288 crc 0ad5b775 sha1 01f68a0a45408da9892b8cc0a4a9c688dcdd9618 ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (France) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (France) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible).gbc" size 1015808 crc c17259db sha1 a5a6f0251e8eafd0a02b1eeceaa5b51705c12f0d ) + name "Pocket Soccer (Europe) (En,Fr,De,Es,It,Pt)" + description "Pocket Soccer (Europe) (En,Fr,De,Es,It,Pt)" + rom ( name "Pocket Soccer (Europe) (En,Fr,De,Es,It,Pt).gbc" size 2097152 crc e8f5824f sha1 4d06ea937a02a8f458186a9382994b09a97481a4 ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (France) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (France) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible).gbc" size 1015808 crc 8afd751e sha1 797925a26eb39656aea60e10c8e9dd986b515b53 ) + name "Pokemon - Crystal Version (Australia)" + description "Pokemon - Crystal Version (Australia)" + rom ( name "Pokemon - Crystal Version (Australia).gbc" size 2097152 crc bb6dd80c sha1 a0fc810f1d4e124434f7be2c989ab5b5892ddf36 flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-23) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-23) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-23) (SGB Enhanced) (GB Compatible).gbc" size 1015808 crc 0559bc89 sha1 dbe7a909c71d407f01af2cdb0aaf7d164ac7a9bd ) + name "Pokemon - Crystal Version (USA)" + description "Pokemon - Crystal Version (USA)" + rom ( name "Pokemon - Crystal Version (USA).gbc" size 2097152 crc ee6f5188 sha1 f4cd194bdee0d04ca4eac29e09b8e4e9d818c133 flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (Germany) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (Germany) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Beta) (1998-12-11) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc be5e366e sha1 6bcd23a3a8afde7c220bc1da4e32d47749139305 ) + name "Pokemon - Crystal Version (USA, Europe) (Rev 1)" + description "Pokemon - Crystal Version (USA, Europe) (Rev 1)" + rom ( name "Pokemon - Crystal Version (USA, Europe) (Rev 1).gbc" size 2097152 crc 3358e30a sha1 f2f52230b536214ef7c9924f483392993e226cfb flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 84415b28 sha1 95417ae15e0b89c918d97e2e658056a6869eb0ef ) + name "Pokemon - Edicion Cristal (Spain)" + description "Pokemon - Edicion Cristal (Spain)" + rom ( name "Pokemon - Edicion Cristal (Spain).gbc" size 2097152 crc ff0a6f8a sha1 889a06fc0bb863666865aa69def0adf97945ac2a ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 33c65722 sha1 b76adb353acf520084529c4f9c9cd137b07016c5 ) + name "Pokemon - Edicion Oro (Spain) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Edicion Oro (Spain) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Edicion Oro (Spain) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 3434a92b sha1 162ea54c6a3cff374642e6dd842f9bffac847e7b ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc fdccc2bd sha1 6daa7e77b0f329da5641e61bcdb0fecf941437f0 ) + name "Pokemon - Edicion Plata (Spain) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Edicion Plata (Spain) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Edicion Plata (Spain) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 1d9faac5 sha1 05bd978ab2cb104b0aff3f696896e30885203a18 ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-09-04) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 865cc1ed sha1 7d78f4bda653ff76618a38f33444602d1b54b206 ) + name "Pokemon - Gold Version (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Gold Version (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Gold Version (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 6bde3c3e sha1 d8b8a3600a465308c9953dfa04f0081c05bdcb94 flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (France) (Rev 1) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 05f23861 sha1 a3f5445fcb463e801b70466e736fe2d495581289 ) + name "Pokemon - Goldene Edition (Germany) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Goldene Edition (Germany) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Goldene Edition (Germany) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4889dfaa sha1 9254195d461ea942eaaa08cc4b83de3cf82aea0d flags verified ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-07) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-07) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-09-07) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 5715d896 sha1 8b8eeb368dfadc73e4f051fb53134974d688491d ) + name "Pokemon - Kristall-Edition (Germany)" + description "Pokemon - Kristall-Edition (Germany)" + rom ( name "Pokemon - Kristall-Edition (Germany).gbc" size 2097152 crc 616d85de sha1 accb584293ba056152f1fd908439b019017ff2fe ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (Europe) (Rev 2) (Beta) (1999-09-19) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (Europe) (Rev 2) (Beta) (1999-09-19) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (Europe) (Rev 2) (Beta) (1999-09-19) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f9a66cda sha1 eb862e0ab4d0456d98187ddfb4948cd45d923f6d ) + name "Pokemon - La Version Esmeralda - Special Pikachu Edition (Spain) (Pirate)" + description "Pokemon - La Version Esmeralda - Special Pikachu Edition (Spain) (Pirate)" + rom ( name "Pokemon - La Version Esmeralda - Special Pikachu Edition (Spain) (Pirate).gbc" size 524288 crc 0d009399 sha1 9e953c1acccd3527a555cf4ba25da38adf99755c ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (USA, Europe) (Rev 2) (Beta) (1999-08-19) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a8855c67 sha1 a86161ca5ce9e1e8c7a6ab0931edb12a1ace5f39 ) + name "Pokemon - Mewtwo Strikes Back (Taiwan) (Zh) (Unl)" + description "Pokemon - Mewtwo Strikes Back (Taiwan) (Zh) (Unl)" + rom ( name "Pokemon - Mewtwo Strikes Back (Taiwan) (Zh) (Unl).gbc" size 524288 crc 2930fa45 sha1 382a257199720d970f58e94cd4102acb809dec07 ) ) game ( - name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" - description "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" - rom ( name "Legend of Zelda, The - Link's Awakening DX (Germany) (Rev 1) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 3e88a24a sha1 1cbca5313b1c0163620d7d81b649f158ba59e6b3 ) + name "Pokemon - Mewtwo Strikes Back (Taiwan) (En) (Unl)" + description "Pokemon - Mewtwo Strikes Back (Taiwan) (En) (Unl)" + rom ( name "Pokemon - Mewtwo Strikes Back (Taiwan) (En) (Unl).gbc" size 524288 crc 6e447a33 sha1 079b9d8190e8df451882f6eabc2799f82fbb9ec0 ) ) game ( - name "Legend of Zelda, The - Oracle of Ages (Europe) (En,Fr,De,Es,It)" - description "Legend of Zelda, The - Oracle of Ages (Europe) (En,Fr,De,Es,It)" - rom ( name "Legend of Zelda, The - Oracle of Ages (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 5933e3fa sha1 9f2dff3c46406839f839a8d535353dfc1e3e8670 flags verified ) + name "Pokemon - Sapphire Version (USA) (Unl)" + description "Pokemon - Sapphire Version (USA) (Unl)" + rom ( name "Pokemon - Sapphire Version (USA) (Unl).gbc" size 2097152 crc 71536b8e sha1 88818c67fb1d9ae5c06e8213f09342d230923113 ) ) game ( - name "Legend of Zelda, The - Oracle of Ages (USA, Australia)" - description "Legend of Zelda, The - Oracle of Ages (USA, Australia)" - rom ( name "Legend of Zelda, The - Oracle of Ages (USA, Australia).gbc" size 1048576 crc 3800a387 sha1 880374fb978b18af4aa529e2e32f7ffb4d7dd2f4 flags verified ) + name "Pokemon - Silberne Edition (Germany) (Beta) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Silberne Edition (Germany) (Beta) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Silberne Edition (Germany) (Beta) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 576f5ced sha1 76fa60d66b2f22a035adc54c61aad9a415c894cd flags verified ) ) game ( - name "Legend of Zelda, The - Oracle of Seasons (Europe) (En,Fr,De,Es,It)" - description "Legend of Zelda, The - Oracle of Seasons (Europe) (En,Fr,De,Es,It)" - rom ( name "Legend of Zelda, The - Oracle of Seasons (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc dbac1357 sha1 360b9408e569ba826212eac1ebea1b09573cb48c flags verified ) + name "Pokemon - Silberne Edition (Germany) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Silberne Edition (Germany) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Silberne Edition (Germany) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 96c9db95 sha1 8ecc58d621faaedf2a934bd2583d527220df7bb9 flags verified ) ) game ( - name "Legend of Zelda, The - Oracle of Seasons (USA, Australia)" - description "Legend of Zelda, The - Oracle of Seasons (USA, Australia)" - rom ( name "Legend of Zelda, The - Oracle of Seasons (USA, Australia).gbc" size 1048576 crc d7e9f5d7 sha1 ba1268290fb2b1b70505d2d7b5825fc8a4816a4b flags verified ) + name "Pokemon - Silver Version (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Silver Version (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Silver Version (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 8ad48636 sha1 49b163f7e57702bc939d642a18f591de55d92dae flags verified ) ) game ( - name "LEGO Alpha Team (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - description "LEGO Alpha Team (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - rom ( name "LEGO Alpha Team (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gbc" size 1048576 crc 690c0373 sha1 4bd3bf401e861fe9991a58b523622c68138274e6 ) + name "Pokemon - Version Argent (France) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Version Argent (France) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Version Argent (France) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc e0c216ea sha1 a4a7e8079b7a53e4d9ef43382bbb1090b9d45d1a flags verified ) ) game ( - name "LEGO Alpha Team (USA)" - description "LEGO Alpha Team (USA)" - rom ( name "LEGO Alpha Team (USA).gbc" size 1048576 crc 6d7ec41b sha1 b5d521d5b7504442c886944a6fb7dd830a28b496 flags verified ) + name "Pokemon - Version Cristal (France)" + description "Pokemon - Version Cristal (France)" + rom ( name "Pokemon - Version Cristal (France).gbc" size 2097152 crc 878b2aa7 sha1 c055992b16b7399c687647725cdd1f4f13a2f75c flags verified ) ) game ( - name "LEGO Island 2 - The Brickster's Revenge (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - description "LEGO Island 2 - The Brickster's Revenge (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - rom ( name "LEGO Island 2 - The Brickster's Revenge (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gbc" size 1048576 crc 921abb21 sha1 b70a22669256735abae16a32bb5f8944cff4a37c ) + name "Pokemon - Version Or (France) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Version Or (France) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Version Or (France) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 37a70702 sha1 c147c0d8c2b71b7628a7233436f5c052b5b17081 flags verified ) ) game ( - name "LEGO Island 2 - The Brickster's Revenge (USA) (En,Fr,Es)" - description "LEGO Island 2 - The Brickster's Revenge (USA) (En,Fr,Es)" - rom ( name "LEGO Island 2 - The Brickster's Revenge (USA) (En,Fr,Es).gbc" size 1048576 crc b14fa7e7 sha1 cd49bde3c3641e34cfbc1d55fd08d54ccc5b099b ) + name "Pokemon - Versione Argento (Italy) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Versione Argento (Italy) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Versione Argento (Italy) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc cba6d2d4 sha1 c9eca9d0a837beb9137bb7d779e469c54e9f8d77 ) ) game ( - name "LEGO Racers (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - description "LEGO Racers (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - rom ( name "LEGO Racers (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gbc" size 1048576 crc 0a109f13 sha1 25877740f157db965a2caf30f081a89b6c13df23 ) + name "Pokemon - Versione Cristallo (Italy)" + description "Pokemon - Versione Cristallo (Italy)" + rom ( name "Pokemon - Versione Cristallo (Italy).gbc" size 2097152 crc d45ac039 sha1 6cee05e5b95beeae74b8365ad18ec4a07a8c4af8 ) ) game ( - name "LEGO Racers (USA) (En,Fr,Es)" - description "LEGO Racers (USA) (En,Fr,Es)" - rom ( name "LEGO Racers (USA) (En,Fr,Es).gbc" size 1048576 crc f6865b09 sha1 8e46d2920bccc9a67fcfed404d0f8dd1bd9cb807 ) + name "Pokemon - Versione Oro (Italy) (SGB Enhanced) (GB Compatible)" + description "Pokemon - Versione Oro (Italy) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon - Versione Oro (Italy) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4c184ce3 sha1 032608fe8947b627584a4a0eccc7bf9ad3588426 ) ) game ( - name "LEGO Stunt Rally (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - description "LEGO Stunt Rally (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da)" - rom ( name "LEGO Stunt Rally (Europe) (En,Fr,De,Es,It,Nl,Pt,Sv,No,Da).gbc" size 1048576 crc 05cc01fb sha1 32dc01db6a5af637e96a6d83895c352d920fba04 ) + name "Pokemon Adventure (Taiwan) (Unl)" + description "Pokemon Adventure (Taiwan) (Unl)" + rom ( name "Pokemon Adventure (Taiwan) (Unl).gbc" size 524288 crc 8edb9eb7 sha1 f86884a85cc560b91340a4c53a37cc8026699ddc ) ) game ( - name "LEGO Stunt Rally (USA)" - description "LEGO Stunt Rally (USA)" - rom ( name "LEGO Stunt Rally (USA).gbc" size 1048576 crc da084760 sha1 106cb59ac42c3573dcf27b448503ab4d3029d90a ) + name "Pokemon Card GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Pokemon Card GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon Card GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1926f570 sha1 2287627c5b4d56bd9a01aab83408c301b9cf1a6c flags verified ) ) game ( - name "Lemmings (Europe) (Proto)" - description "Lemmings (Europe) (Proto)" - rom ( name "Lemmings (Europe) (Proto).gbc" size 4194304 crc 5ea0796b sha1 f1f9ab3878c606b488e89c24068af10060b1640f ) + name "Pokemon Card GB 2 - GR Dan Sanjou! (Japan)" + description "Pokemon Card GB 2 - GR Dan Sanjou! (Japan)" + rom ( name "Pokemon Card GB 2 - GR Dan Sanjou! (Japan).gbc" size 2097152 crc 6c933a14 sha1 a7e12bcc5f514e3aad8de570fd511aab0a308822 ) ) game ( - name "Lemmings & Oh No! More Lemmings (USA)" - description "Lemmings & Oh No! More Lemmings (USA)" - rom ( name "Lemmings & Oh No! More Lemmings (USA).gbc" size 4194304 crc 97e5ce2f sha1 2662b9fdfb243392ec1268feea993ed36ac840b1 ) + name "Pokemon de Panepon (Japan)" + description "Pokemon de Panepon (Japan)" + rom ( name "Pokemon de Panepon (Japan).gbc" size 2097152 crc 6bf7e4a6 sha1 110ae6649b4264f88d82760ad6ae4ee7f07db9b2 ) ) game ( - name "Lemmings VS (Japan)" - description "Lemmings VS (Japan)" - rom ( name "Lemmings VS (Japan).gbc" size 4194304 crc 947d45ae sha1 2ebb428a53acbcbc215f37bb263e44d94f547473 ) + name "Pokemon Diamond (Taiwan) (En) (Unl)" + description "Pokemon Diamond (Taiwan) (En) (Unl)" + rom ( name "Pokemon Diamond (Taiwan) (En) (Unl).gbc" size 524288 crc 1b5bef4b sha1 433e7991b706baedf59af8b91bc142ba2f72112f ) ) game ( - name "Let's Bee Friends (World) (GB Compatible) (Aftermarket) (Unl)" - description "Let's Bee Friends (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Let's Bee Friends (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc a91a698f sha1 26f38b3908c086b3e349324da32bc37213975030 ) + name "Pokemon Diamond (Taiwan) (Zh) (Unl)" + description "Pokemon Diamond (Taiwan) (Zh) (Unl)" + rom ( name "Pokemon Diamond (Taiwan) (Zh) (Unl).gbc" size 524288 crc 7309551a sha1 3fb38a7f49e13f5bfce0cd1983d9006b30f68930 ) ) game ( - name "Liberator (World) (Aftermarket) (Unl)" - description "Liberator (World) (Aftermarket) (Unl)" - rom ( name "Liberator (World) (Aftermarket) (Unl).gbc" size 262144 crc ebe70d3d sha1 e3afce5a2357732ed15d7f3c0900f7b48113efdc ) + name "Pokemon Gold (Taiwan) (En) (Unl)" + description "Pokemon Gold (Taiwan) (En) (Unl)" + rom ( name "Pokemon Gold (Taiwan) (En) (Unl).gbc" size 1048576 crc 479f3c4e sha1 26503e3262022be29b845a0b2ba555013d8ad12f ) ) game ( - name "Lightseeker (World) (GB Compatible) (Aftermarket) (Unl)" - description "Lightseeker (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Lightseeker (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc b8dd8409 sha1 281abb583ec0039e2c981c2e95f7a92002da081b ) + name "Pokemon Gold Version 2 (Taiwan) (Unl)" + description "Pokemon Gold Version 2 (Taiwan) (Unl)" + rom ( name "Pokemon Gold Version 2 (Taiwan) (Unl).gbc" size 524288 crc 5eab2b1e sha1 9e14a8c897b921e177ae4a3efc71125d1e91cc30 ) ) game ( - name "Lil' Monster (USA) (SGB Enhanced) (GB Compatible)" - description "Lil' Monster (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Lil' Monster (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c6859b34 sha1 cb812599f23f8812ff756e269a621de39b1b1def ) + name "Pokemon Jade (Taiwan) (En) (Pirate)" + description "Pokemon Jade (Taiwan) (En) (Pirate)" + rom ( name "Pokemon Jade (Taiwan) (En) (Pirate).gbc" size 2097152 crc aa07f269 sha1 994a205d7c0b55f45715a65b23ec31258e43652f ) ) game ( - name "Lion King, The - Simba's Mighty Adventure (USA, Europe)" - description "Lion King, The - Simba's Mighty Adventure (USA, Europe)" - rom ( name "Lion King, The - Simba's Mighty Adventure (USA, Europe).gbc" size 1048576 crc d5b4b7bb sha1 4fcb6698e4fd6bb03812a35ed545ec68b7c11fa7 ) + name "Pokemon Jade (Taiwan) (Zh) (Unl)" + description "Pokemon Jade (Taiwan) (Zh) (Unl)" + rom ( name "Pokemon Jade (Taiwan) (Zh) (Unl).gbc" size 524288 crc b9ffd78c sha1 c46c3a9e221da8d41a9eb1a84765368d975dfaa1 ) ) game ( - name "Little Magic (Japan)" - description "Little Magic (Japan)" - rom ( name "Little Magic (Japan).gbc" size 1048576 crc ca38283d sha1 4cd610be44a9fbfde9de81167f1e4051a62b01a9 ) + name "Pokemon Jade Version - Special Pikachu Edition (USA) (Pirate)" + description "Pokemon Jade Version - Special Pikachu Edition (USA) (Pirate)" + rom ( name "Pokemon Jade Version - Special Pikachu Edition (USA) (Pirate).gbc" size 524288 crc e9488e13 sha1 254355aac31a6a75481a6a14c5c5cae1e4f41adf ) ) game ( - name "Little Mermaid II, The - Pinball Frenzy (Europe) (En,Fr,De,Es,It)" - description "Little Mermaid II, The - Pinball Frenzy (Europe) (En,Fr,De,Es,It)" - rom ( name "Little Mermaid II, The - Pinball Frenzy (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 9fec297e sha1 c84c653eada20161c8d0aa966303b378fe5feef1 ) + name "Pokemon Pearl (Taiwan) (En) (Unl)" + description "Pokemon Pearl (Taiwan) (En) (Unl)" + rom ( name "Pokemon Pearl (Taiwan) (En) (Unl).gbc" size 524288 crc e2f527ff sha1 31551ca917a6df7d645f0b7dde1efd2d7a0485e6 ) ) game ( - name "Little Mermaid II, The - Pinball Frenzy (USA) (En,Fr,De,Es,It) (Rumble Version)" - description "Little Mermaid II, The - Pinball Frenzy (USA) (En,Fr,De,Es,It) (Rumble Version)" - rom ( name "Little Mermaid II, The - Pinball Frenzy (USA) (En,Fr,De,Es,It) (Rumble Version).gbc" size 1048576 crc 364f9ccd sha1 0940a1a86127cf8228a6a015035d8189218f57db flags verified ) + name "Pokemon Picross (Japan) (Proto)" + description "Pokemon Picross (Japan) (Proto)" + rom ( name "Pokemon Picross (Japan) (Proto).gbc" size 2097152 crc cf647f4b sha1 8204064b7149357939b57342820e7955749183b6 ) ) game ( - name "Little Mermaid II, The - Pinball Frenzy (Japan) (Proto)" - description "Little Mermaid II, The - Pinball Frenzy (Japan) (Proto)" - rom ( name "Little Mermaid II, The - Pinball Frenzy (Japan) (Proto).gbc" size 1048576 crc 6b974b2d sha1 ed001b5792e1afb35178e22d3adf45bbf0c4d721 ) + name "Pokemon Pinball (Europe) (En,Fr,De,Es,It) (Rumble Version) (SGB Enhanced) (GB Compatible)" + description "Pokemon Pinball (Europe) (En,Fr,De,Es,It) (Rumble Version) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon Pinball (Europe) (En,Fr,De,Es,It) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 39c432a4 sha1 24c693b8048594e2bf61ec1dc2182e75d81e532d flags verified ) ) game ( - name "Little Nicky (USA)" - description "Little Nicky (USA)" - rom ( name "Little Nicky (USA).gbc" size 2097152 crc 27310900 sha1 f2fa3ae6bb82ebf31c4863b64b330716bd839362 flags verified ) + name "Pokemon Pinball (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" + description "Pokemon Pinball (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon Pinball (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 13c70de9 sha1 96d0d854b9b49d724cd1dcbacd6313f0fc6c1c10 flags verified ) ) game ( - name "LNF Stars 2001 (France)" - description "LNF Stars 2001 (France)" - rom ( name "LNF Stars 2001 (France).gbc" size 1048576 crc f8bf3ee7 sha1 07a0e1c0ddde6371dbaf25fd016bdc77c0eca090 ) + name "Pokemon Pinball (USA, Australia) (Rumble Version) (SGB Enhanced) (GB Compatible)" + description "Pokemon Pinball (USA, Australia) (Rumble Version) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon Pinball (USA, Australia) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 03ce8d9a sha1 9402014d14969432142abfde728c6f1a10ee4dac flags verified ) ) game ( - name "Loco-coco (World) (Aftermarket) (Unl)" - description "Loco-coco (World) (Aftermarket) (Unl)" - rom ( name "Loco-coco (World) (Aftermarket) (Unl).gbc" size 262144 crc f6b9fe4e sha1 8a8972ff3e208280a746a2015a20f67248180a1c ) + name "Pokemon Puzzle Challenge (Europe) (En,Fr,De,Es,It)" + description "Pokemon Puzzle Challenge (Europe) (En,Fr,De,Es,It)" + rom ( name "Pokemon Puzzle Challenge (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 8206b1ce sha1 e40d6a7f78b449e5a55baaaea7e227ab19d510e4 ) ) game ( - name "Lode Runner - Domudomu Dan no Yabou (Japan) (GB Compatible)" - description "Lode Runner - Domudomu Dan no Yabou (Japan) (GB Compatible)" - rom ( name "Lode Runner - Domudomu Dan no Yabou (Japan) (GB Compatible).gbc" size 1048576 crc eceab84e sha1 c49569e4453f18b00bcf5ea3de43dee9ba3b4499 ) + name "Pokemon Puzzle Challenge (USA, Australia)" + description "Pokemon Puzzle Challenge (USA, Australia)" + rom ( name "Pokemon Puzzle Challenge (USA, Australia).gbc" size 2097152 crc d06bba96 sha1 bbf952412250ae511b3b862566e424ce6a672f99 flags verified ) ) game ( - name "Lodoss-tou Senki - Eiyuu Kishiden GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Lodoss-tou Senki - Eiyuu Kishiden GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Lodoss-tou Senki - Eiyuu Kishiden GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 66e166bb sha1 3431247ffae511b6c2a836759e5ed0545d11ba05 ) + name "Pokemon Ruby (Taiwan) (Unl)" + description "Pokemon Ruby (Taiwan) (Unl)" + rom ( name "Pokemon Ruby (Taiwan) (Unl).gbc" size 524288 crc 7a2fc378 sha1 1f9e62faa85e9058bec16be8b6c14223bb3ac15b ) ) game ( - name "Logical (Europe)" - description "Logical (Europe)" - rom ( name "Logical (Europe).gbc" size 1048576 crc 5eee76c4 sha1 bfcc97d28a0fe90521258de9cdf75a8abb5fbd0b ) + name "Pokemon Sapphire (Taiwan) (En) (Unl)" + description "Pokemon Sapphire (Taiwan) (En) (Unl)" + rom ( name "Pokemon Sapphire (Taiwan) (En) (Unl).gbc" size 524288 crc 8077dd95 sha1 2e3a28e02d5bfe259d9367d1205daa52912a1f8f ) ) game ( - name "Logical (USA)" - description "Logical (USA)" - rom ( name "Logical (USA).gbc" size 1048576 crc d67275f7 sha1 3163071800753f29f2ce6142931356d8d6dfbe68 ) + name "Pokemon Sapphire (Taiwan) (Zh) (Unl)" + description "Pokemon Sapphire (Taiwan) (Zh) (Unl)" + rom ( name "Pokemon Sapphire (Taiwan) (Zh) (Unl).gbc" size 524288 crc f3c1c00c sha1 75639d4dbe72d044002f768d5dbbd08caf003fdc ) ) game ( - name "Looney Tunes (Europe) (GB Compatible)" - description "Looney Tunes (Europe) (GB Compatible)" - rom ( name "Looney Tunes (Europe) (GB Compatible).gbc" size 1048576 crc 76cf3e3a sha1 e631eaa8f7be44a1f41e06878ca81bd3fa779f6b flags verified ) + name "Pokemon Trading Card Game (Europe) (En,Fr,De) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Pokemon Trading Card Game (Europe) (En,Fr,De) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon Trading Card Game (Europe) (En,Fr,De) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 942d0b7f sha1 dffc15f3063a4c2df84c6361406b41aec1696d3e flags verified ) ) game ( - name "Looney Tunes (USA) (GB Compatible)" - description "Looney Tunes (USA) (GB Compatible)" - rom ( name "Looney Tunes (USA) (GB Compatible).gbc" size 1048576 crc 4ef3ddd7 sha1 80a0e66754ce81a01385941459b9ea15a450b2b6 ) + name "Pokemon Trading Card Game (Europe) (En,Es,It) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Pokemon Trading Card Game (Europe) (En,Es,It) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon Trading Card Game (Europe) (En,Es,It) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 3f1d7e58 sha1 c54b81e638b0c45d3569f9f5f0345df9e95ce975 ) ) game ( - name "Looney Tunes - Carrot Crazy (USA) (En,Fr,Es) (GB Compatible)" - description "Looney Tunes - Carrot Crazy (USA) (En,Fr,Es) (GB Compatible)" - rom ( name "Looney Tunes - Carrot Crazy (USA) (En,Fr,Es) (GB Compatible).gbc" size 1048576 crc 11fb5617 sha1 4d8fa4d930f7f2ba7d674eed1c5a284f20c434ca ) + name "Pokemon Trading Card Game (Europe) (En,Es,It) (SGB Enhanced) (GB Compatible)" + description "Pokemon Trading Card Game (Europe) (En,Es,It) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon Trading Card Game (Europe) (En,Es,It) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 966daef1 sha1 2138a422d135a13c49fce71229ae36bc1dc4fbb5 ) ) game ( - name "Looney Tunes - Twouble! (USA) (En,Fr,Es) (GB Compatible)" - description "Looney Tunes - Twouble! (USA) (En,Fr,Es) (GB Compatible)" - rom ( name "Looney Tunes - Twouble! (USA) (En,Fr,Es) (GB Compatible).gbc" size 1048576 crc 698d7be4 sha1 f08bd36a0933ac56eeed2dd235d476d3b80a1f50 ) + name "Pokemon Trading Card Game (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + description "Pokemon Trading Card Game (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon Trading Card Game (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4523376e sha1 868e7b376e39f7d65a735538d90fbe6bbc99d198 flags verified ) ) -game ( - name "Looney Tunes Collector - Alert! (USA) (En,Fr,Es)" - description "Looney Tunes Collector - Alert! (USA) (En,Fr,Es)" - rom ( name "Looney Tunes Collector - Alert! (USA) (En,Fr,Es).gbc" size 2097152 crc 54509d24 sha1 54c4f732a8c328a9331a8a500438b1b1e9472b39 ) +game ( + name "Pokemon Trading Card Game (USA, Australia) (SGB Enhanced) (GB Compatible)" + description "Pokemon Trading Card Game (USA, Australia) (SGB Enhanced) (GB Compatible)" + rom ( name "Pokemon Trading Card Game (USA, Australia) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 81069d53 sha1 0f8670a583255cff3e5b7ca71b5d7454d928fc48 flags verified ) ) game ( - name "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl)" - description "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl).gbc" size 2097152 crc 5d85dfad sha1 645c4cf67faf33248d2102f137a605de94305796 flags verified ) + name "Pokemon Vision Jade (Taiwan) (De) (Unl)" + description "Pokemon Vision Jade (Taiwan) (De) (Unl)" + rom ( name "Pokemon Vision Jade (Taiwan) (De) (Unl).gbc" size 2097152 crc 2705ca20 sha1 72d5c6b8a570e67e7bce59070417cb89e985efb0 ) ) game ( - name "Looney Tunes Collector - Martian Alert! (Europe) (Fr) (Beta 1) (1999-10-28)" - description "Looney Tunes Collector - Martian Alert! (Europe) (Fr) (Beta 1) (1999-10-28)" - rom ( name "Looney Tunes Collector - Martian Alert! (Europe) (Fr) (Beta 1) (1999-10-28).gbc" size 2097152 crc 3acb4840 sha1 4c05c1a15bb90feb09fbc2d8dfbfb42794313936 ) + name "Polaris SnoCross (USA) (Beta) (Rumble Version)" + description "Polaris SnoCross (USA) (Beta) (Rumble Version)" + rom ( name "Polaris SnoCross (USA) (Beta) (Rumble Version).gbc" size 1048576 crc 673623c4 sha1 4176ef1f9fd37156a4cac37a2d146ed2deeb5a7b ) ) game ( - name "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl) (Beta 2)" - description "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl) (Beta 2)" - rom ( name "Looney Tunes Collector - Martian Alert! (Europe) (En,Fr,De,Es,It,Nl) (Beta 2).gbc" size 2097152 crc 9058eae3 sha1 601236c323f4adbe5bd6091fac8871e11d71f105 ) + name "Polaris SnoCross (USA) (Rumble Version)" + description "Polaris SnoCross (USA) (Rumble Version)" + rom ( name "Polaris SnoCross (USA) (Rumble Version).gbc" size 1048576 crc dd8b189e sha1 e893808fe227a1608c0604382d6a0340ec704c3b flags verified ) ) game ( - name "Looney Tunes Collector - Martian Quest! (Japan)" - description "Looney Tunes Collector - Martian Quest! (Japan)" - rom ( name "Looney Tunes Collector - Martian Quest! (Japan).gbc" size 2097152 crc bc46a2d2 sha1 450e43cf2d9cfa18856b3f3312e2194f132dbb1b ) + name "Pong - The Next Level (USA, Europe)" + description "Pong - The Next Level (USA, Europe)" + rom ( name "Pong - The Next Level (USA, Europe).gbc" size 1048576 crc 476bd39d sha1 637827a89a0948f6561bf2a018de6244e2811a99 flags verified ) ) game ( - name "Looney Tunes Collector - Martian Revenge! (Europe) (En,Fr,De,Es,It,Nl)" - description "Looney Tunes Collector - Martian Revenge! (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Looney Tunes Collector - Martian Revenge! (Europe) (En,Fr,De,Es,It,Nl).gbc" size 2097152 crc 22952662 sha1 9e17af53ef89e2d436096c88dd293b838026b75f ) + name "Pooh and Tigger's Hunny Safari (Europe) (En,Fr,De,Es,It,Nl)" + description "Pooh and Tigger's Hunny Safari (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Pooh and Tigger's Hunny Safari (Europe) (En,Fr,De,Es,It,Nl).gbc" size 2097152 crc 8505d139 sha1 4141887f0b152f8592b905355e11cf43147128c2 ) ) game ( - name "Looney Tunes Racing (Europe) (En,Fr,De,Es,It,Nl)" - description "Looney Tunes Racing (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Looney Tunes Racing (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 7efdca8a sha1 2552c1f0e864e1689e59f8d80837bffdffa211fa ) + name "Pooh and Tigger's Hunny Safari (USA)" + description "Pooh and Tigger's Hunny Safari (USA)" + rom ( name "Pooh and Tigger's Hunny Safari (USA).gbc" size 2097152 crc 622690da sha1 934918da6249723760a356748bf240f57262bd77 ) ) game ( - name "Looney Tunes Racing (USA) (En,Fr,De,Es,It,Nl)" - description "Looney Tunes Racing (USA) (En,Fr,De,Es,It,Nl)" - rom ( name "Looney Tunes Racing (USA) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 66792cde sha1 249759398fb9e484b00e0d5416da2411c79d2d39 ) + name "Pop'n Music GB (Japan)" + description "Pop'n Music GB (Japan)" + rom ( name "Pop'n Music GB (Japan).gbc" size 1048576 crc 07e6ca95 sha1 f2b31ecdd1dbd3c7c120d436ed8d5e19743e9cf0 ) ) game ( - name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 29e193c5 sha1 8cc512784d323f7c0bfe36848c5f7fdc49257285 ) + name "Pop'n Music GB - Animation Melody (Japan)" + description "Pop'n Music GB - Animation Melody (Japan)" + rom ( name "Pop'n Music GB - Animation Melody (Japan).gbc" size 1048576 crc 9b2429a7 sha1 f4442d7e984ebefc7735e205ca759c2be3bd1843 ) ) game ( - name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc d54d5836 sha1 c88ae04f7adbec5ad40edec650198cbe58a561bd ) + name "Pop'n Music GB - Disney Tunes (Japan)" + description "Pop'n Music GB - Disney Tunes (Japan)" + rom ( name "Pop'n Music GB - Disney Tunes (Japan).gbc" size 1048576 crc 48c3c6ef sha1 ff34d9d68c81b82a70ed11ac509ec5daaf29cd46 ) ) game ( - name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc e078d9f8 sha1 a7faa970e71d38c68948b646d3dcb9cbea1df995 ) + name "Pop'n Pop (Europe)" + description "Pop'n Pop (Europe)" + rom ( name "Pop'n Pop (Europe).gbc" size 1048576 crc fc67f7e4 sha1 5874cc64b184692ed03fb860de058fa3475b1d5c ) ) game ( - name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 065a3bf5 sha1 42721b99b427e51f7e815c852bf53e807c52dd65 ) + name "Pop'n Pop (Japan)" + description "Pop'n Pop (Japan)" + rom ( name "Pop'n Pop (Japan).gbc" size 1048576 crc 1cffb764 sha1 ef425613296573225e42228ca12bce5124374206 ) ) game ( - name "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc c0287cf2 sha1 7425bd94790866bf716fd3c23886a5cdc06f1aad ) + name "Portal Runner (USA)" + description "Portal Runner (USA)" + rom ( name "Portal Runner (USA).gbc" size 1048576 crc 913ac306 sha1 a8347366f15c0e454fa253bad5b4053d2a9613aa ) ) game ( - name "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Hirameku Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 267b5253 sha1 f977d3dd6395066bbea729ea547c7a81e1c4464d ) + name "Power Pro Kun Pocket (Japan) (SGB Enhanced) (GB Compatible)" + description "Power Pro Kun Pocket (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Power Pro Kun Pocket (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 145540d8 sha1 f796f9cb259646555f0d429b9337ac6b423755a3 ) ) game ( - name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc d457cc6c sha1 cb14866337caecd5458edc72f2d56f2c8c028411 ) + name "Power Pro Kun Pocket (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Power Pro Kun Pocket (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Power Pro Kun Pocket (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 894d88f2 sha1 ae145f2de0d53c19b973c71baaf3f2cca2ca395a ) ) game ( - name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-2-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 27ab2187 sha1 49a63339bc253d1bd55f6db75f7324980572925a ) + name "Power Pro Kun Pocket 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Power Pro Kun Pocket 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Power Pro Kun Pocket 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc c2a4a3eb sha1 5c0ba404cf30296dceeb427a54e3644415c9e8db flags verified ) ) game ( - name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 3ef25533 sha1 9822fecf183d3d0a6e9af80696463b09e1f31a60 ) + name "Power Quest (Europe) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" + description "Power Quest (Europe) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" + rom ( name "Power Quest (Europe) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 30e1e567 sha1 b9b41a90baba13888ac8f3788b96935f4d394c2c flags verified ) ) game ( - name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Dai-3-gou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 62d3f1e5 sha1 a3ddd9794e05f2962481b802f84e783495e853b2 ) + name "Power Quest (USA) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" + description "Power Quest (USA) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" + rom ( name "Power Quest (USA) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc dad6f6b4 sha1 d1665784a007c122d65f43bd2751db6b395ff3cd ) ) game ( - name "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 094ffd1e sha1 5a476f79db61aa8c6f32bbabd82fade5cde811d2 ) + name "Power Spike - Pro Beach Volleyball (USA)" + description "Power Spike - Pro Beach Volleyball (USA)" + rom ( name "Power Spike - Pro Beach Volleyball (USA).gbc" size 1048576 crc ae57d1c3 sha1 cbf7377e2dfea331f983b34486ab7761ac75e3ac ) ) game ( - name "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - description "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Loppi Puzzle Magazine - Kangaeru Puzzle Soukangou (Japan) (Rev 1) (SGB Enhanced, GB Compatible) (NP).gbc" size 262144 crc 88ce5c13 sha1 7e493878e0b755df3c6d6ab93c7b15b4b10a0896 ) + name "Powerpuff Girls, The - Bad Mojo Jojo (USA)" + description "Powerpuff Girls, The - Bad Mojo Jojo (USA)" + rom ( name "Powerpuff Girls, The - Bad Mojo Jojo (USA).gbc" size 2097152 crc 834caf7a sha1 92d86ec01e8669bbb8d26a5ec51efc0f761eeaf4 ) ) game ( - name "Lord of the Rings, The - The Fellowship of the Ring (Taiwan) (En) (Unl)" - description "Lord of the Rings, The - The Fellowship of the Ring (Taiwan) (En) (Unl)" - rom ( name "Lord of the Rings, The - The Fellowship of the Ring (Taiwan) (En) (Unl).gbc" size 2097152 crc c01bbc48 sha1 3ecb3ae13e0934ed94dbb8621e62820a07fdffb0 ) + name "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 1)" + description "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 1)" + rom ( name "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 1).gbc" size 2097152 crc 548a287a sha1 d3f74815bec29ae7d580b112a1c1f913c19ac89e ) ) game ( - name "Love Hina Party (Japan)" - description "Love Hina Party (Japan)" - rom ( name "Love Hina Party (Japan).gbc" size 2097152 crc 034d2686 sha1 d3551d99bb03e7945862cc8f1c3c095477119cf2 ) + name "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 2)" + description "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 2)" + rom ( name "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 2).gbc" size 2097152 crc a111704f sha1 98f46abbd8792bf716928bf2e28af94af467ef51 flags verified ) ) game ( - name "Love Hina Pocket (Japan)" - description "Love Hina Pocket (Japan)" - rom ( name "Love Hina Pocket (Japan).gbc" size 4194304 crc 1c877abd sha1 912c09f99bdae6e7fcd62d0c6f727e5fff93db70 ) + name "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJP)" + description "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJP)" + rom ( name "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJP).gbc" size 2097152 crc 75d1063a sha1 e1fde0d5c3f428a0932a2ceeac1889ebcabc3f7e ) ) game ( - name "Love Hina Pocket (Japan) (Rev 1)" - description "Love Hina Pocket (Japan) (Rev 1)" - rom ( name "Love Hina Pocket (Japan) (Rev 1).gbc" size 4194304 crc 55dd0ba6 sha1 b29abee319ccb223e5d1a4f88982fb53e538d527 ) + name "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJX) (Proto)" + description "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJX) (Proto)" + rom ( name "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJX) (Proto).gbc" size 2097152 crc 24b23af1 sha1 cffa029b5aa51b2ce1c192e66bd2881eddd532fd ) ) game ( - name "Luca no Puzzle de Daibouken! (Japan) (SGB Enhanced) (GB Compatible)" - description "Luca no Puzzle de Daibouken! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Luca no Puzzle de Daibouken! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc 3aebfad8 sha1 3c06fe05909ad632b761c6a1c00bc69da81aa358 ) + name "Powerpuff Girls, The - Battle Him (Europe)" + description "Powerpuff Girls, The - Battle Him (Europe)" + rom ( name "Powerpuff Girls, The - Battle Him (Europe).gbc" size 2097152 crc 788859ae sha1 9d2cbe85c7c0da6ea4354822f85cd597bfaff1c5 ) ) game ( - name "Lucky Luke (Europe) (En,Fr,De,Es)" - description "Lucky Luke (Europe) (En,Fr,De,Es)" - rom ( name "Lucky Luke (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 412fb57c sha1 36b59251751a55285dbedc3bd4b33b2c73b811c9 flags verified ) + name "Powerpuff Girls, The - Battle Him (USA)" + description "Powerpuff Girls, The - Battle Him (USA)" + rom ( name "Powerpuff Girls, The - Battle Him (USA).gbc" size 2097152 crc d8455984 sha1 3d90946a2cbe503d040b10958301587998d4e86f ) ) game ( - name "Lucky Luke (USA) (En,Fr,De,Es)" - description "Lucky Luke (USA) (En,Fr,De,Es)" - rom ( name "Lucky Luke (USA) (En,Fr,De,Es).gbc" size 1048576 crc a5e29f34 sha1 ebf61143a16be4bfc0c99a7feb9455685f86acfa ) + name "Powerpuff Girls, The - Battle Him (USA) (Rev 1)" + description "Powerpuff Girls, The - Battle Him (USA) (Rev 1)" + rom ( name "Powerpuff Girls, The - Battle Him (USA) (Rev 1).gbc" size 2097152 crc e3d6964c sha1 8f22b2cd9552eb1146f0a78a9c9242c031046e1c ) ) game ( - name "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl)" - description "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc ce7f108a sha1 857dda99bdb15c49918c633dbcb73bd96ef7bae9 ) + name "Powerpuff Girls, The - Bulle Contre Lui (France)" + description "Powerpuff Girls, The - Bulle Contre Lui (France)" + rom ( name "Powerpuff Girls, The - Bulle Contre Lui (France).gbc" size 2097152 crc 7085270c sha1 5c1c53b9c002680c2da8b24aa31d4a247586263d ) ) game ( - name "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - description "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - rom ( name "Lucky Luke - Desperado Train (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 1048576 crc b558c401 sha1 ab9b610f2858fec8bd4542731f6fbfd4b7faf9e1 ) + name "Powerpuff Girls, The - Il Terribile Mojo Jojo (Italy) (Proto)" + description "Powerpuff Girls, The - Il Terribile Mojo Jojo (Italy) (Proto)" + rom ( name "Powerpuff Girls, The - Il Terribile Mojo Jojo (Italy) (Proto).gbc" size 2097152 crc 5c265103 sha1 5ca837632930689fad9086b772928bf5995193f9 ) ) game ( - name "Lufia - The Legend Returns (Europe) (En,De)" - description "Lufia - The Legend Returns (Europe) (En,De)" - rom ( name "Lufia - The Legend Returns (Europe) (En,De).gbc" size 2097152 crc 470dcb1d sha1 10faaefba4c97d8392bb0231cf898a77db4f73f2 flags verified ) + name "Powerpuff Girls, The - L'Affreux Mojo Jojo (France)" + description "Powerpuff Girls, The - L'Affreux Mojo Jojo (France)" + rom ( name "Powerpuff Girls, The - L'Affreux Mojo Jojo (France).gbc" size 2097152 crc 256d166f sha1 1b5037f53fb77dd2c9c359052d46e5362c6a9801 ) ) game ( - name "Lufia - The Legend Returns (USA)" - description "Lufia - The Legend Returns (USA)" - rom ( name "Lufia - The Legend Returns (USA).gbc" size 2097152 crc 5bae3c04 sha1 9eb52c525620e7bda619f2161961071e8996c0db ) + name "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 1)" + description "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 1)" + rom ( name "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 1).gbc" size 2097152 crc 295b3646 sha1 023d4d9374e7fe9844f970dd0004c5d7eefd2d38 flags verified ) ) game ( - name "Luke Yingxiong 2 - Zook Hero 2 (Taiwan) (Unl)" - description "Luke Yingxiong 2 - Zook Hero 2 (Taiwan) (Unl)" - rom ( name "Luke Yingxiong 2 - Zook Hero 2 (Taiwan) (Unl).gbc" size 524288 crc 59822b31 sha1 4bf85d9641e3b842a917474dcb49a8b7f282711b ) + name "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTP)" + description "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTP)" + rom ( name "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTP).gbc" size 2097152 crc 98e4b0c4 sha1 e214ab665ffab3682b9833b4e4d0494fc53cd26f flags verified ) ) game ( - name "Luke Yingxiong Z (Taiwan) (Unl)" - description "Luke Yingxiong Z (Taiwan) (Unl)" - rom ( name "Luke Yingxiong Z (Taiwan) (Unl).gbc" size 1048576 crc 8ced0c21 sha1 271097c99be5f60fbdb561875d006a622093fe70 ) + name "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTX) (Proto)" + description "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTX) (Proto)" + rom ( name "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTX) (Proto).gbc" size 2097152 crc 310b52f7 sha1 6522029f585c6ab4b5ca342e2127f6403e735222 ) ) game ( - name "Lunar Docking (World) (2021-12-30) (Aftermarket) (Unl)" - description "Lunar Docking (World) (2021-12-30) (Aftermarket) (Unl)" - rom ( name "Lunar Docking (World) (2021-12-30) (Aftermarket) (Unl).gbc" size 262144 crc 9edd066c sha1 4d43a38e8b5df41309f5b6ec13e4829db739d980 ) + name "Powerpuff Girls, The - Paint the Townsville Green (USA)" + description "Powerpuff Girls, The - Paint the Townsville Green (USA)" + rom ( name "Powerpuff Girls, The - Paint the Townsville Green (USA).gbc" size 2097152 crc 9d47261a sha1 2d52551fce2cb6d246c6296beeb6a8a3dfbc2159 ) ) game ( - name "Lunar Docking (World) (2022-08-07) (Aftermarket) (Unl)" - description "Lunar Docking (World) (2022-08-07) (Aftermarket) (Unl)" - rom ( name "Lunar Docking (World) (2022-08-07) (Aftermarket) (Unl).gbc" size 262144 crc de5d5c0b sha1 5f038ef3657d3fbfb3be6917b24c3f933363ad4c ) + name "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 2)" + description "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 2)" + rom ( name "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 2).gbc" size 2097152 crc 443367ae sha1 ef93e793067bbb3748aac17d661c8c8b68ccee9b ) ) game ( - name "Luoke Yingxiong EXE5 (Taiwan) (Unl)" - description "Luoke Yingxiong EXE5 (Taiwan) (Unl)" - rom ( name "Luoke Yingxiong EXE5 (Taiwan) (Unl).gbc" size 2097152 crc 51f92403 sha1 c498a5fb261e921828831bff5c2c705453ea314e ) + name "Powerpuff Girls, The - Panique a Townsville (France)" + description "Powerpuff Girls, The - Panique a Townsville (France)" + rom ( name "Powerpuff Girls, The - Panique a Townsville (France).gbc" size 2097152 crc 79a417db sha1 978d68300b625d8e375571475b4f2c2c1a65fd60 flags verified ) ) game ( - name "M&M's Minis Madness (Europe)" - description "M&M's Minis Madness (Europe)" - rom ( name "M&M's Minis Madness (Europe).gbc" size 1048576 crc 60683bc4 sha1 d0b18a3acf9495db5af52b5c28df4129f48010bf ) + name "Primera Division Stars 2001 (Spain) (Proto)" + description "Primera Division Stars 2001 (Spain) (Proto)" + rom ( name "Primera Division Stars 2001 (Spain) (Proto).gbc" size 1048576 crc ce3a1022 sha1 ea2c721c905404a5a90e12eca598570d95e2812f ) ) game ( - name "M&M's Minis Madness (Germany)" - description "M&M's Minis Madness (Germany)" - rom ( name "M&M's Minis Madness (Germany).gbc" size 1048576 crc a666f54d sha1 9ccc1f1f0b6bd65913e60e2f9b7d5f9859b46535 ) + name "Prince Naseem Boxing (Europe) (En,Fr,De)" + description "Prince Naseem Boxing (Europe) (En,Fr,De)" + rom ( name "Prince Naseem Boxing (Europe) (En,Fr,De).gbc" size 2097152 crc 91def753 sha1 f0500b3ca8a24b3bd2c11e77fbe4c75db178dfbe ) ) game ( - name "M&M's Minis Madness (USA)" - description "M&M's Minis Madness (USA)" - rom ( name "M&M's Minis Madness (USA).gbc" size 1048576 crc 8649d7a0 sha1 7cc20e133a66163c6dec140e960b5be3848ccd44 ) + name "Prince of Persia (USA, Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "Prince of Persia (USA, Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Prince of Persia (USA, Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc e6bec6d1 sha1 ef2f6402e8ef367273200e3b07f310ebd80ccdc2 flags verified ) ) game ( - name "M&M's Minis Madness (USA) (Sample)" - description "M&M's Minis Madness (USA) (Sample)" - rom ( name "M&M's Minis Madness (USA) (Sample).gbc" size 1048576 crc 83293b1b sha1 2a0d0b7aa3b96b05bc020da496f2ce08e8fac190 ) + name "Prince of Persia (Japan) (Proto)" + description "Prince of Persia (Japan) (Proto)" + rom ( name "Prince of Persia (Japan) (Proto).gbc" size 1048576 crc d7dbbe1e sha1 6fd97e1f75570e7568b3dc4ab28834813afb4484 ) ) game ( - name "Machine, The (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Machine, The (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Machine, The (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc f55a9d95 sha1 2b22fbd76e11e6e45053b1e6989de303e3033c9e ) + name "Pro Darts (USA)" + description "Pro Darts (USA)" + rom ( name "Pro Darts (USA).gbc" size 1048576 crc 834a72c0 sha1 60a89486f747e7440a79774b280b24b6498ef5ea ) ) game ( - name "Machine, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Machine, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Machine, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 5662865e sha1 a5ac99a4087bd5ea45417e5b4a7c9af10433911a ) + name "Pro Foot (France) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + description "Pro Foot (France) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + rom ( name "Pro Foot (France) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 1048576 crc a9905932 sha1 c43daa82286d3a910a6a922d4ea722c594a2cde0 ) ) game ( - name "Macross 7 - Ginga no Heart o Furuwasero!! (Japan)" - description "Macross 7 - Ginga no Heart o Furuwasero!! (Japan)" - rom ( name "Macross 7 - Ginga no Heart o Furuwasero!! (Japan).gbc" size 2097152 crc 2b7abba4 sha1 88746c361cfbdac49e5d72807b396a6667c42229 ) + name "Pro Mahjong Kiwame II GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Pro Mahjong Kiwame II GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pro Mahjong Kiwame II GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 14f91f86 sha1 2c9c2967400ab9bad95ffe104763b3190f28aa39 ) ) game ( - name "Madden NFL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Madden NFL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Madden NFL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 482944aa sha1 df03f3e5e3f6fd3905dc332b307b5566f0f35252 flags verified ) + name "Pro Mahjong Tsuwamono GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Pro Mahjong Tsuwamono GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Pro Mahjong Tsuwamono GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1461d8d8 sha1 b9e7cd7e53fda3db329c57971a47d35255bd0b34 ) ) game ( - name "Madden NFL 2000 (USA, Europe) (Beta) (SGB Enhanced) (GB Compatible)" - description "Madden NFL 2000 (USA, Europe) (Beta) (SGB Enhanced) (GB Compatible)" - rom ( name "Madden NFL 2000 (USA, Europe) (Beta) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b3fead85 sha1 09bf3dea1dc01b018ba86e3affbcbab7b9d2eb63 ) + name "Pro Mahjong Tsuwamono GB 2 (Japan)" + description "Pro Mahjong Tsuwamono GB 2 (Japan)" + rom ( name "Pro Mahjong Tsuwamono GB 2 (Japan).gbc" size 1048576 crc f03016f5 sha1 3e49a76d36c39e9a4248a12f88a08ab3e30c96ba ) ) game ( - name "Madden NFL 2001 (USA)" - description "Madden NFL 2001 (USA)" - rom ( name "Madden NFL 2001 (USA).gbc" size 1048576 crc 160e9e3c sha1 5f7c156b7a141a8f373d626f53c9ce8b95cec880 ) + name "Pro Pool (USA) (En,Fr,De) (Beta)" + description "Pro Pool (USA) (En,Fr,De) (Beta)" + rom ( name "Pro Pool (USA) (En,Fr,De) (Beta).gbc" size 1048576 crc 04d3031a sha1 56252a97a3d463103e1047a6e1a64cad43bedd4c ) ) game ( - name "Madden NFL 2002 (USA)" - description "Madden NFL 2002 (USA)" - rom ( name "Madden NFL 2002 (USA).gbc" size 1048576 crc de1338d2 sha1 f32926053b8e565c2a3634c68a456d459e1f01a0 ) + name "Pro Pool (Europe) (En,Fr,De)" + description "Pro Pool (Europe) (En,Fr,De)" + rom ( name "Pro Pool (Europe) (En,Fr,De).gbc" size 1048576 crc 21a4da64 sha1 575c02f73a0bdc357289073f053d8a3969927880 ) ) game ( - name "Magi Nation (USA)" - description "Magi Nation (USA)" - rom ( name "Magi Nation (USA).gbc" size 2097152 crc 5042450b sha1 9972a7bca43210b4b6c0b3f6ee5d1957a865e12d ) + name "Pro Pool (USA) (En,Fr,De)" + description "Pro Pool (USA) (En,Fr,De)" + rom ( name "Pro Pool (USA) (En,Fr,De).gbc" size 1048576 crc 2611fa3d sha1 c85e514c24c82071907c6495243dae448b46c2b2 ) ) game ( - name "Magi-Nation - Keeper's Quest (USA) (Proto)" - description "Magi-Nation - Keeper's Quest (USA) (Proto)" - rom ( name "Magi-Nation - Keeper's Quest (USA) (Proto).gbc" size 1048576 crc 89de57b7 sha1 7c6b427810be2f0d7496ccb5eff2226d3ed1194e ) + name "Project S-11 (USA)" + description "Project S-11 (USA)" + rom ( name "Project S-11 (USA).gbc" size 524288 crc 20cee2e8 sha1 cbedd34a0c6a2f4e58d05f0bb6d54f7cbcda815c ) ) game ( - name "Magic & Legend - Time Knights (World) (Demo) (The Retro Room) (GB Compatible) (Aftermarket) (Unl)" - description "Magic & Legend - Time Knights (World) (Demo) (The Retro Room) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Magic & Legend - Time Knights (World) (Demo) (The Retro Room) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c276843d sha1 852697a2952d2e7375b73aba877ebc17aa4f4179 ) + name "Puchi Carat (USA) (Proto 2) (SGB Enhanced) (GB Compatible)" + description "Puchi Carat (USA) (Proto 2) (SGB Enhanced) (GB Compatible)" + rom ( name "Puchi Carat (USA) (Proto 2) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a97ea742 sha1 de755124425f9de8bef5eea8026751c54f7f1e00 ) ) game ( - name "Magical Chase GB - Minarai Mahoutsukai Kenja no Tani e (Japan)" - description "Magical Chase GB - Minarai Mahoutsukai Kenja no Tani e (Japan)" - rom ( name "Magical Chase GB - Minarai Mahoutsukai Kenja no Tani e (Japan).gbc" size 1048576 crc 15e5d499 sha1 3b13fc974d68a8b057ab8133a0ba7e3fbac23f11 ) + name "Puchi Carat (USA) (Proto 1) (SGB Enhanced) (GB Compatible)" + description "Puchi Carat (USA) (Proto 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Puchi Carat (USA) (Proto 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d79b6f46 sha1 b91b121a6951bcc74f0e4af33d41a1fba62f9822 ) ) game ( - name "Magical Drop (Europe) (En,Fr,De)" - description "Magical Drop (Europe) (En,Fr,De)" - rom ( name "Magical Drop (Europe) (En,Fr,De).gbc" size 1048576 crc ea9ee203 sha1 8ef276f9c6a64d7cec527bcba8d1b7223de0e01c ) + name "Puchi Carat (Europe) (SGB Enhanced) (GB Compatible)" + description "Puchi Carat (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Puchi Carat (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a9a89dda sha1 f703796e5551e12924c070cd8a0e77c6d82073af ) ) game ( - name "Magical Drop (USA)" - description "Magical Drop (USA)" - rom ( name "Magical Drop (USA).gbc" size 1048576 crc e4188a79 sha1 2106b22776a87825d3edb408503e719f4927c3e6 ) + name "Puchi Carat (Japan) (SGB Enhanced) (GB Compatible)" + description "Puchi Carat (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Puchi Carat (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f0d0c36d sha1 25abda13f97140d412bb00e109baca8574d5af6e ) ) game ( - name "Magical Drop (Europe) (En,Fr,De) (Beta)" - description "Magical Drop (Europe) (En,Fr,De) (Beta)" - rom ( name "Magical Drop (Europe) (En,Fr,De) (Beta).gbc" size 1048576 crc 799e2020 sha1 99fbf24ca924acf5a4ea64817fb29d6e408cb722 ) + name "Pumuckls Abenteuer bei den Piraten (Germany)" + description "Pumuckls Abenteuer bei den Piraten (Germany)" + rom ( name "Pumuckls Abenteuer bei den Piraten (Germany).gbc" size 1048576 crc f55cdb79 sha1 1f90e982ead050796722d98f94e31a836945f84d ) ) game ( - name "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv)" - description "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv)" - rom ( name "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv).gbc" size 1048576 crc 0a421839 sha1 3c315f3f77002456f09df9643be323608ae72088 ) + name "Pumuckls Abenteuer im Geisterschloss (Germany)" + description "Pumuckls Abenteuer im Geisterschloss (Germany)" + rom ( name "Pumuckls Abenteuer im Geisterschloss (Germany).gbc" size 1048576 crc 87fcec24 sha1 0fe14ef81b11c854f080e804c5d3cb14601b2794 ) ) game ( - name "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1)" - description "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1)" - rom ( name "Magical Tetris Challenge (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1).gbc" size 1048576 crc c82be2f4 sha1 950b30b267b0f0b79d7e85e91b8536b096b6a1b2 ) + name "Puyo Puyo Gaiden - Puyo Wars (Japan) (SGB Enhanced) (GB Compatible)" + description "Puyo Puyo Gaiden - Puyo Wars (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Puyo Puyo Gaiden - Puyo Wars (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 67350bc9 sha1 b1802797e892d09e4da53304d096bdf35bac1118 ) ) game ( - name "Magical Tetris Challenge (USA)" - description "Magical Tetris Challenge (USA)" - rom ( name "Magical Tetris Challenge (USA).gbc" size 1048576 crc f53cf66c sha1 7cdb0bf463ad87ec8a68a564c3f03dbc890edd7e ) + name "Puzz Loop (Japan) (GB Compatible)" + description "Puzz Loop (Japan) (GB Compatible)" + rom ( name "Puzz Loop (Japan) (GB Compatible).gbc" size 1048576 crc af858234 sha1 f8b299c665552621ca067886a8f16e842f699487 ) ) game ( - name "Magician's Curse, The (World) (Aftermarket) (Unl)" - description "Magician's Curse, The (World) (Aftermarket) (Unl)" - rom ( name "Magician's Curse, The (World) (Aftermarket) (Unl).gbc" size 524288 crc f2b1967e sha1 3b5f97f9a0b4d63a3795695b0bda6e969de8e051 ) + name "Puzzle Bobble 4 (Japan) (GB Compatible)" + description "Puzzle Bobble 4 (Japan) (GB Compatible)" + rom ( name "Puzzle Bobble 4 (Japan) (GB Compatible).gbc" size 524288 crc 79a35284 sha1 9c1e0055c2067688e066079778a795dbfa70c565 ) ) game ( - name "Mahjong Joou (Japan) (SGB Enhanced) (GB Compatible)" - description "Mahjong Joou (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Mahjong Joou (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 7d83a5e8 sha1 68f2326f7fa70d0ed0207bd087c6fe26ec6f9a53 ) + name "Puzzle Bobble Millennium (Japan)" + description "Puzzle Bobble Millennium (Japan)" + rom ( name "Puzzle Bobble Millennium (Japan).gbc" size 1048576 crc 00fded94 sha1 adbb7b1544cf26e017053137ed7e9668f442e608 ) ) game ( - name "Mahjong Quest (Japan) (SGB Enhanced) (GB Compatible)" - description "Mahjong Quest (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Mahjong Quest (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c870b88f sha1 3ab49ce8aa69013c1b2d9427926513e21d5efe1d ) + name "Puzzle de Shoubuyo! - Wootama-chan (Japan) (GB Compatible)" + description "Puzzle de Shoubuyo! - Wootama-chan (Japan) (GB Compatible)" + rom ( name "Puzzle de Shoubuyo! - Wootama-chan (Japan) (GB Compatible).gbc" size 1048576 crc 73ed3042 sha1 2c8630324767675e7f3da67e3a3071c73174a47d ) ) game ( - name "Mail Junkies World Port (United Kingdom) (v1.01) (Unl)" - description "Mail Junkies World Port (United Kingdom) (v1.01) (Unl)" - rom ( name "Mail Junkies World Port (United Kingdom) (v1.01) (Unl).gbc" size 262144 crc d4df856f sha1 004deb1e75ffa08080028cb4c08a7c981c313eb8 ) + name "Puzzle Master (USA) (GB Compatible)" + description "Puzzle Master (USA) (GB Compatible)" + rom ( name "Puzzle Master (USA) (GB Compatible).gbc" size 1048576 crc 06eb7a01 sha1 cbaccc88628194c82e115a8127ceeb035cd9c0a0 ) ) game ( - name "Majokko Mari-chan no Kisekae Monogatari (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Majokko Mari-chan no Kisekae Monogatari (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Majokko Mari-chan no Kisekae Monogatari (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 0d16a545 sha1 a56e2a42d4a0b21e656bc928e4451cf0623486cf flags verified ) + name "Puzzled (Europe) (En,Fr,De)" + description "Puzzled (Europe) (En,Fr,De)" + rom ( name "Puzzled (Europe) (En,Fr,De).gbc" size 1048576 crc 15b44d68 sha1 4e40ecd30a4e9c367f31cf5367c279f88b7df11c ) ) game ( - name "Majokko Mari-chan no Kisekae Monogatari (Japan) (SGB Enhanced) (GB Compatible)" - description "Majokko Mari-chan no Kisekae Monogatari (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Majokko Mari-chan no Kisekae Monogatari (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 934f4b0a sha1 8bdd3bd414da91c6ea05bc29435e09b0b72e3790 ) + name "Puzzled (USA)" + description "Puzzled (USA)" + rom ( name "Puzzled (USA).gbc" size 1048576 crc f03ffdaf sha1 8fd66d88174e429e9b909796745c74640de7db29 ) ) game ( - name "Marble Madness (USA, Europe)" - description "Marble Madness (USA, Europe)" - rom ( name "Marble Madness (USA, Europe).gbc" size 1048576 crc 4ec78785 sha1 32c84b75b10bd00812589f3c8cfd537518f021c6 flags verified ) + name "Q-bert (USA)" + description "Q-bert (USA)" + rom ( name "Q-bert (USA).gbc" size 1048576 crc 90f46d7e sha1 4b2767ca512228b7db0f814f31ca45c4b92d349b ) ) game ( - name "Marie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Marie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Marie no Atelier GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 6144fc66 sha1 f2b175da93054372531bc7d839bdbf3192c6a5eb ) + name "Qi Tian Dasheng - Sun Wukong (Taiwan) (Unl)" + description "Qi Tian Dasheng - Sun Wukong (Taiwan) (Unl)" + rom ( name "Qi Tian Dasheng - Sun Wukong (Taiwan) (Unl).gbc" size 524288 crc a336c40c sha1 3d7e987f1315242422c0db45c4aea120c1b41429 ) ) game ( - name "Mario Golf (Europe)" - description "Mario Golf (Europe)" - rom ( name "Mario Golf (Europe).gbc" size 2097152 crc a132417d sha1 ae3aec0d376c1bc5b83ae4c4c1e245c3ab2b9392 ) + name "Qilongzhu Z3 (Taiwan) (Unl)" + description "Qilongzhu Z3 (Taiwan) (Unl)" + rom ( name "Qilongzhu Z3 (Taiwan) (Unl).gbc" size 2097152 crc ccfdd63a sha1 4f3b63cd11522b6fb291661f4d918601d95138e0 ) ) game ( - name "Mario Golf (USA)" - description "Mario Golf (USA)" - rom ( name "Mario Golf (USA).gbc" size 2097152 crc 905ad0cb sha1 7f2062e51b4fc87378c1d5e6b9578c9277b94e0b ) + name "Qix Adventure (USA) (Proto)" + description "Qix Adventure (USA) (Proto)" + rom ( name "Qix Adventure (USA) (Proto).gbc" size 1048576 crc bb3744a9 sha1 43ebf78cf1ce4024d23a211a8dfb006b16c1a168 ) ) game ( - name "Mario Golf GB (Japan)" - description "Mario Golf GB (Japan)" - rom ( name "Mario Golf GB (Japan).gbc" size 2097152 crc 4ca2191a sha1 5658666a30288c6104f01985018a213e851067de ) + name "Qix Adventure (Europe)" + description "Qix Adventure (Europe)" + rom ( name "Qix Adventure (Europe).gbc" size 1048576 crc d729db40 sha1 95406795e7e1cc5207ecccac57d6b77bd0c575a1 ) ) game ( - name "Mario Tennis (Europe)" - description "Mario Tennis (Europe)" - rom ( name "Mario Tennis (Europe).gbc" size 2097152 crc 0510d601 sha1 550dcc99d0a56bbb13ae3abb2a4193b830e54970 ) + name "Qix Adventure (Japan)" + description "Qix Adventure (Japan)" + rom ( name "Qix Adventure (Japan).gbc" size 1048576 crc 5acea4a9 sha1 363b284e18a303d1dd3c2affc967fcd6912594d8 ) ) game ( - name "Mario Tennis (USA)" - description "Mario Tennis (USA)" - rom ( name "Mario Tennis (USA).gbc" size 2097152 crc a781c63c sha1 414ba58340a27fc27b127bc01455b32764151ff0 ) + name "Quan Ba Tianxia (Taiwan) (Unl)" + description "Quan Ba Tianxia (Taiwan) (Unl)" + rom ( name "Quan Ba Tianxia (Taiwan) (Unl).gbc" size 4194304 crc 2c922ed6 sha1 c19eb98a9745d2c2ce9e4dba3f17ae0b3dee0f49 ) ) game ( - name "Mario Tennis GB (Japan)" - description "Mario Tennis GB (Japan)" - rom ( name "Mario Tennis GB (Japan).gbc" size 2097152 crc 19070962 sha1 ad003d51b5a7adb7beb8b946cdf467db6d940204 flags verified ) + name "Quest - Brian's Journey (USA) (GB Compatible)" + description "Quest - Brian's Journey (USA) (GB Compatible)" + rom ( name "Quest - Brian's Journey (USA) (GB Compatible).gbc" size 2097152 crc 9ac27645 sha1 deef2b6ba0c4e468b90e32ad28f62a32f56db413 ) ) game ( - name "Marvin Strikes Back! (USA) (En,Fr,Es)" - description "Marvin Strikes Back! (USA) (En,Fr,Es)" - rom ( name "Marvin Strikes Back! (USA) (En,Fr,Es).gbc" size 2097152 crc 11b4788c sha1 6e420ef902a52a5a932e0932d0aeb11c3d71fda2 ) + name "Quest - Fantasy Challenge (USA) (SGB Enhanced) (GB Compatible)" + description "Quest - Fantasy Challenge (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Quest - Fantasy Challenge (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 98285775 sha1 86812b2cd4304dc7ee2dd3faf16737b0414aaffb ) ) game ( - name "Mary-Kate & Ashley - Get a Clue! (USA, Europe) (GB Compatible)" - description "Mary-Kate & Ashley - Get a Clue! (USA, Europe) (GB Compatible)" - rom ( name "Mary-Kate & Ashley - Get a Clue! (USA, Europe) (GB Compatible).gbc" size 1048576 crc 46faa730 sha1 4d7884e985a07ac640c3ddd1b9b482c205c5a709 flags verified ) + name "Quest for Camelot (Europe) (En,Fr,De,Es,It,Nl) (SGB Enhanced) (GB Compatible)" + description "Quest for Camelot (Europe) (En,Fr,De,Es,It,Nl) (SGB Enhanced) (GB Compatible)" + rom ( name "Quest for Camelot (Europe) (En,Fr,De,Es,It,Nl) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ce55a4de sha1 27b1839deb7fbf384539b3686ba029ca54637196 ) ) game ( - name "Mary-Kate and Ashley - Crush Course (USA, Europe)" - description "Mary-Kate and Ashley - Crush Course (USA, Europe)" - rom ( name "Mary-Kate and Ashley - Crush Course (USA, Europe).gbc" size 1048576 crc 69db3cd8 sha1 11b2a52e19862a907d340a35a49d206059f21369 ) + name "Quest for Camelot (USA, Australia) (En,Fr,Es) (SGB Enhanced) (GB Compatible)" + description "Quest for Camelot (USA, Australia) (En,Fr,Es) (SGB Enhanced) (GB Compatible)" + rom ( name "Quest for Camelot (USA, Australia) (En,Fr,Es) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d903db7d sha1 aac9d4d1869fd1374ec7b7a9de47575f7e5f54b6 flags verified ) ) game ( - name "Mary-Kate and Ashley - Pocket Planner (USA, Europe) (GB Compatible)" - description "Mary-Kate and Ashley - Pocket Planner (USA, Europe) (GB Compatible)" - rom ( name "Mary-Kate and Ashley - Pocket Planner (USA, Europe) (GB Compatible).gbc" size 1048576 crc 84a880b9 sha1 138472b98387169425b6a652be6cc8594e031bbe flags verified ) + name "Qui Qui (Japan) (GB Compatible)" + description "Qui Qui (Japan) (GB Compatible)" + rom ( name "Qui Qui (Japan) (GB Compatible).gbc" size 1048576 crc 56d76ba2 sha1 5617ca94d3c909beaccad4702e52ffaaa0279add ) ) game ( - name "Mary-Kate and Ashley - Winners Circle (USA, Europe)" - description "Mary-Kate and Ashley - Winners Circle (USA, Europe)" - rom ( name "Mary-Kate and Ashley - Winners Circle (USA, Europe).gbc" size 1048576 crc 35d6ddcc sha1 b12133af5ea63d05c2625cc46d1ffa55d19054fc flags verified ) + name "Qunxia Zhuan II (Taiwan) (Unl)" + description "Qunxia Zhuan II (Taiwan) (Unl)" + rom ( name "Qunxia Zhuan II (Taiwan) (Unl).gbc" size 2097152 crc d9a7fcd3 sha1 063d892c757464ae091a26f45cc7f021658d262a ) ) game ( - name "Mask of Zorro, The (Europe)" - description "Mask of Zorro, The (Europe)" - rom ( name "Mask of Zorro, The (Europe).gbc" size 1048576 crc 909c870f sha1 20fd1b3ed55a21fd6bf62a29ef8b57ddf1c0c73e ) + name "R-Type DX (Japan) (En) (GB Compatible)" + description "R-Type DX (Japan) (En) (GB Compatible)" + rom ( name "R-Type DX (Japan) (En) (GB Compatible).gbc" size 1048576 crc 3623ebb6 sha1 73c6b524136ef7e5318f526561b99dd0488cf36e ) ) game ( - name "Mask of Zorro, The (USA)" - description "Mask of Zorro, The (USA)" - rom ( name "Mask of Zorro, The (USA).gbc" size 1048576 crc 2c92ad12 sha1 134c03f90b21facf8720783c5dcefb182e3839ec ) + name "R-Type DX (USA, Europe) (GB Compatible)" + description "R-Type DX (USA, Europe) (GB Compatible)" + rom ( name "R-Type DX (USA, Europe) (GB Compatible).gbc" size 1048576 crc fc1d4089 sha1 e6a5c632b616e520b10b8b7589207c87c0092047 flags verified ) ) game ( - name "Mat Hoffman's Pro BMX (USA, Europe)" - description "Mat Hoffman's Pro BMX (USA, Europe)" - rom ( name "Mat Hoffman's Pro BMX (USA, Europe).gbc" size 1048576 crc 515c1459 sha1 15f58d2647fd772c8d08e6c0a23911f1f486aee2 flags verified ) + name "Race Time (Europe) (Unl)" + description "Race Time (Europe) (Unl)" + rom ( name "Race Time (Europe) (Unl).gbc" size 262144 crc 599c867d sha1 157f15e601dfb858630a53313b71e4ecd0bb13e1 ) ) game ( - name "Matchbox Emergency Patrol (USA, Europe)" - description "Matchbox Emergency Patrol (USA, Europe)" - rom ( name "Matchbox Emergency Patrol (USA, Europe).gbc" size 2097152 crc a3f23d7e sha1 8697a1a2d3575527c06114b422bd855384cf8905 flags verified ) + name "Racin' Ratz (USA)" + description "Racin' Ratz (USA)" + rom ( name "Racin' Ratz (USA).gbc" size 1048576 crc d6881014 sha1 32c63be36093db84fb5fec110ad5af49be78c4af ) ) game ( - name "Matel Gear II (Taiwan) (En) (Unl)" - description "Matel Gear II (Taiwan) (En) (Unl)" - rom ( name "Matel Gear II (Taiwan) (En) (Unl).gbc" size 2097152 crc 55494332 sha1 64da797bb0b6fe97b1956443f7bed4555436af46 ) + name "Radikal Bikers (Europe) (En,Fr,De,Es) (Proto)" + description "Radikal Bikers (Europe) (En,Fr,De,Es) (Proto)" + rom ( name "Radikal Bikers (Europe) (En,Fr,De,Es) (Proto).gbc" size 2097152 crc 81e25d37 sha1 f16aa29669b15153a63ad92388768e38aa18fbf8 ) ) game ( - name "Maus, Die (Europe) (En,Fr,De,Es) (Beta)" - description "Maus, Die (Europe) (En,Fr,De,Es) (Beta)" - rom ( name "Maus, Die (Europe) (En,Fr,De,Es) (Beta).gbc" size 1048576 crc d6e8f27e sha1 5c60b47701329e0d3ed9a1a4c929255f0fe360d9 ) + name "Rainbow Islands (Europe) (En,Fr,De,Es,It)" + description "Rainbow Islands (Europe) (En,Fr,De,Es,It)" + rom ( name "Rainbow Islands (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 6decc6b3 sha1 15dcf2f868686aea28611df69089e1929ac186f9 ) ) game ( - name "Maus, Die (Europe) (En,Fr,De,Es)" - description "Maus, Die (Europe) (En,Fr,De,Es)" - rom ( name "Maus, Die (Europe) (En,Fr,De,Es).gbc" size 1048576 crc e7bd4a49 sha1 23b612ab97b9d5e0454f9ae91b7bdbd50df91131 ) + name "Raku x Raku - Cut Shuu (Japan)" + description "Raku x Raku - Cut Shuu (Japan)" + rom ( name "Raku x Raku - Cut Shuu (Japan).gbc" size 2097152 crc 430cfcf3 sha1 b51a62358c37539021bc980c1699825596b118ef ) ) game ( - name "Maus, Die - Verrueckte Olympiade (Germany)" - description "Maus, Die - Verrueckte Olympiade (Germany)" - rom ( name "Maus, Die - Verrueckte Olympiade (Germany).gbc" size 1048576 crc fd11138e sha1 861f53ec6d5981b5f5237777fd776299d90f4cc0 ) + name "Raku x Raku - Mishin (Japan) (GB Compatible)" + description "Raku x Raku - Mishin (Japan) (GB Compatible)" + rom ( name "Raku x Raku - Mishin (Japan) (GB Compatible).gbc" size 1048576 crc 0ba0711b sha1 58bf5df55d2bab8877f7ec43110339ebe1a5d4c5 ) ) game ( - name "Maus, Die - Verrueckte Olympiade (Germany) (Beta)" - description "Maus, Die - Verrueckte Olympiade (Germany) (Beta)" - rom ( name "Maus, Die - Verrueckte Olympiade (Germany) (Beta).gbc" size 2097152 crc 39671abc sha1 ee110f4db4e2776198894baba00941e75696bc29 ) + name "Raku x Raku - Moji (Japan)" + description "Raku x Raku - Moji (Japan)" + rom ( name "Raku x Raku - Moji (Japan).gbc" size 2097152 crc abe58a8b sha1 d9502543c6cd05c7e06a3b89286eec155aff83a0 ) ) game ( - name "Max Steel - Covert Missions (USA) (En,Fr,De,Es) (Proto)" - description "Max Steel - Covert Missions (USA) (En,Fr,De,Es) (Proto)" - rom ( name "Max Steel - Covert Missions (USA) (En,Fr,De,Es) (Proto).gbc" size 1048576 crc 57b1e978 sha1 050a3f041328016c433d923b213674014546db6e ) + name "Rampage - World Tour (USA, Europe) (GB Compatible)" + description "Rampage - World Tour (USA, Europe) (GB Compatible)" + rom ( name "Rampage - World Tour (USA, Europe) (GB Compatible).gbc" size 524288 crc b029017f sha1 5064f76557ce4235c8d1d4da7bac94e3af352126 ) ) game ( - name "Maya the Bee - Garden Adventures (Europe) (En,Fr,De,Es)" - description "Maya the Bee - Garden Adventures (Europe) (En,Fr,De,Es)" - rom ( name "Maya the Bee - Garden Adventures (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 142b6efb sha1 e46ea15b4c780a49e29e86516cb1ec5a03bdddce ) + name "Rampage 2 - Universal Tour (USA, Europe)" + description "Rampage 2 - Universal Tour (USA, Europe)" + rom ( name "Rampage 2 - Universal Tour (USA, Europe).gbc" size 1048576 crc 20b86f1e sha1 4f6f14588e385357206f52e2c74b07b44d16f78f ) ) game ( - name "Maya the Bee & Her Friends (Europe) (En,Fr,De) (GB Compatible)" - description "Maya the Bee & Her Friends (Europe) (En,Fr,De) (GB Compatible)" - rom ( name "Maya the Bee & Her Friends (Europe) (En,Fr,De) (GB Compatible).gbc" size 1048576 crc 983b1d26 sha1 522d7f33fd39bd00f48208743fb2246ef0bd3ff1 ) + name "Rampart (USA)" + description "Rampart (USA)" + rom ( name "Rampart (USA).gbc" size 1048576 crc d5aeed2e sha1 40cef7a1af53d2da5cd7b9d7927f1f64399e69dc flags verified ) ) game ( - name "Mayhem (World) (Aftermarket) (Unl)" - description "Mayhem (World) (Aftermarket) (Unl)" - rom ( name "Mayhem (World) (Aftermarket) (Unl).gbc" size 262144 crc 4d739ad7 sha1 9f141728a74432820f47cc24d230dc56d6ac099b ) + name "Rats! (USA) (En,Es) (GB Compatible)" + description "Rats! (USA) (En,Es) (GB Compatible)" + rom ( name "Rats! (USA) (En,Es) (GB Compatible).gbc" size 524288 crc 17635ad1 sha1 5e423dfab8221b69a641d2e535ebfe1e3759a2e4 ) ) game ( - name "McDonald's Monogatari - Honobono Tenchou Ikusei Game (Japan)" - description "McDonald's Monogatari - Honobono Tenchou Ikusei Game (Japan)" - rom ( name "McDonald's Monogatari - Honobono Tenchou Ikusei Game (Japan).gbc" size 2097152 crc 66328695 sha1 5198a1c3a2bb2cfd6d5986a71e322cb6f43609bb ) + name "Rayman (Europe) (En,Fr,De,Es,It,Nl)" + description "Rayman (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Rayman (Europe) (En,Fr,De,Es,It,Nl).gbc" size 4194304 crc c430a89a sha1 2e2d674426f2d29195a4bfbd82dca4c25416e475 flags verified ) ) game ( - name "Medarot 2 - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible)" - description "Medarot 2 - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Medarot 2 - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc bf6bd446 sha1 01adf621d6e2cbfec46306d69882fc2eb3d92de5 ) + name "Rayman (USA) (En,Fr,De,Es,It,Nl)" + description "Rayman (USA) (En,Fr,De,Es,It,Nl)" + rom ( name "Rayman (USA) (En,Fr,De,Es,It,Nl).gbc" size 4194304 crc eda12f0d sha1 5a6999c0ca4be80a6259664fdffbc79fd4bb1ed6 ) ) game ( - name "Medarot 2 - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible)" - description "Medarot 2 - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Medarot 2 - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 5b8ffd37 sha1 48fc8c6e84c63ee47f5a2c5e99dc1666d6e9f496 flags verified ) + name "Rayman - Mister Dark no Wana (Japan)" + description "Rayman - Mister Dark no Wana (Japan)" + rom ( name "Rayman - Mister Dark no Wana (Japan).gbc" size 4194304 crc 3fde5bac sha1 ef057156806dddcc3d0cc5776843c639c6c3cae4 ) ) game ( - name "Medarot 2 - Parts Collection (Japan) (SGB Enhanced) (GB Compatible)" - description "Medarot 2 - Parts Collection (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Medarot 2 - Parts Collection (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 159673db sha1 62e6e2800025918a0df9ceb31418dcbfe9e64289 ) + name "Rayman 2 (USA) (En,Fr,De,Es,It)" + description "Rayman 2 (USA) (En,Fr,De,Es,It)" + rom ( name "Rayman 2 (USA) (En,Fr,De,Es,It).gbc" size 4194304 crc 6f5c315d sha1 d984deaf66933571404eb5be754972d73ec7fbd5 ) ) game ( - name "Medarot 3 - Kabuto Version (Japan)" - description "Medarot 3 - Kabuto Version (Japan)" - rom ( name "Medarot 3 - Kabuto Version (Japan).gbc" size 4194304 crc e655632c sha1 5478069c840b5b13e2413771f35fdc844d1974f1 ) + name "Rayman 2 Forever (Europe) (En,Fr,De,Es,It)" + description "Rayman 2 Forever (Europe) (En,Fr,De,Es,It)" + rom ( name "Rayman 2 Forever (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 250015d4 sha1 5ea438c5b52696255e8df74eb19e3cac1427a14a ) ) game ( - name "Medarot 3 - Kuwagata Version (Japan)" - description "Medarot 3 - Kuwagata Version (Japan)" - rom ( name "Medarot 3 - Kuwagata Version (Japan).gbc" size 4194304 crc bc617834 sha1 5207698702d206046dd105b07e0c0bbdbc6ed39c ) + name "Razmoket a Paris, Les - Le Film (France)" + description "Razmoket a Paris, Les - Le Film (France)" + rom ( name "Razmoket a Paris, Les - Le Film (France).gbc" size 1048576 crc 094494e9 sha1 ed9ec61de28dc1a83f0e98e8d651399cb45bd387 ) ) game ( - name "Medarot 3 - Parts Collection - Z kara no Chousenjou (Japan)" - description "Medarot 3 - Parts Collection - Z kara no Chousenjou (Japan)" - rom ( name "Medarot 3 - Parts Collection - Z kara no Chousenjou (Japan).gbc" size 2097152 crc ee2d977f sha1 3f13ced98ee7edf3504559c111825c6f0997f3d9 ) + name "Razmoket, Les - 100% Angelica (France)" + description "Razmoket, Les - 100% Angelica (France)" + rom ( name "Razmoket, Les - 100% Angelica (France).gbc" size 1048576 crc 1d66cb29 sha1 a04285ae27def1e0b808561099cc2cb86ba94f07 ) ) game ( - name "Medarot 4 - Kabuto Version (Japan)" - description "Medarot 4 - Kabuto Version (Japan)" - rom ( name "Medarot 4 - Kabuto Version (Japan).gbc" size 4194304 crc c192a368 sha1 a62a00ee6095b3dcdf347fbb7c536b51976a109f ) + name "Razmoket, Les - Voyage dans le Temps (France)" + description "Razmoket, Les - Voyage dans le Temps (France)" + rom ( name "Razmoket, Les - Voyage dans le Temps (France).gbc" size 1048576 crc 2f8fef3f sha1 9587eb9c373399401bdd2208d22425999956733d ) ) game ( - name "Medarot 4 - Kuwagata Version (Japan)" - description "Medarot 4 - Kuwagata Version (Japan)" - rom ( name "Medarot 4 - Kuwagata Version (Japan).gbc" size 4194304 crc 6a29b9d8 sha1 10b3e69d19897fd233915e3949d02be71af0e521 ) + name "Razor Freestyle Scooter (USA)" + description "Razor Freestyle Scooter (USA)" + rom ( name "Razor Freestyle Scooter (USA).gbc" size 1048576 crc 5c201286 sha1 9360aa3e7062399527686ed55b06faeaa388178c ) ) game ( - name "Medarot 5 - Susutake Mura no Tenkousei - Kabuto (Japan)" - description "Medarot 5 - Susutake Mura no Tenkousei - Kabuto (Japan)" - rom ( name "Medarot 5 - Susutake Mura no Tenkousei - Kabuto (Japan).gbc" size 4194304 crc a3c1756e sha1 7f52ecb2a057d99b0448d82e3b5263eb92c2396c ) + name "Ready 2 Rumble Boxing (Europe)" + description "Ready 2 Rumble Boxing (Europe)" + rom ( name "Ready 2 Rumble Boxing (Europe).gbc" size 2097152 crc bea36bf9 sha1 46dba4b01cc71f07ceb6472064e0312ca70b31bd flags verified ) ) game ( - name "Medarot 5 - Susutake Mura no Tenkousei - Kuwagata (Japan)" - description "Medarot 5 - Susutake Mura no Tenkousei - Kuwagata (Japan)" - rom ( name "Medarot 5 - Susutake Mura no Tenkousei - Kuwagata (Japan).gbc" size 4194304 crc 014083a8 sha1 3fcc292449da992f04c61d9117f3d5cc1bef446f ) + name "Ready 2 Rumble Boxing (USA) (Rumble Version)" + description "Ready 2 Rumble Boxing (USA) (Rumble Version)" + rom ( name "Ready 2 Rumble Boxing (USA) (Rumble Version).gbc" size 2097152 crc 345e20a4 sha1 30ea96ba1f4ffbe2546eac86f57827138c5d676e flags verified ) ) game ( - name "Medarot Cardrobottle - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible)" - description "Medarot Cardrobottle - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Medarot Cardrobottle - Kabuto Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4f03d80a sha1 b7a02cee93169f73675b562d09d10175684ec77f flags verified ) + name "Real Pro Yakyuu! - Central League Hen (Japan) (SGB Enhanced) (GB Compatible)" + description "Real Pro Yakyuu! - Central League Hen (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Real Pro Yakyuu! - Central League Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc afff6bb9 sha1 02c18d98a07b3af9a1d26d0c3003f8e75c81f4d9 ) ) game ( - name "Medarot Cardrobottle - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible)" - description "Medarot Cardrobottle - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Medarot Cardrobottle - Kuwagata Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc a3735f81 sha1 26b5516170ea0fa1669cafb9484e1aeb5d2cae6c ) + name "Real Pro Yakyuu! - Pacific League Hen (Japan) (SGB Enhanced) (GB Compatible)" + description "Real Pro Yakyuu! - Pacific League Hen (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Real Pro Yakyuu! - Pacific League Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc 16b81c36 sha1 a7a2cd7bbb4cae171b5f2c798293afefe2882afc ) ) game ( - name "Mega Man Xtreme (USA, Europe) (GB Compatible)" - description "Mega Man Xtreme (USA, Europe) (GB Compatible)" - rom ( name "Mega Man Xtreme (USA, Europe) (GB Compatible).gbc" size 1048576 crc 3a4d94d5 sha1 c877449ba0889fdcacf23c49b0611d0ca57283c5 flags verified ) + name "Remen Gaoxiao - Shuma Guaishou III (Taiwan) (Unl)" + description "Remen Gaoxiao - Shuma Guaishou III (Taiwan) (Unl)" + rom ( name "Remen Gaoxiao - Shuma Guaishou III (Taiwan) (Unl).gbc" size 524288 crc 9f64fb1c sha1 b8d6910c8b5c1cab044c61679bbbc4f213648f56 ) ) game ( - name "Mega Man Xtreme 2 (USA, Europe)" - description "Mega Man Xtreme 2 (USA, Europe)" - rom ( name "Mega Man Xtreme 2 (USA, Europe).gbc" size 1048576 crc 8fedb6d8 sha1 cb1811ac8969f6b683df954b57138dd28ebb40ff flags verified ) + name "Rescue Heroes - Fire Frenzy (USA)" + description "Rescue Heroes - Fire Frenzy (USA)" + rom ( name "Rescue Heroes - Fire Frenzy (USA).gbc" size 1048576 crc 77a4dc63 sha1 a57aeb43ef88ffd09f5028368a3142c3e9f5e792 ) ) game ( - name "Mega Memory Card (USA) (GB Compatible) (Unl)" - description "Mega Memory Card (USA) (GB Compatible) (Unl)" - rom ( name "Mega Memory Card (USA) (GB Compatible) (Unl).gbc" size 32768 crc 69e35940 sha1 06803c6342b6b5aa2d4b85ef096e11241bf5c90d ) + name "Reservoir Rat (Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "Reservoir Rat (Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Reservoir Rat (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 524288 crc 22621803 sha1 7ee86635f9d9735cc57673b08995be7003ff6082 flags verified ) ) game ( - name "Megaman X4 (Taiwan) (En) (Rumble Version) (Unl)" - description "Megaman X4 (Taiwan) (En) (Rumble Version) (Unl)" - rom ( name "Megaman X4 (Taiwan) (En) (Rumble Version) (Unl).gbc" size 524288 crc 043a17b3 sha1 64a2ca35c2fa8a8db8604f167652b1ae2148ac0b ) + name "Resident Evil (World) (Proto 1)" + description "Resident Evil (World) (Proto 1)" + rom ( name "Resident Evil (World) (Proto 1).gbc" size 4194304 crc e6e722c8 sha1 87f8b1bad965bc9214ccd2932020163418a4e8f1 ) ) game ( - name "Megami Tensei Gaiden - Last Bible (Japan) (SGB Enhanced) (GB Compatible)" - description "Megami Tensei Gaiden - Last Bible (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Megami Tensei Gaiden - Last Bible (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc bd9ba639 sha1 419c5afdbc9b59e05e7861de8cc59ee367cd29f0 ) + name "Resident Evil (World) (Proto 2)" + description "Resident Evil (World) (Proto 2)" + rom ( name "Resident Evil (World) (Proto 2).gbc" size 4194304 crc 53f7bba1 sha1 bda5a658631a5714e761ee1805baaa0008ee8cdf ) ) game ( - name "Megami Tensei Gaiden - Last Bible II (Japan) (SGB Enhanced) (GB Compatible)" - description "Megami Tensei Gaiden - Last Bible II (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Megami Tensei Gaiden - Last Bible II (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 9caa00b5 sha1 84df9508bdd8b24dfb19a74744fec492fffee56d ) + name "Resident Evil (Unknown) (Demo) (Climax Entertainment)" + description "Resident Evil (Unknown) (Demo) (Climax Entertainment)" + rom ( name "Resident Evil (Unknown) (Demo) (Climax Entertainment).gbc" size 524288 crc 1a921065 sha1 bec002e2d9e7852cd85b720b570f4ae73453b756 ) ) game ( - name "Meitantei Conan - Karakuri Jiin Satsujin Jiken (Japan) (SGB Enhanced) (GB Compatible)" - description "Meitantei Conan - Karakuri Jiin Satsujin Jiken (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Meitantei Conan - Karakuri Jiin Satsujin Jiken (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 3b5f24fc sha1 a418ff2f97536e105b4f0a1bd4bb3fa31f911a7d flags verified ) + name "Resident Evil Gaiden (Europe) (En,Fr,De,Es,It)" + description "Resident Evil Gaiden (Europe) (En,Fr,De,Es,It)" + rom ( name "Resident Evil Gaiden (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc f85c3f2c sha1 2116120a930bd93d5e32cc588acadb559b0d65e8 ) ) game ( - name "Meitantei Conan - Kigantou Hihou Densetsu (Japan) (SGB Enhanced) (GB Compatible)" - description "Meitantei Conan - Kigantou Hihou Densetsu (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Meitantei Conan - Kigantou Hihou Densetsu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e620fae2 sha1 cd3f8015e5b708f1eb14c374042a1701eeaafc4f flags verified ) + name "Resident Evil Gaiden (USA)" + description "Resident Evil Gaiden (USA)" + rom ( name "Resident Evil Gaiden (USA).gbc" size 2097152 crc f8c5021b sha1 a302cddc085d65ca778153e2a591bd648ce963c9 ) ) game ( - name "Meitantei Conan - Norowareta Kouro (Japan) (SGB Enhanced) (GB Compatible)" - description "Meitantei Conan - Norowareta Kouro (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Meitantei Conan - Norowareta Kouro (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc cabdd802 sha1 0858a619d716b0191713734d506d9f113f0d1c62 ) + name "Return of the Ninja (Europe)" + description "Return of the Ninja (Europe)" + rom ( name "Return of the Ninja (Europe).gbc" size 1048576 crc 8e04849a sha1 e49ce291a1da791955a5de8c894aca28ffc97f9b ) ) game ( - name "Melanie and the Magic Forest (World) (GB Compatible) (Aftermarket) (Unl)" - description "Melanie and the Magic Forest (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Melanie and the Magic Forest (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f614bdff sha1 7e46c193f6566f620acf20ead3a1fca1d677c221 ) + name "Return of the Ninja (USA)" + description "Return of the Ninja (USA)" + rom ( name "Return of the Ninja (USA).gbc" size 1048576 crc a07da702 sha1 e33352f0ac19d28983ebed0758d022861473ec0e ) ) game ( - name "Melanie and the Magic Forest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "Melanie and the Magic Forest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Melanie and the Magic Forest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 949c6ab9 sha1 34269af4db6c37b92fdc7f7f914c282174603ba8 ) + name "Return of the Ninja (World) (Limited Run Games)" + description "Return of the Ninja (World) (Limited Run Games)" + rom ( name "Return of the Ninja (World) (Limited Run Games).gbc" size 1048576 crc df445c4a sha1 d73049119fbc163183fdb95e9b299ca4d1d4e8e3 ) ) game ( - name "Memory Mania Challenge (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" - description "Memory Mania Challenge (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Memory Mania Challenge (World) (v1.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 50618f4b sha1 c8d74af4746313800df3a23c1ad01f931e0e2eca flags verified ) + name "Revelations - The Demon Slayer (USA) (SGB Enhanced) (GB Compatible)" + description "Revelations - The Demon Slayer (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Revelations - The Demon Slayer (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d1a65d74 sha1 bd684074944ccc02b5f997e7ab95d0b03327773d ) ) game ( - name "Men in Black - The Series (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Men in Black - The Series (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Men in Black - The Series (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 65b8b343 sha1 7ceb1c82bdd185546c3dd5d2653788d74d811f7a ) + name "Rhino Rumble (USA, Europe)" + description "Rhino Rumble (USA, Europe)" + rom ( name "Rhino Rumble (USA, Europe).gbc" size 1048576 crc 73160e05 sha1 2caf47c20d8632e47c4426dd3564e76415139973 flags verified ) ) game ( - name "Men in Black 2 - The Series (Europe) (En,Fr,De)" - description "Men in Black 2 - The Series (Europe) (En,Fr,De)" - rom ( name "Men in Black 2 - The Series (Europe) (En,Fr,De).gbc" size 1048576 crc ca675933 sha1 f1527fd7f82329ef676a6d475596e7d91c4065cc ) + name "Rip-Tide Racer (Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "Rip-Tide Racer (Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Rip-Tide Racer (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc ab8c3a31 sha1 3354d6e79b8094bbaa4ef48eb8bd2b0774c46e1a ) ) game ( - name "Men in Black 2 - The Series (USA) (En,Fr,De)" - description "Men in Black 2 - The Series (USA) (En,Fr,De)" - rom ( name "Men in Black 2 - The Series (USA) (En,Fr,De).gbc" size 1048576 crc 8b63f36f sha1 ccfb89824e81d128a26a38f3e2c49aae1e9752ed ) + name "Road Champs - BXS Stunt Biking (USA, Europe)" + description "Road Champs - BXS Stunt Biking (USA, Europe)" + rom ( name "Road Champs - BXS Stunt Biking (USA, Europe).gbc" size 1048576 crc 98c59706 sha1 15134178346c5209197f4847d7de5ef86be36b85 flags verified ) ) game ( - name "Menghuan Moni Zhan II (Taiwan) (Zh) (Unl)" - description "Menghuan Moni Zhan II (Taiwan) (Zh) (Unl)" - rom ( name "Menghuan Moni Zhan II (Taiwan) (Zh) (Unl).gbc" size 2097152 crc 366067e8 sha1 745e43cba91ed6f2af0bdedf136f4247d690aa1a ) + name "Road Rash (USA, Europe)" + description "Road Rash (USA, Europe)" + rom ( name "Road Rash (USA, Europe).gbc" size 1048576 crc 11025eeb sha1 b3329c0f92c1a6a6cfa894f487f68a7fcceb5844 ) ) game ( - name "Merlin (Europe) (En,Fr,De,Es,It,Nl)" - description "Merlin (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Merlin (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc c5290cee sha1 96ee6a40abf4bcbb90f3ea7c232fb3866333a202 ) + name "Roadsters (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + description "Roadsters (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + rom ( name "Roadsters (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc 717b3525 sha1 3c0a54fba91a6df88c152a824d192e05c0a68250 ) ) game ( - name "MetaFight EX (Japan)" - description "MetaFight EX (Japan)" - rom ( name "MetaFight EX (Japan).gbc" size 1048576 crc 00733c77 sha1 95057addec90061cfab3e5c5c56d4f87ffc9d00e ) + name "Roadsters (USA) (En,Fr,De,Es,It,Nl) (GB Compatible)" + description "Roadsters (USA) (En,Fr,De,Es,It,Nl) (GB Compatible)" + rom ( name "Roadsters (USA) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc 38b022be sha1 ede737e99108be29daf94fee8e10f5dd770731bb flags verified ) ) game ( - name "Metal Gear - Ghost Babel (Japan)" - description "Metal Gear - Ghost Babel (Japan)" - rom ( name "Metal Gear - Ghost Babel (Japan).gbc" size 2097152 crc 7831f84d sha1 ca9c35b578171f7ac4957ebb838195e806b5c1e8 ) + name "Roadsters '98 (USA) (Proto) (SGB Enhanced) (GB Compatible)" + description "Roadsters '98 (USA) (Proto) (SGB Enhanced) (GB Compatible)" + rom ( name "Roadsters '98 (USA) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 131072 crc fe2995a1 sha1 30a28cd5e020e98b0e7016b5ccda5bc0972a0ac9 ) ) game ( - name "Metal Gear Solid (Europe) (En,Fr,De,Es,It)" - description "Metal Gear Solid (Europe) (En,Fr,De,Es,It)" - rom ( name "Metal Gear Solid (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 16796957 sha1 488bff9c4cee9e692a05b3938fd7b2014e743eac flags verified ) + name "Robin Hood (Europe) (En,Fr,De,Es,It,Nl)" + description "Robin Hood (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Robin Hood (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc d4f84329 sha1 fe0c42e949bc41f070b22dd24e643aa42b007667 ) ) game ( - name "Metal Gear Solid (USA)" - description "Metal Gear Solid (USA)" - rom ( name "Metal Gear Solid (USA).gbc" size 2097152 crc 04b0c5d6 sha1 2266499cfa10351b23fefd2216308867d1f1558b ) + name "RoboCop (Europe) (En,Fr,De,Es,It,Nl)" + description "RoboCop (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "RoboCop (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 6c6423e2 sha1 fbac3bdc8ed40c0f752ec711c4cc82262358f9bd ) ) game ( - name "Metal Walker (USA) (GB Compatible)" - description "Metal Walker (USA) (GB Compatible)" - rom ( name "Metal Walker (USA) (GB Compatible).gbc" size 1048576 crc 3be68391 sha1 1ccb07d705ef68e078440118c178b87646e9b724 ) + name "Robopon - Star Version (USA) (Proto)" + description "Robopon - Star Version (USA) (Proto)" + rom ( name "Robopon - Star Version (USA) (Proto).gbc" size 1048576 crc cf5f0a63 sha1 54e064a24cd50b7e25df5c827c54a20643ec314a ) ) game ( - name "Metamode (Japan)" - description "Metamode (Japan)" - rom ( name "Metamode (Japan).gbc" size 2097152 crc a76eed5b sha1 1c1d74c810b90cf4d2ee32859eaea569a5b45c3f ) + name "Robopon - Sun Version (USA) (SGB Enhanced) (GB Compatible)" + description "Robopon - Sun Version (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Robopon - Sun Version (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 32caef11 sha1 399c928a38a3901b7a1093bd61f5a4d8c05b9771 flags verified ) ) game ( - name "Meteorite (World) (Aftermarket) (Unl)" - description "Meteorite (World) (Aftermarket) (Unl)" - rom ( name "Meteorite (World) (Aftermarket) (Unl).gbc" size 131072 crc fafbcebf sha1 25a81d916f1ed80a2bca2fe7a555433f06d025e3 ) + name "Robopon - Sun Version (USA) (Beta) (SGB Enhanced) (GB Compatible)" + description "Robopon - Sun Version (USA) (Beta) (SGB Enhanced) (GB Compatible)" + rom ( name "Robopon - Sun Version (USA) (Beta) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0b6985e4 sha1 30f36f420bec76126171b1139538de4017ed75ac ) ) game ( - name "Mia Hamm Soccer Shootout (USA)" - description "Mia Hamm Soccer Shootout (USA)" - rom ( name "Mia Hamm Soccer Shootout (USA).gbc" size 1048576 crc d77971c0 sha1 82e7c25bdee895a6dfdc01ad3e94138bf7b98e59 ) + name "Robot Poncots - Comic Bom Bom Special Version (Japan) (SGB Enhanced) (GB Compatible)" + description "Robot Poncots - Comic Bom Bom Special Version (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Robot Poncots - Comic Bom Bom Special Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4aa209cd sha1 79d1eda07e792497506ff1494e5222db2a52702f flags verified ) ) game ( - name "Mickey's Racing Adventure (USA, Europe) (En,Fr,De,Es,It)" - description "Mickey's Racing Adventure (USA, Europe) (En,Fr,De,Es,It)" - rom ( name "Mickey's Racing Adventure (USA, Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc d5e845f4 sha1 e93e8cde531dbca8a5cc40a8a4e3936f13541f01 flags verified ) + name "Robot Poncots - Moon Version (Japan) (SGB Enhanced) (GB Compatible)" + description "Robot Poncots - Moon Version (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Robot Poncots - Moon Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 87a29030 sha1 7d6424bfecfeb17aee9f779dcb9bac47114730cd flags verified ) ) game ( - name "Mickey's Speedway USA (USA, Europe) (En,Fr,De,Es)" - description "Mickey's Speedway USA (USA, Europe) (En,Fr,De,Es)" - rom ( name "Mickey's Speedway USA (USA, Europe) (En,Fr,De,Es).gbc" size 4194304 crc 11763934 sha1 edd7f3fecfef81bcd5445b6b5df89ca2be897d2f flags verified ) + name "Robot Poncots - Star Version (Japan) (SGB Enhanced) (GB Compatible)" + description "Robot Poncots - Star Version (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Robot Poncots - Star Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b28f32ac sha1 27a96410b38e695d9b80ae861af3b472f0e84c60 flags verified ) ) game ( - name "Micro Machines 1 and 2 - Twin Turbo (USA, Europe)" - description "Micro Machines 1 and 2 - Twin Turbo (USA, Europe)" - rom ( name "Micro Machines 1 and 2 - Twin Turbo (USA, Europe).gbc" size 2097152 crc 5dd337eb sha1 18b5c14ee3b3f3c16b9d641c3b3824b15c0a0c78 ) + name "Robot Poncots - Sun Version (Japan) (SGB Enhanced) (GB Compatible)" + description "Robot Poncots - Sun Version (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Robot Poncots - Sun Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc cb0b8003 sha1 2f82dd4a1537111d14f11eb13c7ce6fc748e83fe flags verified ) ) game ( - name "Micro Machines 2 - Turbo Tournament (Europe) (Proto)" - description "Micro Machines 2 - Turbo Tournament (Europe) (Proto)" - rom ( name "Micro Machines 2 - Turbo Tournament (Europe) (Proto).gbc" size 2097152 crc e932c818 sha1 cbdefc7f63bf9a6c0fc15d7ab72b4b532b0d2422 ) + name "Robot Wars - Metal Mayhem (Europe) (En,Fr,De,It,Nl,Sv)" + description "Robot Wars - Metal Mayhem (Europe) (En,Fr,De,It,Nl,Sv)" + rom ( name "Robot Wars - Metal Mayhem (Europe) (En,Fr,De,It,Nl,Sv).gbc" size 1048576 crc e99bdee6 sha1 745a6d813ba561b53379a718312e7e8b6730c15f ) ) game ( - name "Micro Machines V3 (USA, Europe)" - description "Micro Machines V3 (USA, Europe)" - rom ( name "Micro Machines V3 (USA, Europe).gbc" size 2097152 crc b8064453 sha1 8e9efbe195bcecfec4b233921b22b2e7fce38d3a flags verified ) + name "Rocket Power - Gettin' Air (USA, Europe)" + description "Rocket Power - Gettin' Air (USA, Europe)" + rom ( name "Rocket Power - Gettin' Air (USA, Europe).gbc" size 1048576 crc 7025eb63 sha1 d9c5c22f1f5a2a922cb2b39d5e8f3df31c1155d7 flags verified ) ) game ( - name "Micro Maniacs (Europe)" - description "Micro Maniacs (Europe)" - rom ( name "Micro Maniacs (Europe).gbc" size 2097152 crc e66e093b sha1 53773090e44e0a24a4481249541d48ea1432e83d ) + name "Rocket Power - La Glisse de l'Extreme (France)" + description "Rocket Power - La Glisse de l'Extreme (France)" + rom ( name "Rocket Power - La Glisse de l'Extreme (France).gbc" size 1048576 crc c9a7aa7b sha1 b6b9b7b2fb2ff11d41c6531fe21bfd5aa89f7ab4 ) ) game ( - name "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (Europe) (En,Fr,De,Es,It)" - description "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (Europe) (En,Fr,De,Es,It)" - rom ( name "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc ee4cba24 sha1 0af8ea56fcbf49c49d6815d316b1cd80cd8e1538 ) + name "Rockman 3 (Taiwan) (Unl)" + description "Rockman 3 (Taiwan) (Unl)" + rom ( name "Rockman 3 (Taiwan) (Unl).gbc" size 1048576 crc 46c5b31d sha1 70e5c1dae3bf0aee8dc901aba9e66751f2c1fc01 ) ) game ( - name "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (USA)" - description "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (USA)" - rom ( name "Microsoft - The 6 in 1 Puzzle Collection Entertainment Pack (USA).gbc" size 1048576 crc 0777b8d7 sha1 edf2b960209d8763a330c72fcfd890b360864aeb ) + name "Rockman DX6 (Taiwan) (Unl)" + description "Rockman DX6 (Taiwan) (Unl)" + rom ( name "Rockman DX6 (Taiwan) (Unl).gbc" size 1048576 crc 154f885b sha1 222e8362da7a7eb999150c367a305271c60661b6 ) ) game ( - name "Microsoft - The Best of Entertainment Pack (Europe)" - description "Microsoft - The Best of Entertainment Pack (Europe)" - rom ( name "Microsoft - The Best of Entertainment Pack (Europe).gbc" size 1048576 crc 0f02d708 sha1 be52fa14e66f4b35c66f434db61da4cfcec71762 ) + name "Rockman DX8 (China) (En) (Unl)" + description "Rockman DX8 (China) (En) (Unl)" + rom ( name "Rockman DX8 (China) (En) (Unl).gbc" size 1048576 crc 4c6c9eaf sha1 1274bb7d5570f4f1101dff1d13d9b5665deaa3da ) ) game ( - name "Microsoft - The Best of Entertainment Pack (USA)" - description "Microsoft - The Best of Entertainment Pack (USA)" - rom ( name "Microsoft - The Best of Entertainment Pack (USA).gbc" size 1048576 crc d2d88cfa sha1 38b4814afd24bf1fffa382ed3396b6413abc5616 ) + name "Rockman X - Cyber Mission (Japan) (GB Compatible)" + description "Rockman X - Cyber Mission (Japan) (GB Compatible)" + rom ( name "Rockman X - Cyber Mission (Japan) (GB Compatible).gbc" size 1048576 crc 919077ab sha1 c47d50814489b7426ce110d35d1c059d0c24af21 ) ) game ( - name "Microsoft Pinball Arcade (USA)" - description "Microsoft Pinball Arcade (USA)" - rom ( name "Microsoft Pinball Arcade (USA).gbc" size 1048576 crc 504f55c5 sha1 da4593edb37be892374e00d0174e45ff6301c907 ) + name "Rockman X2 - Soul Eraser (Japan)" + description "Rockman X2 - Soul Eraser (Japan)" + rom ( name "Rockman X2 - Soul Eraser (Japan).gbc" size 1048576 crc 17913dd0 sha1 b7308301706c5414bb75f33232042124d9a608f1 ) ) game ( - name "Microsoft Pinball Arcade (Europe)" - description "Microsoft Pinball Arcade (Europe)" - rom ( name "Microsoft Pinball Arcade (Europe).gbc" size 1048576 crc 4eb7db14 sha1 f2874f0f3023d96edbdb94e5c0dc181d8baa3efb flags verified ) + name "Rockman X3 (Taiwan) (Unl)" + description "Rockman X3 (Taiwan) (Unl)" + rom ( name "Rockman X3 (Taiwan) (Unl).gbc" size 524288 crc 7f4112a3 sha1 6c1d24162f2682bb6e82fb09639f2e311fda5aff ) ) game ( - name "Midterm Moments (World) (2022-05-28) (GB Compatible) (Aftermarket) (Unl)" - description "Midterm Moments (World) (2022-05-28) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Midterm Moments (World) (2022-05-28) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f9a5ed4e sha1 8b3e18287d5adf3b5a711e28a896f843927f22a2 ) + name "Rocky Mountain - Trophy Hunter (USA)" + description "Rocky Mountain - Trophy Hunter (USA)" + rom ( name "Rocky Mountain - Trophy Hunter (USA).gbc" size 1048576 crc 9aa5b021 sha1 864bbf4437ea1210e9e3012b290659af765c87b4 ) ) game ( - name "Midterm Moments (World) (2022-06-15) (GB Compatible) (Aftermarket) (Unl)" - description "Midterm Moments (World) (2022-06-15) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Midterm Moments (World) (2022-06-15) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 177f0b6e sha1 e5fdb741d870de25affdc841c07eaa3000da25f5 ) + name "Rocman X Gold + 4 in 1 (Taiwan) (1B-002, 4B-003, Sachen) (Unl)" + description "Rocman X Gold + 4 in 1 (Taiwan) (1B-002, 4B-003, Sachen) (Unl)" + rom ( name "Rocman X Gold + 4 in 1 (Taiwan) (1B-002, 4B-003, Sachen) (Unl).gbc" size 524288 crc 7e1351cf sha1 7e62472c13b5a6a933aa93dc5b239f11a664f337 ) ) game ( - name "Midway Presents Arcade Hits - Joust & Defender (USA, Europe) (GB Compatible)" - description "Midway Presents Arcade Hits - Joust & Defender (USA, Europe) (GB Compatible)" - rom ( name "Midway Presents Arcade Hits - Joust & Defender (USA, Europe) (GB Compatible).gbc" size 1048576 crc 4c1ececb sha1 f0f35970517090165797568448b5ef5cad8e4952 ) + name "Roi Lion, Le - La Formidable Aventure de Simba (France)" + description "Roi Lion, Le - La Formidable Aventure de Simba (France)" + rom ( name "Roi Lion, Le - La Formidable Aventure de Simba (France).gbc" size 1048576 crc 6467fba0 sha1 a0bef7df1ba3d75e7958763f0cec9c76428415df ) ) game ( - name "Midway Presents Arcade Hits - Moon Patrol & Spy Hunter (USA, Europe) (GB Compatible)" - description "Midway Presents Arcade Hits - Moon Patrol & Spy Hunter (USA, Europe) (GB Compatible)" - rom ( name "Midway Presents Arcade Hits - Moon Patrol & Spy Hunter (USA, Europe) (GB Compatible).gbc" size 1048576 crc f40199c9 sha1 8dc667e7d44b46ad42ec7e465091cfacc0009974 flags verified ) + name "Roi Lion, Le - La Formidable Aventure de Simba (France) (Rev 1)" + description "Roi Lion, Le - La Formidable Aventure de Simba (France) (Rev 1)" + rom ( name "Roi Lion, Le - La Formidable Aventure de Simba (France) (Rev 1).gbc" size 1048576 crc c7aae1b3 sha1 b8cc2f1d3a8d40c7588d5c535f28e2f80446a793 ) ) game ( - name "Millennium Winter Sports (USA)" - description "Millennium Winter Sports (USA)" - rom ( name "Millennium Winter Sports (USA).gbc" size 1048576 crc b57dabae sha1 f47321c3c1217467dc48240bf53b50ed9630b28a ) + name "Rokumon Tengai Mon-Colle-Knight GB (Japan)" + description "Rokumon Tengai Mon-Colle-Knight GB (Japan)" + rom ( name "Rokumon Tengai Mon-Colle-Knight GB (Japan).gbc" size 2097152 crc e48adf8d sha1 ab0a9630c16407549da28ff47ac4da33579975e4 ) ) game ( - name "Mingzhu Koudai Guaishou 2 (Taiwan) (Unl)" - description "Mingzhu Koudai Guaishou 2 (Taiwan) (Unl)" - rom ( name "Mingzhu Koudai Guaishou 2 (Taiwan) (Unl).gbc" size 2097152 crc 31f14d99 sha1 0ea3390e4479acf96d65791dd9ab08464753d48a ) + name "Roland Garros French Open (Europe) (En,Fr,De,Es,It,Nl)" + description "Roland Garros French Open (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Roland Garros French Open (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 10dbde7c sha1 86ab2d43e62f8a765992bdebe38b41a8d95ef5cb flags verified ) ) game ( - name "Mingzhu Koudai Guaishou 3 (Taiwan) (En,Es,Zh) (Unl)" - description "Mingzhu Koudai Guaishou 3 (Taiwan) (En,Es,Zh) (Unl)" - rom ( name "Mingzhu Koudai Guaishou 3 (Taiwan) (En,Es,Zh) (Unl).gbc" size 4194304 crc a477c7ce sha1 0e1b3e60d4a982538d4645c36693d5fd548cb641 ) + name "Ronaldo V-Football (Europe) (En,Fr,De,Es,It,Nl,Pt) (GB Compatible)" + description "Ronaldo V-Football (Europe) (En,Fr,De,Es,It,Nl,Pt) (GB Compatible)" + rom ( name "Ronaldo V-Football (Europe) (En,Fr,De,Es,It,Nl,Pt) (GB Compatible).gbc" size 1048576 crc a856c066 sha1 33350360394904a03c069261cc53ab1381f326b7 ) ) game ( - name "Minna no Shougi - Shokyuu Hen (Japan) (Rev 1) (GB Compatible)" - description "Minna no Shougi - Shokyuu Hen (Japan) (Rev 1) (GB Compatible)" - rom ( name "Minna no Shougi - Shokyuu Hen (Japan) (Rev 1) (GB Compatible).gbc" size 1048576 crc f766015a sha1 948d2015c29342fdb6052940a5d65e771b0a81d0 flags verified ) + name "Ronaldo V-Soccer (USA) (En,Fr,Es,Pt) (GB Compatible)" + description "Ronaldo V-Soccer (USA) (En,Fr,Es,Pt) (GB Compatible)" + rom ( name "Ronaldo V-Soccer (USA) (En,Fr,Es,Pt) (GB Compatible).gbc" size 1048576 crc d0204f10 sha1 4558565434fb3527178a183d6c4c4fb1a132e3d2 ) ) game ( - name "Minna no Shougi - Shokyuu Hen (Japan) (GB Compatible)" - description "Minna no Shougi - Shokyuu Hen (Japan) (GB Compatible)" - rom ( name "Minna no Shougi - Shokyuu Hen (Japan) (GB Compatible).gbc" size 1048576 crc 5cb4fc8a sha1 777088b9a3963e55dd6f90a523a84ed58a008149 ) + name "Roswell Conspiracies - Aliens, Myths & Legends (Europe) (En,Fr,De)" + description "Roswell Conspiracies - Aliens, Myths & Legends (Europe) (En,Fr,De)" + rom ( name "Roswell Conspiracies - Aliens, Myths & Legends (Europe) (En,Fr,De).gbc" size 1048576 crc 49101556 sha1 9e0a431d3b9d046cc9e2339624631f756e2bc68e ) ) game ( - name "Minnie & Friends - Yume no Kuni o Sagashite (Japan)" - description "Minnie & Friends - Yume no Kuni o Sagashite (Japan)" - rom ( name "Minnie & Friends - Yume no Kuni o Sagashite (Japan).gbc" size 2097152 crc d47ae577 sha1 146f336d16d165590d09f41f44ba52a81816a033 flags verified ) + name "Roswell Conspiracies - Aliens, Myths & Legends (USA) (En,Fr,De)" + description "Roswell Conspiracies - Aliens, Myths & Legends (USA) (En,Fr,De)" + rom ( name "Roswell Conspiracies - Aliens, Myths & Legends (USA) (En,Fr,De).gbc" size 1048576 crc 1f5ec131 sha1 ec27e608b2787dc18184be7a5a713a1d88403afd ) ) game ( - name "Mirror Between Us, The (World) (GB Compatible) (Aftermarket) (Unl)" - description "Mirror Between Us, The (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Mirror Between Us, The (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 854f4297 sha1 a1a44ce8052f06349df3cbdf9a6d976609213d68 ) + name "Rox (Japan) (En) (GB Compatible)" + description "Rox (Japan) (En) (GB Compatible)" + rom ( name "Rox (Japan) (En) (GB Compatible).gbc" size 262144 crc 4bd73d99 sha1 196eff1c40b3dc552e6fac9e16cc0f5f0e293434 ) ) game ( - name "Missile Command (Europe)" - description "Missile Command (Europe)" - rom ( name "Missile Command (Europe).gbc" size 1048576 crc 18216e26 sha1 ba4c1c10cfeb74584338d49a64f835995af734fd ) + name "Rox (USA, Europe) (GB Compatible)" + description "Rox (USA, Europe) (GB Compatible)" + rom ( name "Rox (USA, Europe) (GB Compatible).gbc" size 262144 crc 2e944775 sha1 86cb1f29e5d061431978d6dc48d7278b9c290cda ) ) game ( - name "Missile Command (USA) (Rumble Version)" - description "Missile Command (USA) (Rumble Version)" - rom ( name "Missile Command (USA) (Rumble Version).gbc" size 1048576 crc 47543c51 sha1 7bd68586df8754cbc81b2dcbb6e2b5de43f812e8 ) + name "RPG Tsukuru GB (Japan)" + description "RPG Tsukuru GB (Japan)" + rom ( name "RPG Tsukuru GB (Japan).gbc" size 2097152 crc 0b614307 sha1 119a0ab3d82fabbaff5949dacd6b77e20c7a8fb0 flags verified ) ) game ( - name "Mission - Impossible (Europe) (En,Fr,De,Es,It)" - description "Mission - Impossible (Europe) (En,Fr,De,Es,It)" - rom ( name "Mission - Impossible (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 0af32baa sha1 5eb8dad248ff23809016a2515657089116e8df33 flags verified ) + name "RPG Tsukuru GB (Japan) (Rev 1) (Possible Proto) (NP)" + description "RPG Tsukuru GB (Japan) (Rev 1) (Possible Proto) (NP)" + rom ( name "RPG Tsukuru GB (Japan) (Rev 1) (Possible Proto) (NP).gbc" size 2097152 crc 57f82031 sha1 f4c36b3cbb13d3cbaaa81e97b0636c4515ce501e ) ) game ( - name "Mission - Impossible (USA) (En,Fr,Es)" - description "Mission - Impossible (USA) (En,Fr,Es)" - rom ( name "Mission - Impossible (USA) (En,Fr,Es).gbc" size 1048576 crc 41230d11 sha1 a987998cf57d2eb2275de94cd0e81254b711ccac ) + name "Rugrats - Time Travelers (USA, Europe) (GB Compatible)" + description "Rugrats - Time Travelers (USA, Europe) (GB Compatible)" + rom ( name "Rugrats - Time Travelers (USA, Europe) (GB Compatible).gbc" size 1048576 crc 9c743f03 sha1 680b38692f9cbd1e9e37ccfe45c5f65817164ec2 flags verified ) ) game ( - name "Mission - Impossible (Europe) (En,Fr,De,Es,It) (Rev 1) (Possible Proto)" - description "Mission - Impossible (Europe) (En,Fr,De,Es,It) (Rev 1) (Possible Proto)" - rom ( name "Mission - Impossible (Europe) (En,Fr,De,Es,It) (Rev 1) (Possible Proto).gbc" size 1048576 crc 9c51f4c7 sha1 f822bda01d881f34d1e17664465faf6a3ff64356 ) + name "Rugrats - Totally Angelica (USA, Europe)" + description "Rugrats - Totally Angelica (USA, Europe)" + rom ( name "Rugrats - Totally Angelica (USA, Europe).gbc" size 1048576 crc fc6195ef sha1 d4396a974aee16f74a5a80f4845c24dde5a083d6 flags verified ) ) game ( - name "Mission Bravo (USA) (Proto)" - description "Mission Bravo (USA) (Proto)" - rom ( name "Mission Bravo (USA) (Proto).gbc" size 1048576 crc b8fc72b6 sha1 2833855bb2b9fde988f8efcac3e357ef9f0f4f50 ) + name "Rugrats - Typisch Angelica (Germany)" + description "Rugrats - Typisch Angelica (Germany)" + rom ( name "Rugrats - Typisch Angelica (Germany).gbc" size 1048576 crc 026c4794 sha1 a00f5eac5e6d50cf38bc3114a9d0d30a02d93e7c ) ) game ( - name "Mission Mars (World) (Aftermarket) (Unl)" - description "Mission Mars (World) (Aftermarket) (Unl)" - rom ( name "Mission Mars (World) (Aftermarket) (Unl).gbc" size 262144 crc f651fcf4 sha1 479c70dd9c63cdcad99ca44720a9e0e2582df119 ) + name "Rugrats en Paris - La pelicula (Spain) (En,Es)" + description "Rugrats en Paris - La pelicula (Spain) (En,Es)" + rom ( name "Rugrats en Paris - La pelicula (Spain) (En,Es).gbc" size 1048576 crc 35323432 sha1 5aa140068f3460f027f155566534b19500ad30e9 ) ) game ( - name "Mizuki Shigeru no Shin Youkaiden (Japan)" - description "Mizuki Shigeru no Shin Youkaiden (Japan)" - rom ( name "Mizuki Shigeru no Shin Youkaiden (Japan).gbc" size 4194304 crc fc1f100f sha1 ab12770558fb95434bba0da0d3b8a91e2d9179fb ) + name "Rugrats in Paris - The Movie (USA, Europe)" + description "Rugrats in Paris - The Movie (USA, Europe)" + rom ( name "Rugrats in Paris - The Movie (USA, Europe).gbc" size 1048576 crc 8b195237 sha1 f4cdc771299e9e6539443a9c9d62d3842877e618 flags verified ) ) game ( - name "Mobile Golf (Japan)" - description "Mobile Golf (Japan)" - rom ( name "Mobile Golf (Japan).gbc" size 4194304 crc 35fc5b32 sha1 fde414fc9efef2c30d1a9e0a2ed35ad2efc0edee flags verified ) + name "Rugrats Movie, The (Europe) (SGB Enhanced) (GB Compatible)" + description "Rugrats Movie, The (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Rugrats Movie, The (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b4091600 sha1 29953d2d41fcb6ba4a78853a328dd01a6918ef8f flags verified ) ) game ( - name "Mobile Trainer (Japan)" - description "Mobile Trainer (Japan)" - rom ( name "Mobile Trainer (Japan).gbc" size 2097152 crc 7226ead0 sha1 ecc0579edeaf9eccd722d605cc288cd023c8576a flags verified ) + name "Rugrats Movie, The (USA) (SGB Enhanced) (GB Compatible)" + description "Rugrats Movie, The (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Rugrats Movie, The (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc febe2606 sha1 c64ddf11c12d34f13d86e4a468b1eedacb698081 ) ) game ( - name "Mojie 3-bu Wanme de Shijie (Taiwan) (Zh) (Unl)" - description "Mojie 3-bu Wanme de Shijie (Taiwan) (Zh) (Unl)" - rom ( name "Mojie 3-bu Wanme de Shijie (Taiwan) (Zh) (Unl).gbc" size 524288 crc d91e3f98 sha1 556913f2687a49034e1229ef1e375f6036ec5719 ) + name "Rumble & Tumble (USA) (Demo) (E3 2001)" + description "Rumble & Tumble (USA) (Demo) (E3 2001)" + rom ( name "Rumble & Tumble (USA) (Demo) (E3 2001).gbc" size 131072 crc 4400496d sha1 2429581d154ac04a12c99a24c2fd2c1b45a90807 ) ) game ( - name "Mojie Chuanshuo (Taiwan) (Unl)" - description "Mojie Chuanshuo (Taiwan) (Unl)" - rom ( name "Mojie Chuanshuo (Taiwan) (Unl).gbc" size 524288 crc 7aa7eea5 sha1 109e4ba61b04afe15cc5a5ee994f56405938cee3 ) + name "Runelords (USA) (Proto)" + description "Runelords (USA) (Proto)" + rom ( name "Runelords (USA) (Proto).gbc" size 4194304 crc 392af730 sha1 2bdcf8208cd0530c75195fd23f2f7839a3480bff ) ) game ( - name "Mojie Zhanshi Chuanshuo (Taiwan) (Unl)" - description "Mojie Zhanshi Chuanshuo (Taiwan) (Unl)" - rom ( name "Mojie Zhanshi Chuanshuo (Taiwan) (Unl).gbc" size 2097152 crc 620c56b8 sha1 25fd8c132601cd9f74784a010141572505a2ef66 ) + name "Saban's Power Rangers - Lightspeed Rescue (USA, Europe)" + description "Saban's Power Rangers - Lightspeed Rescue (USA, Europe)" + rom ( name "Saban's Power Rangers - Lightspeed Rescue (USA, Europe).gbc" size 1048576 crc 99869172 sha1 e7d0f2f21cdcda49516f682092d0b2017e82d379 flags verified ) ) game ( - name "Momotarou Densetsu 1-2 (Japan)" - description "Momotarou Densetsu 1-2 (Japan)" - rom ( name "Momotarou Densetsu 1-2 (Japan).gbc" size 2097152 crc da7fb08f sha1 acffa3417c85be574aa28432e29e1d40f28a565b flags verified ) + name "Saban's Power Rangers - Time Force (USA, Europe)" + description "Saban's Power Rangers - Time Force (USA, Europe)" + rom ( name "Saban's Power Rangers - Time Force (USA, Europe).gbc" size 1048576 crc 17e51443 sha1 9c383013c5ec0e1f2c33b95d66cd93a3d0743928 flags verified ) ) game ( - name "Mona and the Witch's Hat Deluxe (World) (GB Compatible) (Aftermarket) (Unl)" - description "Mona and the Witch's Hat Deluxe (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Mona and the Witch's Hat Deluxe (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 39480c79 sha1 4348a7903e538e5367f2a60718f43cbeeccf96df ) + name "Sabrina - The Animated Series - Spooked! (USA, Europe)" + description "Sabrina - The Animated Series - Spooked! (USA, Europe)" + rom ( name "Sabrina - The Animated Series - Spooked! (USA, Europe).gbc" size 1048576 crc 2cf48188 sha1 7a219159ef46c5ef88eb6b478667c2ec80194edc flags verified ) ) game ( - name "Monkey Magic (World) (Aftermarket) (Unl)" - description "Monkey Magic (World) (Aftermarket) (Unl)" - rom ( name "Monkey Magic (World) (Aftermarket) (Unl).gbc" size 262144 crc c9c68715 sha1 bf5dc5593334fe1114461065a2b7284d28b31462 ) + name "Sabrina - The Animated Series - Zapped! (Europe) (En,Fr,De)" + description "Sabrina - The Animated Series - Zapped! (Europe) (En,Fr,De)" + rom ( name "Sabrina - The Animated Series - Zapped! (Europe) (En,Fr,De).gbc" size 2097152 crc 818f3af6 sha1 d2e207a07ffa7cd0cc5b168c95ad409cd3df3fa3 ) ) game ( - name "Monkey Puncher (Europe) (SGB Enhanced) (GB Compatible)" - description "Monkey Puncher (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Monkey Puncher (Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc bc1809ce sha1 87f08f8adc8db96ce396bd21f33a804f63826bf3 ) + name "Sabrina - The Animated Series - Zapped! (USA, Europe)" + description "Sabrina - The Animated Series - Zapped! (USA, Europe)" + rom ( name "Sabrina - The Animated Series - Zapped! (USA, Europe).gbc" size 2097152 crc 5d39a9b0 sha1 099e2ec855f47344f5d188cc57f540c88cdb33fd ) ) game ( - name "Monopoly (Japan) (SGB Enhanced) (GB Compatible)" - description "Monopoly (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Monopoly (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0503e567 sha1 3f42d9b423c15b4c1b997c7a2292ab2cba1ab23f ) + name "Sakata Gorou Kudan no Renju Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible)" + description "Sakata Gorou Kudan no Renju Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Sakata Gorou Kudan no Renju Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b5412c6f sha1 f2330533b10c22e98c140bb550827618985253cb ) ) game ( - name "Monopoly (USA) (GB Compatible)" - description "Monopoly (USA) (GB Compatible)" - rom ( name "Monopoly (USA) (GB Compatible).gbc" size 1048576 crc e559a717 sha1 058c34bc2d86cc7d6a3f5263a21946661662f893 ) + name "Sakura Taisen GB - Geki Hana Gumi Nyuutai! (Japan)" + description "Sakura Taisen GB - Geki Hana Gumi Nyuutai! (Japan)" + rom ( name "Sakura Taisen GB - Geki Hana Gumi Nyuutai! (Japan).gbc" size 4194304 crc ef503d50 sha1 4e30a9b06b5048449057376c8f37b3f687fabd18 ) ) game ( - name "Monster AG, Die (Germany)" - description "Monster AG, Die (Germany)" - rom ( name "Monster AG, Die (Germany).gbc" size 1048576 crc 3a9602e8 sha1 afe20aa46ff136c0ddf6f2692b1bbde9c30e71f6 ) + name "Sakura Taisen GB 2 - Thunderbolt Sakusen (Japan)" + description "Sakura Taisen GB 2 - Thunderbolt Sakusen (Japan)" + rom ( name "Sakura Taisen GB 2 - Thunderbolt Sakusen (Japan).gbc" size 4194304 crc 47636a2c sha1 13092603ea1d54264bc48f02c2796947badb462c ) ) game ( - name "Monster Farm Battle Card GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Monster Farm Battle Card GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Monster Farm Battle Card GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 69b88f1e sha1 7e036e175c9e865572ab613ae0f8e6d3642ffb0e flags verified ) + name "Samurai Kid (Japan)" + description "Samurai Kid (Japan)" + rom ( name "Samurai Kid (Japan).gbc" size 1048576 crc 44a9ddfb sha1 42834c6a1ea9a0e1d73bb01ac83a4bc504c86c4e ) ) game ( - name "Monster Go! Go! Go!! (Taiwan) (En) (Unl)" - description "Monster Go! Go! Go!! (Taiwan) (En) (Unl)" - rom ( name "Monster Go! Go! Go!! (Taiwan) (En) (Unl).gbc" size 524288 crc dd13f234 sha1 8e687d6b2439db522b238361bc2d7458296c9b62 ) + name "San Francisco Rush - Extreme Racing (USA) (Proto)" + description "San Francisco Rush - Extreme Racing (USA) (Proto)" + rom ( name "San Francisco Rush - Extreme Racing (USA) (Proto).gbc" size 524288 crc 4d26ea38 sha1 4d48a6cd886543bae555d0dc4b8012e13c7cdb55 ) ) - -game ( - name "Monster Race 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Monster Race 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Monster Race 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b985f0d8 sha1 8d4a6b4cdaa37b9daaff5a05ac5926a407bacce3 ) + +game ( + name "San Francisco Rush 2049 (USA, Europe)" + description "San Francisco Rush 2049 (USA, Europe)" + rom ( name "San Francisco Rush 2049 (USA, Europe).gbc" size 1048576 crc ef368f16 sha1 b783b770e6680745dcc0b599199a4429957c874e flags verified ) ) game ( - name "Monster Rancher Battle Card GB (USA) (SGB Enhanced) (GB Compatible)" - description "Monster Rancher Battle Card GB (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Monster Rancher Battle Card GB (USA) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 50ddf120 sha1 f94dc1dbdf25d9ab7f7abd3d7878209d404b206d ) + name "San Guo Wushang 5 (Taiwan) (Unl)" + description "San Guo Wushang 5 (Taiwan) (Unl)" + rom ( name "San Guo Wushang 5 (Taiwan) (Unl).gbc" size 2097152 crc 8a64c933 sha1 e97508fa49564d56550ad467f4c543f3f218db76 ) ) game ( - name "Monster Rancher Explorer (USA)" - description "Monster Rancher Explorer (USA)" - rom ( name "Monster Rancher Explorer (USA).gbc" size 1048576 crc 6c35e8f0 sha1 649fec320d3bafd7a03670ee435a419d2a86c12b ) + name "Sangokushi - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Sangokushi - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Sangokushi - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e787b44c sha1 ec6089ff2cfcb17faf6a8ea9a4171869b3c7289b ) ) game ( - name "Monster Traveler (Japan) (Rev 1)" - description "Monster Traveler (Japan) (Rev 1)" - rom ( name "Monster Traveler (Japan) (Rev 1).gbc" size 4194304 crc f60a376e sha1 23842b7ad88a051b14c1676b1f561b933177f150 flags verified ) + name "Sanguozhi - Aoshi Tianxia (Taiwan) (Unl) (Alt)" + description "Sanguozhi - Aoshi Tianxia (Taiwan) (Unl) (Alt)" + rom ( name "Sanguozhi - Aoshi Tianxia (Taiwan) (Unl) (Alt).gbc" size 1048576 crc 728255e5 sha1 d9a978c6b4745d964128eb0eced022337849467c ) ) game ( - name "Monster Traveler (Japan) (Possible Proto)" - description "Monster Traveler (Japan) (Possible Proto)" - rom ( name "Monster Traveler (Japan) (Possible Proto).gbc" size 4194304 crc 5d596cf6 sha1 5195f55ad6aaa302c0a0e11c0ec6ecad4efe0e27 ) + name "Sanguozhi - Aoshi Tianxia (Taiwan) (Unl)" + description "Sanguozhi - Aoshi Tianxia (Taiwan) (Unl)" + rom ( name "Sanguozhi - Aoshi Tianxia (Taiwan) (Unl).gbc" size 1048576 crc 48d2607f sha1 8ee81543442932b87349eef3a9287a923cec827c ) ) game ( - name "Monsters, Inc. (Europe) (Rev 1)" - description "Monsters, Inc. (Europe) (Rev 1)" - rom ( name "Monsters, Inc. (Europe) (Rev 1).gbc" size 1048576 crc 3726858a sha1 31e64a1cdd25cdc4413e0a1bc15dc22017e881e4 ) + name "Sanguozhi Wudai (Taiwan) (Unl)" + description "Sanguozhi Wudai (Taiwan) (Unl)" + rom ( name "Sanguozhi Wudai (Taiwan) (Unl).gbc" size 2097152 crc de136996 sha1 8e476e9db9caceb52d048b28163227d987a09a21 ) ) game ( - name "Monsters, Inc. (Europe) (En,Es,Nl)" - description "Monsters, Inc. (Europe) (En,Es,Nl)" - rom ( name "Monsters, Inc. (Europe) (En,Es,Nl).gbc" size 1048576 crc 63e3bbb4 sha1 8713b1d51ce33a761f64455b59cd49952b7f7cd1 ) + name "Sanrio Timenet - Kako Hen (Japan) (SGB Enhanced) (GB Compatible)" + description "Sanrio Timenet - Kako Hen (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Sanrio Timenet - Kako Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 458b579d sha1 8421e0d0fc356b25df62cde1967e7775a91983c2 ) ) game ( - name "Monsters, Inc. (Europe) (En,Fr,It)" - description "Monsters, Inc. (Europe) (En,Fr,It)" - rom ( name "Monsters, Inc. (Europe) (En,Fr,It).gbc" size 1048576 crc 712d40a5 sha1 34ab1e38f34287f022c871b6ed2116ded6d4b60d ) + name "Sanrio Timenet - Kako Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Sanrio Timenet - Kako Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Sanrio Timenet - Kako Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6555b740 sha1 b3b80b4a48faec9cc71d80a6b08b12b3541b4c1b flags verified ) ) game ( - name "Monsters, Inc. (USA, Europe)" - description "Monsters, Inc. (USA, Europe)" - rom ( name "Monsters, Inc. (USA, Europe).gbc" size 1048576 crc 183dbb31 sha1 58befa4dbe7dac79bfadcaf259999cdcddf4f2c8 flags verified ) + name "Sanrio Timenet - Mirai Hen (Japan) (SGB Enhanced) (GB Compatible)" + description "Sanrio Timenet - Mirai Hen (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Sanrio Timenet - Mirai Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc efe51e17 sha1 65c4113401336784be4c53a51fe8d9b4b3d287da flags verified ) ) game ( - name "Montezuma's Return! (Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "Montezuma's Return! (Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Montezuma's Return! (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 524288 crc 659693de sha1 014b174f569984360442fb2142a0e4ae09366dc4 flags verified ) + name "Sanrio Timenet - Mirai Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Sanrio Timenet - Mirai Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Sanrio Timenet - Mirai Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 179da7f3 sha1 5ccaf8450862dab90b45b06ab2df291d72ea6033 flags verified ) ) game ( - name "Montezuma's Return! (USA) (En,Es) (GB Compatible)" - description "Montezuma's Return! (USA) (En,Es) (GB Compatible)" - rom ( name "Montezuma's Return! (USA) (En,Es) (GB Compatible).gbc" size 524288 crc de04772f sha1 616bb04e0254ef2ba9e1ea629493efdcc37d807c ) + name "Santa Claus Junior (Europe)" + description "Santa Claus Junior (Europe)" + rom ( name "Santa Claus Junior (Europe).gbc" size 1048576 crc a744df64 sha1 ab74474cd63a2c74bf9617907270d26b5d183b89 ) ) game ( - name "Monty on the Run (World) (Aftermarket) (Unl)" - description "Monty on the Run (World) (Aftermarket) (Unl)" - rom ( name "Monty on the Run (World) (Aftermarket) (Unl).gbc" size 524288 crc fd1066ac sha1 8390175e6be4731d9afa91715d7f8dd11693bb69 ) + name "Saru Puncher (Japan) (SGB Enhanced) (GB Compatible)" + description "Saru Puncher (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Saru Puncher (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b02564fc sha1 db7cc42b4e2a181c31caa4ae8635ec33b5a09f73 ) ) game ( - name "Moomin no Daibouken (Japan) (Beta)" - description "Moomin no Daibouken (Japan) (Beta)" - rom ( name "Moomin no Daibouken (Japan) (Beta).gbc" size 2097152 crc 3c193973 sha1 b60e7896fa4ceca42530f1de01e4691ee9590a7f ) + name "Scooby-Doo! - Classic Creep Capers (USA, Europe)" + description "Scooby-Doo! - Classic Creep Capers (USA, Europe)" + rom ( name "Scooby-Doo! - Classic Creep Capers (USA, Europe).gbc" size 1048576 crc e3704755 sha1 f45b42e92e9a570658a2790854578d3766f8c14f flags verified ) ) game ( - name "Moomin no Daibouken (Japan)" - description "Moomin no Daibouken (Japan)" - rom ( name "Moomin no Daibouken (Japan).gbc" size 2097152 crc bd29ee6f sha1 0846545cebec8b376db9bdb0d3744c7d157ee980 ) + name "Scrabble (Europe)" + description "Scrabble (Europe)" + rom ( name "Scrabble (Europe).gbc" size 1048576 crc 998657b7 sha1 ae24e07e8906bae07661cf5b8f50cd9b86a5c94d ) ) game ( - name "Moomin's Tale (Europe) (En,Fr,De)" - description "Moomin's Tale (Europe) (En,Fr,De)" - rom ( name "Moomin's Tale (Europe) (En,Fr,De).gbc" size 1048576 crc 45543ba2 sha1 06e57b38b7f9ec71809f309aa7d220af48ca96b6 ) + name "SD Hiryuu no Ken EX (Japan) (SGB Enhanced) (GB Compatible)" + description "SD Hiryuu no Ken EX (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "SD Hiryuu no Ken EX (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 365bf43f sha1 bed7b913a395ae4b62eac39ff8d6b3093529ed45 ) ) game ( - name "Moorhuhn 2 - Die Jagd geht weiter (Germany)" - description "Moorhuhn 2 - Die Jagd geht weiter (Germany)" - rom ( name "Moorhuhn 2 - Die Jagd geht weiter (Germany).gbc" size 1048576 crc ed52ceaf sha1 1de0fa5b1dcac8c8b188fd141e889461317dc28d flags verified ) + name "Sea-Doo HydroCross (USA) (Proto)" + description "Sea-Doo HydroCross (USA) (Proto)" + rom ( name "Sea-Doo HydroCross (USA) (Proto).gbc" size 1048576 crc fb1783f3 sha1 3612e549ba2a71585fc9a57033c97562386cdea4 ) ) game ( - name "Moorhuhn 3 - ...Es Gibt Huhn! (Europe) (En,Fr,De,Es,It)" - description "Moorhuhn 3 - ...Es Gibt Huhn! (Europe) (En,Fr,De,Es,It)" - rom ( name "Moorhuhn 3 - ...Es Gibt Huhn! (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc b7c1025b sha1 154db731f5e1cda137eb0faf55a8e4458387485f ) + name "Second Edition Harry Boy, The - The Secret of the Chamber of Secrets (USA) (Unl)" + description "Second Edition Harry Boy, The - The Secret of the Chamber of Secrets (USA) (Unl)" + rom ( name "Second Edition Harry Boy, The - The Secret of the Chamber of Secrets (USA) (Unl).gbc" size 2097152 crc cba2c784 sha1 99d852998fa84c8c0160cc9dfb2e2165a94756ca ) ) game ( - name "Mortal Kombat 4 (Germany) (En) (SGB Enhanced) (GB Compatible)" - description "Mortal Kombat 4 (Germany) (En) (SGB Enhanced) (GB Compatible)" - rom ( name "Mortal Kombat 4 (Germany) (En) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 87588725 sha1 1006b279eab113afe50f84e714a93c63de8cbfcf flags verified ) + name "Sei Hai Densetsu (Japan) (SGB Enhanced) (GB Compatible)" + description "Sei Hai Densetsu (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Sei Hai Densetsu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 8804f856 sha1 0840846bd0a3956fc49b5c7aec598ade93e3ff77 ) ) game ( - name "Mortal Kombat 4 (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Mortal Kombat 4 (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Mortal Kombat 4 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4eb71448 sha1 ea54fb35cd8c4d4cea234423a81f8f953b1d33e4 ) + name "Seme COM Dungeon - Drururuaga (Japan) (GB Compatible)" + description "Seme COM Dungeon - Drururuaga (Japan) (GB Compatible)" + rom ( name "Seme COM Dungeon - Drururuaga (Japan) (GB Compatible).gbc" size 2097152 crc 0b1b928c sha1 24b9bea003a5653ff592d3d63f5ac116c1de2d60 ) ) game ( - name "Moshou Shiji - Zhanshen (Taiwan) (Unl)" - description "Moshou Shiji - Zhanshen (Taiwan) (Unl)" - rom ( name "Moshou Shiji - Zhanshen (Taiwan) (Unl).gbc" size 2097152 crc 80c4fd52 sha1 d2569f8176164cef1cc2a8bd94949ea9cd7dbbea ) + name "Senkai Ibunroku Juntei Taisen - TV Animation Senkaiden Houshin Engi Yori (Japan) (SGB Enhanced) (GB Compatible)" + description "Senkai Ibunroku Juntei Taisen - TV Animation Senkaiden Houshin Engi Yori (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Senkai Ibunroku Juntei Taisen - TV Animation Senkaiden Houshin Engi Yori (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 23fa5f53 sha1 c10249ef96a1989c3532a48917862b4dd8bad12a ) ) game ( - name "Motocross Maniacs 2 (USA)" - description "Motocross Maniacs 2 (USA)" - rom ( name "Motocross Maniacs 2 (USA).gbc" size 1048576 crc 17d27fa9 sha1 5a0e7a9a71a88ee79529531274eb3696cf0fa42c ) + name "Sesame Street - Elmo's 123s (Europe) (GB Compatible)" + description "Sesame Street - Elmo's 123s (Europe) (GB Compatible)" + rom ( name "Sesame Street - Elmo's 123s (Europe) (GB Compatible).gbc" size 1048576 crc 3bf7fcd4 sha1 841bda2e2c1542c44b45c98a390ba3320ef735cc ) ) game ( - name "Mountain Climber (World) (En,Es) (GB Compatible) (Aftermarket) (Unl)" - description "Mountain Climber (World) (En,Es) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Mountain Climber (World) (En,Es) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 362a84ba sha1 b4b3afa2379a07acab6965ae8fcf6d2ba82d6d7e ) + name "Sesame Street - Elmo's 123s (USA) (GB Compatible)" + description "Sesame Street - Elmo's 123s (USA) (GB Compatible)" + rom ( name "Sesame Street - Elmo's 123s (USA) (GB Compatible).gbc" size 262144 crc 1833fb38 sha1 0aca4297ec6dc582b668681452f1805aab991bec ) ) game ( - name "Mr. Angry (World) (Aftermarket) (Unl)" - description "Mr. Angry (World) (Aftermarket) (Unl)" - rom ( name "Mr. Angry (World) (Aftermarket) (Unl).gbc" size 524288 crc b85e63a5 sha1 127ad5315e2bce37614a1e9f8605798e68718926 ) + name "Sesame Street - Elmo's ABCs (USA) (GB Compatible)" + description "Sesame Street - Elmo's ABCs (USA) (GB Compatible)" + rom ( name "Sesame Street - Elmo's ABCs (USA) (GB Compatible).gbc" size 262144 crc cc1fb2a9 sha1 c63ea7ff94250f1f7514a01250bbd5f04a5d2037 ) ) game ( - name "Mr. Driller (Europe)" - description "Mr. Driller (Europe)" - rom ( name "Mr. Driller (Europe).gbc" size 1048576 crc bdf9b05c sha1 6163cc65e7697ef77075a3665a234ce5d720ad9c ) + name "Sesame Street - Elmo's ABCs (Europe) (GB Compatible)" + description "Sesame Street - Elmo's ABCs (Europe) (GB Compatible)" + rom ( name "Sesame Street - Elmo's ABCs (Europe) (GB Compatible).gbc" size 1048576 crc 20158fbc sha1 e98d4d4179ca13c22d0205f118470ecc795928b1 ) ) game ( - name "Mr. Driller (Japan) (NP)" - description "Mr. Driller (Japan) (NP)" - rom ( name "Mr. Driller (Japan) (NP).gbc" size 524288 crc 35fd440d sha1 fb64fa7da6a0fec3e358bb3357e66d68473ada67 flags verified ) + name "Sesame Street - The Adventures of Elmo in Grouchland (Europe) (GB Compatible)" + description "Sesame Street - The Adventures of Elmo in Grouchland (Europe) (GB Compatible)" + rom ( name "Sesame Street - The Adventures of Elmo in Grouchland (Europe) (GB Compatible).gbc" size 1048576 crc 41228ee7 sha1 af1c3912da946d858f9eeb10a3b9d95cbb6a00d8 flags verified ) ) game ( - name "Mr. Driller (Japan)" - description "Mr. Driller (Japan)" - rom ( name "Mr. Driller (Japan).gbc" size 1048576 crc 773729af sha1 b0d725dacea717be7109bd6a81817e717641da86 flags verified ) + name "Sesame Street - The Adventures of Elmo in Grouchland (USA) (GB Compatible)" + description "Sesame Street - The Adventures of Elmo in Grouchland (USA) (GB Compatible)" + rom ( name "Sesame Street - The Adventures of Elmo in Grouchland (USA) (GB Compatible).gbc" size 262144 crc 2c4c2a5f sha1 60f240476d2fac81b1efb83e1128e6223c766f15 ) ) game ( - name "Mr. Driller (USA)" - description "Mr. Driller (USA)" - rom ( name "Mr. Driller (USA).gbc" size 1048576 crc 492c0ebf sha1 3bfda5edb7d125ee99b9235434488876dc6d8245 ) + name "Sesame Street Sports (USA)" + description "Sesame Street Sports (USA)" + rom ( name "Sesame Street Sports (USA).gbc" size 1048576 crc 4ed4aafa sha1 c5f4d432f37a261da5d11426a36893718ef94b86 ) ) game ( - name "Mr. Nutz (Europe) (En,Fr,De,Es,It,Nl)" - description "Mr. Nutz (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Mr. Nutz (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 4e37c741 sha1 d60dffc330f25a61ac1b0b4ba078178585da6fc6 ) + name "Sesame Street Sports (Europe)" + description "Sesame Street Sports (Europe)" + rom ( name "Sesame Street Sports (Europe).gbc" size 1048576 crc 55be1a6e sha1 2cf168dbaa51c1a0d49e6ab776872a0d2d5ced42 ) ) game ( - name "Mr. Nutz (USA) (En,Fr,Es)" - description "Mr. Nutz (USA) (En,Fr,Es)" - rom ( name "Mr. Nutz (USA) (En,Fr,Es).gbc" size 1048576 crc 59f67529 sha1 43bb8621e3d05e81a7faa63cd76b0757f3954ba1 ) + name "Sewing Machine Operation Software (USA) (En,Fr,Es) (GB Compatible)" + description "Sewing Machine Operation Software (USA) (En,Fr,Es) (GB Compatible)" + rom ( name "Sewing Machine Operation Software (USA) (En,Fr,Es) (GB Compatible).gbc" size 1048576 crc e42fd7c4 sha1 a05a67f2d29bf29c56c9533c172da02ee0ad26b1 ) ) game ( - name "Ms. Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible)" - description "Ms. Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Ms. Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc 103e212d sha1 a468f7ad011c1b42ea3144e65607694493e7e4a7 ) + name "Sewing Machine Operation Software (Europe) (En,Fr,De,It) (GB Compatible)" + description "Sewing Machine Operation Software (Europe) (En,Fr,De,It) (GB Compatible)" + rom ( name "Sewing Machine Operation Software (Europe) (En,Fr,De,It) (GB Compatible).gbc" size 1048576 crc d8433dee sha1 4b12589fb14932381afa8433130d684120c5e3cd flags verified ) ) game ( - name "Ms. Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible)" - description "Ms. Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Ms. Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f2335da9 sha1 d0f831165dc9a24e46fed26f90507dadeb5f1e0e ) + name "Sewing Machine Operation Software (Europe) (En,De,It,Nl) (Proto) (GB Compatible)" + description "Sewing Machine Operation Software (Europe) (En,De,It,Nl) (Proto) (GB Compatible)" + rom ( name "Sewing Machine Operation Software (Europe) (En,De,It,Nl) (Proto) (GB Compatible).gbc" size 1048576 crc 9f1dbedd sha1 35d242fbbde2f6f1fb869fd68396e6be4aad8f9b ) ) game ( - name "MTV Sports - Pure Ride (USA, Europe)" - description "MTV Sports - Pure Ride (USA, Europe)" - rom ( name "MTV Sports - Pure Ride (USA, Europe).gbc" size 1048576 crc b7b2354b sha1 539772ed4ed2a579453dc57ba06e5aaeda1b4981 flags verified ) + name "Sewing Machine Operation Software (Europe) (En,Fr,Es,Pt) (Proto) (GB Compatible)" + description "Sewing Machine Operation Software (Europe) (En,Fr,Es,Pt) (Proto) (GB Compatible)" + rom ( name "Sewing Machine Operation Software (Europe) (En,Fr,Es,Pt) (Proto) (GB Compatible).gbc" size 1048576 crc e34b5ce8 sha1 500439c5e14400ef2bc45cacf5ff834b70c2acd4 ) ) game ( - name "MTV Sports - Skateboarding Featuring Andy MacDonald (USA, Europe)" - description "MTV Sports - Skateboarding Featuring Andy MacDonald (USA, Europe)" - rom ( name "MTV Sports - Skateboarding Featuring Andy MacDonald (USA, Europe).gbc" size 1048576 crc 744561f3 sha1 91b6e99a68293d72df74528e8077fae58d9c33c3 ) + name "SGB Test Program (World) (1994.4) (Demo) (SGB Enhanced)" + description "SGB Test Program (World) (1994.4) (Demo) (SGB Enhanced)" + rom ( name "SGB Test Program (World) (1994.4) (Demo) (SGB Enhanced).gbc" size 49152 crc 8960ac1d sha1 a310a9629ce6ad0a607ac9e985056fe257f305b5 ) ) game ( - name "MTV Sports - T.J. Lavin's Ultimate BMX (USA, Europe)" - description "MTV Sports - T.J. Lavin's Ultimate BMX (USA, Europe)" - rom ( name "MTV Sports - T.J. Lavin's Ultimate BMX (USA, Europe).gbc" size 1048576 crc 904663af sha1 2922d99b87497d1519fb4fde707b4dfd0b2e24e3 ) + name "Sgt. Rock - On the Frontline (USA)" + description "Sgt. Rock - On the Frontline (USA)" + rom ( name "Sgt. Rock - On the Frontline (USA).gbc" size 1048576 crc 521a2f77 sha1 53d7fa6fdac65519f8a78f4a42e79e56162589ad ) ) game ( - name "Muchang Wuyu GB 6 (Taiwan) (Unl)" - description "Muchang Wuyu GB 6 (Taiwan) (Unl)" - rom ( name "Muchang Wuyu GB 6 (Taiwan) (Unl).gbc" size 2097152 crc 416e6efa sha1 86b2de0fc2806f3d13145e2c0296389ec0897a6a ) + name "Shadowgate Classic (USA, Europe) (En,Fr,De,Es,Sv) (GB Compatible)" + description "Shadowgate Classic (USA, Europe) (En,Fr,De,Es,Sv) (GB Compatible)" + rom ( name "Shadowgate Classic (USA, Europe) (En,Fr,De,Es,Sv) (GB Compatible).gbc" size 1048576 crc f6a876a5 sha1 4e0c0e15beac73913320f8ab68001f90f52beb92 flags verified ) ) game ( - name "Mud Warriors (World) (GB Compatible) (Aftermarket) (Unl)" - description "Mud Warriors (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Mud Warriors (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 846afc79 sha1 dae84fbc60839da29878714cd845c3704b915323 ) + name "Shadowgate Classic (Europe) (En,Fr,De,Es,Sv) (Rev 1) (GB Compatible)" + description "Shadowgate Classic (Europe) (En,Fr,De,Es,Sv) (Rev 1) (GB Compatible)" + rom ( name "Shadowgate Classic (Europe) (En,Fr,De,Es,Sv) (Rev 1) (GB Compatible).gbc" size 1048576 crc d337f450 sha1 b7343c9ce3343fa618a6c208969446b964dde5f5 flags verified ) ) game ( - name "Mummy Returns, The (Europe) (En,Fr,De,Es,It)" - description "Mummy Returns, The (Europe) (En,Fr,De,Es,It)" - rom ( name "Mummy Returns, The (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 64052b9b sha1 186f541e046c6223ef07defb3ba4e065262249b7 ) + name "Shadowgate Return (Japan) (GB Compatible)" + description "Shadowgate Return (Japan) (GB Compatible)" + rom ( name "Shadowgate Return (Japan) (GB Compatible).gbc" size 1048576 crc 1bcd7d70 sha1 15c4a88e7fbbeed6f529b86601285794e92ccf0c ) ) game ( - name "Mummy Returns, The (USA)" - description "Mummy Returns, The (USA)" - rom ( name "Mummy Returns, The (USA).gbc" size 1048576 crc c997f45b sha1 6dfd1724110f1abff48ab349f89ae11fd201609a ) + name "Shaman King Card Game - Chou Senjiryakketsu - Funbari Hen (Japan)" + description "Shaman King Card Game - Chou Senjiryakketsu - Funbari Hen (Japan)" + rom ( name "Shaman King Card Game - Chou Senjiryakketsu - Funbari Hen (Japan).gbc" size 4194304 crc ef10272e sha1 7b5aabc533784634ca210a2ed2b44ba136dc7276 ) ) game ( - name "Mummy, The (Europe) (En,Fr,De)" - description "Mummy, The (Europe) (En,Fr,De)" - rom ( name "Mummy, The (Europe) (En,Fr,De).gbc" size 1048576 crc 84fc838a sha1 e1f312f6499229bdcc11c90306c321eadcdb78ca ) + name "Shaman King Card Game - Chou Senjiryakketsu - Meramera Hen (Japan)" + description "Shaman King Card Game - Chou Senjiryakketsu - Meramera Hen (Japan)" + rom ( name "Shaman King Card Game - Chou Senjiryakketsu - Meramera Hen (Japan).gbc" size 4194304 crc 5730393d sha1 03901428fe3a791a0078c9295aa4e41994282013 ) ) game ( - name "Mummy, The (USA)" - description "Mummy, The (USA)" - rom ( name "Mummy, The (USA).gbc" size 1048576 crc c6ba9f27 sha1 35b10f392d514bce858c8c64f9c489500466d0ff ) + name "Shamus (USA, Europe) (GB Compatible)" + description "Shamus (USA, Europe) (GB Compatible)" + rom ( name "Shamus (USA, Europe) (GB Compatible).gbc" size 1048576 crc efb9196d sha1 66349abf080e85738875f22a86e0453e5b68f425 ) ) game ( - name "Musical Notes (World) (2023-05-27) (Aftermarket) (Unl)" - description "Musical Notes (World) (2023-05-27) (Aftermarket) (Unl)" - rom ( name "Musical Notes (World) (2023-05-27) (Aftermarket) (Unl).gbc" size 524288 crc ec4f9d49 sha1 357db81755f1f0eb732367dd4090c446eb226ddf ) + name "Shanghai Pocket (Europe) (SGB Enhanced) (GB Compatible)" + description "Shanghai Pocket (Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Shanghai Pocket (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 9401ba47 sha1 6436b152924a8612d7cd28fef09f10a81ec91ad7 ) ) game ( - name "Musical Notes (World) (2023-05-19) (Aftermarket) (Unl)" - description "Musical Notes (World) (2023-05-19) (Aftermarket) (Unl)" - rom ( name "Musical Notes (World) (2023-05-19) (Aftermarket) (Unl).gbc" size 524288 crc 1ba7d27f sha1 d4c4be65ba469369cd90aaa733d0a8e8af6bcdc1 ) + name "Shanghai Pocket (Europe) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Shanghai Pocket (Europe) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Shanghai Pocket (Europe) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d8fac36c sha1 adbf1a18dea69e46c3dbccec03e09668912f12a7 ) ) game ( - name "Muteki Ou Tri-Zenon (Japan)" - description "Muteki Ou Tri-Zenon (Japan)" - rom ( name "Muteki Ou Tri-Zenon (Japan).gbc" size 2097152 crc 0bab7a61 sha1 2a7f422bf9af9aff126e47ede8b5ceec0630eb08 ) + name "Shanghai Pocket (USA) (SGB Enhanced) (GB Compatible)" + description "Shanghai Pocket (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Shanghai Pocket (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a5e3ece9 sha1 2058964274d8bd596bb81bc24e9cfe306411c803 ) ) game ( - name "My Friendly Little Island (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" - description "My Friendly Little Island (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "My Friendly Little Island (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 9bff7b15 sha1 1f3aac8a3725cd1d0968529afc1c2031372d8ed1 ) + name "Shanghai Pocket (USA) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible)" + description "Shanghai Pocket (USA) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible)" + rom ( name "Shanghai Pocket (USA) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d529dafd sha1 b36edbb0721fb71aafecd6f48609c14c1107e3f0 ) ) game ( - name "My Friendly Little Island (World) (Aftermarket) (Unl)" - description "My Friendly Little Island (World) (Aftermarket) (Unl)" - rom ( name "My Friendly Little Island (World) (Aftermarket) (Unl).gbc" size 1048576 crc f6bf0584 sha1 81d724ad696084283712145adfef15769648b045 ) + name "Shantae (USA)" + description "Shantae (USA)" + rom ( name "Shantae (USA).gbc" size 4194304 crc e994b59b sha1 520e48c50f6e997fcd841ca368fc9abc1dbddec1 flags verified ) ) game ( - name "Mythri (USA) (Proto 1) (2000-08-02)" - description "Mythri (USA) (Proto 1) (2000-08-02)" - rom ( name "Mythri (USA) (Proto 1) (2000-08-02).gbc" size 524288 crc 664882ac sha1 d79650a853fffcef878fedc690d5e3a607b5b9df ) + name "Shantae (USA) (Beta)" + description "Shantae (USA) (Beta)" + rom ( name "Shantae (USA) (Beta).gbc" size 4194304 crc 3b4d6c50 sha1 141dc57955e84d51f0099c0709a0626d43ab8fa7 ) ) game ( - name "Mythri (USA) (Proto 2) (2001-03-31)" - description "Mythri (USA) (Proto 2) (2001-03-31)" - rom ( name "Mythri (USA) (Proto 2) (2001-03-31).gbc" size 524288 crc d4149106 sha1 d5b5880ab12939065abfb377dc35fbc39d9922ac ) + name "Shantae (World) (Limited Run Games)" + description "Shantae (World) (Limited Run Games)" + rom ( name "Shantae (World) (Limited Run Games).gbc" size 4194304 crc 96d2774e sha1 71bc428f2746df2a2c6238e14f594d3e5c8da131 ) ) game ( - name "Nakayoshi Cooking Series 1 - Oishii Cake-ya-san (Japan)" - description "Nakayoshi Cooking Series 1 - Oishii Cake-ya-san (Japan)" - rom ( name "Nakayoshi Cooking Series 1 - Oishii Cake-ya-san (Japan).gbc" size 1048576 crc e5c9569a sha1 f98c3209fe712e5696648d946bd63fbca16b0ed3 ) + name "Shantae (World) (Switch)" + description "Shantae (World) (Switch)" + rom ( name "Shantae (World) (Switch).gbc" size 4194304 crc 5009b832 sha1 e1cc66f1950d585d5b644bf9720c87a356354e6a ) ) game ( - name "Nakayoshi Cooking Series 2 - Oishii Panya-san (Japan)" - description "Nakayoshi Cooking Series 2 - Oishii Panya-san (Japan)" - rom ( name "Nakayoshi Cooking Series 2 - Oishii Panya-san (Japan).gbc" size 1048576 crc b9fa3ce4 sha1 cf1b69a198c8d95f95bc99eb9fb1f3caed4b961d ) + name "Shantae (World) (GBA Enhanced) (Switch)" + description "Shantae (World) (GBA Enhanced) (Switch)" + rom ( name "Shantae (World) (GBA Enhanced) (Switch).gbc" size 4194304 crc 1ef9fa6b sha1 d14e8b0029b0aff52134a4fa6794eea72f25f4a6 ) ) game ( - name "Nakayoshi Cooking Series 3 - Tanoshii Obentou (Japan)" - description "Nakayoshi Cooking Series 3 - Tanoshii Obentou (Japan)" - rom ( name "Nakayoshi Cooking Series 3 - Tanoshii Obentou (Japan).gbc" size 1048576 crc dd7666ce sha1 eb56e8a2a2d77141104cdbdd2ad6d0924ae10e88 ) + name "Shaolin Shisan Gun - Ying Xiong Jiu Zhu (Taiwan) (Zh) (Unl)" + description "Shaolin Shisan Gun - Ying Xiong Jiu Zhu (Taiwan) (Zh) (Unl)" + rom ( name "Shaolin Shisan Gun - Ying Xiong Jiu Zhu (Taiwan) (Zh) (Unl).gbc" size 2097152 crc 25a857af sha1 2fbbf4e3a40eda75b0876d207502727f8dacca11 ) ) game ( - name "Nakayoshi Cooking Series 4 - Tanoshii Dessert (Japan)" - description "Nakayoshi Cooking Series 4 - Tanoshii Dessert (Japan)" - rom ( name "Nakayoshi Cooking Series 4 - Tanoshii Dessert (Japan).gbc" size 1048576 crc 7e5c8542 sha1 c86420aba490db1e0bfdda7a4b5db7f5777c509b flags verified ) + name "Shaoling Legend - Hero, the Saver (Taiwan) (En) (Unl)" + description "Shaoling Legend - Hero, the Saver (Taiwan) (En) (Unl)" + rom ( name "Shaoling Legend - Hero, the Saver (Taiwan) (En) (Unl).gbc" size 2097152 crc a321ff7d sha1 b1194edd0962c50cf909262004a102f01f556723 ) ) game ( - name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan)" - description "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan)" - rom ( name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan).gbc" size 4194304 crc c04539f8 sha1 f1b845d5508da37f3600437609d8cc8743799918 flags verified ) + name "Shaun Palmer's Pro Snowboarder (USA, Australia)" + description "Shaun Palmer's Pro Snowboarder (USA, Australia)" + rom ( name "Shaun Palmer's Pro Snowboarder (USA, Australia).gbc" size 2097152 crc 709cda93 sha1 3563d3085198bf40ba92c4de40093e5fa2d422d5 flags verified ) ) game ( - name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 1)" - description "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 1)" - rom ( name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 1).gbc" size 4194304 crc b65a9fb6 sha1 df98eed187a3691ff7fe07619bab1d01072daec6 ) + name "Shelly Club (Europe) (En,Fr,De,Es,It)" + description "Shelly Club (Europe) (En,Fr,De,Es,It)" + rom ( name "Shelly Club (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 767caa42 sha1 f81fe7427484d9c2af043819690fae9b81b29813 flags verified ) ) game ( - name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 2)" - description "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 2)" - rom ( name "Nakayoshi Cooking Series 5 - Cake o Tsukurou (Japan) (Beta 2).gbc" size 4194304 crc f4e674be sha1 aa5e2dd4590bbe9d20c76d8fb1ed408cfdc7350b ) + name "Sheng Shou Wuyu - Shenlong Chuanshuo (Taiwan) (Unl)" + description "Sheng Shou Wuyu - Shenlong Chuanshuo (Taiwan) (Unl)" + rom ( name "Sheng Shou Wuyu - Shenlong Chuanshuo (Taiwan) (Unl).gbc" size 1048576 crc 99a6e58a sha1 13bd97249b68eb824858a9d7a6061edf94140ac3 ) ) game ( - name "Nakayoshi Pet Series 1 - Kawaii Hamster (Japan) (GB Compatible)" - description "Nakayoshi Pet Series 1 - Kawaii Hamster (Japan) (GB Compatible)" - rom ( name "Nakayoshi Pet Series 1 - Kawaii Hamster (Japan) (GB Compatible).gbc" size 1048576 crc 98d0fcb0 sha1 aaa59f2500aa82454cb74aeafa342f8907c82aaf flags verified ) + name "Shenghuo Jiangmo Lu Waizhuan (Taiwan) (Unl)" + description "Shenghuo Jiangmo Lu Waizhuan (Taiwan) (Unl)" + rom ( name "Shenghuo Jiangmo Lu Waizhuan (Taiwan) (Unl).gbc" size 2097152 crc 1066ec96 sha1 394709afedc0632c09fee33785b0c4f00a45d3e6 ) ) game ( - name "Nakayoshi Pet Series 2 - Kawaii Usagi (Japan) (GB Compatible)" - description "Nakayoshi Pet Series 2 - Kawaii Usagi (Japan) (GB Compatible)" - rom ( name "Nakayoshi Pet Series 2 - Kawaii Usagi (Japan) (GB Compatible).gbc" size 1048576 crc 866095c2 sha1 9d155a4dd73785c2cc725184954fc2d44b4d6f34 flags verified ) + name "Shenghuo Jiangmo Lu Waizhuan - Guang Yu An De Lunhui (Taiwan) (Unl)" + description "Shenghuo Jiangmo Lu Waizhuan - Guang Yu An De Lunhui (Taiwan) (Unl)" + rom ( name "Shenghuo Jiangmo Lu Waizhuan - Guang Yu An De Lunhui (Taiwan) (Unl).gbc" size 2097152 crc 808f19d7 sha1 62620a2cb01fe93388adc42da0b7cbaf53c11ba8 ) ) game ( - name "Nakayoshi Pet Series 3 - Kawaii Koinu (Japan)" - description "Nakayoshi Pet Series 3 - Kawaii Koinu (Japan)" - rom ( name "Nakayoshi Pet Series 3 - Kawaii Koinu (Japan).gbc" size 1048576 crc fa4e9896 sha1 2e6f44bddfffad5defbcf45cf489151ffe43bcdb ) + name "Shengui Diguo Zhi Emo Cheng (Taiwan) (Unl)" + description "Shengui Diguo Zhi Emo Cheng (Taiwan) (Unl)" + rom ( name "Shengui Diguo Zhi Emo Cheng (Taiwan) (Unl).gbc" size 2097152 crc 1823e24d sha1 3fc2533f71cea3aec6310f5f7c33fa7eac427b99 ) ) game ( - name "Nakayoshi Pet Series 4 - Kawaii Koneko (Japan)" - description "Nakayoshi Pet Series 4 - Kawaii Koneko (Japan)" - rom ( name "Nakayoshi Pet Series 4 - Kawaii Koneko (Japan).gbc" size 1048576 crc 1a382367 sha1 e5d5f1092e991a7538b9d24a12de35da21e23edd flags verified ) + name "Shi Mian Maifu - Fengyun Pian (China) (Unl)" + description "Shi Mian Maifu - Fengyun Pian (China) (Unl)" + rom ( name "Shi Mian Maifu - Fengyun Pian (China) (Unl).gbc" size 1048576 crc a5f686c3 sha1 68798ac090df9f5fb1ea9c409adf3dc639bc9842 ) ) game ( - name "Nakayoshi Pet Series 5 - Kawaii Hamster 2 (Japan)" - description "Nakayoshi Pet Series 5 - Kawaii Hamster 2 (Japan)" - rom ( name "Nakayoshi Pet Series 5 - Kawaii Hamster 2 (Japan).gbc" size 1048576 crc e5ec7be5 sha1 8465423089e87bc5a8f3485403c1b8a9b32915a1 ) + name "Shi Mian Maifu - Tianlong Pian (China) (Unl)" + description "Shi Mian Maifu - Tianlong Pian (China) (Unl)" + rom ( name "Shi Mian Maifu - Tianlong Pian (China) (Unl).gbc" size 1048576 crc 605cd86e sha1 b457bafb6b55a82920743d52284918ac74f35852 ) ) game ( - name "Naminori Yarou! (Japan) (NP)" - description "Naminori Yarou! (Japan) (NP)" - rom ( name "Naminori Yarou! (Japan) (NP).gbc" size 1048576 crc ac5e477d sha1 d305a76307bf05f4d31d395785784ba317a9689f ) + name "Shi Mian Maifu - Yingxiong Pian (China) (Unl)" + description "Shi Mian Maifu - Yingxiong Pian (China) (Unl)" + rom ( name "Shi Mian Maifu - Yingxiong Pian (China) (Unl).gbc" size 1048576 crc 2382b3d7 sha1 72077d32c2ab84b6bb1e4ad59bc8c88dbcf1da77 ) ) game ( - name "NASCAR 2000 (USA, Europe)" - description "NASCAR 2000 (USA, Europe)" - rom ( name "NASCAR 2000 (USA, Europe).gbc" size 1048576 crc 54d90a4c sha1 37d3ffb5ae9bcf4c1cab7cece0a19d6b0b45c3a2 ) + name "Shikong Xing Shou (Taiwan) (Unl)" + description "Shikong Xing Shou (Taiwan) (Unl)" + rom ( name "Shikong Xing Shou (Taiwan) (Unl).gbc" size 2097152 crc ec970863 sha1 bc43036da01bb1aef4daa9e7316907193285011f ) ) game ( - name "NASCAR Challenge (USA) (Rumble Version)" - description "NASCAR Challenge (USA) (Rumble Version)" - rom ( name "NASCAR Challenge (USA) (Rumble Version).gbc" size 1048576 crc 39c6b868 sha1 4282d0d76af3d022f9e76082be17522ce5699e54 ) + name "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (SGB Enhanced) (GB Compatible)" + description "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc f90c4977 sha1 b15cbd01a21048d0fd022f0e023ab5d91faaf442 flags verified ) ) game ( - name "NASCAR Heat (USA)" - description "NASCAR Heat (USA)" - rom ( name "NASCAR Heat (USA).gbc" size 1048576 crc fa83b37c sha1 059411b2c51fbc0c79d2b8911cbf313f14f15738 ) + name "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc c1e27556 sha1 e9a3edd28503ee94db8ec4ea48832dc2ba0264d9 flags verified ) ) game ( - name "NASCAR Racers (USA)" - description "NASCAR Racers (USA)" - rom ( name "NASCAR Racers (USA).gbc" size 1048576 crc f39a5c4f sha1 2e1b822afa8537cd7b2be8d608c4c000b5b59d46 ) + name "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (SGB Enhanced) (GB Compatible)" + description "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 55b9af51 sha1 b6177175ab34b8301ce146306dc95c3702b38ca6 flags verified ) ) game ( - name "Nations, The - Land of Legends (Europe) (En,De)" - description "Nations, The - Land of Legends (Europe) (En,De)" - rom ( name "Nations, The - Land of Legends (Europe) (En,De).gbc" size 1048576 crc 8c195f49 sha1 2fa6767632e37dc70d97061cbece2cdbace7ab1c ) + name "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 3d4ae536 sha1 421d20bf556e28d07801d808ecfef45daf86a974 ) ) game ( - name "NBA 3 on 3 Featuring Kobe Bryant (USA) (SGB Enhanced) (GB Compatible)" - description "NBA 3 on 3 Featuring Kobe Bryant (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "NBA 3 on 3 Featuring Kobe Bryant (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 001f4754 sha1 8f8d1a33a71b22c9359ddc1aae0bd9cad4cc7456 ) + name "Shin Megami Tensei Devil Children - Shiro no Sho (Japan)" + description "Shin Megami Tensei Devil Children - Shiro no Sho (Japan)" + rom ( name "Shin Megami Tensei Devil Children - Shiro no Sho (Japan).gbc" size 2097152 crc 39a10855 sha1 0ad803e30cd4653855a0c878e4c7a63f1183e369 flags verified ) ) game ( - name "NBA Hoopz (USA)" - description "NBA Hoopz (USA)" - rom ( name "NBA Hoopz (USA).gbc" size 1048576 crc 5011a419 sha1 c23d8276c3766d4265ac017bfada04a664ee4e8f ) + name "Shin Megami Tensei Devil Children - Shiro no Sho (Japan) (Rev 1) (Proto)" + description "Shin Megami Tensei Devil Children - Shiro no Sho (Japan) (Rev 1) (Proto)" + rom ( name "Shin Megami Tensei Devil Children - Shiro no Sho (Japan) (Rev 1) (Proto).gbc" size 2097152 crc 79ea53f4 sha1 6ba2a43d6975340852eb2ce85f36f35855b36eaf ) ) game ( - name "NBA in the Zone (USA) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "NBA in the Zone (USA) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "NBA in the Zone (USA) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc be949f74 sha1 f4ba926ad640d7b3e9d175fb58c90347dafcbef4 ) + name "Shin Megami Tensei Trading Card - Card Summoner (Japan)" + description "Shin Megami Tensei Trading Card - Card Summoner (Japan)" + rom ( name "Shin Megami Tensei Trading Card - Card Summoner (Japan).gbc" size 2097152 crc 85264877 sha1 67daaf5aad65d91109b122e61c1eb3a864437fd4 ) ) game ( - name "NBA in the Zone (USA) (Possible Proto) (SGB Enhanced) (GB Compatible)" - description "NBA in the Zone (USA) (Possible Proto) (SGB Enhanced) (GB Compatible)" - rom ( name "NBA in the Zone (USA) (Possible Proto) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f6bae9a0 sha1 7f0d5a37956ae58077656a42b26629784c203038 ) + name "Shinseiki Evangelion - Mahjong Hokan Keikaku (Japan)" + description "Shinseiki Evangelion - Mahjong Hokan Keikaku (Japan)" + rom ( name "Shinseiki Evangelion - Mahjong Hokan Keikaku (Japan).gbc" size 2097152 crc 5337ff55 sha1 f9b048c7c18148197ad82ec9dec65ce124d663e1 ) ) game ( - name "NBA in the Zone 2000 (Europe)" - description "NBA in the Zone 2000 (Europe)" - rom ( name "NBA in the Zone 2000 (Europe).gbc" size 2097152 crc e6af6d07 sha1 773a303c25bc907476bee20064f2c1f154361d82 ) + name "Shishang Chaoqiang RPG + Gedou + Yizhi Ban Zuhe Ka 18 in 1 (Taiwan) (Unl)" + description "Shishang Chaoqiang RPG + Gedou + Yizhi Ban Zuhe Ka 18 in 1 (Taiwan) (Unl)" + rom ( name "Shishang Chaoqiang RPG + Gedou + Yizhi Ban Zuhe Ka 18 in 1 (Taiwan) (Unl).gbc" size 16777216 crc 28519ab1 sha1 b4c81c2b1d7f787ee92f38d45c86fe602c0aba22 ) ) game ( - name "NBA in the Zone 2000 (USA)" - description "NBA in the Zone 2000 (USA)" - rom ( name "NBA in the Zone 2000 (USA).gbc" size 2097152 crc fdb38c49 sha1 57cd13938fb394752f1e070026df716771561cc2 ) + name "Shougi 2 (Japan) (GB Compatible)" + description "Shougi 2 (Japan) (GB Compatible)" + rom ( name "Shougi 2 (Japan) (GB Compatible).gbc" size 262144 crc a7748d2b sha1 7c89cebc4dfcf8713c94b0553e4f4d4f8945052f flags verified ) ) game ( - name "NBA Jam 2001 (USA, Europe)" - description "NBA Jam 2001 (USA, Europe)" - rom ( name "NBA Jam 2001 (USA, Europe).gbc" size 1048576 crc 3aa75f1c sha1 b1f7230dcccaecb7ae9b2a0e786effac2fc24497 flags verified ) + name "Shougi 3 (Japan) (GB Compatible)" + description "Shougi 3 (Japan) (GB Compatible)" + rom ( name "Shougi 3 (Japan) (GB Compatible).gbc" size 262144 crc 64b479fa sha1 6927c466f838a913850a7eecb86fe75840f1cf09 ) ) game ( - name "NBA Jam 99 (USA, Europe) (GB Compatible)" - description "NBA Jam 99 (USA, Europe) (GB Compatible)" - rom ( name "NBA Jam 99 (USA, Europe) (GB Compatible).gbc" size 1048576 crc 84be0eed sha1 f34d0ac01f14c7c2671b6097c2ef891e70826d72 ) + name "Shrek - Fairy Tale Freakdown (USA, Europe) (En,Fr,De,Es,It)" + description "Shrek - Fairy Tale Freakdown (USA, Europe) (En,Fr,De,Es,It)" + rom ( name "Shrek - Fairy Tale Freakdown (USA, Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 387e6459 sha1 e6a728cafd14a4df952467f2a7434ff14e53e268 flags verified ) ) game ( - name "NBA Pro 99 (Europe) (SGB Enhanced) (GB Compatible)" - description "NBA Pro 99 (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "NBA Pro 99 (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 748564ae sha1 6eb56b61b8a77ce1060343f2c99f18c3271fa5f5 flags verified ) + name "Shuihu Shenshou (Taiwan) (Unl)" + description "Shuihu Shenshou (Taiwan) (Unl)" + rom ( name "Shuihu Shenshou (Taiwan) (Unl).gbc" size 2097152 crc ef18774d sha1 ca240c132de7a56d037776a85e2d2bba1037924e ) ) game ( - name "NBA Show Time - NBA on NBC (USA)" - description "NBA Show Time - NBA on NBC (USA)" - rom ( name "NBA Show Time - NBA on NBC (USA).gbc" size 1048576 crc 7ae23888 sha1 a72cd784883f2299b8b51d763ff4f8cf99a103bd ) + name "Shuihu Shenshou (Taiwan) (Unl) (Alt)" + description "Shuihu Shenshou (Taiwan) (Unl) (Alt)" + rom ( name "Shuihu Shenshou (Taiwan) (Unl) (Alt).gbc" size 2097152 crc 618080cd sha1 93aaddc93941cf53978acd9a88e6525b61c7ea24 ) ) game ( - name "NBA Show Time - NBA on NBC (USA) (Rev 1) (Proto)" - description "NBA Show Time - NBA on NBC (USA) (Rev 1) (Proto)" - rom ( name "NBA Show Time - NBA on NBC (USA) (Rev 1) (Proto).gbc" size 1048576 crc 8bc9be45 sha1 fd4bb16f306e309834e276ed768e8e2ed402e138 ) + name "Shuihu Zhuan - Jingdian Ban (Taiwan) (Unl)" + description "Shuihu Zhuan - Jingdian Ban (Taiwan) (Unl)" + rom ( name "Shuihu Zhuan - Jingdian Ban (Taiwan) (Unl).gbc" size 1048576 crc 4a083b6e sha1 c40a80ab26a2a5d884434c215e649dbfebf64fc3 ) ) game ( - name "Neclaus' Quest (World) (GB Compatible) (Aftermarket) (Unl)" - description "Neclaus' Quest (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Neclaus' Quest (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc eedefa0c sha1 e63c16fe987fe655408be66198366a0147ac607c ) + name "Shuihu Zhuan Zhi Qunmo Fengyun Lu (China) (Unl)" + description "Shuihu Zhuan Zhi Qunmo Fengyun Lu (China) (Unl)" + rom ( name "Shuihu Zhuan Zhi Qunmo Fengyun Lu (China) (Unl).gbc" size 1048576 crc a4ad3678 sha1 408930e31489dd69570088c5bbbf8bce9b574a34 ) ) game ( - name "Neclaus' Quest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "Neclaus' Quest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Neclaus' Quest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 53cf930c sha1 bd3272ca7ead64da3f68f774661a560add433b94 ) + name "Shuma Baobei - Chao Mengmeng Fanji Zhan (Taiwan) (Zh) (Unl)" + description "Shuma Baobei - Chao Mengmeng Fanji Zhan (Taiwan) (Zh) (Unl)" + rom ( name "Shuma Baobei - Chao Mengmeng Fanji Zhan (Taiwan) (Zh) (Unl).gbc" size 524288 crc fc844e0e sha1 6abec431a861315fb1b284ff964c2abf933444ae ) ) game ( - name "Neighbor (World) (GB Compatible) (Aftermarket) (Unl)" - description "Neighbor (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Neighbor (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 705b150f sha1 6258cf6ad167c9ae86609a8e620face1674a7ea7 ) + name "Shuma Baobei - Hai Zhi Shen (Taiwan) (Zh) (Unl)" + description "Shuma Baobei - Hai Zhi Shen (Taiwan) (Zh) (Unl)" + rom ( name "Shuma Baobei - Hai Zhi Shen (Taiwan) (Zh) (Unl).gbc" size 524288 crc c3cedaed sha1 4e7b7b361302e5e400047c9e668f23cbc885a9e0 ) ) game ( - name "Net de Get - Minigame @ 100 (Japan)" - description "Net de Get - Minigame @ 100 (Japan)" - rom ( name "Net de Get - Minigame @ 100 (Japan).gbc" size 1048576 crc 6e33d509 sha1 819efde3ebd0f52b080a8307979803914d029035 flags verified ) + name "Shuma Baobei - Huojian Bingtuan (Taiwan) (Unl)" + description "Shuma Baobei - Huojian Bingtuan (Taiwan) (Unl)" + rom ( name "Shuma Baobei - Huojian Bingtuan (Taiwan) (Unl).gbc" size 524288 crc b0d45b6a sha1 5e16517d7d4f9ade3c1a65dfc52ab9d6985a821a ) ) game ( - name "Network Boukenki Bugsite - Alpha Version (Japan)" - description "Network Boukenki Bugsite - Alpha Version (Japan)" - rom ( name "Network Boukenki Bugsite - Alpha Version (Japan).gbc" size 2097152 crc d65c8ba1 sha1 a5be33b3cefa2af0865caddb287814c8cca19edd flags verified ) + name "Shuma Baobei DX6 (Taiwan) (Unl)" + description "Shuma Baobei DX6 (Taiwan) (Unl)" + rom ( name "Shuma Baobei DX6 (Taiwan) (Unl).gbc" size 2097152 crc 23c19a4d sha1 f08a5470667be1bb232866b4cb4dfa974752e1a0 ) ) game ( - name "Network Boukenki Bugsite - Beta Version (Japan)" - description "Network Boukenki Bugsite - Beta Version (Japan)" - rom ( name "Network Boukenki Bugsite - Beta Version (Japan).gbc" size 2097152 crc 56f52663 sha1 0c03e241e2931a0e2e54de30678334999beacb48 ) + name "Shuma Baolong - Diannao Pian (Taiwan) (Zh) (Unl)" + description "Shuma Baolong - Diannao Pian (Taiwan) (Zh) (Unl)" + rom ( name "Shuma Baolong - Diannao Pian (Taiwan) (Zh) (Unl).gbc" size 1048576 crc 363808b4 sha1 bac6e8b313e87c06dd4838ebc5098e0ef6383925 ) ) game ( - name "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt)" - description "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt)" - rom ( name "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt).gbc" size 2097152 crc fbb97680 sha1 87af7b26281adc9efb8b5b5e31a13b8f6be16042 ) + name "Shuma Baolong - Koudai Ban (Taiwan) (Unl) (Alt)" + description "Shuma Baolong - Koudai Ban (Taiwan) (Unl) (Alt)" + rom ( name "Shuma Baolong - Koudai Ban (Taiwan) (Unl) (Alt).gbc" size 524288 crc 16b85ca2 sha1 9f20bfb1dbe01ef3d00588a2fbb14c27ef9a4b30 ) ) game ( - name "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt) (Rev 1) (Proto)" - description "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt) (Rev 1) (Proto)" - rom ( name "New Addams Family Series, The (Europe) (En,Fr,De,Es,It,Pt) (Rev 1) (Proto).gbc" size 2097152 crc 910df34b sha1 c0582e350ade53908a9f091a4796d58b3c1806f8 ) + name "Shuma Baolong - Koudai Ban (Taiwan) (Unl)" + description "Shuma Baolong - Koudai Ban (Taiwan) (Unl)" + rom ( name "Shuma Baolong - Koudai Ban (Taiwan) (Unl).gbc" size 524288 crc 9507e5d3 sha1 99d5c7ad319158735597432e195615c9df09840c ) ) game ( - name "New Adventures of Mary-Kate & Ashley, The (USA, Europe) (GB Compatible)" - description "New Adventures of Mary-Kate & Ashley, The (USA, Europe) (GB Compatible)" - rom ( name "New Adventures of Mary-Kate & Ashley, The (USA, Europe) (GB Compatible).gbc" size 1048576 crc dca4474e sha1 d42515a16143319afac0d980e9cb080103085f5c flags verified ) + name "Shuma Baolong - Shuijing Ban (Taiwan) (Vast Fame) (Unl)" + description "Shuma Baolong - Shuijing Ban (Taiwan) (Vast Fame) (Unl)" + rom ( name "Shuma Baolong - Shuijing Ban (Taiwan) (Vast Fame) (Unl).gbc" size 1048576 crc 10bf11a4 sha1 a0f81548e3d4184c146d0df1cc9e18930bedf644 ) ) game ( - name "New Super Color 145 in 1 (Taiwan) (Unl)" - description "New Super Color 145 in 1 (Taiwan) (Unl)" - rom ( name "New Super Color 145 in 1 (Taiwan) (Unl).gbc" size 16777216 crc b087710c sha1 cbeb1745d68163978a422a8d7260a6a0f2693b85 ) + name "Shuma Baolong - Shuijing Ban (Taiwan) (Li Cheng) (Unl)" + description "Shuma Baolong - Shuijing Ban (Taiwan) (Li Cheng) (Unl)" + rom ( name "Shuma Baolong - Shuijing Ban (Taiwan) (Li Cheng) (Unl).gbc" size 1048576 crc ba03bd71 sha1 39d8ebe977cf139be398d87be735ea4f7e6885f7 ) ) game ( - name "NFL Blitz (USA, Europe) (GB Compatible)" - description "NFL Blitz (USA, Europe) (GB Compatible)" - rom ( name "NFL Blitz (USA, Europe) (GB Compatible).gbc" size 524288 crc d731ded7 sha1 14649b51e40aeea24cb4d9cbc41b847cadf68067 ) + name "Shuma Baolong - Shuijing Ban II (Taiwan) (Unl)" + description "Shuma Baolong - Shuijing Ban II (Taiwan) (Unl)" + rom ( name "Shuma Baolong - Shuijing Ban II (Taiwan) (Unl).gbc" size 2097152 crc b67999ae sha1 435c26f47c4e244e8adb3b7f18f2b1d129e163e9 ) ) game ( - name "NFL Blitz (USA, Europe) (Rev 1) (GB Compatible)" - description "NFL Blitz (USA, Europe) (Rev 1) (GB Compatible)" - rom ( name "NFL Blitz (USA, Europe) (Rev 1) (GB Compatible).gbc" size 524288 crc 107d734b sha1 66b69cba0705f0670759f01cfd586a50c47c7c89 ) + name "Shuma Baolong 02 4 (Taiwan) (Unl)" + description "Shuma Baolong 02 4 (Taiwan) (Unl)" + rom ( name "Shuma Baolong 02 4 (Taiwan) (Unl).gbc" size 1048576 crc 2ee18ab2 sha1 839f0880749735ba2113e437f8efede171b7474d ) ) game ( - name "NFL Blitz 2000 (USA)" - description "NFL Blitz 2000 (USA)" - rom ( name "NFL Blitz 2000 (USA).gbc" size 1048576 crc 090c7dac sha1 26e60d551b71ac65feef7882062a61c0bad03664 flags verified ) + name "Shuma Baolong 02 4 (China) (Unl)" + description "Shuma Baolong 02 4 (China) (Unl)" + rom ( name "Shuma Baolong 02 4 (China) (Unl).gbc" size 1048576 crc 6f67dfc6 sha1 5c5d1675188a5f618f9babf2b3848942ce08c659 ) ) game ( - name "NFL Blitz 2001 (USA)" - description "NFL Blitz 2001 (USA)" - rom ( name "NFL Blitz 2001 (USA).gbc" size 1048576 crc 61c653ae sha1 51da92005e63c427f5edf030c8a35b33b5e07cfc ) + name "Shuma Baolong 02 5 (Taiwan) (Unl)" + description "Shuma Baolong 02 5 (Taiwan) (Unl)" + rom ( name "Shuma Baolong 02 5 (Taiwan) (Unl).gbc" size 1048576 crc 5ba9f8b5 sha1 c441fcbdb343e0c3c76803aa55ceb728158a8948 ) ) game ( - name "NHL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "NHL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "NHL 2000 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc bb625129 sha1 8f7cb463a1438c70310f319e602df4b13530d96f ) + name "Shuma Baolong 2 (China) (Unl)" + description "Shuma Baolong 2 (China) (Unl)" + rom ( name "Shuma Baolong 2 (China) (Unl).gbc" size 1048576 crc acbfc58f sha1 76b1eccf666ea01320134d88d6f7558c24016ca8 ) ) game ( - name "NHL Blades of Steel (USA)" - description "NHL Blades of Steel (USA)" - rom ( name "NHL Blades of Steel (USA).gbc" size 1048576 crc a890adb2 sha1 9a93f90645b929ff0344fd256815f02b3bf33a99 ) + name "Shuma Baolong 3 (China) (Unl)" + description "Shuma Baolong 3 (China) (Unl)" + rom ( name "Shuma Baolong 3 (China) (Unl).gbc" size 1048576 crc dab66d8c sha1 3902ecd4b233d0dff168a285788843de0b6df05e ) ) game ( - name "NHL Blades of Steel 2000 (USA)" - description "NHL Blades of Steel 2000 (USA)" - rom ( name "NHL Blades of Steel 2000 (USA).gbc" size 1048576 crc 8bc5b62a sha1 271782de2566fb0c36c96d7def5f439009371870 ) + name "Shuma Baolong 9 - Baolong Pian (Taiwan) (Zh) (Unl)" + description "Shuma Baolong 9 - Baolong Pian (Taiwan) (Zh) (Unl)" + rom ( name "Shuma Baolong 9 - Baolong Pian (Taiwan) (Zh) (Unl).gbc" size 1048576 crc c10fa909 sha1 bdc4a2ca7170f41bc10b89a2e6e96fb990a44f0b ) ) game ( - name "Nicktoons Racing (USA)" - description "Nicktoons Racing (USA)" - rom ( name "Nicktoons Racing (USA).gbc" size 1048576 crc a3f079d4 sha1 8b023f596d9b37ae442578c02c6ba859bc81c5c6 ) + name "Shuma Baolong Zhuanji 10 in 1 (Taiwan) (Unl)" + description "Shuma Baolong Zhuanji 10 in 1 (Taiwan) (Unl)" + rom ( name "Shuma Baolong Zhuanji 10 in 1 (Taiwan) (Unl).gbc" size 4194304 crc 37603b3a sha1 37366ff0b3a722da867327c62cae6ad0e51d4a12 ) ) game ( - name "Ninja JaJaMaru - The Great World Adventure DX (USA, Europe) (Ninja JaJaMaru Retro Collection) (Switch)" - description "Ninja JaJaMaru - The Great World Adventure DX (USA, Europe) (Ninja JaJaMaru Retro Collection) (Switch)" - rom ( name "Ninja JaJaMaru - The Great World Adventure DX (USA, Europe) (Ninja JaJaMaru Retro Collection) (Switch).gbc" size 262144 crc b5af4ca5 sha1 73efaca14c998dd6790e08f2ce2b6f73e7909ce4 flags verified ) + name "Shutokou Racing, The (Japan) (SGB Enhanced) (GB Compatible)" + description "Shutokou Racing, The (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Shutokou Racing, The (Japan) (SGB Enhanced) (GB Compatible).gbc" size 131072 crc 36e781cd sha1 0f29818190ea9ce8c242b648ba64d50cc5408e5a ) ) game ( - name "Ninja Master (World) (Aftermarket) (Unl)" - description "Ninja Master (World) (Aftermarket) (Unl)" - rom ( name "Ninja Master (World) (Aftermarket) (Unl).gbc" size 262144 crc bc550b84 sha1 0def135723ac40e4981c88f8888afbd40a15bb40 ) + name "Simpsons, The - Night of the Living Treehouse of Horror (USA, Europe)" + description "Simpsons, The - Night of the Living Treehouse of Horror (USA, Europe)" + rom ( name "Simpsons, The - Night of the Living Treehouse of Horror (USA, Europe).gbc" size 1048576 crc ebaf4888 sha1 a5be079336e48552e53706f0380f35829d91b3c0 ) ) game ( - name "Nintama Rantarou - Ninjutsu Gakuen ni Nyuugaku Shiyou no Dan (Japan)" - description "Nintama Rantarou - Ninjutsu Gakuen ni Nyuugaku Shiyou no Dan (Japan)" - rom ( name "Nintama Rantarou - Ninjutsu Gakuen ni Nyuugaku Shiyou no Dan (Japan).gbc" size 1048576 crc 4631d8bf sha1 916bb8c06539cfcf6b4499a2046ea89e17a8874c ) + name "Smurfs Nightmare, The (Europe) (En,Fr,De,Es)" + description "Smurfs Nightmare, The (Europe) (En,Fr,De,Es)" + rom ( name "Smurfs Nightmare, The (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 6f97b043 sha1 fe9f70d6ff58174f533a08b556358d916eda8a1e flags verified ) ) game ( - name "Nisemon Puzzle da Mon! - Feromon Kyuushutsu Daisakusen! (Japan)" - description "Nisemon Puzzle da Mon! - Feromon Kyuushutsu Daisakusen! (Japan)" - rom ( name "Nisemon Puzzle da Mon! - Feromon Kyuushutsu Daisakusen! (Japan).gbc" size 2097152 crc 2f7d62f3 sha1 8d60e4af5504fe68277e1da162e6352d8438900e ) + name "Smurfs Nightmare, The (USA)" + description "Smurfs Nightmare, The (USA)" + rom ( name "Smurfs Nightmare, The (USA).gbc" size 1048576 crc b50cafe4 sha1 1d0d3512f32176b7035f9c2a77d4636b1d08b349 ) ) game ( - name "No Fear - Downhill Mountain Biking (Europe)" - description "No Fear - Downhill Mountain Biking (Europe)" - rom ( name "No Fear - Downhill Mountain Biking (Europe).gbc" size 1048576 crc 0f69f574 sha1 d04c3578f3abed229c9bc44f55fc3a2154e15429 ) + name "Snobow Champion (Japan)" + description "Snobow Champion (Japan)" + rom ( name "Snobow Champion (Japan).gbc" size 1048576 crc 846fea2b sha1 e99284640d67643102e68aca25bf56d78a1a0d39 ) ) game ( - name "Nobunaga no Yabou - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Nobunaga no Yabou - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Nobunaga no Yabou - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 233862d0 sha1 a61e35306405e41c03b98b162ee14442e77c0da1 flags verified ) + name "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl)" + description "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 8c2d9b43 sha1 e51347bb82e44a2ecefeb3f220a0b3def6daf514 ) ) game ( - name "Noddy and the Birthday Party (Europe) (En,Fr,De,Es)" - description "Noddy and the Birthday Party (Europe) (En,Fr,De,Es)" - rom ( name "Noddy and the Birthday Party (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 845b4e44 sha1 9db01baf9aec2dd3df8ddc583694b1b7aa85ac2c ) + name "Snoopy Tennis (Japan)" + description "Snoopy Tennis (Japan)" + rom ( name "Snoopy Tennis (Japan).gbc" size 1048576 crc d088eefd sha1 66b78ec7de2d407b3b4fac0323ad6c6df223c744 ) ) game ( - name "NSYNC - Get to the Show (USA)" - description "NSYNC - Get to the Show (USA)" - rom ( name "NSYNC - Get to the Show (USA).gbc" size 1048576 crc f770878b sha1 23b031d03a139c4d963099070b0b290f5f806a6d ) + name "Snoopy Tennis (USA) (En,Fr,Es)" + description "Snoopy Tennis (USA) (En,Fr,Es)" + rom ( name "Snoopy Tennis (USA) (En,Fr,Es).gbc" size 1048576 crc d882eccc sha1 a07b8fe92b4fee98586a09fdd5a8dd4c8345bf16 ) ) game ( - name "Number Builder (World) (Aftermarket) (Unl)" - description "Number Builder (World) (Aftermarket) (Unl)" - rom ( name "Number Builder (World) (Aftermarket) (Unl).gbc" size 262144 crc b8609d43 sha1 92952b752f50af889db891acc9eed8436ac6b87e ) + name "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + description "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + rom ( name "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 1048576 crc 49db04a6 sha1 03adc2731945bc86588fffedfee2050a00679ce6 ) ) game ( - name "Nushi Tsuri Adventure - Kite no Bouken (Japan) (Rumble Version)" - description "Nushi Tsuri Adventure - Kite no Bouken (Japan) (Rumble Version)" - rom ( name "Nushi Tsuri Adventure - Kite no Bouken (Japan) (Rumble Version).gbc" size 2097152 crc ac52f6ef sha1 2c72cfaa3cb1080ed4393e961bf2990a7df79cbe ) + name "Snow White and the Seven Dwarfs (Europe) (En,Fr,De,Es,It,Nl,Sv,No,Da)" + description "Snow White and the Seven Dwarfs (Europe) (En,Fr,De,Es,It,Nl,Sv,No,Da)" + rom ( name "Snow White and the Seven Dwarfs (Europe) (En,Fr,De,Es,It,Nl,Sv,No,Da).gbc" size 1048576 crc c9c68471 sha1 bcb5f2141bdfa0bd055e7e94301cf0aff00971a0 ) ) game ( - name "Nv Wang Gedou 2000 (Taiwan) (Unl)" - description "Nv Wang Gedou 2000 (Taiwan) (Unl)" - rom ( name "Nv Wang Gedou 2000 (Taiwan) (Unl).gbc" size 2097152 crc e1668b49 sha1 37516139aa317a16440379c1dc00bdfc4c1e607a flags verified ) + name "Snow White and the Seven Dwarfs (USA)" + description "Snow White and the Seven Dwarfs (USA)" + rom ( name "Snow White and the Seven Dwarfs (USA).gbc" size 1048576 crc 8dd38534 sha1 865e5bd17e336b4696fb891bc21c966ef2e186c9 ) ) game ( - name "Nyghtmare - The Ninth King (World) (v0.2.6) (Beta) (Aftermarket) (Unl)" - description "Nyghtmare - The Ninth King (World) (v0.2.6) (Beta) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - The Ninth King (World) (v0.2.6) (Beta) (Aftermarket) (Unl).gbc" size 1048576 crc e983e8d1 sha1 fc2a58d49327c88c895ae6681bde57e1a2687974 flags verified ) + name "SnowCross (Europe) (En,Fr,De,Es,It,Pt)" + description "SnowCross (Europe) (En,Fr,De,Es,It,Pt)" + rom ( name "SnowCross (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc 4ba47dbc sha1 436bed2117772f4632a37d54a83e2310dddf1121 ) ) game ( - name "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl)" - description "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc ef42955e sha1 485b4d672d9edda40f9191f5f5cc223046000e67 flags verified ) + name "Soccer Manager (Europe) (En,Fr,De,Es)" + description "Soccer Manager (Europe) (En,Fr,De,Es)" + rom ( name "Soccer Manager (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 237ecef9 sha1 353eb6aaf40a78ebf1bca9298726d068a5986efa ) ) game ( - name "Nyghtmare - The Ninth King (World) (v0.2.1) (Beta) (Aftermarket) (Unl)" - description "Nyghtmare - The Ninth King (World) (v0.2.1) (Beta) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - The Ninth King (World) (v0.2.1) (Beta) (Aftermarket) (Unl).gbc" size 1048576 crc 581efe4d sha1 125bb0564ee17f8e55046a1c25e53ee9a4254303 ) + name "Solomon (Japan)" + description "Solomon (Japan)" + rom ( name "Solomon (Japan).gbc" size 1048576 crc 6aee0958 sha1 0c8da92984888a2c4eea29a3cb05dc75f35efaaa ) ) game ( - name "Nyghtmare - The Ninth King (World) (v0.2.3) (Beta) (Aftermarket) (Unl)" - description "Nyghtmare - The Ninth King (World) (v0.2.3) (Beta) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - The Ninth King (World) (v0.2.3) (Beta) (Aftermarket) (Unl).gbc" size 1048576 crc e26ddbbb sha1 853115369b8ca583d038d00c1dde59b6a74b73a2 ) + name "Sonic Adventure 7 (Taiwan) (En) (Unl)" + description "Sonic Adventure 7 (Taiwan) (En) (Unl)" + rom ( name "Sonic Adventure 7 (Taiwan) (En) (Unl).gbc" size 524288 crc dec1260e sha1 d3ea57e8df8f8d3a80581eaf8e807e359c9059df ) ) game ( - name "Nyghtmare - The Ninth King (World) (v0.2.5) (Beta) (Aftermarket) (Unl)" - description "Nyghtmare - The Ninth King (World) (v0.2.5) (Beta) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - The Ninth King (World) (v0.2.5) (Beta) (Aftermarket) (Unl).gbc" size 1048576 crc 1e8ac5b9 sha1 99c11bef7feb17a9e7212cf9b6593478f671bc32 ) + name "Sonic Adventure 8 (Taiwan) (En) (Rumble Version) (Unl)" + description "Sonic Adventure 8 (Taiwan) (En) (Rumble Version) (Unl)" + rom ( name "Sonic Adventure 8 (Taiwan) (En) (Rumble Version) (Unl).gbc" size 524288 crc c5d8b776 sha1 2fc703f8c8e3768b6ad90b4d5898a79bb3e8fa38 ) ) game ( - name "Nyghtmare - The Ninth King (World) (Free Version) (GB Compatible) (Aftermarket) (Unl)" - description "Nyghtmare - The Ninth King (World) (Free Version) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - The Ninth King (World) (Free Version) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc f5df28c2 sha1 7b511444e1eb86fffcf93599a78e0e2c44aecc8a ) + name "Soreike! Anpanman - 5-tsu no Tou no Ousama (Japan)" + description "Soreike! Anpanman - 5-tsu no Tou no Ousama (Japan)" + rom ( name "Soreike! Anpanman - 5-tsu no Tou no Ousama (Japan).gbc" size 1048576 crc c9a25b0c sha1 e3e4d1e2d1fe6d0683db9d17356080542e1a6905 ) ) game ( - name "Nyghtmare - The Ninth King (World) (Rev 1) (Free Version) (Aftermarket) (Unl)" - description "Nyghtmare - The Ninth King (World) (Rev 1) (Free Version) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - The Ninth King (World) (Rev 1) (Free Version) (Aftermarket) (Unl).gbc" size 2097152 crc 63bddc68 sha1 fab777e607bd8aba70eb65829143039dbe6ac08e ) + name "Soreike! Anpanman - Fushigi na Nikoniko Album (Japan) (SGB Enhanced) (GB Compatible)" + description "Soreike! Anpanman - Fushigi na Nikoniko Album (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Soreike! Anpanman - Fushigi na Nikoniko Album (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a80eeead sha1 fe75b7b7a904ce76130d65b67d24e291ba3c2693 ) ) game ( - name "Nyghtmare - The Ninth King (World) (v0.1.0) (Beta) (GB Compatible) (Aftermarket) (Unl)" - description "Nyghtmare - The Ninth King (World) (v0.1.0) (Beta) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - The Ninth King (World) (v0.1.0) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 1f1af42a sha1 ddcdbfa716d716e1b7bb258caaaa7b76d041b5a9 ) + name "Soukoban Densetsu - Hikari to Yami no Kuni (Japan) (SGB Enhanced) (GB Compatible)" + description "Soukoban Densetsu - Hikari to Yami no Kuni (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Soukoban Densetsu - Hikari to Yami no Kuni (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 081d7fcb sha1 cb249bd50dc8c7d503544383af6fb5df0e874ae5 ) ) game ( - name "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl) (Alt)" - description "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl) (Alt)" - rom ( name "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl) (Alt).gbc" size 524288 crc 834a8021 sha1 d5af2bf38eda4c181993e992764788003509ebfd ) + name "Soul Getter - Houkago Bouken RPG (Japan) (GB Compatible)" + description "Soul Getter - Houkago Bouken RPG (Japan) (GB Compatible)" + rom ( name "Soul Getter - Houkago Bouken RPG (Japan) (GB Compatible).gbc" size 2097152 crc 3ffcd45b sha1 ded83fde342a5dc9e56cdbb91acad2cd5f4ac754 ) ) game ( - name "Nyghtmare - The Ninth King (World) (v0.1.9) (Beta) (GB Compatible) (Aftermarket) (Unl)" - description "Nyghtmare - The Ninth King (World) (v0.1.9) (Beta) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Nyghtmare - The Ninth King (World) (v0.1.9) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 42d9c38c sha1 ae719190cf2f433c359bc425775710f4aa67e860 ) + name "South Park (USA) (Proto)" + description "South Park (USA) (Proto)" + rom ( name "South Park (USA) (Proto).gbc" size 524288 crc e79d411a sha1 ad9240b30e381cd7b260f5fc78aaaeed00c6b43d ) ) game ( - name "NYR - New York Race (Europe) (En,Fr,De,Es,It,Pt)" - description "NYR - New York Race (Europe) (En,Fr,De,Es,It,Pt)" - rom ( name "NYR - New York Race (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc 62f560d8 sha1 001decc8331b4beb94a01a1b6ef08e1bf2920ece ) + name "Space Baby (USA) (Unl)" + description "Space Baby (USA) (Unl)" + rom ( name "Space Baby (USA) (Unl).gbc" size 2097152 crc 509f1bb5 sha1 8bdf15e4160e87f83667ecfdbab26ef111a5d5d2 ) ) game ( - name "O'Leary Manager 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca)" - description "O'Leary Manager 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca)" - rom ( name "O'Leary Manager 2000 (Europe) (En,Fr,De,Es,It,Nl,Ca).gbc" size 1048576 crc 3485761a sha1 724aa0f905d7a6e7b9b2b01a477f424ac95eadf9 ) + name "Space Invaders (USA, Europe) (GB Compatible)" + description "Space Invaders (USA, Europe) (GB Compatible)" + rom ( name "Space Invaders (USA, Europe) (GB Compatible).gbc" size 1048576 crc dab7460c sha1 392a8087633969ed0be05e7da628d6e92befb711 flags verified ) ) game ( - name "Octopus Stressus (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "Octopus Stressus (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Octopus Stressus (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 2c055ef9 sha1 d4fa4e02753a9fe539f70d0927ba5bf9caa02d3c ) + name "Space Invaders X (Japan) (En) (GB Compatible)" + description "Space Invaders X (Japan) (En) (GB Compatible)" + rom ( name "Space Invaders X (Japan) (En) (GB Compatible).gbc" size 1048576 crc c016bc79 sha1 40d16062bf170647cdf060359fc65ff02350f40a ) ) game ( - name "Octopus Stressus (World) (GB Compatible) (Aftermarket) (Unl)" - description "Octopus Stressus (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Octopus Stressus (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 7ed58128 sha1 e543c39f8e55b1788476b94028a54fc2fc9c7ea0 ) + name "Space Invasion (Europe) (Unl)" + description "Space Invasion (Europe) (Unl)" + rom ( name "Space Invasion (Europe) (Unl).gbc" size 131072 crc 2b2d9868 sha1 bcf0940375a23bca6957eec2ab8e49af695aeb32 ) ) game ( - name "Oddworld Adventures 2 (Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "Oddworld Adventures 2 (Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Oddworld Adventures 2 (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc 4b83b14f sha1 c9d4d1dd1c33a9fa9b54e9f2a7a5f6dd90069b91 flags verified ) + name "Space Invasion & Karate Joe (Europe) (Unl)" + description "Space Invasion & Karate Joe (Europe) (Unl)" + rom ( name "Space Invasion & Karate Joe (Europe) (Unl).gbc" size 524288 crc 6a184c55 sha1 96918cbd3648b227eb43e5a9711d1a9939541bea flags verified ) ) game ( - name "Oddworld Adventures 2 (USA) (En,Fr,De,Es,It) (GB Compatible)" - description "Oddworld Adventures 2 (USA) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Oddworld Adventures 2 (USA) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc 5c260d5a sha1 a35ccdf0789ce84df3c12cfe7c4b9b98af08ca9a ) + name "Space Invasion & Painter (Europe) (Unl)" + description "Space Invasion & Painter (Europe) (Unl)" + rom ( name "Space Invasion & Painter (Europe) (Unl).gbc" size 524288 crc bd4c1065 sha1 a5bf26ed894576dada84f6925cc659980cf150a0 ) ) game ( - name "Office Combat (World) (GB Compatible) (Aftermarket) (Unl)" - description "Office Combat (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Office Combat (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 9742276d sha1 cd8f18d6e5fabaa130a42e5618e29c5ff26f6a93 ) + name "Space Marauder (USA)" + description "Space Marauder (USA)" + rom ( name "Space Marauder (USA).gbc" size 1048576 crc 4f83b35e sha1 e6738767434f53af8221fb06513c0758ab228a94 ) ) game ( - name "Ohasuta Dance Dance Revolution GB (Japan)" - description "Ohasuta Dance Dance Revolution GB (Japan)" - rom ( name "Ohasuta Dance Dance Revolution GB (Japan).gbc" size 2097152 crc e338c118 sha1 bec623a9f0d4ca75905bb23595b17d9c33ff0775 ) + name "Space-Net - Cosmo Blue (Japan)" + description "Space-Net - Cosmo Blue (Japan)" + rom ( name "Space-Net - Cosmo Blue (Japan).gbc" size 2097152 crc f606d369 sha1 9d662a4b95f8b562406eb89fad8cade1edaca954 ) ) game ( - name "Ohasuta Yama-chan & Raymond (Japan) (SGB Enhanced) (GB Compatible)" - description "Ohasuta Yama-chan & Raymond (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Ohasuta Yama-chan & Raymond (Japan) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 840ef32f sha1 373166bc65dd9b6c5734add30a8d278986fc9c98 flags verified ) + name "Space-Net - Cosmo Neo (Japan) (Proto)" + description "Space-Net - Cosmo Neo (Japan) (Proto)" + rom ( name "Space-Net - Cosmo Neo (Japan) (Proto).gbc" size 2097152 crc 3a9d791b sha1 077006fce23059c40bc7135d195766504e376aa8 ) ) game ( - name "Oide Rascal (Japan)" - description "Oide Rascal (Japan)" - rom ( name "Oide Rascal (Japan).gbc" size 1048576 crc 9e0799f4 sha1 9b73a9dc4424029261579193fdbd5a30ca84052b ) + name "Space-Net - Cosmo Red (Japan)" + description "Space-Net - Cosmo Red (Japan)" + rom ( name "Space-Net - Cosmo Red (Japan).gbc" size 2097152 crc 01f96353 sha1 aa4669d5a6d1c3a53de889543d8477adae6f3ed4 ) ) game ( - name "Ojarumaru - Mangan Jinja no Ennichi de Ojaru! (Japan) (GB Compatible)" - description "Ojarumaru - Mangan Jinja no Ennichi de Ojaru! (Japan) (GB Compatible)" - rom ( name "Ojarumaru - Mangan Jinja no Ennichi de Ojaru! (Japan) (GB Compatible).gbc" size 1048576 crc d86507c9 sha1 f17175f7744f97ad4f9943c5dadd4776ad85e5cb ) + name "Spacestation Silicon Valley (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + description "Spacestation Silicon Valley (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + rom ( name "Spacestation Silicon Valley (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 2097152 crc 63353c0f sha1 1dbfa27ebc11c63b86cb36075b807b24426dcfd5 ) ) game ( - name "Ojarumaru - Tsukiyo ga Ike no Takaramono (Japan) (GB Compatible)" - description "Ojarumaru - Tsukiyo ga Ike no Takaramono (Japan) (GB Compatible)" - rom ( name "Ojarumaru - Tsukiyo ga Ike no Takaramono (Japan) (GB Compatible).gbc" size 2097152 crc ed7461d2 sha1 66d87a06d4d951e7695df73f53793a462509e4d0 ) + name "Spawn (USA)" + description "Spawn (USA)" + rom ( name "Spawn (USA).gbc" size 2097152 crc 72fcb0ad sha1 4f816eec1b5dc79928ade9f3a3c687b8aa5b2f87 ) ) game ( - name "Olympic Skier (World) (Aftermarket) (Unl)" - description "Olympic Skier (World) (Aftermarket) (Unl)" - rom ( name "Olympic Skier (World) (Aftermarket) (Unl).gbc" size 524288 crc 5e81cef7 sha1 a7a552a9eb984098a67e063c2eca907eec000fc1 ) + name "Speedy Gonzales - Aztec Adventure (USA, Europe) (GB Compatible)" + description "Speedy Gonzales - Aztec Adventure (USA, Europe) (GB Compatible)" + rom ( name "Speedy Gonzales - Aztec Adventure (USA, Europe) (GB Compatible).gbc" size 1048576 crc ae82afa4 sha1 95f868358979c5bbdfa70920fb35b7d4e00bf8cc ) ) game ( - name "One Day (World) (GB Compatible) (Aftermarket) (Unl)" - description "One Day (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "One Day (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc fd52acc7 sha1 bdb5590b61791b89e9afa871d32648d7a66ce1f4 ) + name "Speedy Gonzales - Aztec Adventure (Japan) (Proto) (GB Compatible)" + description "Speedy Gonzales - Aztec Adventure (Japan) (Proto) (GB Compatible)" + rom ( name "Speedy Gonzales - Aztec Adventure (Japan) (Proto) (GB Compatible).gbc" size 1048576 crc c97d74f5 sha1 b65cd4a60014ecef55b1daca7e17379987f1d983 ) ) game ( - name "Opossum Country (World) (GB Compatible) (Aftermarket) (Unl)" - description "Opossum Country (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Opossum Country (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 7348bb32 sha1 e63e06d602473206b21138f5322acf86b5b6b9b8 ) + name "Spider-Man (France)" + description "Spider-Man (France)" + rom ( name "Spider-Man (France).gbc" size 1048576 crc f6334dc5 sha1 4bff8a1324c6530b719e99f91bf6d46b2483c9e9 ) ) game ( - name "Original Moorhuhn Jagd, Die (Germany)" - description "Original Moorhuhn Jagd, Die (Germany)" - rom ( name "Original Moorhuhn Jagd, Die (Germany).gbc" size 1048576 crc 714ec204 sha1 d4f3fe5bdeed4bbf40d3f1eb6eab7a69676c6138 flags verified ) + name "Spider-Man (Japan)" + description "Spider-Man (Japan)" + rom ( name "Spider-Man (Japan).gbc" size 1048576 crc 5a83dfc4 sha1 ef05291a6197e5f1d9790422466e2663e76f64d4 ) ) game ( - name "Othello Millennium (Japan) (GB Compatible)" - description "Othello Millennium (Japan) (GB Compatible)" - rom ( name "Othello Millennium (Japan) (GB Compatible).gbc" size 1048576 crc c7800576 sha1 1546e2b676931c87b4a48e77c761f49a8e39b9e7 ) + name "Spider-Man (USA, Europe)" + description "Spider-Man (USA, Europe)" + rom ( name "Spider-Man (USA, Europe).gbc" size 1048576 crc 34e2b3ba sha1 ea432c3f2b0d92b4cf03d762e273abc68f45f072 ) ) game ( - name "Other Life - Azure Dreams GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Other Life - Azure Dreams GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Other Life - Azure Dreams GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c6f1abd4 sha1 9e473df09e962a9accc3f6446140b0333f6a088e ) + name "Spider-Man 2 - The Sinister Six (USA, Europe)" + description "Spider-Man 2 - The Sinister Six (USA, Europe)" + rom ( name "Spider-Man 2 - The Sinister Six (USA, Europe).gbc" size 1048576 crc a7faaccf sha1 22c63fa198df68edb9cbe22e35cbd307174c9eb9 flags verified ) ) game ( - name "Ottifanten - Kommando Stoertebeker (Germany)" - description "Ottifanten - Kommando Stoertebeker (Germany)" - rom ( name "Ottifanten - Kommando Stoertebeker (Germany).gbc" size 1048576 crc 3eac3d1c sha1 79c774ab9999cec95087ebe0982b6abba8f4ab91 ) + name "Spider-Man 3 - Movie Version (USA) (Unl)" + description "Spider-Man 3 - Movie Version (USA) (Unl)" + rom ( name "Spider-Man 3 - Movie Version (USA) (Unl).gbc" size 2097152 crc 2c0d43a9 sha1 8a6b6a1300db59b86ddf87599cfc8edd2e52e2b0 ) ) game ( - name "Ou Dorobou Jing - Angel Version (Japan) (SGB Enhanced) (GB Compatible)" - description "Ou Dorobou Jing - Angel Version (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Ou Dorobou Jing - Angel Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d47c0dcf sha1 493e37dac6d8b037e44e64f9f31dba7f08a89e08 ) + name "Spirou - The Robot Invasion (Europe) (En,Fr,De,Es,It,Nl,Da)" + description "Spirou - The Robot Invasion (Europe) (En,Fr,De,Es,It,Nl,Da)" + rom ( name "Spirou - The Robot Invasion (Europe) (En,Fr,De,Es,It,Nl,Da).gbc" size 1048576 crc 3e9bc90b sha1 ae46ebe1d5a8bd13e9d7533b1fe3b04392630e41 ) ) game ( - name "Ou Dorobou Jing - Devil Version (Japan) (SGB Enhanced) (GB Compatible)" - description "Ou Dorobou Jing - Devil Version (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Ou Dorobou Jing - Devil Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 2a39a874 sha1 71797aa125b88614182ce3d0f8252d6ed8cfa08e ) + name "SpongeBob SquarePants - Legend of the Lost Spatula (USA, Europe)" + description "SpongeBob SquarePants - Legend of the Lost Spatula (USA, Europe)" + rom ( name "SpongeBob SquarePants - Legend of the Lost Spatula (USA, Europe).gbc" size 1048576 crc 81230564 sha1 d3bea58987c9904056587242bf3ad26f91b4ef34 ) ) game ( - name "Out on a Limb (World) (Aftermarket) (Unl)" - description "Out on a Limb (World) (Aftermarket) (Unl)" - rom ( name "Out on a Limb (World) (Aftermarket) (Unl).gbc" size 262144 crc a6671528 sha1 f21cb71adcea1029151930eb98c4e9b446e4cfee ) + name "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv)" + description "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv)" + rom ( name "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv).gbc" size 1048576 crc 713c6c17 sha1 574c90cc4ef318d76a76392e5165351dbc9a1ab0 flags verified ) ) game ( - name "Owarai Yoiko no Geemumichi - Oyaji Sagashite 3 Choume (Japan) (SGB Enhanced) (GB Compatible)" - description "Owarai Yoiko no Geemumichi - Oyaji Sagashite 3 Choume (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Owarai Yoiko no Geemumichi - Oyaji Sagashite 3 Choume (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 3f635a4f sha1 21644c1ef67bdd6038686d8522e957e3de803237 ) + name "Spy vs Spy (Japan)" + description "Spy vs Spy (Japan)" + rom ( name "Spy vs Spy (Japan).gbc" size 1048576 crc 0e783117 sha1 0167b0d74004aa9ace10069c5d4bf51adfe7297b ) ) game ( - name "Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible)" - description "Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Pac-Man - Special Color Edition (USA) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 3485ef86 sha1 a0a6f55c15dca60350b3a74b1973cc13ff328730 flags verified ) + name "Spy vs Spy (USA)" + description "Spy vs Spy (USA)" + rom ( name "Spy vs Spy (USA).gbc" size 1048576 crc f0463d51 sha1 7249cdaf769f959f527a6e01435420bb8102df7a ) ) game ( - name "Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible)" - description "Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Pac-Man - Special Colour Edition (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f565647f sha1 d80a9d8ba18d5cecff332bab48afdd00bf30df25 ) + name "Spy vs Spy (Japan) (Rev 1) (NP)" + description "Spy vs Spy (Japan) (Rev 1) (NP)" + rom ( name "Spy vs Spy (Japan) (Rev 1) (NP).gbc" size 1048576 crc eb47d63b sha1 9e203f04857cd84ec49b0e6c6d4917b1a5cc199e ) ) game ( - name "Pachinko CR Mouretsu Genshijin T (Japan) (GB Compatible)" - description "Pachinko CR Mouretsu Genshijin T (Japan) (GB Compatible)" - rom ( name "Pachinko CR Mouretsu Genshijin T (Japan) (GB Compatible).gbc" size 1048576 crc f75e269e sha1 3c473f1e5e849d42e5412dc968d0514f1d85855f ) + name "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto)" + description "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto)" + rom ( name "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto).gbc" size 1048576 crc 6ca71209 sha1 ec249546a4652ef9375b67ddbac882b13ed4a807 ) ) game ( - name "Pachinko Hisshou Guide - Data no Ousama (Japan) (GB Compatible)" - description "Pachinko Hisshou Guide - Data no Ousama (Japan) (GB Compatible)" - rom ( name "Pachinko Hisshou Guide - Data no Ousama (Japan) (GB Compatible).gbc" size 1048576 crc 1a631bab sha1 9ba368431d307ff4c4455f9befee2ac9b1efb64a ) + name "Spy vs Spy (USA) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto)" + description "Spy vs Spy (USA) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto)" + rom ( name "Spy vs Spy (USA) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto).gbc" size 1048576 crc 549bf1e4 sha1 38dd0c729c0d878ea05df7de0b3aba2d098d2975 ) ) game ( - name "Pachipachi Pachisurou - New Pulsar Hen (Japan) (SGB Enhanced) (GB Compatible)" - description "Pachipachi Pachisurou - New Pulsar Hen (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pachipachi Pachisurou - New Pulsar Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1e443d1b sha1 969d5352c15e3e5daa891edcda91bd48a8380308 ) + name "Star Heritage (Europe) (Proto) (SRAM Version)" + description "Star Heritage (Europe) (Proto) (SRAM Version)" + rom ( name "Star Heritage (Europe) (Proto) (SRAM Version).gbc" size 1048576 crc c72e6dfe sha1 4eb7ad40520e21f1b371b06ac2adb6f2e1b507a9 ) ) game ( - name "Pacifist, The (World) (GB Compatible) (Aftermarket) (Unl)" - description "Pacifist, The (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Pacifist, The (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc c6e83f41 sha1 44b117d94a80617a77abbdcc76d9d69b66efe56b ) + name "Star Heritage (Europe) (Proto) (Password Version)" + description "Star Heritage (Europe) (Proto) (Password Version)" + rom ( name "Star Heritage (Europe) (Proto) (Password Version).gbc" size 1048576 crc b39b4532 sha1 6eb2c27e2eedb22b4055ded87fce0621d460fe5b ) ) game ( - name "Pacifist, The (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" - description "Pacifist, The (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Pacifist, The (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 69483f81 sha1 4d162c9637a20cfc7c92e6ea7a61fad0ed22137a ) + name "Star Ocean - Blue Sphere (Japan) (SGB Enhanced) (GB Compatible)" + description "Star Ocean - Blue Sphere (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Star Ocean - Blue Sphere (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 8c7ddbda sha1 3d07ae53ba21eda4923bf4da6c938e2a407c990c ) ) game ( - name "Pact, The (World) (GB Showdown) (Aftermarket) (Unl)" - description "Pact, The (World) (GB Showdown) (Aftermarket) (Unl)" - rom ( name "Pact, The (World) (GB Showdown) (Aftermarket) (Unl).gbc" size 262144 crc 0db301c2 sha1 58ec8f209ed6e33adfb253014ea69ae1ee53c145 ) + name "Star Trek (Europe) (Proto)" + description "Star Trek (Europe) (Proto)" + rom ( name "Star Trek (Europe) (Proto).gbc" size 65536 crc 4d423347 sha1 8f708ef7249a72f27a7037651f588fb5daf4c8fb ) ) game ( - name "Pact, The (World) (Aftermarket) (Unl)" - description "Pact, The (World) (Aftermarket) (Unl)" - rom ( name "Pact, The (World) (Aftermarket) (Unl).gbc" size 262144 crc 304df19a sha1 97af064f9063cd353e55ac0e1f6d1ca8b4a6d2b9 ) + name "Star Wars - Yoda Stories (USA, Europe) (GB Compatible)" + description "Star Wars - Yoda Stories (USA, Europe) (GB Compatible)" + rom ( name "Star Wars - Yoda Stories (USA, Europe) (GB Compatible).gbc" size 1048576 crc 6314da32 sha1 f0dd388373e863f91a05cf6f2df00a56e26d3b18 ) ) game ( - name "Painter (Europe) (Unl)" - description "Painter (Europe) (Unl)" - rom ( name "Painter (Europe) (Unl).gbc" size 262144 crc f4801f21 sha1 78db482d1d12b4556b6a5b995ce37a2435236a06 ) + name "Star Wars Episode I - Obi-Wan's Adventures (Europe) (En,Fr,De,Es,It)" + description "Star Wars Episode I - Obi-Wan's Adventures (Europe) (En,Fr,De,Es,It)" + rom ( name "Star Wars Episode I - Obi-Wan's Adventures (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc e584dfc2 sha1 f6a4f115e553f67512373fc5fcbf295c1d6d9fcd ) ) game ( - name "Panik!16 (World) (Aftermarket) (Unl)" - description "Panik!16 (World) (Aftermarket) (Unl)" - rom ( name "Panik!16 (World) (Aftermarket) (Unl).gbc" size 262144 crc 7b31122d sha1 98d74fd64e4f7e835f1101b05816b8938a34a416 ) + name "Star Wars Episode I - Obi-Wan's Adventures (USA)" + description "Star Wars Episode I - Obi-Wan's Adventures (USA)" + rom ( name "Star Wars Episode I - Obi-Wan's Adventures (USA).gbc" size 1048576 crc 0e697582 sha1 fb15a0ae700a11f0925113e5f5c9cb5c655acdb5 ) ) game ( - name "Paperboy (USA, Europe)" - description "Paperboy (USA, Europe)" - rom ( name "Paperboy (USA, Europe).gbc" size 1048576 crc c0a98305 sha1 b96acf81c82286148c3a2154715aa043e2612a36 ) + name "Star Wars Episode I - Racer (USA, Europe) (Rumble Version)" + description "Star Wars Episode I - Racer (USA, Europe) (Rumble Version)" + rom ( name "Star Wars Episode I - Racer (USA, Europe) (Rumble Version).gbc" size 2097152 crc 0ebc5758 sha1 c0613d654a4382f0c50fd4d389d3a6aeef4d5207 flags verified ) ) game ( - name "Papyrus (Europe) (En,Fr,De,Es,It,Nl)" - description "Papyrus (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Papyrus (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc da3a3278 sha1 422c5f48f307820ee7c610e761a30a8cab85aed9 ) + name "Startled 911 (Taiwan) (En) (Unl)" + description "Startled 911 (Taiwan) (En) (Unl)" + rom ( name "Startled 911 (Taiwan) (En) (Unl).gbc" size 2097152 crc 7273a4f4 sha1 14154ba420826a406890079d7cc0b420a042e34f ) ) game ( - name "PaZeek (USA) (Proto)" - description "PaZeek (USA) (Proto)" - rom ( name "PaZeek (USA) (Proto).gbc" size 262144 crc 952b0028 sha1 590dc27682dacb8a044b68d76ad3a0548973c390 ) + name "Stranded Kids (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + description "Stranded Kids (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" + rom ( name "Stranded Kids (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 816a4d94 sha1 5c1d738f23a68cce8d2561f91f06c9998e0fe5a9 ) ) game ( - name "Perfect Choro Q (Japan)" - description "Perfect Choro Q (Japan)" - rom ( name "Perfect Choro Q (Japan).gbc" size 2097152 crc afa1aac3 sha1 3c7024086f9bedc223c7d482c309336c250ed039 ) + name "Street Fighter Alpha - Warriors' Dreams (Europe)" + description "Street Fighter Alpha - Warriors' Dreams (Europe)" + rom ( name "Street Fighter Alpha - Warriors' Dreams (Europe).gbc" size 1048576 crc 28a3ab3a sha1 8baad8f1fe999d1ee352d534b1dbe6e10c0281fe ) ) game ( - name "Perfect Dark (USA, Europe) (En,Fr,De,Es,It) (Rumble Version)" - description "Perfect Dark (USA, Europe) (En,Fr,De,Es,It) (Rumble Version)" - rom ( name "Perfect Dark (USA, Europe) (En,Fr,De,Es,It) (Rumble Version).gbc" size 4194304 crc 0601bef6 sha1 2d1e47bf3fb4a28ffb82a4fd2ae779ec99aaa87d flags verified ) + name "Street Fighter Alpha - Warriors' Dreams (Japan)" + description "Street Fighter Alpha - Warriors' Dreams (Japan)" + rom ( name "Street Fighter Alpha - Warriors' Dreams (Japan).gbc" size 1048576 crc 32739b34 sha1 c0086c92381b1561153fbe97fa455fc8c6573c1d ) ) game ( - name "Peugeot - Orbital Diagnostic System (Unknown) (Unl) [b]" - description "Peugeot - Orbital Diagnostic System (Unknown) (Unl) [b]" - rom ( name "Peugeot - Orbital Diagnostic System (Unknown) (Unl) [b].gbc" size 1048576 crc f971fce9 sha1 6bc140722fad759830fd6e4b6ac0b41443795fb2 flags baddump ) + name "Street Fighter Alpha - Warriors' Dreams (USA)" + description "Street Fighter Alpha - Warriors' Dreams (USA)" + rom ( name "Street Fighter Alpha - Warriors' Dreams (USA).gbc" size 1048576 crc aa5f14d2 sha1 ca26852ee2c0e691cd0fc30a44de84fd1465b4de ) ) game ( - name "Peugeot - Orbital Diagnostic System (Unknown) (Alt) (Unl) [b]" - description "Peugeot - Orbital Diagnostic System (Unknown) (Alt) (Unl) [b]" - rom ( name "Peugeot - Orbital Diagnostic System (Unknown) (Alt) (Unl) [b].gbc" size 32768 crc 424912fe sha1 bd5735021e4593ec07082e6197e683496d0ecf0b flags baddump ) + name "Street Fighter Alpha - Warriors' Dreams (Europe) (Rev 1) (Proto)" + description "Street Fighter Alpha - Warriors' Dreams (Europe) (Rev 1) (Proto)" + rom ( name "Street Fighter Alpha - Warriors' Dreams (Europe) (Rev 1) (Proto).gbc" size 1048576 crc cdf56f1a sha1 b7c04a24e7f0355a0113109b5e97ad044057a006 ) ) game ( - name "Phantom Fright (World) (GB Compatible) (Aftermarket) (Unl)" - description "Phantom Fright (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Phantom Fright (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 154cb547 sha1 3b217c595e6a5b115dc7130123a321049cf01d22 ) + name "Street Hero (Taiwan) (En) (1B-004, EB-004, Sachen) (Unl)" + description "Street Hero (Taiwan) (En) (1B-004, EB-004, Sachen) (Unl)" + rom ( name "Street Hero (Taiwan) (En) (1B-004, EB-004, Sachen) (Unl).gbc" size 393216 crc b580cb1f sha1 f80ffcaf0757f16ce0e6940a2ec786ebd7549458 flags verified ) ) game ( - name "Phantom Zona (Japan) (SGB Enhanced) (GB Compatible)" - description "Phantom Zona (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Phantom Zona (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 3e43f25f sha1 bf2162f970a9dbb658afbdd7354155768daa96b1 flags verified ) + name "Stuart Little - The Journey Home (Europe) (Fr,De)" + description "Stuart Little - The Journey Home (Europe) (Fr,De)" + rom ( name "Stuart Little - The Journey Home (Europe) (Fr,De).gbc" size 1048576 crc acb08666 sha1 153f8ffab32e78dd4a6c2eec4560b2cf6509774d ) ) game ( - name "Pia Carrot e Youkoso!! 2.2 (Japan)" - description "Pia Carrot e Youkoso!! 2.2 (Japan)" - rom ( name "Pia Carrot e Youkoso!! 2.2 (Japan).gbc" size 4194304 crc 2267360b sha1 e18cd437c52ca37c6c13ba71e0bd50f1b517a8d6 ) + name "Stuart Little - The Journey Home (USA, Europe)" + description "Stuart Little - The Journey Home (USA, Europe)" + rom ( name "Stuart Little - The Journey Home (USA, Europe).gbc" size 1048576 crc eb273887 sha1 d3c31e41709c54af328787036db1b98997f508ea ) ) game ( - name "Pian Wai Zhang - Huangjin Taiyang - Fengyin de Yuangu Lianjin Shu (Taiwan) (Unl)" - description "Pian Wai Zhang - Huangjin Taiyang - Fengyin de Yuangu Lianjin Shu (Taiwan) (Unl)" - rom ( name "Pian Wai Zhang - Huangjin Taiyang - Fengyin de Yuangu Lianjin Shu (Taiwan) (Unl).gbc" size 2097152 crc 0db9fdfa sha1 6d2acdca141001bfefdcbf0076702fec6619e368 ) + name "Super 16 in 1 (Taiwan) (En) (Sachen) (Unl)" + description "Super 16 in 1 (Taiwan) (En) (Sachen) (Unl)" + rom ( name "Super 16 in 1 (Taiwan) (En) (Sachen) (Unl).gbc" size 2097152 crc 6a99a079 sha1 bcb683600278094e4d40a7da0226b83ec1f92c81 ) ) game ( - name "Piecrust (World) (Unl)" - description "Piecrust (World) (Unl)" - rom ( name "Piecrust (World) (Unl).gbc" size 32768 crc f39c8119 sha1 b01cad9652bf1c65151dd8d2bd21251a9cf44d43 ) + name "Super 21 in 1 - New GB Rumble (Taiwan) (Unl)" + description "Super 21 in 1 - New GB Rumble (Taiwan) (Unl)" + rom ( name "Super 21 in 1 - New GB Rumble (Taiwan) (Unl).gbc" size 2097152 crc 21746216 sha1 829cc0fcd4b96cf5cac909a7c0697583f4c62241 ) ) game ( - name "Pilgrim's Peril (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Pilgrim's Peril (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Pilgrim's Peril (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 3c2bafdc sha1 d38f3f5e491dbaed84e88099987712449db9b33d ) + name "Super 6 in 1 (Taiwan) (En,Zh) (6B-001, Sachen) (Unl)" + description "Super 6 in 1 (Taiwan) (En,Zh) (6B-001, Sachen) (Unl)" + rom ( name "Super 6 in 1 (Taiwan) (En,Zh) (6B-001, Sachen) (Unl).gbc" size 2097152 crc fb60d1c5 sha1 8670282e7ea22235e374d5dcd1beb5ac54b35fe6 ) ) game ( - name "Pine Creek (World) (En-US,Es-MX,Pt-BR) (Beta) (GB Compatible) (Aftermarket) (Unl)" - description "Pine Creek (World) (En-US,Es-MX,Pt-BR) (Beta) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Pine Creek (World) (En-US,Es-MX,Pt-BR) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 189aa999 sha1 2cf46a36502eaf22ac9572fe1136d369fcbe9e46 ) + name "Super Black Bass - Real Fight (Japan) (Rumble Version)" + description "Super Black Bass - Real Fight (Japan) (Rumble Version)" + rom ( name "Super Black Bass - Real Fight (Japan) (Rumble Version).gbc" size 4194304 crc b7f77b6a sha1 8c587086f3dec061027322da305081e3aa06ff60 ) ) game ( - name "Pinecone Pizza Party (World) (Prototype) (GB Compatible) (Aftermarket) (Unl)" - description "Pinecone Pizza Party (World) (Prototype) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Pinecone Pizza Party (World) (Prototype) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 1601d6fa sha1 87b4edf0398f0154d7556e3cd96f97b19e699a40 ) + name "Super Black Bass Pocket 3 (Japan) (SGB Enhanced) (GB Compatible)" + description "Super Black Bass Pocket 3 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Super Black Bass Pocket 3 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ae466545 sha1 b416f8fe1d229bd4e90259f2e6a7d78dd1f7bf3e ) ) game ( - name "Pitfall - Beyond the Jungle (USA, Europe) (GB Compatible)" - description "Pitfall - Beyond the Jungle (USA, Europe) (GB Compatible)" - rom ( name "Pitfall - Beyond the Jungle (USA, Europe) (GB Compatible).gbc" size 1048576 crc f911bb5d sha1 249e4c0370961eaff6bdcff20a0bd8e42aba2393 ) + name "Super Bombliss DX (Japan) (En) (SGB Enhanced) (GB Compatible)" + description "Super Bombliss DX (Japan) (En) (SGB Enhanced) (GB Compatible)" + rom ( name "Super Bombliss DX (Japan) (En) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 34c8a4a5 sha1 44070e77eb2b56b67f979e444d404e56b67edbb0 ) ) game ( - name "Pitfall GB (Japan) (GB Compatible)" - description "Pitfall GB (Japan) (GB Compatible)" - rom ( name "Pitfall GB (Japan) (GB Compatible).gbc" size 1048576 crc fa09cebe sha1 5b8ed6b038084890ce198133a7ae8ca93257d0f8 ) + name "Super Breakout! (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + description "Super Breakout! (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + rom ( name "Super Breakout! (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 524288 crc 6833923d sha1 5bd06600b35cd2b2e8d51ede6f79db76ba97e78e ) ) game ( - name "Planet of the Apes (Europe) (En,Fr,De,Es,It,Nl)" - description "Planet of the Apes (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Planet of the Apes (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc a92dcb79 sha1 fa8ca9a374fa3151ae912c7210b116d9fe0fce2b ) + name "Super Breakout! (USA) (GB Compatible)" + description "Super Breakout! (USA) (GB Compatible)" + rom ( name "Super Breakout! (USA) (GB Compatible).gbc" size 1048576 crc 52f51cb5 sha1 8c795b6d8ebc3a796821a6b2879f3e5cebf9215c ) ) game ( - name "Planet of the Apes (USA) (En,Fr,De,Es,It,Nl)" - description "Planet of the Apes (USA) (En,Fr,De,Es,It,Nl)" - rom ( name "Planet of the Apes (USA) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 91d7ccca sha1 84b616c937b9dcc7cdcb05f583a4d60467ede385 ) + name "Super Chinese Fighter EX (Japan)" + description "Super Chinese Fighter EX (Japan)" + rom ( name "Super Chinese Fighter EX (Japan).gbc" size 1048576 crc dcdaa333 sha1 0296d0a60933c798b21399195789d10eb319872f ) ) game ( - name "Player Manager 2001 (Europe) (En,Fr)" - description "Player Manager 2001 (Europe) (En,Fr)" - rom ( name "Player Manager 2001 (Europe) (En,Fr).gbc" size 1048576 crc 375c35e0 sha1 6e21a85257361be76914f418409124c5bc315429 ) + name "Super Color 26-in-1 (Taiwan) (Unl)" + description "Super Color 26-in-1 (Taiwan) (Unl)" + rom ( name "Super Color 26-in-1 (Taiwan) (Unl).gbc" size 4194304 crc 71e9a5d9 sha1 0f8657e4583389a23d61d8d0bd7fe322bcaabf6b ) ) game ( - name "PlayTime (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "PlayTime (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "PlayTime (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 29415ff7 sha1 89b3fd633e8cef3b8523b1ef2a0072db2d7416d7 ) + name "Super Doll Licca-chan - Kisekae Daisakusen (Japan)" + description "Super Doll Licca-chan - Kisekae Daisakusen (Japan)" + rom ( name "Super Doll Licca-chan - Kisekae Daisakusen (Japan).gbc" size 1048576 crc df50473f sha1 8becf5a8834285f2aff42812c8e44d864ee46d02 ) ) game ( - name "Pocket Billiards - Funk the 9 Ball (Japan)" - description "Pocket Billiards - Funk the 9 Ball (Japan)" - rom ( name "Pocket Billiards - Funk the 9 Ball (Japan).gbc" size 1048576 crc 3b46e7c9 sha1 24673a0d0c274d8eda3b3952d63772c65778b8c3 ) + name "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl)" + description "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl)" + rom ( name "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl).gbc" size 524288 crc d44c9806 sha1 c761dca73b520711b3205e11091e2bf8d4fd7549 flags verified ) ) game ( - name "Pocket Bomberman (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Pocket Bomberman (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket Bomberman (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc fa2a66e9 sha1 b0ae803600e06cd1cc9a0d801f2511c9ecc50584 flags verified ) + name "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl) (Alt)" + description "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl) (Alt)" + rom ( name "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl) (Alt).gbc" size 524288 crc 33093c28 sha1 f5b556a15a1929cbcd21f0f2fc0da7bf23b99bd4 ) ) game ( - name "Pocket Bowling (Japan) (GB Compatible)" - description "Pocket Bowling (Japan) (GB Compatible)" - rom ( name "Pocket Bowling (Japan) (GB Compatible).gbc" size 524288 crc 26589b79 sha1 8a29e82be027a82030c1dc7f7cf9bc9ecf010e64 ) + name "Super Fighters 99 (Taiwan) (SGB Enhanced) (Unl)" + description "Super Fighters 99 (Taiwan) (SGB Enhanced) (Unl)" + rom ( name "Super Fighters 99 (Taiwan) (SGB Enhanced) (Unl).gbc" size 2097152 crc ce41b1bb sha1 e5af8afdce844f02c4128748067933840a759773 ) ) game ( - name "Pocket Bowling (USA) (GB Compatible)" - description "Pocket Bowling (USA) (GB Compatible)" - rom ( name "Pocket Bowling (USA) (GB Compatible).gbc" size 524288 crc 3ed30908 sha1 5435ccec39ef27d9cab626425671bd81e7fa4d55 ) + name "Super Fighters S (Taiwan) (GB Compatible) (Unl)" + description "Super Fighters S (Taiwan) (GB Compatible) (Unl)" + rom ( name "Super Fighters S (Taiwan) (GB Compatible) (Unl).gbc" size 2097152 crc 64db799a sha1 ef0bf0feaf9e2bdfb10acd469e915266655adb43 ) ) game ( - name "Pocket Color Billiards (Japan)" - description "Pocket Color Billiards (Japan)" - rom ( name "Pocket Color Billiards (Japan).gbc" size 1048576 crc 911007e1 sha1 7d2f568887449d7d34e82022007568c035949539 ) + name "Super Gals! Kotobuki Ran (Japan)" + description "Super Gals! Kotobuki Ran (Japan)" + rom ( name "Super Gals! Kotobuki Ran (Japan).gbc" size 4194304 crc 90379c16 sha1 fc18f5137d6063ca1afe20f5d3ed544e527e6bcf flags verified ) ) game ( - name "Pocket Color Block (Japan) (SGB Enhanced) (GB Compatible)" - description "Pocket Color Block (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket Color Block (Japan) (SGB Enhanced) (GB Compatible).gbc" size 131072 crc 389cf56f sha1 84d243c64f98731965ca78b75ad48f8787d3c907 ) + name "Super Gals! Kotobuki Ran 2 - Miracle Getting (Japan)" + description "Super Gals! Kotobuki Ran 2 - Miracle Getting (Japan)" + rom ( name "Super Gals! Kotobuki Ran 2 - Miracle Getting (Japan).gbc" size 4194304 crc e77fa0f2 sha1 a724c6dd33b84ae9120d041fc49d66692c798dd0 ) ) game ( - name "Pocket Color Mahjong (Japan) (GB Compatible)" - description "Pocket Color Mahjong (Japan) (GB Compatible)" - rom ( name "Pocket Color Mahjong (Japan) (GB Compatible).gbc" size 1048576 crc 08dc0af4 sha1 23067c8b37f283facc5c3a8e96c804ddd53aeaf4 ) + name "Super Mario Bros. Deluxe (Japan) (NP)" + description "Super Mario Bros. Deluxe (Japan) (NP)" + rom ( name "Super Mario Bros. Deluxe (Japan) (NP).gbc" size 1048576 crc 866b1212 sha1 94466f48d8b4f811608ce8641de5f82315cd60b5 ) ) game ( - name "Pocket Color Trump (Japan) (GB Compatible)" - description "Pocket Color Trump (Japan) (GB Compatible)" - rom ( name "Pocket Color Trump (Japan) (GB Compatible).gbc" size 1048576 crc c73eb10e sha1 ddc9846964a19e8702f226ffd9060b94a60011c3 ) + name "Super Mario Bros. Deluxe (USA, Europe)" + description "Super Mario Bros. Deluxe (USA, Europe)" + rom ( name "Super Mario Bros. Deluxe (USA, Europe).gbc" size 1048576 crc a4cd26ff sha1 f84f26f22751b58ed57bd332274e18131660729a flags verified ) ) game ( - name "Pocket Cooking (Japan)" - description "Pocket Cooking (Japan)" - rom ( name "Pocket Cooking (Japan).gbc" size 4194304 crc f5ab554d sha1 60a13fc904100655a52dfb61d9abe77cc126e58c flags verified ) + name "Super Mario Bros. Deluxe (USA, Europe) (Rev 1)" + description "Super Mario Bros. Deluxe (USA, Europe) (Rev 1)" + rom ( name "Super Mario Bros. Deluxe (USA, Europe) (Rev 1).gbc" size 1048576 crc 90ab047b sha1 07295cd60ae44183ebecb013930727e0404169d5 flags verified ) ) game ( - name "Pocket Densha 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Pocket Densha 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket Densha 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4d26e880 sha1 859331f57a964197f271acafa7e8dc586e598cf5 ) + name "Super Mario Bros. Deluxe (Europe) (Rev 2)" + description "Super Mario Bros. Deluxe (Europe) (Rev 2)" + rom ( name "Super Mario Bros. Deluxe (Europe) (Rev 2).gbc" size 1048576 crc 62bbae83 sha1 254f2254e9d54e2501e3e4ebe09491e03573a6a4 ) ) game ( - name "Pocket Family GB 2 (Japan)" - description "Pocket Family GB 2 (Japan)" - rom ( name "Pocket Family GB 2 (Japan).gbc" size 2097152 crc 2a273244 sha1 fc88fcf5aab548936cd6617c4e2ea07b77ee43c8 flags verified ) + name "Super Mario Bros. Deluxe (Japan) (Rev 1) (NP)" + description "Super Mario Bros. Deluxe (Japan) (Rev 1) (NP)" + rom ( name "Super Mario Bros. Deluxe (Japan) (Rev 1) (NP).gbc" size 1048576 crc f4e91f63 sha1 e61d564e1ff19eb4b7c62a6cd96214f2bca4b01d ) ) game ( - name "Pocket GI Stable (Japan) (SGB Enhanced) (GB Compatible)" - description "Pocket GI Stable (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket GI Stable (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc c424874e sha1 f818e6284d198f4b394f79cb8511c9b906d69f03 ) + name "Super Mario Special 3 (Taiwan) (En) (Unl)" + description "Super Mario Special 3 (Taiwan) (En) (Unl)" + rom ( name "Super Mario Special 3 (Taiwan) (En) (Unl).gbc" size 524288 crc 5e4266a7 sha1 f493da9f707ad84c4d720687ec1ca3f635dc35c6 ) ) game ( - name "Pocket Golf! (USA) (Proto) (SGB Enhanced) (GB Compatible)" - description "Pocket Golf! (USA) (Proto) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket Golf! (USA) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc d06ecb1f sha1 bbe2651547c1f3c79bbf822b41ddbb54133a489f ) + name "Super Marrio Sunshine (Taiwan) (En) (Unl)" + description "Super Marrio Sunshine (Taiwan) (En) (Unl)" + rom ( name "Super Marrio Sunshine (Taiwan) (En) (Unl).gbc" size 2097152 crc 031a82dc sha1 cdb5707ee84f7404bfb04d6bd5a4c653b7927e35 ) ) game ( - name "Pocket GT (USA) (Proto)" - description "Pocket GT (USA) (Proto)" - rom ( name "Pocket GT (USA) (Proto).gbc" size 1048576 crc 9e120d94 sha1 c48f302009c405aa379ebf048bc46a284a74c84c ) + name "Super Me-Mail GB - Me-Mail Bear no Happy Mail Town (Japan)" + description "Super Me-Mail GB - Me-Mail Bear no Happy Mail Town (Japan)" + rom ( name "Super Me-Mail GB - Me-Mail Bear no Happy Mail Town (Japan).gbc" size 1048576 crc 315caa18 sha1 4b96d2447b763f08d079eb07b95b6627d3fc120b ) ) game ( - name "Pocket GT (Japan)" - description "Pocket GT (Japan)" - rom ( name "Pocket GT (Japan).gbc" size 1048576 crc 2ac77c5a sha1 035e2284654751491fafb9d752740eefc2aa80cd ) + name "Super Nenas, Las - El Malvado Mojo Jojo (Spain)" + description "Super Nenas, Las - El Malvado Mojo Jojo (Spain)" + rom ( name "Super Nenas, Las - El Malvado Mojo Jojo (Spain).gbc" size 2097152 crc efe652bf sha1 286cabc9ea92d1866e59748a788658c5e3d32a35 ) ) game ( - name "Pocket Hanafuda (Japan)" - description "Pocket Hanafuda (Japan)" - rom ( name "Pocket Hanafuda (Japan).gbc" size 262144 crc af0c51b8 sha1 339e97a223da844efe889e18eaced20756b0ba28 ) + name "Super Nenas, Las - Lucha Con Ese (Spain)" + description "Super Nenas, Las - Lucha Con Ese (Spain)" + rom ( name "Super Nenas, Las - Lucha Con Ese (Spain).gbc" size 2097152 crc 7ba87c11 sha1 06b0835c40d4f27ad45833d54f606a0964e09de0 ) ) game ( - name "Pocket King (Japan) (SGB Enhanced) (GB Compatible)" - description "Pocket King (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket King (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc dee71d44 sha1 ceb6679568dca09212e758cbf76a170c4719aae1 ) + name "Super Nenas, Las - Panico en Townsville (Spain)" + description "Super Nenas, Las - Panico en Townsville (Spain)" + rom ( name "Super Nenas, Las - Panico en Townsville (Spain).gbc" size 2097152 crc 03edb574 sha1 34463c99193e4cf99aa1833242fa2b30db9fe522 ) ) game ( - name "Pocket Lure Boy (Japan)" - description "Pocket Lure Boy (Japan)" - rom ( name "Pocket Lure Boy (Japan).gbc" size 1048576 crc 35a29628 sha1 2cc7337a2b6ac37238ac1cdaf8e7966bd9493295 ) + name "Super Real Fishing (Japan) (Rumble Version)" + description "Super Real Fishing (Japan) (Rumble Version)" + rom ( name "Super Real Fishing (Japan) (Rumble Version).gbc" size 1048576 crc 00865161 sha1 cbd6ca89332ee11f89b580e53b53285760dd025a ) ) game ( - name "Pocket Monsters - Crystal Version (Japan)" - description "Pocket Monsters - Crystal Version (Japan)" - rom ( name "Pocket Monsters - Crystal Version (Japan).gbc" size 2097152 crc 270c4ecc sha1 95127b901bbce2407daf43cce9f45d4c27ef635d flags verified ) + name "Super Robot Pinball (Japan)" + description "Super Robot Pinball (Japan)" + rom ( name "Super Robot Pinball (Japan).gbc" size 2097152 crc 6e330fcd sha1 2dbe45e3d5912b270b8bfacc5d9ffc836fe74284 ) ) game ( - name "Pocket Monsters - Crystal Version (Taiwan) (Unl)" - description "Pocket Monsters - Crystal Version (Taiwan) (Unl)" - rom ( name "Pocket Monsters - Crystal Version (Taiwan) (Unl).gbc" size 2097152 crc 4b2b8b57 sha1 9a2b381a134bb7ed1b566bb6f94596b57e690a4e ) + name "Super Robot Taisen - Link Battler (Japan) (SGB Enhanced) (GB Compatible)" + description "Super Robot Taisen - Link Battler (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Super Robot Taisen - Link Battler (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d24e592d sha1 e6c715042adc4c1b52a7295e082953ada79cf95e ) ) game ( - name "Pocket Monsters Diamond (Taiwan) (En) (Unl)" - description "Pocket Monsters Diamond (Taiwan) (En) (Unl)" - rom ( name "Pocket Monsters Diamond (Taiwan) (En) (Unl).gbc" size 2097152 crc 41e3723c sha1 47391ca3d68c41a627e1bb5cf987425ce391abf0 ) + name "Supercross Freestyle (Europe) (En,Fr,De,Es,It)" + description "Supercross Freestyle (Europe) (En,Fr,De,Es,It)" + rom ( name "Supercross Freestyle (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 4d3e0f51 sha1 4f4aa8353d230e3a65a7e68dbb3312ad871894df ) ) game ( - name "Pocket Monsters Eun (Korea)" - description "Pocket Monsters Eun (Korea)" - rom ( name "Pocket Monsters Eun (Korea).gbc" size 2097152 crc 9cc1f90f sha1 cb22d7e03a74dc3a563fde6be8626626b2b392e7 flags verified ) + name "Superman - Battle for Metropolis (Europe) (Proto) (2001-01-12) (GB Compatible)" + description "Superman - Battle for Metropolis (Europe) (Proto) (2001-01-12) (GB Compatible)" + rom ( name "Superman - Battle for Metropolis (Europe) (Proto) (2001-01-12) (GB Compatible).gbc" size 2097152 crc 6606382c sha1 4d9a17deefaf03532e952cd909584fca2d3cdd09 ) ) game ( - name "Pocket Monsters Geum (Korea)" - description "Pocket Monsters Geum (Korea)" - rom ( name "Pocket Monsters Geum (Korea).gbc" size 2097152 crc 249a7a66 sha1 c0ff3999e1093e1af59ef3eea3f1bfd7c1f18a65 ) + name "Supershot Golf Robot (USA) (Proto)" + description "Supershot Golf Robot (USA) (Proto)" + rom ( name "Supershot Golf Robot (USA) (Proto).gbc" size 2097152 crc b6a7f781 sha1 aa1447d78e380d2a936fb5f713521e34420fe68c ) ) game ( - name "Pocket Monsters Gin (Japan) (SGB Enhanced) (GB Compatible)" - description "Pocket Monsters Gin (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket Monsters Gin (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc be1b928a sha1 fa8c51059c1642faa570db56ef089f54d1d2011f ) + name "Supreme Snowboarding (Europe) (En,Fr,De)" + description "Supreme Snowboarding (Europe) (En,Fr,De)" + rom ( name "Supreme Snowboarding (Europe) (En,Fr,De).gbc" size 2097152 crc 53b1e661 sha1 4f745ffa0146e21bb26408cf7431376887499919 ) ) game ( - name "Pocket Monsters Gin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Pocket Monsters Gin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket Monsters Gin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0aea5383 sha1 a11d5ddc26eb826086593f82370b15d16404d33e flags verified ) + name "Survival Kids (USA) (SGB Enhanced) (GB Compatible)" + description "Survival Kids (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "Survival Kids (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c46aba56 sha1 0e3d3821710b07f68628edda071b928df0c6a2f2 ) ) game ( - name "Pocket Monsters Kin (Japan) (SGB Enhanced) (GB Compatible)" - description "Pocket Monsters Kin (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket Monsters Kin (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 524478d4 sha1 8814f1039450a5d3684b1389f588ccd7ee7c3436 flags verified ) + name "Survival Kids - Kotou no Boukensha (Japan) (SGB Enhanced) (GB Compatible)" + description "Survival Kids - Kotou no Boukensha (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Survival Kids - Kotou no Boukensha (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 61fa675c sha1 f80abbeaa2cf0631c1cdf812c13f13f1fea41f18 ) ) game ( - name "Pocket Monsters Kin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Pocket Monsters Kin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket Monsters Kin (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4ef7f2a5 sha1 a222402235d484ee8e39f3f31bae57cf13daf585 flags verified ) + name "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (SGB Enhanced) (GB Compatible)" + description "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ab8b25d8 sha1 8fd720d5b035939b553910a3ec45c1bd052484eb ) ) game ( - name "Pocket Music (Europe) (En,Fr,De,Es,It)" - description "Pocket Music (Europe) (En,Fr,De,Es,It)" - rom ( name "Pocket Music (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 1bfb531e sha1 74dc5efab773fde400304d3df8034a095af8a742 ) + name "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (Rev 1) (Possible Proto) (SGB Enhanced, GB Compatible) (NP)" + description "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (Rev 1) (Possible Proto) (SGB Enhanced, GB Compatible) (NP)" + rom ( name "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (Rev 1) (Possible Proto) (SGB Enhanced, GB Compatible) (NP).gbc" size 1048576 crc bd366d22 sha1 505ffc930057719cf28560333342dfd6944c15da ) ) game ( - name "Pocket Music (USA) (En,Es) (Proto)" - description "Pocket Music (USA) (En,Es) (Proto)" - rom ( name "Pocket Music (USA) (En,Es) (Proto).gbc" size 1048576 crc c4387812 sha1 ad547a79af864eb56a18e1c2ad4346eb35df41ed ) + name "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 1)" + description "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 1)" + rom ( name "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 1).gbc" size 524288 crc 617d7667 sha1 b215146fe8e2a5836d0ac6fa4785f95db464fc1a ) ) game ( - name "Pocket no Naka no Oukoku (Japan) (Proto)" - description "Pocket no Naka no Oukoku (Japan) (Proto)" - rom ( name "Pocket no Naka no Oukoku (Japan) (Proto).gbc" size 2097152 crc 1eed33c6 sha1 b91750cc805beb753e3c61a99c256d9cc006d3b8 ) + name "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 2)" + description "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 2)" + rom ( name "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 2).gbc" size 524288 crc 6bfcfd87 sha1 83c64dd44d3d03e3fd0711b23bf63e2264256dea ) ) game ( - name "Pocket Pro Wrestling - Perfect Wrestler (Japan)" - description "Pocket Pro Wrestling - Perfect Wrestler (Japan)" - rom ( name "Pocket Pro Wrestling - Perfect Wrestler (Japan).gbc" size 2097152 crc d4ebba41 sha1 1b029aa7097672c469e48179d45534ab33fcca1d ) + name "Sutte Hakkun GB (Japan) (Proto)" + description "Sutte Hakkun GB (Japan) (Proto)" + rom ( name "Sutte Hakkun GB (Japan) (Proto).gbc" size 524288 crc e0386f84 sha1 6efd637f039d4f3a2240640921724a69a2844cc7 ) ) game ( - name "Pocket Pro Yakyuu (Japan)" - description "Pocket Pro Yakyuu (Japan)" - rom ( name "Pocket Pro Yakyuu (Japan).gbc" size 1048576 crc 2a6ef6a8 sha1 4fbbc6bd6a1631b92218632540e242820ec889ca ) + name "Suzuki Alstare Extreme Racing (Europe) (En,Fr,De,Es,It,Nl)" + description "Suzuki Alstare Extreme Racing (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Suzuki Alstare Extreme Racing (Europe) (En,Fr,De,Es,It,Nl).gbc" size 524288 crc 0f7264ba sha1 2489b5c2572246edf3f28f9d62abcda9d63b62bf ) ) game ( - name "Pocket Puyo Puyo Sun (Japan) (SGB Enhanced) (GB Compatible)" - description "Pocket Puyo Puyo Sun (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pocket Puyo Puyo Sun (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 45661ec3 sha1 c2f72fad1a26ad765eb3036f0c9e9e8945133d3a flags verified ) + name "Suzuki Alstare Extreme Racing (USA) (Proto)" + description "Suzuki Alstare Extreme Racing (USA) (Proto)" + rom ( name "Suzuki Alstare Extreme Racing (USA) (Proto).gbc" size 524288 crc a13cf42e sha1 b2816e8585e03b7d547e8acfda716b7adddf3b41 ) ) game ( - name "Pocket Puyo Puyo-n (Japan)" - description "Pocket Puyo Puyo-n (Japan)" - rom ( name "Pocket Puyo Puyo-n (Japan).gbc" size 1048576 crc 870db337 sha1 a86d4a24b5da3444b1967362b13d321b5c4f7a64 ) + name "Sweet Ange (Japan) (SGB Enhanced) (GB Compatible)" + description "Sweet Ange (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Sweet Ange (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4be9b159 sha1 5b6f268d945bcdb070195459582f01b434c01495 ) ) game ( - name "Pocket Puyo Puyo-n (Japan) (Rev 1)" - description "Pocket Puyo Puyo-n (Japan) (Rev 1)" - rom ( name "Pocket Puyo Puyo-n (Japan) (Rev 1).gbc" size 1048576 crc c884037a sha1 3d52805f712e6d1ce22b88dfebfcac2a31743ff3 flags verified ) + name "Swing (Germany)" + description "Swing (Germany)" + rom ( name "Swing (Germany).gbc" size 1048576 crc 7041929d sha1 c681530a49a5287ef59b4bae02cb1f9e82c72386 ) ) game ( - name "Pocket Puyo Puyo-n (Japan) (Rev 2)" - description "Pocket Puyo Puyo-n (Japan) (Rev 2)" - rom ( name "Pocket Puyo Puyo-n (Japan) (Rev 2).gbc" size 1048576 crc 573613d7 sha1 09b217161ac326da63887693281b60751ca2dfcf flags verified ) + name "Swing (Europe) (En,Fr,De,Es,It) (Proto)" + description "Swing (Europe) (En,Fr,De,Es,It) (Proto)" + rom ( name "Swing (Europe) (En,Fr,De,Es,It) (Proto).gbc" size 1048576 crc 60d06df9 sha1 576d4338665f159a88875819f0681fdc49443fe4 ) ) game ( - name "Pocket Racing (Europe)" - description "Pocket Racing (Europe)" - rom ( name "Pocket Racing (Europe).gbc" size 1048576 crc fbf97372 sha1 76cdbd2fe7a2ad49c22083cd49f444ee51c4d140 ) + name "SWiV (Europe) (En,Fr,De,Es,It)" + description "SWiV (Europe) (En,Fr,De,Es,It)" + rom ( name "SWiV (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 44d30b7a sha1 7e037008eabf01fa647cdfb0d5c88766a6f77423 ) ) game ( - name "Pocket Smash Out (Europe) (Unl)" - description "Pocket Smash Out (Europe) (Unl)" - rom ( name "Pocket Smash Out (Europe) (Unl).gbc" size 262144 crc cbd14276 sha1 0a721164053a8b2765ea9826a0958415701ca6f5 ) + name "Sylvanian Families - Otogi no Kuni no Pendant (Japan) (SGB Enhanced) (GB Compatible)" + description "Sylvanian Families - Otogi no Kuni no Pendant (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Sylvanian Families - Otogi no Kuni no Pendant (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc c6fe4497 sha1 440d0010386f3f2d658740cc6584558f546482a6 ) ) game ( - name "Pocket Smash Out & Race Time (Europe) (Unl)" - description "Pocket Smash Out & Race Time (Europe) (Unl)" - rom ( name "Pocket Smash Out & Race Time (Europe) (Unl).gbc" size 524288 crc 0ad5b775 sha1 01f68a0a45408da9892b8cc0a4a9c688dcdd9618 ) + name "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan)" + description "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan)" + rom ( name "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan).gbc" size 2097152 crc f82d391f sha1 16f5d02e0272fbb2b0a3c219487484c7013ba4fb ) ) game ( - name "Pocket Soccer (Europe) (En,Fr,De,Es,It,Pt)" - description "Pocket Soccer (Europe) (En,Fr,De,Es,It,Pt)" - rom ( name "Pocket Soccer (Europe) (En,Fr,De,Es,It,Pt).gbc" size 2097152 crc e8f5824f sha1 4d06ea937a02a8f458186a9382994b09a97481a4 ) + name "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan) (Rev 1) (Possible Proto)" + description "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan) (Rev 1) (Possible Proto)" + rom ( name "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan) (Rev 1) (Possible Proto).gbc" size 2097152 crc ad6f3bdf sha1 c96044d57a2367ffb7b2325aa8d0c9b659e0aaba ) ) game ( - name "Pogo Pete (World) (Aftermarket) (Unl)" - description "Pogo Pete (World) (Aftermarket) (Unl)" - rom ( name "Pogo Pete (World) (Aftermarket) (Unl).gbc" size 262144 crc 3001ed1b sha1 f9dab150843c2b8f300d36b1dd53dd1a22b481a3 ) + name "Sylvanian Families 3 - Hoshi Furu Yoru no Sunadokei (Japan)" + description "Sylvanian Families 3 - Hoshi Furu Yoru no Sunadokei (Japan)" + rom ( name "Sylvanian Families 3 - Hoshi Furu Yoru no Sunadokei (Japan).gbc" size 2097152 crc abf32b8b sha1 ab279c72758cd2ca41a5f41ce3c9cad9490aaca3 ) ) game ( - name "Pokemon - Crystal Version (Australia)" - description "Pokemon - Crystal Version (Australia)" - rom ( name "Pokemon - Crystal Version (Australia).gbc" size 2097152 crc bb6dd80c sha1 a0fc810f1d4e124434f7be2c989ab5b5892ddf36 flags verified ) + name "Sylvanian Melodies - Mori no Nakama to Odori Masho! (Japan) (SGB Enhanced) (GB Compatible)" + description "Sylvanian Melodies - Mori no Nakama to Odori Masho! (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Sylvanian Melodies - Mori no Nakama to Odori Masho! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6dd8ac91 sha1 55230e865958f7301076a4354b6b8b083a494bae ) ) game ( - name "Pokemon - Crystal Version (USA)" - description "Pokemon - Crystal Version (USA)" - rom ( name "Pokemon - Crystal Version (USA).gbc" size 2097152 crc ee6f5188 sha1 f4cd194bdee0d04ca4eac29e09b8e4e9d818c133 flags verified ) + name "Sylvester & Tweety - Breakfast on the Run (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + description "Sylvester & Tweety - Breakfast on the Run (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + rom ( name "Sylvester & Tweety - Breakfast on the Run (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc 6bb3b0dc sha1 8999a54b27b51a078fb3776ec7842c56287f05df flags verified ) ) game ( - name "Pokemon - Crystal Version (USA, Europe) (Rev 1)" - description "Pokemon - Crystal Version (USA, Europe) (Rev 1)" - rom ( name "Pokemon - Crystal Version (USA, Europe) (Rev 1).gbc" size 2097152 crc 3358e30a sha1 f2f52230b536214ef7c9924f483392993e226cfb flags verified ) + name "Tabaluga (Germany) (GB Compatible)" + description "Tabaluga (Germany) (GB Compatible)" + rom ( name "Tabaluga (Germany) (GB Compatible).gbc" size 1048576 crc f09f92d7 sha1 d23fe68a0d95a8efb5d4536b03c0a3fc250e8258 ) ) game ( - name "Pokemon - Edicion Cristal (Spain)" - description "Pokemon - Edicion Cristal (Spain)" - rom ( name "Pokemon - Edicion Cristal (Spain).gbc" size 2097152 crc ff0a6f8a sha1 889a06fc0bb863666865aa69def0adf97945ac2a ) + name "Taikong Baobei (Taiwan) (Sintax) (Unl)" + description "Taikong Baobei (Taiwan) (Sintax) (Unl)" + rom ( name "Taikong Baobei (Taiwan) (Sintax) (Unl).gbc" size 2097152 crc f2d0f0ae sha1 bb2f4b475b6a7f355913267f02722f3b15bd0858 ) ) game ( - name "Pokemon - Edicion Oro (Spain) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Edicion Oro (Spain) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Edicion Oro (Spain) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 3434a92b sha1 162ea54c6a3cff374642e6dd842f9bffac847e7b ) + name "Taikong Baobei (Taiwan) (Li Cheng) (Unl)" + description "Taikong Baobei (Taiwan) (Li Cheng) (Unl)" + rom ( name "Taikong Baobei (Taiwan) (Li Cheng) (Unl).gbc" size 4194304 crc 23f291b3 sha1 278b484fa26f13a98ae5bbe06d19a5c47ccfcd34 ) ) game ( - name "Pokemon - Edicion Plata (Spain) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Edicion Plata (Spain) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Edicion Plata (Spain) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 1d9faac5 sha1 05bd978ab2cb104b0aff3f696896e30885203a18 ) + name "Taikong Zhanshi - Jingdian Ban (Taiwan) (Unl)" + description "Taikong Zhanshi - Jingdian Ban (Taiwan) (Unl)" + rom ( name "Taikong Zhanshi - Jingdian Ban (Taiwan) (Unl).gbc" size 1048576 crc 8b9f30d7 sha1 8f7272ed851844e78d1920614f5de94f0f0cecde ) ) game ( - name "Pokemon - Gold Version (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Gold Version (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Gold Version (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 6bde3c3e sha1 d8b8a3600a465308c9953dfa04f0081c05bdcb94 flags verified ) + name "Taikong Zhanshi DX3 - Zuizhong Huanxiang (Taiwan) (Unl)" + description "Taikong Zhanshi DX3 - Zuizhong Huanxiang (Taiwan) (Unl)" + rom ( name "Taikong Zhanshi DX3 - Zuizhong Huanxiang (Taiwan) (Unl).gbc" size 2097152 crc ddf36a27 sha1 0a62b484c5730a3a1f8b32cc2ed97af128d2130c ) ) game ( - name "Pokemon - Goldene Edition (Germany) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Goldene Edition (Germany) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Goldene Edition (Germany) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4889dfaa sha1 9254195d461ea942eaaa08cc4b83de3cf82aea0d flags verified ) + name "Taikong Zhanshi X - Fantasy War (Taiwan) (Unl)" + description "Taikong Zhanshi X - Fantasy War (Taiwan) (Unl)" + rom ( name "Taikong Zhanshi X - Fantasy War (Taiwan) (Unl).gbc" size 1048576 crc 09fedecc sha1 c4fd2de9cf8d75de069abadf165252dac5712691 ) ) game ( - name "Pokemon - Kristall-Edition (Germany)" - description "Pokemon - Kristall-Edition (Germany)" - rom ( name "Pokemon - Kristall-Edition (Germany).gbc" size 2097152 crc 616d85de sha1 accb584293ba056152f1fd908439b019017ff2fe ) + name "Taisen Tsume Shougi (Japan) (NP) (GB Compatible)" + description "Taisen Tsume Shougi (Japan) (NP) (GB Compatible)" + rom ( name "Taisen Tsume Shougi (Japan) (NP) (GB Compatible).gbc" size 1048576 crc 95310c8b sha1 813b97785076d2a17b19fa48ee2e0047c54259e0 ) ) game ( - name "Pokemon - Mewtwo Strikes Back (Taiwan) (En) (Unl)" - description "Pokemon - Mewtwo Strikes Back (Taiwan) (En) (Unl)" - rom ( name "Pokemon - Mewtwo Strikes Back (Taiwan) (En) (Unl).gbc" size 524288 crc 6e447a33 sha1 079b9d8190e8df451882f6eabc2799f82fbb9ec0 ) + name "Taito Memorial - Bubble Bobble (Japan) (SGB Enhanced) (GB Compatible)" + description "Taito Memorial - Bubble Bobble (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Taito Memorial - Bubble Bobble (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 388c6760 sha1 6a30d328417e085dcd10588d0a5af90ff4bfa40d ) ) game ( - name "Pokemon - Sapphire Version (USA) (Unl)" - description "Pokemon - Sapphire Version (USA) (Unl)" - rom ( name "Pokemon - Sapphire Version (USA) (Unl).gbc" size 2097152 crc 71536b8e sha1 88818c67fb1d9ae5c06e8213f09342d230923113 ) + name "Taito Memorial - Chase H.Q. - Secret Police (Japan) (SGB Enhanced) (GB Compatible)" + description "Taito Memorial - Chase H.Q. - Secret Police (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Taito Memorial - Chase H.Q. - Secret Police (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6a0c272d sha1 d6d90667ebf295016f01b4604ab03ab5b1876d00 ) ) game ( - name "Pokemon - Silberne Edition (Germany) (Beta) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Silberne Edition (Germany) (Beta) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Silberne Edition (Germany) (Beta) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 576f5ced sha1 76fa60d66b2f22a035adc54c61aad9a415c894cd flags verified ) + name "Tales of Phantasia - Narikiri Dungeon (Japan) (SGB Enhanced) (GB Compatible)" + description "Tales of Phantasia - Narikiri Dungeon (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Tales of Phantasia - Narikiri Dungeon (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 725cf31c sha1 ef322f4160ceebd8da67758ebd73225190af6d23 flags verified ) ) game ( - name "Pokemon - Silberne Edition (Germany) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Silberne Edition (Germany) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Silberne Edition (Germany) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 96c9db95 sha1 8ecc58d621faaedf2a934bd2583d527220df7bb9 flags verified ) + name "Tanimura Hitoshi Ryuu Pachinko Kouryaku Daisakusen - Don Quijote ga Iku (Japan) (SGB Enhanced) (GB Compatible)" + description "Tanimura Hitoshi Ryuu Pachinko Kouryaku Daisakusen - Don Quijote ga Iku (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Tanimura Hitoshi Ryuu Pachinko Kouryaku Daisakusen - Don Quijote ga Iku (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc ce8ae58c sha1 f752e96602274a29006425a06086d8ab45e1075c ) ) game ( - name "Pokemon - Silver Version (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Silver Version (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Silver Version (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 8ad48636 sha1 49b163f7e57702bc939d642a18f591de55d92dae flags verified ) + name "Tarzan (France)" + description "Tarzan (France)" + rom ( name "Tarzan (France).gbc" size 2097152 crc c503afbb sha1 9a4821570f565f7a1b3c7aba3c7cd2e1c1a0b570 flags verified ) ) game ( - name "Pokemon - Version Argent (France) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Version Argent (France) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Version Argent (France) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc e0c216ea sha1 a4a7e8079b7a53e4d9ef43382bbb1090b9d45d1a ) + name "Tarzan (Germany)" + description "Tarzan (Germany)" + rom ( name "Tarzan (Germany).gbc" size 2097152 crc 39d04581 sha1 ac8fc45cddb749b471a9b3f234b72731363c3b14 ) ) game ( - name "Pokemon - Version Cristal (France)" - description "Pokemon - Version Cristal (France)" - rom ( name "Pokemon - Version Cristal (France).gbc" size 2097152 crc 878b2aa7 sha1 c055992b16b7399c687647725cdd1f4f13a2f75c ) + name "Tarzan (Japan)" + description "Tarzan (Japan)" + rom ( name "Tarzan (Japan).gbc" size 2097152 crc f2005973 sha1 920c9aa99a6dd0ca53694e2553de6388b2d22eac ) ) game ( - name "Pokemon - Version Or (France) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Version Or (France) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Version Or (France) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 37a70702 sha1 c147c0d8c2b71b7628a7233436f5c052b5b17081 ) + name "Tarzan (USA, Europe)" + description "Tarzan (USA, Europe)" + rom ( name "Tarzan (USA, Europe).gbc" size 2097152 crc 4224f930 sha1 ce23eaa9aef5909883252d1340cf94e3483652b3 flags verified ) ) game ( - name "Pokemon - Versione Argento (Italy) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Versione Argento (Italy) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Versione Argento (Italy) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc cba6d2d4 sha1 c9eca9d0a837beb9137bb7d779e469c54e9f8d77 ) + name "Tasmanian Devil - Munching Madness (Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "Tasmanian Devil - Munching Madness (Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Tasmanian Devil - Munching Madness (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc 683752a0 sha1 e96ce1658bb9063042c64a161130f95f925f215b ) ) game ( - name "Pokemon - Versione Cristallo (Italy)" - description "Pokemon - Versione Cristallo (Italy)" - rom ( name "Pokemon - Versione Cristallo (Italy).gbc" size 2097152 crc d45ac039 sha1 6cee05e5b95beeae74b8365ad18ec4a07a8c4af8 ) + name "Tasmanian Devil - Munching Madness (USA) (En,Fr,De,Es,It) (GB Compatible)" + description "Tasmanian Devil - Munching Madness (USA) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Tasmanian Devil - Munching Madness (USA) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc 3611d0d8 sha1 e8c2465d0503fd02bcc50b81cb1040fff63bf513 ) ) game ( - name "Pokemon - Versione Oro (Italy) (SGB Enhanced) (GB Compatible)" - description "Pokemon - Versione Oro (Italy) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon - Versione Oro (Italy) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4c184ce3 sha1 032608fe8947b627584a4a0eccc7bf9ad3588426 ) + name "Taxi 2 (France)" + description "Taxi 2 (France)" + rom ( name "Taxi 2 (France).gbc" size 1048576 crc 0fd9fff0 sha1 76927fbf52a4c53dcd58208439eb3f285ec568fb ) ) game ( - name "Pokemon Adventure (Taiwan) (Unl)" - description "Pokemon Adventure (Taiwan) (Unl)" - rom ( name "Pokemon Adventure (Taiwan) (Unl).gbc" size 524288 crc 8edb9eb7 sha1 f86884a85cc560b91340a4c53a37cc8026699ddc ) + name "Taxi 2 (Europe) (En,Fr,De,Es,It,Nl) (Proto)" + description "Taxi 2 (Europe) (En,Fr,De,Es,It,Nl) (Proto)" + rom ( name "Taxi 2 (Europe) (En,Fr,De,Es,It,Nl) (Proto).gbc" size 1048576 crc 288bef6e sha1 28d245a6504694443ddff5f85ba2bfaecf794ff1 ) ) game ( - name "Pokemon Card GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Pokemon Card GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon Card GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1926f570 sha1 2287627c5b4d56bd9a01aab83408c301b9cf1a6c flags verified ) + name "Taxi 3 (France)" + description "Taxi 3 (France)" + rom ( name "Taxi 3 (France).gbc" size 1048576 crc 2838996f sha1 e43817c673d47b7587f542dcc9f74190c63629ff ) ) game ( - name "Pokemon Card GB 2 - GR Dan Sanjou! (Japan)" - description "Pokemon Card GB 2 - GR Dan Sanjou! (Japan)" - rom ( name "Pokemon Card GB 2 - GR Dan Sanjou! (Japan).gbc" size 2097152 crc 6c933a14 sha1 a7e12bcc5f514e3aad8de570fd511aab0a308822 ) + name "Tech Deck Skateboarding (USA, Europe)" + description "Tech Deck Skateboarding (USA, Europe)" + rom ( name "Tech Deck Skateboarding (USA, Europe).gbc" size 1048576 crc c07ebe70 sha1 cd8d7f3eea5df5dcc257d07932c453303d0c64e1 flags verified ) ) game ( - name "Pokemon de Panepon (Japan)" - description "Pokemon de Panepon (Japan)" - rom ( name "Pokemon de Panepon (Japan).gbc" size 2097152 crc 6bf7e4a6 sha1 110ae6649b4264f88d82760ad6ae4ee7f07db9b2 ) + name "Telefang - Power Version (Taiwan) (Unl)" + description "Telefang - Power Version (Taiwan) (Unl)" + rom ( name "Telefang - Power Version (Taiwan) (Unl).gbc" size 2097152 crc 1d505ada sha1 f59b8e282a5bad67f023d5ee00fbd859b64c0270 ) ) game ( - name "Pokemon Diamond (Taiwan) (En) (Unl)" - description "Pokemon Diamond (Taiwan) (En) (Unl)" - rom ( name "Pokemon Diamond (Taiwan) (En) (Unl).gbc" size 524288 crc 1b5bef4b sha1 433e7991b706baedf59af8b91bc142ba2f72112f ) + name "Terrifying 911 (China) (En) (Unl)" + description "Terrifying 911 (China) (En) (Unl)" + rom ( name "Terrifying 911 (China) (En) (Unl).gbc" size 2097152 crc 188b06f8 sha1 a16c065525f52a90d7081f253e613452f7ed757a ) ) game ( - name "Pokemon Gold (Taiwan) (En) (Unl)" - description "Pokemon Gold (Taiwan) (En) (Unl)" - rom ( name "Pokemon Gold (Taiwan) (En) (Unl).gbc" size 1048576 crc 479f3c4e sha1 26503e3262022be29b845a0b2ba555013d8ad12f ) + name "Test Drive 2001 (USA)" + description "Test Drive 2001 (USA)" + rom ( name "Test Drive 2001 (USA).gbc" size 2097152 crc bb894ec7 sha1 8b34597b90d048c3d483acba60ebb49f86bd93cc ) ) game ( - name "Pokemon Gold Version 2 (Taiwan) (Unl)" - description "Pokemon Gold Version 2 (Taiwan) (Unl)" - rom ( name "Pokemon Gold Version 2 (Taiwan) (Unl).gbc" size 524288 crc 5eab2b1e sha1 9e14a8c897b921e177ae4a3efc71125d1e91cc30 ) + name "Test Drive 6 (Europe) (En,Fr,De,Es,It) (GB Compatible)" + description "Test Drive 6 (Europe) (En,Fr,De,Es,It) (GB Compatible)" + rom ( name "Test Drive 6 (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc 13691ceb sha1 92e5b9911032e0b810fcb0b76a94bb117bcf107e ) ) game ( - name "Pokemon Jade (Taiwan) (En) (Pirate)" - description "Pokemon Jade (Taiwan) (En) (Pirate)" - rom ( name "Pokemon Jade (Taiwan) (En) (Pirate).gbc" size 2097152 crc aa07f269 sha1 994a205d7c0b55f45715a65b23ec31258e43652f ) + name "Test Drive 6 (Europe) (En,Fr,De,Es,It) (Sample) (GB Compatible)" + description "Test Drive 6 (Europe) (En,Fr,De,Es,It) (Sample) (GB Compatible)" + rom ( name "Test Drive 6 (Europe) (En,Fr,De,Es,It) (Sample) (GB Compatible).gbc" size 1048576 crc 2f179045 sha1 f50415339a36ecea8a1207b6c197086372e29ab7 ) ) game ( - name "Pokemon Jade Version - Special Pikachu Edition (USA) (Pirate)" - description "Pokemon Jade Version - Special Pikachu Edition (USA) (Pirate)" - rom ( name "Pokemon Jade Version - Special Pikachu Edition (USA) (Pirate).gbc" size 524288 crc e9488e13 sha1 254355aac31a6a75481a6a14c5c5cae1e4f41adf ) + name "Test Drive 6 (USA) (GB Compatible)" + description "Test Drive 6 (USA) (GB Compatible)" + rom ( name "Test Drive 6 (USA) (GB Compatible).gbc" size 1048576 crc 5ce00547 sha1 43ea5758fc6747014f024b567f5768ef43d5c841 ) ) game ( - name "Pokemon Pearl (Taiwan) (En) (Unl)" - description "Pokemon Pearl (Taiwan) (En) (Unl)" - rom ( name "Pokemon Pearl (Taiwan) (En) (Unl).gbc" size 524288 crc e2f527ff sha1 31551ca917a6df7d645f0b7dde1efd2d7a0485e6 ) + name "Test Drive 6 (USA) (Rev 1) (Proto)" + description "Test Drive 6 (USA) (Rev 1) (Proto)" + rom ( name "Test Drive 6 (USA) (Rev 1) (Proto).gbc" size 1048576 crc 5333c5db sha1 f9519940ed05bdb59cd3878db8c479760d93a5bd ) ) game ( - name "Pokemon Picross (Japan) (Proto)" - description "Pokemon Picross (Japan) (Proto)" - rom ( name "Pokemon Picross (Japan) (Proto).gbc" size 2097152 crc cf647f4b sha1 8204064b7149357939b57342820e7955749183b6 ) + name "Test Drive Cycles (USA)" + description "Test Drive Cycles (USA)" + rom ( name "Test Drive Cycles (USA).gbc" size 1048576 crc e32bb06f sha1 e9242949661fb34ce6d6fd521b04eb1926ead070 ) ) game ( - name "Pokemon Pinball (Europe) (En,Fr,De,Es,It) (Rumble Version) (SGB Enhanced) (GB Compatible)" - description "Pokemon Pinball (Europe) (En,Fr,De,Es,It) (Rumble Version) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon Pinball (Europe) (En,Fr,De,Es,It) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 39c432a4 sha1 24c693b8048594e2bf61ec1dc2182e75d81e532d flags verified ) + name "Test Drive Le Mans (USA) (En,Fr,Es)" + description "Test Drive Le Mans (USA) (En,Fr,Es)" + rom ( name "Test Drive Le Mans (USA) (En,Fr,Es).gbc" size 1048576 crc e6d6ac8f sha1 bf007bf9c22633d67b7b46aef656d136dd2d9b25 ) ) game ( - name "Pokemon Pinball (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" - description "Pokemon Pinball (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon Pinball (Japan) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 13c70de9 sha1 96d0d854b9b49d724cd1dcbacd6313f0fc6c1c10 flags verified ) + name "Test Drive Off-Road 3 (USA) (Rumble Version) (SGB Enhanced) (GB Compatible)" + description "Test Drive Off-Road 3 (USA) (Rumble Version) (SGB Enhanced) (GB Compatible)" + rom ( name "Test Drive Off-Road 3 (USA) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0fdd5b9e sha1 71b425cbc02fa20b1f28a7612e7ac259bd1338b0 ) ) game ( - name "Pokemon Pinball (USA, Australia) (Rumble Version) (SGB Enhanced) (GB Compatible)" - description "Pokemon Pinball (USA, Australia) (Rumble Version) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon Pinball (USA, Australia) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 03ce8d9a sha1 9402014d14969432142abfde728c6f1a10ee4dac flags verified ) + name "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan)" + description "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan)" + rom ( name "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan).gbc" size 1048576 crc eaf6e4f2 sha1 aa7dd2044a7e1535da67d7b9439e9771f736086a flags verified ) ) game ( - name "Pokemon Puzzle Challenge (Europe) (En,Fr,De,Es,It)" - description "Pokemon Puzzle Challenge (Europe) (En,Fr,De,Es,It)" - rom ( name "Pokemon Puzzle Challenge (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 8206b1ce sha1 e40d6a7f78b449e5a55baaaea7e227ab19d510e4 ) + name "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan) (Rev 1)" + description "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan) (Rev 1)" + rom ( name "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan) (Rev 1).gbc" size 1048576 crc b7c0831f sha1 a8842e85f2c6de4db40b47c9640dad59ae9d1c51 ) ) game ( - name "Pokemon Puzzle Challenge (USA, Australia)" - description "Pokemon Puzzle Challenge (USA, Australia)" - rom ( name "Pokemon Puzzle Challenge (USA, Australia).gbc" size 2097152 crc d06bba96 sha1 bbf952412250ae511b3b862566e424ce6a672f99 flags verified ) + name "Tetris DX (World) (SGB Enhanced) (GB Compatible)" + description "Tetris DX (World) (SGB Enhanced) (GB Compatible)" + rom ( name "Tetris DX (World) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc 69989152 sha1 7183bcb54dd35f3a07d8fe63339b768f13b8168d flags verified ) ) game ( - name "Pokemon Trading Card Game (Europe) (En,Es,It) (SGB Enhanced) (GB Compatible)" - description "Pokemon Trading Card Game (Europe) (En,Es,It) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon Trading Card Game (Europe) (En,Es,It) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 966daef1 sha1 2138a422d135a13c49fce71229ae36bc1dc4fbb5 ) + name "Tezhong Budui (Taiwan) (Unl)" + description "Tezhong Budui (Taiwan) (Unl)" + rom ( name "Tezhong Budui (Taiwan) (Unl).gbc" size 1048576 crc a658d85e sha1 3b5e765dbda9b355a6ea9ab7920d31f4169fa1d3 ) ) game ( - name "Pokemon Trading Card Game (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - description "Pokemon Trading Card Game (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon Trading Card Game (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 4523376e sha1 868e7b376e39f7d65a735538d90fbe6bbc99d198 flags verified ) + name "Tezhong Budui (Taiwan) (Unl) (Alt) [b]" + description "Tezhong Budui (Taiwan) (Unl) (Alt) [b]" + rom ( name "Tezhong Budui (Taiwan) (Unl) (Alt) [b].gbc" size 1048576 crc bf0028d9 sha1 99f536400bb99892b736f66305e1b11d8229c668 flags baddump ) ) game ( - name "Pokemon Trading Card Game (USA, Australia) (SGB Enhanced) (GB Compatible)" - description "Pokemon Trading Card Game (USA, Australia) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon Trading Card Game (USA, Australia) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 81069d53 sha1 0f8670a583255cff3e5b7ca71b5d7454d928fc48 flags verified ) + name "Tezhong Budui 2 - Jidi (Taiwan) (Unl)" + description "Tezhong Budui 2 - Jidi (Taiwan) (Unl)" + rom ( name "Tezhong Budui 2 - Jidi (Taiwan) (Unl).gbc" size 2097152 crc a2c4f7b3 sha1 5b516c6ce57eed1791a9c20184357c583febdcb8 ) ) game ( - name "Pokemon Trading Card Game (Europe) (En,Fr,De) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Pokemon Trading Card Game (Europe) (En,Fr,De) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon Trading Card Game (Europe) (En,Fr,De) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 942d0b7f sha1 dffc15f3063a4c2df84c6361406b41aec1696d3e flags verified ) + name "TG Rally 2 (United Kingdom)" + description "TG Rally 2 (United Kingdom)" + rom ( name "TG Rally 2 (United Kingdom).gbc" size 1048576 crc 795a9992 sha1 906f886c19c4800a7ac2612951e03a092665b22c ) ) game ( - name "Pokemon Trading Card Game (Europe) (En,Es,It) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Pokemon Trading Card Game (Europe) (En,Es,It) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Pokemon Trading Card Game (Europe) (En,Es,It) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 3f1d7e58 sha1 c54b81e638b0c45d3569f9f5f0345df9e95ce975 ) + name "Three Lions (United Kingdom) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + description "Three Lions (United Kingdom) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" + rom ( name "Three Lions (United Kingdom) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 1048576 crc 1cbea1aa sha1 d6d4eb47595b72c9c3ad77b5f9fa85b76f0acf4c ) ) game ( - name "Pokemon Vision Jade (Taiwan) (De) (Unl)" - description "Pokemon Vision Jade (Taiwan) (De) (Unl)" - rom ( name "Pokemon Vision Jade (Taiwan) (De) (Unl).gbc" size 2097152 crc 2705ca20 sha1 72d5c6b8a570e67e7bce59070417cb89e985efb0 ) + name "Thunder Blast Man (Europe) (Sachen) (Unl)" + description "Thunder Blast Man (Europe) (Sachen) (Unl)" + rom ( name "Thunder Blast Man (Europe) (Sachen) (Unl).gbc" size 262144 crc 1a719ead sha1 676b5f0a304fb83bc04921bc617b7485af529b38 flags verified ) ) game ( - name "Pokettohiro! (World) (v2.0) (Demo) (Aftermarket) (Unl)" - description "Pokettohiro! (World) (v2.0) (Demo) (Aftermarket) (Unl)" - rom ( name "Pokettohiro! (World) (v2.0) (Demo) (Aftermarket) (Unl).gbc" size 1048576 crc 42298fd8 sha1 90c535bf70e2ca7b91af67b8f08865f423c3034f ) + name "Thunderbirds (Europe)" + description "Thunderbirds (Europe)" + rom ( name "Thunderbirds (Europe).gbc" size 2097152 crc b5bececf sha1 4df8353cbb74d368cc139899eabe5288e59adaeb ) ) game ( - name "Pokettohiro! (World) (Demo) (Aftermarket) (Unl)" - description "Pokettohiro! (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Pokettohiro! (World) (Demo) (Aftermarket) (Unl).gbc" size 1048576 crc b9e724ef sha1 28a01fd6ea95a146008435c5bc27b51b607bb86b ) + name "Thunderbirds (Europe) (En,Fr,De,Es,It)" + description "Thunderbirds (Europe) (En,Fr,De,Es,It)" + rom ( name "Thunderbirds (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 36536324 sha1 8c7585e41b8e38f4bc76ba315dc5e7a768c0c516 ) ) game ( - name "Polaris SnoCross (USA) (Rumble Version)" - description "Polaris SnoCross (USA) (Rumble Version)" - rom ( name "Polaris SnoCross (USA) (Rumble Version).gbc" size 1048576 crc dd8b189e sha1 e893808fe227a1608c0604382d6a0340ec704c3b flags verified ) + name "Tiger Woods PGA Tour 2000 (USA, Europe) (GB Compatible)" + description "Tiger Woods PGA Tour 2000 (USA, Europe) (GB Compatible)" + rom ( name "Tiger Woods PGA Tour 2000 (USA, Europe) (GB Compatible).gbc" size 1048576 crc a6dfb1d9 sha1 46e81d5e7d4f41b3b0a0ab8b55a3592abe6911f3 flags verified ) ) game ( - name "Polaris SnoCross (USA) (Beta) (Rumble Version)" - description "Polaris SnoCross (USA) (Beta) (Rumble Version)" - rom ( name "Polaris SnoCross (USA) (Beta) (Rumble Version).gbc" size 1048576 crc 673623c4 sha1 4176ef1f9fd37156a4cac37a2d146ed2deeb5a7b ) + name "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De) (Beta)" + description "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De) (Beta)" + rom ( name "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De) (Beta).gbc" size 1048576 crc 94aed620 sha1 8c29d9135fcf3c74397da8b0898af07d0b3b7955 ) ) game ( - name "Pong - The Next Level (USA, Europe)" - description "Pong - The Next Level (USA, Europe)" - rom ( name "Pong - The Next Level (USA, Europe).gbc" size 1048576 crc 476bd39d sha1 637827a89a0948f6561bf2a018de6244e2811a99 flags verified ) + name "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De)" + description "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De)" + rom ( name "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De).gbc" size 1048576 crc b2205d49 sha1 34ab01951490a9510a3e0d3493d25a2547761aea ) ) game ( - name "Pooh and Tigger's Hunny Safari (Europe) (En,Fr,De,Es,It,Nl)" - description "Pooh and Tigger's Hunny Safari (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Pooh and Tigger's Hunny Safari (Europe) (En,Fr,De,Es,It,Nl).gbc" size 2097152 crc 8505d139 sha1 4141887f0b152f8592b905355e11cf43147128c2 ) + name "Tintin au Tibet (Europe) (En,Fr,De,Es,It,Nl,Sv)" + description "Tintin au Tibet (Europe) (En,Fr,De,Es,It,Nl,Sv)" + rom ( name "Tintin au Tibet (Europe) (En,Fr,De,Es,It,Nl,Sv).gbc" size 1048576 crc 6832f38a sha1 eef17d4a827efab90c03083edb0bee534cd64188 ) ) game ( - name "Pooh and Tigger's Hunny Safari (USA)" - description "Pooh and Tigger's Hunny Safari (USA)" - rom ( name "Pooh and Tigger's Hunny Safari (USA).gbc" size 2097152 crc 622690da sha1 934918da6249723760a356748bf240f57262bd77 ) + name "Tiny Toon Adventures - Buster Saves the Day (Europe) (En,Fr,De,Es,It)" + description "Tiny Toon Adventures - Buster Saves the Day (Europe) (En,Fr,De,Es,It)" + rom ( name "Tiny Toon Adventures - Buster Saves the Day (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 7aa371ed sha1 3a30dc722739fbaa9924c855c83be311befc8ff2 ) ) game ( - name "Pop'n Music GB (Japan)" - description "Pop'n Music GB (Japan)" - rom ( name "Pop'n Music GB (Japan).gbc" size 1048576 crc 07e6ca95 sha1 f2b31ecdd1dbd3c7c120d436ed8d5e19743e9cf0 ) + name "Tiny Toon Adventures - Buster Saves the Day (USA)" + description "Tiny Toon Adventures - Buster Saves the Day (USA)" + rom ( name "Tiny Toon Adventures - Buster Saves the Day (USA).gbc" size 1048576 crc 800efb3d sha1 a3953e9ade5367558f7d430d2dfb83d06c361170 ) ) game ( - name "Pop'n Music GB - Animation Melody (Japan)" - description "Pop'n Music GB - Animation Melody (Japan)" - rom ( name "Pop'n Music GB - Animation Melody (Japan).gbc" size 1048576 crc 9b2429a7 sha1 f4442d7e984ebefc7735e205ca759c2be3bd1843 ) + name "Tiny Toon Adventures - Dizzy's Candy Quest (Europe) (En,Fr,De,Es,It,Nl)" + description "Tiny Toon Adventures - Dizzy's Candy Quest (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Tiny Toon Adventures - Dizzy's Candy Quest (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 5a0d41aa sha1 cf8948c148af76c00e7b6b557c5451d9be364f55 ) ) game ( - name "Pop'n Music GB - Disney Tunes (Japan)" - description "Pop'n Music GB - Disney Tunes (Japan)" - rom ( name "Pop'n Music GB - Disney Tunes (Japan).gbc" size 1048576 crc 48c3c6ef sha1 ff34d9d68c81b82a70ed11ac509ec5daaf29cd46 ) + name "Tiny Toon Adventures - Dizzy's Candy Quest (USA) (Proto)" + description "Tiny Toon Adventures - Dizzy's Candy Quest (USA) (Proto)" + rom ( name "Tiny Toon Adventures - Dizzy's Candy Quest (USA) (Proto).gbc" size 1048576 crc 23bb87a5 sha1 4eb0359a278173ae6c12e9452a7a2a9573a58c77 ) ) game ( - name "Pop'n Pop (Europe)" - description "Pop'n Pop (Europe)" - rom ( name "Pop'n Pop (Europe).gbc" size 1048576 crc fc67f7e4 sha1 5874cc64b184692ed03fb860de058fa3475b1d5c ) + name "Titi - Le Tour du Monde en 80 Chats (France)" + description "Titi - Le Tour du Monde en 80 Chats (France)" + rom ( name "Titi - Le Tour du Monde en 80 Chats (France).gbc" size 1048576 crc ce55ed18 sha1 1b3e161dcde3709cc4b26d6d753cb879ab75c8c0 ) ) game ( - name "Pop'n Pop (Japan)" - description "Pop'n Pop (Japan)" - rom ( name "Pop'n Pop (Japan).gbc" size 1048576 crc 1cffb764 sha1 ef425613296573225e42228ca12bce5124374206 ) + name "Titus the Fox (Europe) (GB Compatible)" + description "Titus the Fox (Europe) (GB Compatible)" + rom ( name "Titus the Fox (Europe) (GB Compatible).gbc" size 1048576 crc 2f9f19de sha1 b595c2e0a11bf843e91e9128e38252222133659b ) ) game ( - name "Portal Runner (USA)" - description "Portal Runner (USA)" - rom ( name "Portal Runner (USA).gbc" size 1048576 crc 913ac306 sha1 a8347366f15c0e454fa253bad5b4053d2a9613aa ) + name "Titus the Fox (USA) (GB Compatible)" + description "Titus the Fox (USA) (GB Compatible)" + rom ( name "Titus the Fox (USA) (GB Compatible).gbc" size 1048576 crc ba70d28f sha1 3ec16a3ce1cfdc03b6f3b04a455c8b5c54a37eee ) ) game ( - name "Postie (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "Postie (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Postie (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 50393a65 sha1 2c2c6ed8be7a13bf279e435c5984f175c8affcad ) + name "TNN Outdoors Fishing Champ (USA) (SGB Enhanced) (GB Compatible)" + description "TNN Outdoors Fishing Champ (USA) (SGB Enhanced) (GB Compatible)" + rom ( name "TNN Outdoors Fishing Champ (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 00a14d18 sha1 acfe7c9edd20f7d6b155deebc9428703edf28978 ) ) game ( - name "Postie (World) (GB Compatible) (Aftermarket) (Unl)" - description "Postie (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Postie (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ff6bbc83 sha1 3ff236972d1e344eb50e696db3cc090f2b5d28b1 ) + name "TOCA Touring Car Championship (USA, Europe)" + description "TOCA Touring Car Championship (USA, Europe)" + rom ( name "TOCA Touring Car Championship (USA, Europe).gbc" size 1048576 crc b509892b sha1 8a759a627b436c2b3941c3aa480e38488ad16197 ) ) game ( - name "Potbound (World) (2022-09-27) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "Potbound (World) (2022-09-27) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Potbound (World) (2022-09-27) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 6da19041 sha1 eb581935ad9223d723fdbc8339c03436df051947 ) + name "Toki Tori (USA, Europe) (En,Ja,Fr,De,Es)" + description "Toki Tori (USA, Europe) (En,Ja,Fr,De,Es)" + rom ( name "Toki Tori (USA, Europe) (En,Ja,Fr,De,Es).gbc" size 1048576 crc 0a0f9289 sha1 2025275bb55710594e990ab61cde622947a2fa8d ) ) game ( - name "Potbound (World) (2022-09-26) (Proto) (GBJam 10) (GB Compatible) (Aftermarket) (Unl)" - description "Potbound (World) (2022-09-26) (Proto) (GBJam 10) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Potbound (World) (2022-09-26) (Proto) (GBJam 10) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc d0d8386d sha1 fbddf81a1663388ff0efeeb9051e68e0c323c839 ) + name "Tokimeki Memorial Pocket - Culture Hen - Komorebi no Melody (Japan) (SGB Enhanced) (GB Compatible)" + description "Tokimeki Memorial Pocket - Culture Hen - Komorebi no Melody (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Tokimeki Memorial Pocket - Culture Hen - Komorebi no Melody (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 4be4a8ed sha1 0f64c4afe74b6cfd693b6c65f0168dcb26224443 ) ) game ( - name "POWA! (World) (En) (GB Compatible) (Aftermarket) (Unl)" - description "POWA! (World) (En) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "POWA! (World) (En) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f0191467 sha1 3876f1aa896759f427ad2dc88a48788817e60c06 flags verified ) + name "Tokimeki Memorial Pocket - Sport Hen - Koutei no Photograph (Japan) (SGB Enhanced) (GB Compatible)" + description "Tokimeki Memorial Pocket - Sport Hen - Koutei no Photograph (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Tokimeki Memorial Pocket - Sport Hen - Koutei no Photograph (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 78e14fa9 sha1 ce39fcf903bb3b0529205cab4a412bfa0e8a2ebf ) ) game ( - name "POWA! (World) (Ja) (GB Compatible) (Aftermarket) (Unl)" - description "POWA! (World) (Ja) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "POWA! (World) (Ja) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc e8f68acc sha1 156d315b7a2a035d5cd429fb8c7e051e67e83c93 flags verified ) + name "Tokoro-san no Setagaya C.C. (Japan) (GB Compatible)" + description "Tokoro-san no Setagaya C.C. (Japan) (GB Compatible)" + rom ( name "Tokoro-san no Setagaya C.C. (Japan) (GB Compatible).gbc" size 1048576 crc 9139e307 sha1 f38d776ff74d02c2edce0dcbc84edd5601ee315a ) ) game ( - name "POWA! (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "POWA! (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "POWA! (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 592b6097 sha1 874d5e4ffc7d36259bef6ec6a86a1de8289b8d54 ) + name "Tom and Jerry (USA, Europe)" + description "Tom and Jerry (USA, Europe)" + rom ( name "Tom and Jerry (USA, Europe).gbc" size 1048576 crc b97c0bd9 sha1 86d841e84c68e4d15f4bbf72f1aa0fddc86dcd34 ) ) game ( - name "Power Ball - Monster's Quest (World) (v1.04) (Demo) (GB Compatible) (Aftermarket) (Unl)" - description "Power Ball - Monster's Quest (World) (v1.04) (Demo) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Power Ball - Monster's Quest (World) (v1.04) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc b01c4ff1 sha1 898dbf10550af7e39b8f7a0818a78083ae40f4fe ) + name "Tom and Jerry - Mouse Hunt (USA) (En,Fr,Es)" + description "Tom and Jerry - Mouse Hunt (USA) (En,Fr,Es)" + rom ( name "Tom and Jerry - Mouse Hunt (USA) (En,Fr,Es).gbc" size 1048576 crc 5fc6bec0 sha1 99c71a51921d802a0fcaea1f67b54ef4ec653900 ) ) game ( - name "Power Pro Kun Pocket (Japan) (SGB Enhanced) (GB Compatible)" - description "Power Pro Kun Pocket (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Power Pro Kun Pocket (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 145540d8 sha1 f796f9cb259646555f0d429b9337ac6b423755a3 ) + name "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It)" + description "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It)" + rom ( name "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 3e17d04a sha1 6f837075d7493adcbd5b18ba1e27386b6fc31e62 ) ) game ( - name "Power Pro Kun Pocket (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Power Pro Kun Pocket (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Power Pro Kun Pocket (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 894d88f2 sha1 ae145f2de0d53c19b973c71baaf3f2cca2ca395a ) + name "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It) (Rev 1)" + description "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It) (Rev 1)" + rom ( name "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It) (Rev 1).gbc" size 1048576 crc 4b4553e0 sha1 bf5faf4c5c2aabe9636f8f5afbbf526aba59e21d ) ) game ( - name "Power Pro Kun Pocket 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Power Pro Kun Pocket 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Power Pro Kun Pocket 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc c2a4a3eb sha1 5c0ba404cf30296dceeb427a54e3644415c9e8db flags verified ) + name "Tom and Jerry in - Mouse Attacks! (Europe) (En,Fr,De,Es,It,Nl,Da)" + description "Tom and Jerry in - Mouse Attacks! (Europe) (En,Fr,De,Es,It,Nl,Da)" + rom ( name "Tom and Jerry in - Mouse Attacks! (Europe) (En,Fr,De,Es,It,Nl,Da).gbc" size 2097152 crc 9d9c84f4 sha1 ff3a39ccdf4e9802b38c3095d4a2ae056defc476 ) ) game ( - name "Power Quest (Europe) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" - description "Power Quest (Europe) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" - rom ( name "Power Quest (Europe) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 30e1e567 sha1 b9b41a90baba13888ac8f3788b96935f4d394c2c flags verified ) + name "Tom and Jerry in - Mouse Attacks! (USA)" + description "Tom and Jerry in - Mouse Attacks! (USA)" + rom ( name "Tom and Jerry in - Mouse Attacks! (USA).gbc" size 2097152 crc 38ce3f76 sha1 a58215e2c6240b42779665d85484f02b79a0f9d8 ) ) game ( - name "Power Quest (USA) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" - description "Power Quest (USA) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible)" - rom ( name "Power Quest (USA) (En-US,En-GB,Fr,De,Es,It) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc dad6f6b4 sha1 d1665784a007c122d65f43bd2751db6b395ff3cd ) + name "Tom and Jerry in - Mouse Attacks! (USA) (Rev 1)" + description "Tom and Jerry in - Mouse Attacks! (USA) (Rev 1)" + rom ( name "Tom and Jerry in - Mouse Attacks! (USA) (Rev 1).gbc" size 2097152 crc ce4ca7b1 sha1 89374d81045a3bedf24e42b58ce403b0a5fbcddb ) ) game ( - name "Power Spike - Pro Beach Volleyball (USA)" - description "Power Spike - Pro Beach Volleyball (USA)" - rom ( name "Power Spike - Pro Beach Volleyball (USA).gbc" size 1048576 crc ae57d1c3 sha1 cbf7377e2dfea331f983b34486ab7761ac75e3ac ) + name "Tom Clancy's Rainbow Six (USA, Europe) (En,Fr,De)" + description "Tom Clancy's Rainbow Six (USA, Europe) (En,Fr,De)" + rom ( name "Tom Clancy's Rainbow Six (USA, Europe) (En,Fr,De).gbc" size 1048576 crc e72f2683 sha1 7e9e21db84d1bfdab3c604c9e3328f624f86a9b1 flags verified ) ) game ( - name "Powerpuff Girls, The - Bad Mojo Jojo (USA)" - description "Powerpuff Girls, The - Bad Mojo Jojo (USA)" - rom ( name "Powerpuff Girls, The - Bad Mojo Jojo (USA).gbc" size 2097152 crc 834caf7a sha1 92d86ec01e8669bbb8d26a5ec51efc0f761eeaf4 ) + name "Tomb Raider (USA, Europe) (En,Fr,De,Es,It)" + description "Tomb Raider (USA, Europe) (En,Fr,De,Es,It)" + rom ( name "Tomb Raider (USA, Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 2988fc78 sha1 208b054ca63c43f32befa989c75e8de96847f4fe flags verified ) ) game ( - name "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 1)" - description "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 1)" - rom ( name "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 1).gbc" size 2097152 crc 548a287a sha1 d3f74815bec29ae7d580b112a1c1f913c19ac89e ) + name "Tomb Raider (USA, Europe) (En,Fr,De,Es,It) (Beta)" + description "Tomb Raider (USA, Europe) (En,Fr,De,Es,It) (Beta)" + rom ( name "Tomb Raider (USA, Europe) (En,Fr,De,Es,It) (Beta).gbc" size 4194304 crc 58590868 sha1 3f7259e9def8be46e9b1f2956182084276f105ed ) ) game ( - name "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 2)" - description "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 2)" - rom ( name "Powerpuff Girls, The - Bad Mojo Jojo (USA) (Rev 2).gbc" size 2097152 crc a111704f sha1 98f46abbd8792bf716928bf2e28af94af467ef51 flags verified ) + name "Tomb Raider (Taiwan) (Unl)" + description "Tomb Raider (Taiwan) (Unl)" + rom ( name "Tomb Raider (Taiwan) (Unl).gbc" size 4194304 crc 269f0852 sha1 a4728de2368561ffeb8ecec6077494df64b463d4 ) ) game ( - name "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJP)" - description "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJP)" - rom ( name "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJP).gbc" size 2097152 crc 75d1063a sha1 e1fde0d5c3f428a0932a2ceeac1889ebcabc3f7e ) + name "Tomb Raider - Curse of the Sword (USA, Europe)" + description "Tomb Raider - Curse of the Sword (USA, Europe)" + rom ( name "Tomb Raider - Curse of the Sword (USA, Europe).gbc" size 4194304 crc 02c1035a sha1 c84db1eaf7403ba292be020d410ab453342ab737 flags verified ) ) game ( - name "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJX) (Proto)" - description "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJX) (Proto)" - rom ( name "Powerpuff Girls, The - Bad Mojo Jojo (Europe) (BJJX) (Proto).gbc" size 2097152 crc 24b23af1 sha1 cffa029b5aa51b2ce1c192e66bd2881eddd532fd ) + name "Tomb Raider 2 (Taiwan) (Unl)" + description "Tomb Raider 2 (Taiwan) (Unl)" + rom ( name "Tomb Raider 2 (Taiwan) (Unl).gbc" size 4194304 crc 717a5d19 sha1 5b9325b6e322a806677c6ea37a0054381609b99e ) ) game ( - name "Powerpuff Girls, The - Battle Him (Europe)" - description "Powerpuff Girls, The - Battle Him (Europe)" - rom ( name "Powerpuff Girls, The - Battle Him (Europe).gbc" size 2097152 crc 788859ae sha1 9d2cbe85c7c0da6ea4354822f85cd597bfaff1c5 ) + name "Tonic Trouble (Europe) (En,Fr,De,Es,It,Nl)" + description "Tonic Trouble (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Tonic Trouble (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc a8628f7a sha1 d9ed647746cf23f2f9c7448d682ac34bb7f2ec1c ) ) game ( - name "Powerpuff Girls, The - Battle Him (USA)" - description "Powerpuff Girls, The - Battle Him (USA)" - rom ( name "Powerpuff Girls, The - Battle Him (USA).gbc" size 2097152 crc d8455984 sha1 3d90946a2cbe503d040b10958301587998d4e86f ) + name "Tonka Construction Site (USA)" + description "Tonka Construction Site (USA)" + rom ( name "Tonka Construction Site (USA).gbc" size 1048576 crc 8142a3e8 sha1 19e6fb8b61ec20025061b2703079db926be93c96 ) ) game ( - name "Powerpuff Girls, The - Battle Him (USA) (Rev 1)" - description "Powerpuff Girls, The - Battle Him (USA) (Rev 1)" - rom ( name "Powerpuff Girls, The - Battle Him (USA) (Rev 1).gbc" size 2097152 crc e3d6964c sha1 8f22b2cd9552eb1146f0a78a9c9242c031046e1c ) + name "Tonka Construction Site (USA) (Beta)" + description "Tonka Construction Site (USA) (Beta)" + rom ( name "Tonka Construction Site (USA) (Beta).gbc" size 1048576 crc 901faa34 sha1 16fc094ef9a0af8376fedd6b7e6179d33c4f78bf ) ) game ( - name "Powerpuff Girls, The - Bulle Contre Lui (France)" - description "Powerpuff Girls, The - Bulle Contre Lui (France)" - rom ( name "Powerpuff Girls, The - Bulle Contre Lui (France).gbc" size 2097152 crc 7085270c sha1 5c1c53b9c002680c2da8b24aa31d4a247586263d ) + name "Tonka Raceway (Europe)" + description "Tonka Raceway (Europe)" + rom ( name "Tonka Raceway (Europe).gbc" size 1048576 crc e108b2c2 sha1 ec52838e58d33a3ed36cd0f80f287ef72a578624 ) ) game ( - name "Powerpuff Girls, The - Il Terribile Mojo Jojo (Italy) (Proto)" - description "Powerpuff Girls, The - Il Terribile Mojo Jojo (Italy) (Proto)" - rom ( name "Powerpuff Girls, The - Il Terribile Mojo Jojo (Italy) (Proto).gbc" size 2097152 crc 5c265103 sha1 5ca837632930689fad9086b772928bf5995193f9 ) + name "Tonka Raceway (USA)" + description "Tonka Raceway (USA)" + rom ( name "Tonka Raceway (USA).gbc" size 1048576 crc bc07f4fb sha1 9159b2ffe1ecf2a1a8f6af976e2737c0b22cea6d ) ) game ( - name "Powerpuff Girls, The - L'Affreux Mojo Jojo (France)" - description "Powerpuff Girls, The - L'Affreux Mojo Jojo (France)" - rom ( name "Powerpuff Girls, The - L'Affreux Mojo Jojo (France).gbc" size 2097152 crc 256d166f sha1 1b5037f53fb77dd2c9c359052d46e5362c6a9801 ) + name "Tonka Raceway (USA) (Rumble Version)" + description "Tonka Raceway (USA) (Rumble Version)" + rom ( name "Tonka Raceway (USA) (Rumble Version).gbc" size 1048576 crc a5af4b28 sha1 6a86b7172c53a8e67f3d72f953116991640f6e71 flags verified ) ) game ( - name "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 1)" - description "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 1)" - rom ( name "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 1).gbc" size 2097152 crc 295b3646 sha1 023d4d9374e7fe9844f970dd0004c5d7eefd2d38 flags verified ) + name "Tony Hawk's Pro Skater (USA, Europe)" + description "Tony Hawk's Pro Skater (USA, Europe)" + rom ( name "Tony Hawk's Pro Skater (USA, Europe).gbc" size 1048576 crc 8d8bb5c4 sha1 44236627939371a6db564852f0536f969b21595e flags verified ) ) game ( - name "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTP)" - description "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTP)" - rom ( name "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTP).gbc" size 2097152 crc 98e4b0c4 sha1 e214ab665ffab3682b9833b4e4d0494fc53cd26f flags verified ) + name "Tony Hawk's Pro Skater (Japan) (Proto)" + description "Tony Hawk's Pro Skater (Japan) (Proto)" + rom ( name "Tony Hawk's Pro Skater (Japan) (Proto).gbc" size 1048576 crc 48f17f97 sha1 e399c7d67e3bb1f466002f24f60b9c036e234c4e ) ) game ( - name "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTX) (Proto)" - description "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTX) (Proto)" - rom ( name "Powerpuff Girls, The - Paint the Townsville Green (Europe) (BPTX) (Proto).gbc" size 2097152 crc 310b52f7 sha1 6522029f585c6ab4b5ca342e2127f6403e735222 ) + name "Tony Hawk's Pro Skater 2 (USA, Europe)" + description "Tony Hawk's Pro Skater 2 (USA, Europe)" + rom ( name "Tony Hawk's Pro Skater 2 (USA, Europe).gbc" size 2097152 crc 2c27c61f sha1 300fe89f98711853bee86ccd81481d55b5097b2d flags verified ) ) game ( - name "Powerpuff Girls, The - Paint the Townsville Green (USA)" - description "Powerpuff Girls, The - Paint the Townsville Green (USA)" - rom ( name "Powerpuff Girls, The - Paint the Townsville Green (USA).gbc" size 2097152 crc 9d47261a sha1 2d52551fce2cb6d246c6296beeb6a8a3dfbc2159 ) + name "Tony Hawk's Pro Skater 3 (USA, Europe)" + description "Tony Hawk's Pro Skater 3 (USA, Europe)" + rom ( name "Tony Hawk's Pro Skater 3 (USA, Europe).gbc" size 1048576 crc fd5290a1 sha1 bd210707df413d97eaa1d5b050f3a1b859c30c5e flags verified ) ) game ( - name "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 2)" - description "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 2)" - rom ( name "Powerpuff Girls, The - Paint the Townsville Green (USA) (Rev 2).gbc" size 2097152 crc 443367ae sha1 ef93e793067bbb3748aac17d661c8c8b68ccee9b ) + name "Toobin' (USA)" + description "Toobin' (USA)" + rom ( name "Toobin' (USA).gbc" size 1048576 crc 3d6b598c sha1 ba5a1889f63ac13a1081885f0fcbe4c351c63fea ) ) game ( - name "Powerpuff Girls, The - Panique a Townsville (France)" - description "Powerpuff Girls, The - Panique a Townsville (France)" - rom ( name "Powerpuff Girls, The - Panique a Townsville (France).gbc" size 2097152 crc 79a417db sha1 978d68300b625d8e375571475b4f2c2c1a65fd60 flags verified ) + name "Toonsylvania (Europe) (En,Fr,De,Es,It,Nl)" + description "Toonsylvania (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Toonsylvania (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 6573b88f sha1 48943f0f5d47444889f78da7ee0472d9b42dbc89 ) ) game ( - name "Primera Division Stars 2001 (Spain) (Proto)" - description "Primera Division Stars 2001 (Spain) (Proto)" - rom ( name "Primera Division Stars 2001 (Spain) (Proto).gbc" size 1048576 crc ce3a1022 sha1 ea2c721c905404a5a90e12eca598570d95e2812f ) + name "Toonsylvania (USA)" + description "Toonsylvania (USA)" + rom ( name "Toonsylvania (USA).gbc" size 1048576 crc 096d0c27 sha1 5665f54d1ce0b1e0ef72d8f71a14594920adf81d ) ) game ( - name "Prince Naseem Boxing (Europe) (En,Fr,De)" - description "Prince Naseem Boxing (Europe) (En,Fr,De)" - rom ( name "Prince Naseem Boxing (Europe) (En,Fr,De).gbc" size 2097152 crc 91def753 sha1 f0500b3ca8a24b3bd2c11e77fbe4c75db178dfbe ) + name "Tootuff (Europe) (En,Fr,De,Es,It,Nl)" + description "Tootuff (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Tootuff (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 1972cbf7 sha1 e38c16213c6bb0c1511ade138e3e8eeabd7b8898 ) ) game ( - name "Prince of Persia (USA, Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "Prince of Persia (USA, Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Prince of Persia (USA, Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc e6bec6d1 sha1 ef2f6402e8ef367273200e3b07f310ebd80ccdc2 flags verified ) + name "Tootuff (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + description "Tootuff (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + rom ( name "Tootuff (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 1048576 crc 709f4ad6 sha1 f71f380f9c68c42fc1461532ca92bffaa301da4d ) ) game ( - name "Prince of Persia (Japan) (Proto)" - description "Prince of Persia (Japan) (Proto)" - rom ( name "Prince of Persia (Japan) (Proto).gbc" size 1048576 crc d7dbbe1e sha1 6fd97e1f75570e7568b3dc4ab28834813afb4484 ) + name "Top Gear Pocket (Japan) (En) (Rumble Version)" + description "Top Gear Pocket (Japan) (En) (Rumble Version)" + rom ( name "Top Gear Pocket (Japan) (En) (Rumble Version).gbc" size 1048576 crc ebcca3da sha1 19c861e8ce24c18f8c625c8b920aad8a0acfce64 ) ) game ( - name "Princess Poffin and the Spider Invasion! (World) (2023-06-04) (GB Compatible) (Aftermarket) (Unl)" - description "Princess Poffin and the Spider Invasion! (World) (2023-06-04) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Princess Poffin and the Spider Invasion! (World) (2023-06-04) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc a86cada1 sha1 b02096c489c0f36582061d6eb62beb17e8294b61 ) + name "Top Gear Pocket (USA) (Rumble Version)" + description "Top Gear Pocket (USA) (Rumble Version)" + rom ( name "Top Gear Pocket (USA) (Rumble Version).gbc" size 1048576 crc 84499fc1 sha1 f875f5a637fb861a0845b1753b90fe053d0a5a95 ) ) game ( - name "Princess Poffin and the Spider Invasion! (World) (2023-06-06) (GB Compatible) (Aftermarket) (Unl)" - description "Princess Poffin and the Spider Invasion! (World) (2023-06-06) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Princess Poffin and the Spider Invasion! (World) (2023-06-06) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc e171f327 sha1 b03df48f48529ac1be79699d6f34f324adcfb436 ) + name "Top Gear Pocket 2 (Japan) (Rumble Version)" + description "Top Gear Pocket 2 (Japan) (Rumble Version)" + rom ( name "Top Gear Pocket 2 (Japan) (Rumble Version).gbc" size 1048576 crc 1845f25a sha1 26a357b6df4484d8f98f9c89a0b1b0357df5cf88 ) ) game ( - name "Pro Darts (USA)" - description "Pro Darts (USA)" - rom ( name "Pro Darts (USA).gbc" size 1048576 crc 834a72c0 sha1 60a89486f747e7440a79774b280b24b6498ef5ea ) + name "Top Gear Pocket 2 (USA)" + description "Top Gear Pocket 2 (USA)" + rom ( name "Top Gear Pocket 2 (USA).gbc" size 1048576 crc efb87f80 sha1 bdbb64d13c3c40992d923829a92d7a15a15aabea ) ) game ( - name "Pro Foot (France) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - description "Pro Foot (France) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - rom ( name "Pro Foot (France) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 1048576 crc a9905932 sha1 c43daa82286d3a910a6a922d4ea722c594a2cde0 ) + name "Top Gear Pocket 2 (USA) (Rev 1) (Proto)" + description "Top Gear Pocket 2 (USA) (Rev 1) (Proto)" + rom ( name "Top Gear Pocket 2 (USA) (Rev 1) (Proto).gbc" size 1048576 crc eb0838d6 sha1 5d2ea0b976833f2e3866214e602993ee4653ab96 ) ) game ( - name "Pro Mahjong Kiwame II GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Pro Mahjong Kiwame II GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pro Mahjong Kiwame II GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 14f91f86 sha1 2c9c2967400ab9bad95ffe104763b3190f28aa39 ) + name "Top Gear Pocket 2 (Japan) (Rev 1) (Proto) (Rumble Version)" + description "Top Gear Pocket 2 (Japan) (Rev 1) (Proto) (Rumble Version)" + rom ( name "Top Gear Pocket 2 (Japan) (Rev 1) (Proto) (Rumble Version).gbc" size 1048576 crc fc680273 sha1 52354d36a301b26895eb26ecf152bf696656f4b2 ) ) game ( - name "Pro Mahjong Tsuwamono GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Pro Mahjong Tsuwamono GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Pro Mahjong Tsuwamono GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1461d8d8 sha1 b9e7cd7e53fda3db329c57971a47d35255bd0b34 ) + name "Top Gear Rally (Europe) (Rumble Version)" + description "Top Gear Rally (Europe) (Rumble Version)" + rom ( name "Top Gear Rally (Europe) (Rumble Version).gbc" size 1048576 crc 337e5dd3 sha1 b880f5cfde3724da3ff932bf766cee470c4f664c flags verified ) ) game ( - name "Pro Mahjong Tsuwamono GB 2 (Japan)" - description "Pro Mahjong Tsuwamono GB 2 (Japan)" - rom ( name "Pro Mahjong Tsuwamono GB 2 (Japan).gbc" size 1048576 crc f03016f5 sha1 3e49a76d36c39e9a4248a12f88a08ab3e30c96ba ) + name "Top Gear Rally 2 (Europe)" + description "Top Gear Rally 2 (Europe)" + rom ( name "Top Gear Rally 2 (Europe).gbc" size 1048576 crc 017773cd sha1 5a0ac4ace1d5c2b6dfc0bdd20d6f88f319493558 ) ) game ( - name "Pro Pool (USA) (En,Fr,De) (Beta)" - description "Pro Pool (USA) (En,Fr,De) (Beta)" - rom ( name "Pro Pool (USA) (En,Fr,De) (Beta).gbc" size 1048576 crc 04d3031a sha1 56252a97a3d463103e1047a6e1a64cad43bedd4c ) + name "Top Gun - Fire Storm (USA, Europe) (En,Fr,De,Es,It,Nl)" + description "Top Gun - Fire Storm (USA, Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Top Gun - Fire Storm (USA, Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc e2ad5a0f sha1 bad3f0770e7595ad7b4fd68d8212a902974fe1e1 ) ) game ( - name "Pro Pool (Europe) (En,Fr,De)" - description "Pro Pool (Europe) (En,Fr,De)" - rom ( name "Pro Pool (Europe) (En,Fr,De).gbc" size 1048576 crc 21a4da64 sha1 575c02f73a0bdc357289073f053d8a3969927880 ) + name "Totsugeki! Papparatai (Japan) (SGB Enhanced) (GB Compatible)" + description "Totsugeki! Papparatai (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Totsugeki! Papparatai (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 0aeae8fb sha1 4c98beab325cd058445102c85d30b3724325f2ce ) ) game ( - name "Pro Pool (USA) (En,Fr,De)" - description "Pro Pool (USA) (En,Fr,De)" - rom ( name "Pro Pool (USA) (En,Fr,De).gbc" size 1048576 crc 2611fa3d sha1 c85e514c24c82071907c6495243dae448b46c2b2 ) + name "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan)" + description "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan)" + rom ( name "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan).gbc" size 1048576 crc 19eb4516 sha1 fed38c5131a00f0bbf00ff2a974a8e457373aba6 ) ) game ( - name "Project S-11 (USA)" - description "Project S-11 (USA)" - rom ( name "Project S-11 (USA).gbc" size 524288 crc 20cee2e8 sha1 cbedd34a0c6a2f4e58d05f0bb6d54f7cbcda815c ) + name "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan) (Rev 1)" + description "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan) (Rev 1)" + rom ( name "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan) (Rev 1).gbc" size 1048576 crc d549e074 sha1 369f53d1a8bc7e6f2d1ccd101e648c2744c39fc5 flags verified ) ) game ( - name "Proof of Destruction (World) (Aftermarket) (Unl)" - description "Proof of Destruction (World) (Aftermarket) (Unl)" - rom ( name "Proof of Destruction (World) (Aftermarket) (Unl).gbc" size 262144 crc fa528f88 sha1 5062f16346c31cae1b13e469cb610ce84d4eecb2 ) + name "Tottoko Hamutarou 2 - Hamu-chan Zu Daishuugou Dechu (Japan)" + description "Tottoko Hamutarou 2 - Hamu-chan Zu Daishuugou Dechu (Japan)" + rom ( name "Tottoko Hamutarou 2 - Hamu-chan Zu Daishuugou Dechu (Japan).gbc" size 2097152 crc f1fbcf84 sha1 adb1d5242a62d41c6e435b31082685ea4eec651a flags verified ) ) game ( - name "Puchi Carat (USA) (Proto 2) (SGB Enhanced) (GB Compatible)" - description "Puchi Carat (USA) (Proto 2) (SGB Enhanced) (GB Compatible)" - rom ( name "Puchi Carat (USA) (Proto 2) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a97ea742 sha1 de755124425f9de8bef5eea8026751c54f7f1e00 ) + name "Towers - Lord Baniff's Deceit (USA, Europe)" + description "Towers - Lord Baniff's Deceit (USA, Europe)" + rom ( name "Towers - Lord Baniff's Deceit (USA, Europe).gbc" size 1048576 crc 7b9b2468 sha1 e1324e5d7f61225366bd8dcf6079c171d23e89ca ) ) game ( - name "Puchi Carat (USA) (Proto 1) (SGB Enhanced) (GB Compatible)" - description "Puchi Carat (USA) (Proto 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Puchi Carat (USA) (Proto 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d79b6f46 sha1 b91b121a6951bcc74f0e4af33d41a1fba62f9822 ) + name "Towers II - Plight of the Stargazer (USA) (Proto 3) (2001-12-09)" + description "Towers II - Plight of the Stargazer (USA) (Proto 3) (2001-12-09)" + rom ( name "Towers II - Plight of the Stargazer (USA) (Proto 3) (2001-12-09).gbc" size 1048576 crc 909143c0 sha1 da80a5110913422d48dd8d316fcfb9c8310e4501 ) ) game ( - name "Puchi Carat (Europe) (SGB Enhanced) (GB Compatible)" - description "Puchi Carat (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Puchi Carat (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a9a89dda sha1 f703796e5551e12924c070cd8a0e77c6d82073af ) + name "Towers II - Plight of the Stargazer (USA) (Proto 1) (2000-05-07)" + description "Towers II - Plight of the Stargazer (USA) (Proto 1) (2000-05-07)" + rom ( name "Towers II - Plight of the Stargazer (USA) (Proto 1) (2000-05-07).gbc" size 1048576 crc 5784bce0 sha1 8072c36e198bd5d102052d5175b88e1a45cca9e8 ) ) game ( - name "Puchi Carat (Japan) (SGB Enhanced) (GB Compatible)" - description "Puchi Carat (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Puchi Carat (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc f0d0c36d sha1 25abda13f97140d412bb00e109baca8574d5af6e ) + name "Towers II - Plight of the Stargazer (USA) (Proto 2) (2000-08-05)" + description "Towers II - Plight of the Stargazer (USA) (Proto 2) (2000-08-05)" + rom ( name "Towers II - Plight of the Stargazer (USA) (Proto 2) (2000-08-05).gbc" size 1048576 crc 39e4bfd0 sha1 e9db495992490d88a65df1741f0294357bb96998 ) ) game ( - name "Pumuckls Abenteuer bei den Piraten (Germany)" - description "Pumuckls Abenteuer bei den Piraten (Germany)" - rom ( name "Pumuckls Abenteuer bei den Piraten (Germany).gbc" size 1048576 crc f55cdb79 sha1 1f90e982ead050796722d98f94e31a836945f84d ) + name "Toy Story 2 (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Toy Story 2 (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Toy Story 2 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 47aecb95 sha1 0c8506de2349ecf5241692da2aff239a0c40d862 ) ) game ( - name "Pumuckls Abenteuer im Geisterschloss (Germany)" - description "Pumuckls Abenteuer im Geisterschloss (Germany)" - rom ( name "Pumuckls Abenteuer im Geisterschloss (Germany).gbc" size 1048576 crc 87fcec24 sha1 0fe14ef81b11c854f080e804c5d3cb14601b2794 ) + name "Toy Story Racer (Europe) (En,Fr,De)" + description "Toy Story Racer (Europe) (En,Fr,De)" + rom ( name "Toy Story Racer (Europe) (En,Fr,De).gbc" size 2097152 crc f660ed94 sha1 1d06b1b563ec34014a8eabfd557e20ee03154ff9 ) ) game ( - name "Purple Turtles (World) (Aftermarket) (Unl)" - description "Purple Turtles (World) (Aftermarket) (Unl)" - rom ( name "Purple Turtles (World) (Aftermarket) (Unl).gbc" size 262144 crc 471277df sha1 a73cb69d1fb42f45f3649c4d1b4775e98fe35b78 ) + name "Toy Story Racer (USA, Europe)" + description "Toy Story Racer (USA, Europe)" + rom ( name "Toy Story Racer (USA, Europe).gbc" size 2097152 crc d911dd97 sha1 5deb31321a86b260aa84cab5e45a3fa36ce5efbd ) ) game ( - name "Puyo Puyo Gaiden - Puyo Wars (Japan) (SGB Enhanced) (GB Compatible)" - description "Puyo Puyo Gaiden - Puyo Wars (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Puyo Puyo Gaiden - Puyo Wars (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 67350bc9 sha1 b1802797e892d09e4da53304d096bdf35bac1118 ) + name "Trade & Battle Card Hero (Japan) (SGB Enhanced) (GB Compatible)" + description "Trade & Battle Card Hero (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Trade & Battle Card Hero (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b18cba2a sha1 9787a4583899720ff80a9e478ca096ba5df38fb3 flags verified ) ) game ( - name "Puzz Loop (Japan) (GB Compatible)" - description "Puzz Loop (Japan) (GB Compatible)" - rom ( name "Puzz Loop (Japan) (GB Compatible).gbc" size 1048576 crc af858234 sha1 f8b299c665552621ca067886a8f16e842f699487 ) + name "Trade & Battle Card Hero (Japan) (Rev 1) (3DS Virtual Console) (SGB Enhanced) (GB Compatible)" + description "Trade & Battle Card Hero (Japan) (Rev 1) (3DS Virtual Console) (SGB Enhanced) (GB Compatible)" + rom ( name "Trade & Battle Card Hero (Japan) (Rev 1) (3DS Virtual Console) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc d98a877d sha1 c6c1e0365166b53d25a1f84bc380948a9661df30 ) ) game ( - name "Puzzle Bobble 4 (Japan) (GB Compatible)" - description "Puzzle Bobble 4 (Japan) (GB Compatible)" - rom ( name "Puzzle Bobble 4 (Japan) (GB Compatible).gbc" size 524288 crc 79a35284 sha1 9c1e0055c2067688e066079778a795dbfa70c565 ) + name "Trick Boarder (Europe)" + description "Trick Boarder (Europe)" + rom ( name "Trick Boarder (Europe).gbc" size 1048576 crc efe3fc64 sha1 74573ebe3196e600fb180bc4aedafddea4060a2c ) ) game ( - name "Puzzle Bobble Millennium (Japan)" - description "Puzzle Bobble Millennium (Japan)" - rom ( name "Puzzle Bobble Millennium (Japan).gbc" size 1048576 crc 00fded94 sha1 adbb7b1544cf26e017053137ed7e9668f442e608 ) + name "Trick Boarder (USA)" + description "Trick Boarder (USA)" + rom ( name "Trick Boarder (USA).gbc" size 1048576 crc e856dc3d sha1 a5ba3e762a56801e997335eaf1f0b614ec54400c ) ) game ( - name "Puzzle de Shoubuyo! - Wootama-chan (Japan) (GB Compatible)" - description "Puzzle de Shoubuyo! - Wootama-chan (Japan) (GB Compatible)" - rom ( name "Puzzle de Shoubuyo! - Wootama-chan (Japan) (GB Compatible).gbc" size 1048576 crc 73ed3042 sha1 2c8630324767675e7f3da67e3a3071c73174a47d ) + name "Trickboarder GP (Japan)" + description "Trickboarder GP (Japan)" + rom ( name "Trickboarder GP (Japan).gbc" size 1048576 crc 31740097 sha1 263d8612ecdf651115df6f896737b8c498c970c0 ) ) game ( - name "Puzzle Master (USA) (GB Compatible)" - description "Puzzle Master (USA) (GB Compatible)" - rom ( name "Puzzle Master (USA) (GB Compatible).gbc" size 1048576 crc 06eb7a01 sha1 cbaccc88628194c82e115a8127ceeb035cd9c0a0 ) + name "Trip World DX (World) (Limited Run Games)" + description "Trip World DX (World) (Limited Run Games)" + rom ( name "Trip World DX (World) (Limited Run Games).gbc" size 524288 crc af17b3eb sha1 6871dd15e2081432ab4c7727f88491f7bbd95099 flags verified ) ) game ( - name "Puzzled (Europe) (En,Fr,De)" - description "Puzzled (Europe) (En,Fr,De)" - rom ( name "Puzzled (Europe) (En,Fr,De).gbc" size 1048576 crc 15b44d68 sha1 4e40ecd30a4e9c367f31cf5367c279f88b7df11c ) + name "Triple Play 2001 (USA, Europe)" + description "Triple Play 2001 (USA, Europe)" + rom ( name "Triple Play 2001 (USA, Europe).gbc" size 1048576 crc 74e04c07 sha1 326841285c54476c1fc231886a8cbd9c00e0195c ) ) game ( - name "Puzzled (USA)" - description "Puzzled (USA)" - rom ( name "Puzzled (USA).gbc" size 1048576 crc f03ffdaf sha1 8fd66d88174e429e9b909796745c74640de7db29 ) + name "Trouballs (USA)" + description "Trouballs (USA)" + rom ( name "Trouballs (USA).gbc" size 524288 crc 260eed04 sha1 dc4d0f608354e7cc32df7501dbacf8c50d70e728 ) ) game ( - name "Q-bert (USA)" - description "Q-bert (USA)" - rom ( name "Q-bert (USA).gbc" size 1048576 crc 90f46d7e sha1 4b2767ca512228b7db0f814f31ca45c4b92d349b ) + name "True Color 25 in 1 (Taiwan) (Unl)" + description "True Color 25 in 1 (Taiwan) (Unl)" + rom ( name "True Color 25 in 1 (Taiwan) (Unl).gbc" size 2097152 crc c47392ab sha1 0f1f76944ce2e85127df7d96ecb1eef6813af692 ) ) game ( - name "Qi Tian Dasheng - Sun Wukong (Taiwan) (Unl)" - description "Qi Tian Dasheng - Sun Wukong (Taiwan) (Unl)" - rom ( name "Qi Tian Dasheng - Sun Wukong (Taiwan) (Unl).gbc" size 524288 crc a336c40c sha1 3d7e987f1315242422c0db45c4aea120c1b41429 ) + name "Tsuri Sensei 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Tsuri Sensei 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Tsuri Sensei 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 1be00a6e sha1 ecc0b306501f1a2371a83db808bda38af8bc28ce ) ) game ( - name "Qilongzhu Z3 (Taiwan) (Unl)" - description "Qilongzhu Z3 (Taiwan) (Unl)" - rom ( name "Qilongzhu Z3 (Taiwan) (Unl).gbc" size 2097152 crc ccfdd63a sha1 4f3b63cd11522b6fb291661f4d918601d95138e0 ) + name "Tsuriiko!! (Japan)" + description "Tsuriiko!! (Japan)" + rom ( name "Tsuriiko!! (Japan).gbc" size 2097152 crc 6f2cbd1d sha1 b14cc1e8aca284517d964a909736da6b4540de85 ) ) game ( - name "Qix Adventure (USA) (Proto)" - description "Qix Adventure (USA) (Proto)" - rom ( name "Qix Adventure (USA) (Proto).gbc" size 1048576 crc bb3744a9 sha1 43ebf78cf1ce4024d23a211a8dfb006b16c1a168 ) + name "Turbo RC Racing (USA) (Proto)" + description "Turbo RC Racing (USA) (Proto)" + rom ( name "Turbo RC Racing (USA) (Proto).gbc" size 262144 crc e1983dfd sha1 494466cfed8e082c61b9e56a7275014c38705694 ) ) game ( - name "Qix Adventure (Europe)" - description "Qix Adventure (Europe)" - rom ( name "Qix Adventure (Europe).gbc" size 1048576 crc d729db40 sha1 95406795e7e1cc5207ecccac57d6b77bd0c575a1 ) + name "Turok - Rage Wars (USA, Europe) (En,Fr,De,Es)" + description "Turok - Rage Wars (USA, Europe) (En,Fr,De,Es)" + rom ( name "Turok - Rage Wars (USA, Europe) (En,Fr,De,Es).gbc" size 1048576 crc 786b5ab4 sha1 ce95e00b6e9d7dfb952e8cdf590a4c6948a6340e flags verified ) ) game ( - name "Qix Adventure (Japan)" - description "Qix Adventure (Japan)" - rom ( name "Qix Adventure (Japan).gbc" size 1048576 crc 5acea4a9 sha1 363b284e18a303d1dd3c2affc967fcd6912594d8 ) + name "Turok 2 - Jikku Senshi (Japan) (GB Compatible)" + description "Turok 2 - Jikku Senshi (Japan) (GB Compatible)" + rom ( name "Turok 2 - Jikku Senshi (Japan) (GB Compatible).gbc" size 1048576 crc f095b446 sha1 08a112f0c3fdc4cd4c14cfb98683d25d5d8475de ) ) game ( - name "Quan Ba Tianxia (Taiwan) (Unl)" - description "Quan Ba Tianxia (Taiwan) (Unl)" - rom ( name "Quan Ba Tianxia (Taiwan) (Unl).gbc" size 4194304 crc 2c922ed6 sha1 c19eb98a9745d2c2ce9e4dba3f17ae0b3dee0f49 ) + name "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (GB Compatible)" + description "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (GB Compatible)" + rom ( name "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (GB Compatible).gbc" size 1048576 crc 6eda6a3a sha1 fb7856af0205cc749174cda9eb51ae137984558c ) ) game ( - name "Quartet (World) (GB Compatible) (Aftermarket) (Unl)" - description "Quartet (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Quartet (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 46743216 sha1 bf866b438a602af386f8fad02727b4084edf6047 ) + name "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (Beta) (GB Compatible)" + description "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (Beta) (GB Compatible)" + rom ( name "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (Beta) (GB Compatible).gbc" size 1048576 crc dae30864 sha1 886c73348f4dd50e3ea916f96b8daa2451997dcc ) ) game ( - name "Quest - Brian's Journey (USA) (GB Compatible)" - description "Quest - Brian's Journey (USA) (GB Compatible)" - rom ( name "Quest - Brian's Journey (USA) (GB Compatible).gbc" size 2097152 crc 9ac27645 sha1 deef2b6ba0c4e468b90e32ad28f62a32f56db413 ) + name "Turok 3 - Shadow of Oblivion (USA, Europe) (En,Fr,De,Es)" + description "Turok 3 - Shadow of Oblivion (USA, Europe) (En,Fr,De,Es)" + rom ( name "Turok 3 - Shadow of Oblivion (USA, Europe) (En,Fr,De,Es).gbc" size 1048576 crc 6d48765e sha1 4b240f6b8e3648f2cbafa2fd6ee4e5b508950122 flags verified ) ) game ( - name "Quest - Fantasy Challenge (USA) (SGB Enhanced) (GB Compatible)" - description "Quest - Fantasy Challenge (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Quest - Fantasy Challenge (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 98285775 sha1 86812b2cd4304dc7ee2dd3faf16737b0414aaffb ) + name "Tutty (Europe) (Demo)" + description "Tutty (Europe) (Demo)" + rom ( name "Tutty (Europe) (Demo).gbc" size 131072 crc c4655f0a sha1 51883c4cc1469987483f993e3904da22690faeb9 ) ) game ( - name "Quest Arrest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "Quest Arrest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Quest Arrest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 9ac546d5 sha1 25b3a21135bfc7587c096b10f4a20d8b3095d721 ) + name "Tweenies - Doodles' Bones (Europe) (En,De,Es,It)" + description "Tweenies - Doodles' Bones (Europe) (En,De,Es,It)" + rom ( name "Tweenies - Doodles' Bones (Europe) (En,De,Es,It).gbc" size 1048576 crc 9306edd0 sha1 d1ff6fd8772dbc2038af7220845e817396664ae3 ) ) game ( - name "Quest for Camelot (Europe) (En,Fr,De,Es,It,Nl) (SGB Enhanced) (GB Compatible)" - description "Quest for Camelot (Europe) (En,Fr,De,Es,It,Nl) (SGB Enhanced) (GB Compatible)" - rom ( name "Quest for Camelot (Europe) (En,Fr,De,Es,It,Nl) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ce55a4de sha1 27b1839deb7fbf384539b3686ba029ca54637196 ) + name "Tweenies - Doodles' Bones (Europe) (En,Nl,Sv,No,Da)" + description "Tweenies - Doodles' Bones (Europe) (En,Nl,Sv,No,Da)" + rom ( name "Tweenies - Doodles' Bones (Europe) (En,Nl,Sv,No,Da).gbc" size 1048576 crc c7b61220 sha1 1e39a4ea0a8c7322a2e0653e522e0e486aa1ac36 ) ) game ( - name "Quest for Camelot (USA, Australia) (En,Fr,Es) (SGB Enhanced) (GB Compatible)" - description "Quest for Camelot (USA, Australia) (En,Fr,Es) (SGB Enhanced) (GB Compatible)" - rom ( name "Quest for Camelot (USA, Australia) (En,Fr,Es) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d903db7d sha1 aac9d4d1869fd1374ec7b7a9de47575f7e5f54b6 flags verified ) + name "Tweety Sekaiisshuu - 80 Hiki no Neko o Sagase! (Japan)" + description "Tweety Sekaiisshuu - 80 Hiki no Neko o Sagase! (Japan)" + rom ( name "Tweety Sekaiisshuu - 80 Hiki no Neko o Sagase! (Japan).gbc" size 1048576 crc 147f427a sha1 cf04dac11119c9be4ca6e247e33b935bd0cdc62d ) ) game ( - name "Qui Qui (Japan) (GB Compatible)" - description "Qui Qui (Japan) (GB Compatible)" - rom ( name "Qui Qui (Japan) (GB Compatible).gbc" size 1048576 crc 56d76ba2 sha1 5617ca94d3c909beaccad4702e52ffaaa0279add ) + name "Tweety's High-Flying Adventure (Europe) (En,Es,It)" + description "Tweety's High-Flying Adventure (Europe) (En,Es,It)" + rom ( name "Tweety's High-Flying Adventure (Europe) (En,Es,It).gbc" size 1048576 crc ca9e5385 sha1 e0c3ab341a825b297f9970b00f1d911e48492a72 ) ) game ( - name "Qunxia Zhuan II (Taiwan) (Unl)" - description "Qunxia Zhuan II (Taiwan) (Unl)" - rom ( name "Qunxia Zhuan II (Taiwan) (Unl).gbc" size 2097152 crc d9a7fcd3 sha1 063d892c757464ae091a26f45cc7f021658d262a ) + name "Tweety's High-Flying Adventure (Europe) (En,Fr,De)" + description "Tweety's High-Flying Adventure (Europe) (En,Fr,De)" + rom ( name "Tweety's High-Flying Adventure (Europe) (En,Fr,De).gbc" size 1048576 crc 7361d6bc sha1 94b4e1953b230d862e8f6173e82c822acb7ff02e ) ) game ( - name "R-Type DX (Japan) (En) (GB Compatible)" - description "R-Type DX (Japan) (En) (GB Compatible)" - rom ( name "R-Type DX (Japan) (En) (GB Compatible).gbc" size 1048576 crc 3623ebb6 sha1 73c6b524136ef7e5318f526561b99dd0488cf36e ) + name "Tweety's High-Flying Adventure (USA)" + description "Tweety's High-Flying Adventure (USA)" + rom ( name "Tweety's High-Flying Adventure (USA).gbc" size 1048576 crc 4e226396 sha1 9702aeea4a92625d2c19aa7f606b589cb7531613 ) ) game ( - name "R-Type DX (USA, Europe) (GB Compatible)" - description "R-Type DX (USA, Europe) (GB Compatible)" - rom ( name "R-Type DX (USA, Europe) (GB Compatible).gbc" size 1048576 crc fc1d4089 sha1 e6a5c632b616e520b10b8b7589207c87c0092047 flags verified ) + name "Tyrannosaurus Tex (USA) (Proto)" + description "Tyrannosaurus Tex (USA) (Proto)" + rom ( name "Tyrannosaurus Tex (USA) (Proto).gbc" size 2097152 crc 1bd4e588 sha1 e2fcc7fcc643f9d7fc61acce6c5ed1f8abc13fa0 ) ) game ( - name "Race Time (Europe) (Unl)" - description "Race Time (Europe) (Unl)" - rom ( name "Race Time (Europe) (Unl).gbc" size 262144 crc 599c867d sha1 157f15e601dfb858630a53313b71e4ecd0bb13e1 ) + name "Tyrian 2000 (USA) (Proto) (GB Compatible)" + description "Tyrian 2000 (USA) (Proto) (GB Compatible)" + rom ( name "Tyrian 2000 (USA) (Proto) (GB Compatible).gbc" size 524288 crc 1fb6b290 sha1 1cfe1c97c50155844a349b7ca4ef8c77985adac2 ) ) game ( - name "Racin' Ratz (USA)" - description "Racin' Ratz (USA)" - rom ( name "Racin' Ratz (USA).gbc" size 1048576 crc d6881014 sha1 32c63be36093db84fb5fec110ad5af49be78c4af ) + name "Uchuujin Tanaka Tarou de - RPG Tsukuru GB 2 (Japan)" + description "Uchuujin Tanaka Tarou de - RPG Tsukuru GB 2 (Japan)" + rom ( name "Uchuujin Tanaka Tarou de - RPG Tsukuru GB 2 (Japan).gbc" size 4194304 crc 219e42e3 sha1 aa090449e93e4dcfa0437e7cdba695e90cfa9509 ) ) game ( - name "Radikal Bikers (Europe) (En,Fr,De,Es) (Proto)" - description "Radikal Bikers (Europe) (En,Fr,De,Es) (Proto)" - rom ( name "Radikal Bikers (Europe) (En,Fr,De,Es) (Proto).gbc" size 2097152 crc 81e25d37 sha1 f16aa29669b15153a63ad92388768e38aa18fbf8 ) + name "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl)" + description "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 4b314d4b sha1 56e5f0e62b65a265c85e1a88882b18139f26b94d ) ) game ( - name "Raffles (World) (Aftermarket) (Unl)" - description "Raffles (World) (Aftermarket) (Unl)" - rom ( name "Raffles (World) (Aftermarket) (Unl).gbc" size 262144 crc e41d6472 sha1 4b5eb518ff52c235c674e0695fdde2b8b01f58fa ) + name "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + description "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta)" + rom ( name "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 1048576 crc 03380957 sha1 9f44aa3230aba33c9c38c5e17f9cef2e9a10747e ) ) game ( - name "Rainbow Islands (Europe) (En,Fr,De,Es,It)" - description "Rainbow Islands (Europe) (En,Fr,De,Es,It)" - rom ( name "Rainbow Islands (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 6decc6b3 sha1 15dcf2f868686aea28611df69089e1929ac186f9 ) + name "Ultimate Fighting Championship (Europe)" + description "Ultimate Fighting Championship (Europe)" + rom ( name "Ultimate Fighting Championship (Europe).gbc" size 1048576 crc 92a5a1ad sha1 5036626b97238e17b8fc203c44453e79b108cd2e flags verified ) ) game ( - name "Raku x Raku - Cut Shuu (Japan)" - description "Raku x Raku - Cut Shuu (Japan)" - rom ( name "Raku x Raku - Cut Shuu (Japan).gbc" size 2097152 crc 430cfcf3 sha1 b51a62358c37539021bc980c1699825596b118ef ) + name "Ultimate Fighting Championship (USA)" + description "Ultimate Fighting Championship (USA)" + rom ( name "Ultimate Fighting Championship (USA).gbc" size 1048576 crc d5f036ce sha1 8a02015e399a0311c15f0a8ca31744aa0be0f5e6 ) ) game ( - name "Raku x Raku - Mishin (Japan) (GB Compatible)" - description "Raku x Raku - Mishin (Japan) (GB Compatible)" - rom ( name "Raku x Raku - Mishin (Japan) (GB Compatible).gbc" size 1048576 crc 0ba0711b sha1 58bf5df55d2bab8877f7ec43110339ebe1a5d4c5 ) + name "Ultimate Paintball (USA, Europe)" + description "Ultimate Paintball (USA, Europe)" + rom ( name "Ultimate Paintball (USA, Europe).gbc" size 1048576 crc 6dcfdfe2 sha1 7765398db980c145062f2c0ac92b1f8f4ba40236 ) ) game ( - name "Raku x Raku - Moji (Japan)" - description "Raku x Raku - Moji (Japan)" - rom ( name "Raku x Raku - Moji (Japan).gbc" size 2097152 crc abe58a8b sha1 d9502543c6cd05c7e06a3b89286eec155aff83a0 ) + name "Ultimate Surfing (Europe)" + description "Ultimate Surfing (Europe)" + rom ( name "Ultimate Surfing (Europe).gbc" size 1048576 crc b3398a9b sha1 15426e79cf1c0cafbf8972501b8478951023c21a ) ) game ( - name "Rampage - World Tour (USA, Europe) (GB Compatible)" - description "Rampage - World Tour (USA, Europe) (GB Compatible)" - rom ( name "Rampage - World Tour (USA, Europe) (GB Compatible).gbc" size 524288 crc b029017f sha1 5064f76557ce4235c8d1d4da7bac94e3af352126 ) + name "Ultimate Surfing (USA)" + description "Ultimate Surfing (USA)" + rom ( name "Ultimate Surfing (USA).gbc" size 1048576 crc e84df1f0 sha1 264c19ab212d938839306f7e8230d5caee3cf3e7 ) ) game ( - name "Rampage 2 - Universal Tour (USA, Europe)" - description "Rampage 2 - Universal Tour (USA, Europe)" - rom ( name "Rampage 2 - Universal Tour (USA, Europe).gbc" size 1048576 crc 20b86f1e sha1 4f6f14588e385357206f52e2c74b07b44d16f78f ) + name "Uno (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + description "Uno (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" + rom ( name "Uno (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc 70760cce sha1 b33214a4cd05f58dd019a77b1260bf557293c826 ) ) game ( - name "Rampart (USA)" - description "Rampart (USA)" - rom ( name "Rampart (USA).gbc" size 1048576 crc d5aeed2e sha1 40cef7a1af53d2da5cd7b9d7927f1f64399e69dc flags verified ) + name "Uno (USA) (GB Compatible)" + description "Uno (USA) (GB Compatible)" + rom ( name "Uno (USA) (GB Compatible).gbc" size 1048576 crc f026d509 sha1 20868148461618d1195570775b183a065781ce35 ) ) game ( - name "Rats! (USA) (En,Es) (GB Compatible)" - description "Rats! (USA) (En,Es) (GB Compatible)" - rom ( name "Rats! (USA) (En,Es) (GB Compatible).gbc" size 524288 crc 17635ad1 sha1 5e423dfab8221b69a641d2e535ebfe1e3759a2e4 ) + name "V-Rally - Championship Edition (Europe) (En,Fr,De,Es)" + description "V-Rally - Championship Edition (Europe) (En,Fr,De,Es)" + rom ( name "V-Rally - Championship Edition (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 1312b3f7 sha1 5447f2c317deee8ca6da8f098a7d78f52b87e0cb ) ) game ( - name "Ravenia (World) (GB Compatible) (Aftermarket) (Unl)" - description "Ravenia (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Ravenia (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 09196a32 sha1 8218ad22b29fb32c66430a17a97775dd30b2f34b flags verified ) + name "V-Rally - Championship Edition (Japan)" + description "V-Rally - Championship Edition (Japan)" + rom ( name "V-Rally - Championship Edition (Japan).gbc" size 1048576 crc fab9d941 sha1 c05473dcf45fd4e185f9f3aec3f4e429e4f12bbd ) ) game ( - name "Rayman (Europe) (En,Fr,De,Es,It,Nl)" - description "Rayman (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Rayman (Europe) (En,Fr,De,Es,It,Nl).gbc" size 4194304 crc c430a89a sha1 2e2d674426f2d29195a4bfbd82dca4c25416e475 flags verified ) + name "V-Rally - Edition 99 (USA) (En,Fr,Es)" + description "V-Rally - Edition 99 (USA) (En,Fr,Es)" + rom ( name "V-Rally - Edition 99 (USA) (En,Fr,Es).gbc" size 1048576 crc da300c6c sha1 638266c9d2d16486c2ed00510176112071b05e2c ) ) game ( - name "Rayman (USA) (En,Fr,De,Es,It,Nl)" - description "Rayman (USA) (En,Fr,De,Es,It,Nl)" - rom ( name "Rayman (USA) (En,Fr,De,Es,It,Nl).gbc" size 4194304 crc eda12f0d sha1 5a6999c0ca4be80a6259664fdffbc79fd4bb1ed6 ) + name "Vegas Games (Europe) (En,Fr,De)" + description "Vegas Games (Europe) (En,Fr,De)" + rom ( name "Vegas Games (Europe) (En,Fr,De).gbc" size 1048576 crc 81b2bb8d sha1 9b110d6ee12241aa5c061a1bb5f66e9cab93842f ) ) game ( - name "Rayman - Mister Dark no Wana (Japan)" - description "Rayman - Mister Dark no Wana (Japan)" - rom ( name "Rayman - Mister Dark no Wana (Japan).gbc" size 4194304 crc 3fde5bac sha1 ef057156806dddcc3d0cc5776843c639c6c3cae4 ) + name "Vegas Games (USA)" + description "Vegas Games (USA)" + rom ( name "Vegas Games (USA).gbc" size 1048576 crc 40b5ea96 sha1 c73423444cc5900518fbd163ec7421dc3e5a7ca2 ) ) game ( - name "Rayman 2 (USA) (En,Fr,De,Es,It)" - description "Rayman 2 (USA) (En,Fr,De,Es,It)" - rom ( name "Rayman 2 (USA) (En,Fr,De,Es,It).gbc" size 4194304 crc 6f5c315d sha1 d984deaf66933571404eb5be754972d73ec7fbd5 ) + name "Vegas Games (USA) (En,Fr,De) (Rev 1) (Proto)" + description "Vegas Games (USA) (En,Fr,De) (Rev 1) (Proto)" + rom ( name "Vegas Games (USA) (En,Fr,De) (Rev 1) (Proto).gbc" size 1048576 crc 4167cf29 sha1 658cc13bc436a9ec613400b91288831900e3443e ) ) game ( - name "Rayman 2 Forever (Europe) (En,Fr,De,Es,It)" - description "Rayman 2 Forever (Europe) (En,Fr,De,Es,It)" - rom ( name "Rayman 2 Forever (Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 250015d4 sha1 5ea438c5b52696255e8df74eb19e3cac1427a14a ) + name "Vigilante 8 (USA) (Rumble Version)" + description "Vigilante 8 (USA) (Rumble Version)" + rom ( name "Vigilante 8 (USA) (Rumble Version).gbc" size 1048576 crc d1a188dc sha1 4e4ce54c06e8f71ba6e0d8fc8550c177dcf660fd flags verified ) ) game ( - name "Razmoket a Paris, Les - Le Film (France)" - description "Razmoket a Paris, Les - Le Film (France)" - rom ( name "Razmoket a Paris, Les - Le Film (France).gbc" size 1048576 crc 094494e9 sha1 ed9ec61de28dc1a83f0e98e8d651399cb45bd387 ) + name "VIP (Europe) (En,Fr,De,Es,It)" + description "VIP (Europe) (En,Fr,De,Es,It)" + rom ( name "VIP (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc dbdd6d85 sha1 4da103b9a5c9e9649b26876fcbd70555bd8fd042 flags verified ) ) game ( - name "Razmoket, Les - 100% Angelica (France)" - description "Razmoket, Les - 100% Angelica (France)" - rom ( name "Razmoket, Les - 100% Angelica (France).gbc" size 1048576 crc 1d66cb29 sha1 a04285ae27def1e0b808561099cc2cb86ba94f07 ) + name "VIP (USA) (En,Fr,Es)" + description "VIP (USA) (En,Fr,Es)" + rom ( name "VIP (USA) (En,Fr,Es).gbc" size 1048576 crc 436c87d4 sha1 3ecff5c68e457ee34c42af6349f9ab2a6845b5de ) ) game ( - name "Razmoket, Les - Voyage dans le Temps (France)" - description "Razmoket, Les - Voyage dans le Temps (France)" - rom ( name "Razmoket, Les - Voyage dans le Temps (France).gbc" size 1048576 crc 2f8fef3f sha1 9587eb9c373399401bdd2208d22425999956733d ) + name "Visiteurs, Les (France) (GB Compatible)" + description "Visiteurs, Les (France) (GB Compatible)" + rom ( name "Visiteurs, Les (France) (GB Compatible).gbc" size 1048576 crc d843f898 sha1 307b5d80fd7def049d446bf3406ec8d57dfee93d ) ) game ( - name "Razor Freestyle Scooter (USA)" - description "Razor Freestyle Scooter (USA)" - rom ( name "Razor Freestyle Scooter (USA).gbc" size 1048576 crc 5c201286 sha1 9360aa3e7062399527686ed55b06faeaa388178c ) + name "VR Sports - Powerboat Racing (USA) (Proto)" + description "VR Sports - Powerboat Racing (USA) (Proto)" + rom ( name "VR Sports - Powerboat Racing (USA) (Proto).gbc" size 1048576 crc cff671f1 sha1 1c77f032cdd373bfa108ea82c463f8f9f6874c71 ) ) game ( - name "Ready 2 Rumble Boxing (Europe)" - description "Ready 2 Rumble Boxing (Europe)" - rom ( name "Ready 2 Rumble Boxing (Europe).gbc" size 2097152 crc bea36bf9 sha1 46dba4b01cc71f07ceb6472064e0312ca70b31bd flags verified ) + name "Wacky Races (Europe) (En,Fr,De,Es,It,Nl)" + description "Wacky Races (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Wacky Races (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 37ea6093 sha1 dba18064c886cebe4c4be80f941622f377adab98 ) ) game ( - name "Ready 2 Rumble Boxing (USA) (Rumble Version)" - description "Ready 2 Rumble Boxing (USA) (Rumble Version)" - rom ( name "Ready 2 Rumble Boxing (USA) (Rumble Version).gbc" size 2097152 crc 345e20a4 sha1 30ea96ba1f4ffbe2546eac86f57827138c5d676e flags verified ) + name "Wacky Races (USA) (En,Fr,Es)" + description "Wacky Races (USA) (En,Fr,Es)" + rom ( name "Wacky Races (USA) (En,Fr,Es).gbc" size 1048576 crc 543abb1b sha1 3ec148027d0e5a075d7a4597232e64215c060fa7 ) ) game ( - name "Real Pro Yakyuu! - Central League Hen (Japan) (SGB Enhanced) (GB Compatible)" - description "Real Pro Yakyuu! - Central League Hen (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Real Pro Yakyuu! - Central League Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc afff6bb9 sha1 02c18d98a07b3af9a1d26d0c3003f8e75c81f4d9 ) + name "Wai Xing Tanxian Zhi Xingqiu Dazhan (Taiwan) (Unl)" + description "Wai Xing Tanxian Zhi Xingqiu Dazhan (Taiwan) (Unl)" + rom ( name "Wai Xing Tanxian Zhi Xingqiu Dazhan (Taiwan) (Unl).gbc" size 2097152 crc 4e600093 sha1 32067be39f0bdc354c31a7a02f24ba00b61ae4f1 flags verified ) ) game ( - name "Real Pro Yakyuu! - Pacific League Hen (Japan) (SGB Enhanced) (GB Compatible)" - description "Real Pro Yakyuu! - Pacific League Hen (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Real Pro Yakyuu! - Pacific League Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc 16b81c36 sha1 a7a2cd7bbb4cae171b5f2c798293afefe2882afc ) + name "Walt Disney World Quest - Magical Racing Tour (Europe) (Fr,De,Es)" + description "Walt Disney World Quest - Magical Racing Tour (Europe) (Fr,De,Es)" + rom ( name "Walt Disney World Quest - Magical Racing Tour (Europe) (Fr,De,Es).gbc" size 2097152 crc e54b22b9 sha1 95dbef19504368e73b97cd785e2b19e3c71710f4 flags verified ) ) game ( - name "Remen Gaoxiao - Shuma Guaishou III (Taiwan) (Unl)" - description "Remen Gaoxiao - Shuma Guaishou III (Taiwan) (Unl)" - rom ( name "Remen Gaoxiao - Shuma Guaishou III (Taiwan) (Unl).gbc" size 524288 crc 9f64fb1c sha1 b8d6910c8b5c1cab044c61679bbbc4f213648f56 ) + name "Walt Disney World Quest - Magical Racing Tour (USA, Europe)" + description "Walt Disney World Quest - Magical Racing Tour (USA, Europe)" + rom ( name "Walt Disney World Quest - Magical Racing Tour (USA, Europe).gbc" size 2097152 crc 56beb694 sha1 529289ccfd21397405d08305409c5d9b2119505e ) ) game ( - name "Repugnant Bounty (World) (Demo) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl)" - description "Repugnant Bounty (World) (Demo) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Repugnant Bounty (World) (Demo) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc e92034d8 sha1 14b9614cea9be7d5c6e12aece692582ba2ca2b75 flags verified ) + name "Wangzu Tiantang (Taiwan) (Unl)" + description "Wangzu Tiantang (Taiwan) (Unl)" + rom ( name "Wangzu Tiantang (Taiwan) (Unl).gbc" size 2097152 crc dee597fc sha1 4e01c94ab55f2d299bd0bea83c0ef500fb9e738c ) ) game ( - name "Repugnant Bounty (World) (v0.1.023) (Beta) (GB Compatible) (Aftermarket) (Unl)" - description "Repugnant Bounty (World) (v0.1.023) (Beta) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Repugnant Bounty (World) (v0.1.023) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 3a1b1d83 sha1 4dda0cce6907de94eeae3f11a40238c3f5155ca7 ) + name "Warau Inu no Bouken - Silly Go Lucky! (Japan)" + description "Warau Inu no Bouken - Silly Go Lucky! (Japan)" + rom ( name "Warau Inu no Bouken - Silly Go Lucky! (Japan).gbc" size 1048576 crc e93f1582 sha1 3c337b71aeba3b937caada4c84f2b29add517d03 ) ) game ( - name "Repugnant Bounty (World) (Demo) (Aftermarket) (Unl)" - description "Repugnant Bounty (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Repugnant Bounty (World) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc f8c7f180 sha1 07674d42f5d4efaec14750ae56d8f28c4b54c020 flags verified ) + name "Wario Land 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "Wario Land 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Wario Land 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b30fdbf5 sha1 cd6266e48df816219fb38d223b0ec6760259616d flags verified ) ) game ( - name "Rescue Heroes - Fire Frenzy (USA)" - description "Rescue Heroes - Fire Frenzy (USA)" - rom ( name "Rescue Heroes - Fire Frenzy (USA).gbc" size 1048576 crc 77a4dc63 sha1 a57aeb43ef88ffd09f5028368a3142c3e9f5e792 ) + name "Wario Land 3 (World) (En,Ja)" + description "Wario Land 3 (World) (En,Ja)" + rom ( name "Wario Land 3 (World) (En,Ja).gbc" size 2097152 crc 480d0259 sha1 bb7877309834441fd03adb7fa65738e5d5b2d7ba flags verified ) ) game ( - name "Reservoir Rat (Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "Reservoir Rat (Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Reservoir Rat (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 524288 crc 22621803 sha1 7ee86635f9d9735cc57673b08995be7003ff6082 flags verified ) + name "Wario Land II (USA, Europe) (SGB Enhanced) (GB Compatible)" + description "Wario Land II (USA, Europe) (SGB Enhanced) (GB Compatible)" + rom ( name "Wario Land II (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 047bdf80 sha1 ae37915058035df4ceedd72d709f91efb4878eff flags verified ) ) game ( - name "Resident Evil (World) (Proto 1)" - description "Resident Evil (World) (Proto 1)" - rom ( name "Resident Evil (World) (Proto 1).gbc" size 4194304 crc e6e722c8 sha1 87f8b1bad965bc9214ccd2932020163418a4e8f1 ) + name "Warlocked (USA)" + description "Warlocked (USA)" + rom ( name "Warlocked (USA).gbc" size 2097152 crc cfa0df0f sha1 2f9c05f74476368bd6dbba7d675e7870cf8ca27c flags verified ) ) game ( - name "Resident Evil (World) (Proto 2)" - description "Resident Evil (World) (Proto 2)" - rom ( name "Resident Evil (World) (Proto 2).gbc" size 4194304 crc 53f7bba1 sha1 bda5a658631a5714e761ee1805baaa0008ee8cdf ) + name "Warriors of Might and Magic (USA) (En,Fr,De)" + description "Warriors of Might and Magic (USA) (En,Fr,De)" + rom ( name "Warriors of Might and Magic (USA) (En,Fr,De).gbc" size 1048576 crc ef9f5bea sha1 06163acad95d6ab87ffcd56f18b37c8c9e37a6ec ) ) game ( - name "Resident Evil (Unknown) (Demo) (Climax Entertainment)" - description "Resident Evil (Unknown) (Demo) (Climax Entertainment)" - rom ( name "Resident Evil (Unknown) (Demo) (Climax Entertainment).gbc" size 524288 crc 1a921065 sha1 bec002e2d9e7852cd85b720b570f4ae73453b756 ) + name "Watashi no Kitchen (Japan)" + description "Watashi no Kitchen (Japan)" + rom ( name "Watashi no Kitchen (Japan).gbc" size 1048576 crc bc767b25 sha1 7aa55d3cdd7ab505c62f4e3654256391f3590bf6 ) ) game ( - name "Resident Evil Gaiden (Europe) (En,Fr,De,Es,It)" - description "Resident Evil Gaiden (Europe) (En,Fr,De,Es,It)" - rom ( name "Resident Evil Gaiden (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc f85c3f2c sha1 2116120a930bd93d5e32cc588acadb559b0d65e8 ) + name "Watashi no Kitchen (Japan) (Rev 1)" + description "Watashi no Kitchen (Japan) (Rev 1)" + rom ( name "Watashi no Kitchen (Japan) (Rev 1).gbc" size 1048576 crc 584669e4 sha1 effd0d198bac35abee1a8a6481382a1f2b14ead3 ) ) game ( - name "Resident Evil Gaiden (USA)" - description "Resident Evil Gaiden (USA)" - rom ( name "Resident Evil Gaiden (USA).gbc" size 2097152 crc f8c5021b sha1 a302cddc085d65ca778153e2a591bd648ce963c9 ) + name "Watashi no Restaurant (Japan)" + description "Watashi no Restaurant (Japan)" + rom ( name "Watashi no Restaurant (Japan).gbc" size 1048576 crc 395003ef sha1 d66f728006aaa37c2776b6ade7d1c8cdc2101a57 ) ) game ( - name "Retro Quiz Tower (World) (GB Compatible) (Aftermarket) (Unl)" - description "Retro Quiz Tower (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Retro Quiz Tower (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 8bd98942 sha1 3a5dbafa829e57089de8cfc93c806f7ee023ff1b ) + name "Watashi no Restaurant (Japan) (Beta 1)" + description "Watashi no Restaurant (Japan) (Beta 1)" + rom ( name "Watashi no Restaurant (Japan) (Beta 1).gbc" size 1048576 crc 5ff6b852 sha1 384f1f68e7331f992f1d311f1433ea9f205eddcb ) ) game ( - name "Retro Quiz Tower (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" - description "Retro Quiz Tower (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Retro Quiz Tower (World) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c761189c sha1 f7f18d83218b66b9d1cd7267d6d4acfd4eded6c7 ) + name "Watashi no Restaurant (Japan) (Beta 2)" + description "Watashi no Restaurant (Japan) (Beta 2)" + rom ( name "Watashi no Restaurant (Japan) (Beta 2).gbc" size 1048576 crc 8571099f sha1 98ff6b68b7c79229100f58311ee41e3fec4802e0 ) ) game ( - name "Return of the Ninja (Europe)" - description "Return of the Ninja (Europe)" - rom ( name "Return of the Ninja (Europe).gbc" size 1048576 crc 8e04849a sha1 e49ce291a1da791955a5de8c894aca28ffc97f9b ) + name "Watashi no Restaurant (Japan) (Beta 3)" + description "Watashi no Restaurant (Japan) (Beta 3)" + rom ( name "Watashi no Restaurant (Japan) (Beta 3).gbc" size 1048576 crc a0ed2859 sha1 343bf8ebb6fa3ce89501f7c4c219fb7e864c38a3 ) ) game ( - name "Return of the Ninja (USA)" - description "Return of the Ninja (USA)" - rom ( name "Return of the Ninja (USA).gbc" size 1048576 crc a07da702 sha1 e33352f0ac19d28983ebed0758d022861473ec0e ) + name "WCW Mayhem (USA, Europe)" + description "WCW Mayhem (USA, Europe)" + rom ( name "WCW Mayhem (USA, Europe).gbc" size 1048576 crc 9f8620d1 sha1 ec4e5ab0b78b3a72778700907cccab6306bfd0ea ) ) game ( - name "Revelations - The Demon Slayer (USA) (SGB Enhanced) (GB Compatible)" - description "Revelations - The Demon Slayer (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Revelations - The Demon Slayer (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d1a65d74 sha1 bd684074944ccc02b5f997e7ab95d0b03327773d ) + name "WDL - World Destruction League - Thunder Tanks (USA) (En,Fr,De)" + description "WDL - World Destruction League - Thunder Tanks (USA) (En,Fr,De)" + rom ( name "WDL - World Destruction League - Thunder Tanks (USA) (En,Fr,De).gbc" size 1048576 crc 1a0bf4d7 sha1 665d34621b4d51d4f1cee882a453f5e278e2b5da ) ) game ( - name "Rhino Rumble (USA, Europe)" - description "Rhino Rumble (USA, Europe)" - rom ( name "Rhino Rumble (USA, Europe).gbc" size 1048576 crc 73160e05 sha1 2caf47c20d8632e47c4426dd3564e76415139973 flags verified ) + name "WDL - World Destruction League - Thunder Tanks (USA) (Beta)" + description "WDL - World Destruction League - Thunder Tanks (USA) (Beta)" + rom ( name "WDL - World Destruction League - Thunder Tanks (USA) (Beta).gbc" size 1048576 crc 41df1c79 sha1 126b3626fb4752312834ac42bb5b873c22a3aea3 ) ) game ( - name "Rig Attack (World) (Aftermarket) (Unl)" - description "Rig Attack (World) (Aftermarket) (Unl)" - rom ( name "Rig Attack (World) (Aftermarket) (Unl).gbc" size 262144 crc d013d775 sha1 90bfd921c986abff4555b761cedc90ec36c43fff ) + name "Wendy - Der Traum von Arizona (Germany)" + description "Wendy - Der Traum von Arizona (Germany)" + rom ( name "Wendy - Der Traum von Arizona (Germany).gbc" size 2097152 crc df7c18bc sha1 21141e9e0302ead50456af7b55a1391679455662 ) ) game ( - name "Rip-Tide Racer (Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "Rip-Tide Racer (Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Rip-Tide Racer (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc ab8c3a31 sha1 3354d6e79b8094bbaa4ef48eb8bd2b0774c46e1a ) + name "Wendy - Der Traum von Arizona (Germany) (Beta)" + description "Wendy - Der Traum von Arizona (Germany) (Beta)" + rom ( name "Wendy - Der Traum von Arizona (Germany) (Beta).gbc" size 2097152 crc 20bdca55 sha1 fd39cb84f71ea414c0165a58bac98357739bc406 ) ) game ( - name "River Styx Round-Up (World) (GB Compatible) (Aftermarket) (Unl)" - description "River Styx Round-Up (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "River Styx Round-Up (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ae3f980b sha1 67f63517eacfea22922d07be0efc5fc8f8b8a1d2 ) + name "Wendy - Every Witch Way (USA, Europe)" + description "Wendy - Every Witch Way (USA, Europe)" + rom ( name "Wendy - Every Witch Way (USA, Europe).gbc" size 1048576 crc 4ac6907b sha1 8ca45ed882c23df714bda46b227a857deddc899f flags verified ) ) game ( - name "Road Champs - BXS Stunt Biking (USA, Europe)" - description "Road Champs - BXS Stunt Biking (USA, Europe)" - rom ( name "Road Champs - BXS Stunt Biking (USA, Europe).gbc" size 1048576 crc 98c59706 sha1 15134178346c5209197f4847d7de5ef86be36b85 flags verified ) + name "Wetrix (Europe) (En,Fr,De)" + description "Wetrix (Europe) (En,Fr,De)" + rom ( name "Wetrix (Europe) (En,Fr,De).gbc" size 1048576 crc 9cbfaa3d sha1 6de683dc99feaf7fb0440046668d36a229513ab5 ) ) game ( - name "Road Rash (USA, Europe)" - description "Road Rash (USA, Europe)" - rom ( name "Road Rash (USA, Europe).gbc" size 1048576 crc 11025eeb sha1 b3329c0f92c1a6a6cfa894f487f68a7fcceb5844 ) + name "Wetrix GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Wetrix GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Wetrix GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6215c5b3 sha1 92944052b6e4448abf0103f085998662e0140825 ) ) game ( - name "Roadsters (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - description "Roadsters (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - rom ( name "Roadsters (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc 717b3525 sha1 3c0a54fba91a6df88c152a824d192e05c0a68250 ) + name "Who Wants to Be a Millionaire - 2nd Edition (USA)" + description "Who Wants to Be a Millionaire - 2nd Edition (USA)" + rom ( name "Who Wants to Be a Millionaire - 2nd Edition (USA).gbc" size 1048576 crc 6830b7af sha1 1fd2c608231e6f919fee05da91418e05c502ef61 ) ) game ( - name "Roadsters (USA) (En,Fr,De,Es,It,Nl) (GB Compatible)" - description "Roadsters (USA) (En,Fr,De,Es,It,Nl) (GB Compatible)" - rom ( name "Roadsters (USA) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc 38b022be sha1 ede737e99108be29daf94fee8e10f5dd770731bb ) + name "Wild Thornberrys, The - Rambler (USA)" + description "Wild Thornberrys, The - Rambler (USA)" + rom ( name "Wild Thornberrys, The - Rambler (USA).gbc" size 1048576 crc 0e1465cb sha1 0e806f0e6c1a41e764683850a3c15a80ac7fc9a5 ) ) game ( - name "Roadsters '98 (USA) (Proto) (SGB Enhanced) (GB Compatible)" - description "Roadsters '98 (USA) (Proto) (SGB Enhanced) (GB Compatible)" - rom ( name "Roadsters '98 (USA) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 131072 crc fe2995a1 sha1 30a28cd5e020e98b0e7016b5ccda5bc0972a0ac9 ) + name "Wings of Fury (Europe) (En,Fr,De) (GB Compatible)" + description "Wings of Fury (Europe) (En,Fr,De) (GB Compatible)" + rom ( name "Wings of Fury (Europe) (En,Fr,De) (GB Compatible).gbc" size 1048576 crc 6d59104f sha1 d3f21ea1a1d83546dffcd63ec089cfac04212a03 ) ) game ( - name "Robin Hood (Europe) (En,Fr,De,Es,It,Nl)" - description "Robin Hood (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Robin Hood (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc d4f84329 sha1 fe0c42e949bc41f070b22dd24e643aa42b007667 ) + name "Wings of Fury (USA) (GB Compatible)" + description "Wings of Fury (USA) (GB Compatible)" + rom ( name "Wings of Fury (USA) (GB Compatible).gbc" size 1048576 crc c94a413a sha1 ae217bd12f42ce6297282227b7e2d21e6337420c ) ) game ( - name "Robin to the Rescue (World) (Aftermarket) (Unl)" - description "Robin to the Rescue (World) (Aftermarket) (Unl)" - rom ( name "Robin to the Rescue (World) (Aftermarket) (Unl).gbc" size 262144 crc 9cd52c18 sha1 ef3bea9ed0de41e311b5f15fccbb0f451848d56c ) + name "Winnie the Pooh - Adventures in the 100 Acre Wood (Europe) (En,Fr,De,Es,It,Nl,Da)" + description "Winnie the Pooh - Adventures in the 100 Acre Wood (Europe) (En,Fr,De,Es,It,Nl,Da)" + rom ( name "Winnie the Pooh - Adventures in the 100 Acre Wood (Europe) (En,Fr,De,Es,It,Nl,Da).gbc" size 2097152 crc 1db0840c sha1 b97b33e7423a712b3f77a2bf9a419f78ec5d30be ) ) game ( - name "Robo Knight (World) (Aftermarket) (Unl)" - description "Robo Knight (World) (Aftermarket) (Unl)" - rom ( name "Robo Knight (World) (Aftermarket) (Unl).gbc" size 524288 crc 8d4507f0 sha1 6012f9a3ae6201e363f46a75e0100552ecb91335 ) + name "Winnie the Pooh - Adventures in the 100 Acre Wood (USA)" + description "Winnie the Pooh - Adventures in the 100 Acre Wood (USA)" + rom ( name "Winnie the Pooh - Adventures in the 100 Acre Wood (USA).gbc" size 2097152 crc 066a2196 sha1 5ff68bc5ec735d090b24aab79a787f77f26afb08 flags verified ) ) game ( - name "RoboCop (Europe) (En,Fr,De,Es,It,Nl)" - description "RoboCop (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "RoboCop (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 6c6423e2 sha1 fbac3bdc8ed40c0f752ec711c4cc82262358f9bd ) + name "Wizardry Empire (Japan)" + description "Wizardry Empire (Japan)" + rom ( name "Wizardry Empire (Japan).gbc" size 1048576 crc 7adc90e1 sha1 041c125115c83c6fef1b888761ba0b2b1f9bd291 ) ) game ( - name "Robopon - Star Version (USA) (Proto)" - description "Robopon - Star Version (USA) (Proto)" - rom ( name "Robopon - Star Version (USA) (Proto).gbc" size 1048576 crc cf5f0a63 sha1 54e064a24cd50b7e25df5c827c54a20643ec314a ) + name "Wizardry Empire (Japan) (Rev 1)" + description "Wizardry Empire (Japan) (Rev 1)" + rom ( name "Wizardry Empire (Japan) (Rev 1).gbc" size 1048576 crc fa82620f sha1 f5f4e8bead0fe45075141133a530a0eb116ea78c ) ) game ( - name "Robopon - Sun Version (USA) (SGB Enhanced) (GB Compatible)" - description "Robopon - Sun Version (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Robopon - Sun Version (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 32caef11 sha1 399c928a38a3901b7a1093bd61f5a4d8c05b9771 flags verified ) + name "Wizardry Empire - Fukkatsu no Tsue (Japan)" + description "Wizardry Empire - Fukkatsu no Tsue (Japan)" + rom ( name "Wizardry Empire - Fukkatsu no Tsue (Japan).gbc" size 1048576 crc 1a10552b sha1 07a197f0b5e2ab6379faa95eb1e7a519e1306e09 ) ) game ( - name "Robopon - Sun Version (USA) (Beta) (SGB Enhanced) (GB Compatible)" - description "Robopon - Sun Version (USA) (Beta) (SGB Enhanced) (GB Compatible)" - rom ( name "Robopon - Sun Version (USA) (Beta) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0b6985e4 sha1 30f36f420bec76126171b1139538de4017ed75ac ) + name "Wizardry I - Proving Grounds of the Mad Overlord (Japan)" + description "Wizardry I - Proving Grounds of the Mad Overlord (Japan)" + rom ( name "Wizardry I - Proving Grounds of the Mad Overlord (Japan).gbc" size 1048576 crc a99a33dc sha1 ecc073882d09a90fa1f02448c9ae44d43c8b81dc ) ) game ( - name "Robot Poncots - Comic Bom Bom Special Version (Japan) (SGB Enhanced) (GB Compatible)" - description "Robot Poncots - Comic Bom Bom Special Version (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Robot Poncots - Comic Bom Bom Special Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4aa209cd sha1 79d1eda07e792497506ff1494e5222db2a52702f flags verified ) + name "Wizardry II - Llylgamyn no Isan (Japan)" + description "Wizardry II - Llylgamyn no Isan (Japan)" + rom ( name "Wizardry II - Llylgamyn no Isan (Japan).gbc" size 1048576 crc dd727f1a sha1 2ebfcf6de50f1dea2b96730967b2351e5aa58be9 ) ) game ( - name "Robot Poncots - Moon Version (Japan) (SGB Enhanced) (GB Compatible)" - description "Robot Poncots - Moon Version (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Robot Poncots - Moon Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 87a29030 sha1 7d6424bfecfeb17aee9f779dcb9bac47114730cd flags verified ) + name "Wizardry III - Diamond no Kishi (Japan)" + description "Wizardry III - Diamond no Kishi (Japan)" + rom ( name "Wizardry III - Diamond no Kishi (Japan).gbc" size 1048576 crc d44d3596 sha1 f850ddbbfc8a77d53948de805819b4457380b390 ) ) game ( - name "Robot Poncots - Star Version (Japan) (SGB Enhanced) (GB Compatible)" - description "Robot Poncots - Star Version (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Robot Poncots - Star Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b28f32ac sha1 27a96410b38e695d9b80ae861af3b472f0e84c60 flags verified ) + name "Woody Woodpecker (Europe) (En,Fr,De,Es,It)" + description "Woody Woodpecker (Europe) (En,Fr,De,Es,It)" + rom ( name "Woody Woodpecker (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 2612f8c4 sha1 363111c56bd301a4a4f3b921b5d1ddc65b856699 ) ) game ( - name "Robot Poncots - Sun Version (Japan) (SGB Enhanced) (GB Compatible)" - description "Robot Poncots - Sun Version (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Robot Poncots - Sun Version (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc cb0b8003 sha1 2f82dd4a1537111d14f11eb13c7ce6fc748e83fe flags verified ) + name "Woody Woodpecker (USA)" + description "Woody Woodpecker (USA)" + rom ( name "Woody Woodpecker (USA).gbc" size 1048576 crc bd2d1f8b sha1 09a6363d98f441b57adb725cabde7feff74466e3 ) ) game ( - name "Robot Wars - Metal Mayhem (Europe) (En,Fr,De,It,Nl,Sv)" - description "Robot Wars - Metal Mayhem (Europe) (En,Fr,De,It,Nl,Sv)" - rom ( name "Robot Wars - Metal Mayhem (Europe) (En,Fr,De,It,Nl,Sv).gbc" size 1048576 crc e99bdee6 sha1 745a6d813ba561b53379a718312e7e8b6730c15f ) + name "Woody Woodpecker no Go! Go! Racing (Japan)" + description "Woody Woodpecker no Go! Go! Racing (Japan)" + rom ( name "Woody Woodpecker no Go! Go! Racing (Japan).gbc" size 1048576 crc f59daa99 sha1 42d841bdead319aa43d6bc09d88b4c32b4304ced ) ) game ( - name "Rocket Power - Gettin' Air (USA, Europe)" - description "Rocket Power - Gettin' Air (USA, Europe)" - rom ( name "Rocket Power - Gettin' Air (USA, Europe).gbc" size 1048576 crc 7025eb63 sha1 d9c5c22f1f5a2a922cb2b39d5e8f3df31c1155d7 flags verified ) + name "Woody Woodpecker Racing (Europe)" + description "Woody Woodpecker Racing (Europe)" + rom ( name "Woody Woodpecker Racing (Europe).gbc" size 1048576 crc b0f43498 sha1 47fbfbfb8af15ae388e8dbe2ac521960c2f835ae ) ) game ( - name "Rocket Power - La Glisse de l'Extreme (France)" - description "Rocket Power - La Glisse de l'Extreme (France)" - rom ( name "Rocket Power - La Glisse de l'Extreme (France).gbc" size 1048576 crc c9a7aa7b sha1 b6b9b7b2fb2ff11d41c6531fe21bfd5aa89f7ab4 ) + name "Woody Woodpecker Racing (USA)" + description "Woody Woodpecker Racing (USA)" + rom ( name "Woody Woodpecker Racing (USA).gbc" size 1048576 crc 0424cf43 sha1 be98d0a54aedcf59cddc111c72db66105aea1375 ) ) game ( - name "Rockman (World) (Aftermarket) (Unl)" - description "Rockman (World) (Aftermarket) (Unl)" - rom ( name "Rockman (World) (Aftermarket) (Unl).gbc" size 262144 crc 490b5676 sha1 6f78200acb6698e268e26c1912d64a002cbd3d89 ) + name "World Soccer GB 2 (Japan) (SGB Enhanced) (GB Compatible)" + description "World Soccer GB 2 (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "World Soccer GB 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc dd18db5f sha1 b58c969510aab4930a1846d857f58d57ed342592 ) ) game ( - name "Rockman 3 (Taiwan) (Unl)" - description "Rockman 3 (Taiwan) (Unl)" - rom ( name "Rockman 3 (Taiwan) (Unl).gbc" size 1048576 crc 46c5b31d sha1 70e5c1dae3bf0aee8dc901aba9e66751f2c1fc01 ) + name "World Soccer GB 2000 (Japan)" + description "World Soccer GB 2000 (Japan)" + rom ( name "World Soccer GB 2000 (Japan).gbc" size 2097152 crc 6775b29e sha1 22433fae69d7dd5b1ff351db579a1ee9e883f06f ) ) game ( - name "Rockman DX6 (Taiwan) (Unl)" - description "Rockman DX6 (Taiwan) (Unl)" - rom ( name "Rockman DX6 (Taiwan) (Unl).gbc" size 1048576 crc 154f885b sha1 222e8362da7a7eb999150c367a305271c60661b6 ) + name "Worms Armageddon (Europe) (En,Fr,De,Es,It,Nl)" + description "Worms Armageddon (Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Worms Armageddon (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc cb04f34d sha1 0bff9f46f2c455e98a5f0d9c0d560eda88d939de flags verified ) ) game ( - name "Rockman DX8 (Taiwan) (En) (Unl)" - description "Rockman DX8 (Taiwan) (En) (Unl)" - rom ( name "Rockman DX8 (Taiwan) (En) (Unl).gbc" size 1048576 crc 4c6c9eaf sha1 1274bb7d5570f4f1101dff1d13d9b5665deaa3da ) + name "Worms Armageddon (USA) (En,Fr,Es)" + description "Worms Armageddon (USA) (En,Fr,Es)" + rom ( name "Worms Armageddon (USA) (En,Fr,Es).gbc" size 1048576 crc e241edde sha1 ec587a3660298f95bf85f4471a626727b5fe6d7c ) ) game ( - name "Rockman X - Cyber Mission (Japan) (GB Compatible)" - description "Rockman X - Cyber Mission (Japan) (GB Compatible)" - rom ( name "Rockman X - Cyber Mission (Japan) (GB Compatible).gbc" size 1048576 crc 919077ab sha1 c47d50814489b7426ce110d35d1c059d0c24af21 ) + name "Worms Armageddon (Europe) (Beta)" + description "Worms Armageddon (Europe) (Beta)" + rom ( name "Worms Armageddon (Europe) (Beta).gbc" size 1048576 crc 66fda365 sha1 b0b14b13ec7cffb04efbf0dcdd93a2eea679ea0c ) ) game ( - name "Rockman X2 - Soul Eraser (Japan)" - description "Rockman X2 - Soul Eraser (Japan)" - rom ( name "Rockman X2 - Soul Eraser (Japan).gbc" size 1048576 crc 17913dd0 sha1 b7308301706c5414bb75f33232042124d9a608f1 ) + name "Worms Armageddon (World) (Limited Run Games)" + description "Worms Armageddon (World) (Limited Run Games)" + rom ( name "Worms Armageddon (World) (Limited Run Games).gbc" size 1048576 crc 626dfadb sha1 5fce1d1b6a7cfa994808d473602f569537dc0231 ) ) game ( - name "Rockman X3 (Taiwan) (Unl)" - description "Rockman X3 (Taiwan) (Unl)" - rom ( name "Rockman X3 (Taiwan) (Unl).gbc" size 524288 crc 7f4112a3 sha1 6c1d24162f2682bb6e82fb09639f2e311fda5aff ) + name "WWF Attitude (USA, Europe)" + description "WWF Attitude (USA, Europe)" + rom ( name "WWF Attitude (USA, Europe).gbc" size 1048576 crc d5fdf68a sha1 d5c37eabe3311666123b22f44a973c06d96bfce0 flags verified ) ) game ( - name "Rocky Mountain - Trophy Hunter (USA)" - description "Rocky Mountain - Trophy Hunter (USA)" - rom ( name "Rocky Mountain - Trophy Hunter (USA).gbc" size 1048576 crc 9aa5b021 sha1 864bbf4437ea1210e9e3012b290659af765c87b4 ) + name "WWF Betrayal (USA, Europe)" + description "WWF Betrayal (USA, Europe)" + rom ( name "WWF Betrayal (USA, Europe).gbc" size 1048576 crc 6c28bcb5 sha1 27773b6396ccb55051227ce7ce81d01c33ea75d1 ) ) game ( - name "Rocman X Gold + 4 in 1 (Taiwan) (1B-002, 4B-003, Sachen) (Unl)" - description "Rocman X Gold + 4 in 1 (Taiwan) (1B-002, 4B-003, Sachen) (Unl)" - rom ( name "Rocman X Gold + 4 in 1 (Taiwan) (1B-002, 4B-003, Sachen) (Unl).gbc" size 524288 crc 7e1351cf sha1 7e62472c13b5a6a933aa93dc5b239f11a664f337 ) + name "WWF WrestleMania 2000 (USA, Europe) (GB Compatible)" + description "WWF WrestleMania 2000 (USA, Europe) (GB Compatible)" + rom ( name "WWF WrestleMania 2000 (USA, Europe) (GB Compatible).gbc" size 1048576 crc fcba12ae sha1 ee9a375a16ca77883b7e30c92fc6beb8f772df5f flags verified ) ) game ( - name "Roi Lion, Le - La Formidable Aventure de Simba (France)" - description "Roi Lion, Le - La Formidable Aventure de Simba (France)" - rom ( name "Roi Lion, Le - La Formidable Aventure de Simba (France).gbc" size 1048576 crc 6467fba0 sha1 a0bef7df1ba3d75e7958763f0cec9c76428415df ) + name "X-Men - Mutant Academy (Japan)" + description "X-Men - Mutant Academy (Japan)" + rom ( name "X-Men - Mutant Academy (Japan).gbc" size 1048576 crc 8162adc1 sha1 3de082556a1ddd99149fa10ce4e219d64caf98f3 ) ) game ( - name "Roi Lion, Le - La Formidable Aventure de Simba (France) (Rev 1)" - description "Roi Lion, Le - La Formidable Aventure de Simba (France) (Rev 1)" - rom ( name "Roi Lion, Le - La Formidable Aventure de Simba (France) (Rev 1).gbc" size 1048576 crc c7aae1b3 sha1 b8cc2f1d3a8d40c7588d5c535f28e2f80446a793 ) + name "X-Men - Mutant Academy (USA, Europe)" + description "X-Men - Mutant Academy (USA, Europe)" + rom ( name "X-Men - Mutant Academy (USA, Europe).gbc" size 1048576 crc ec6278a3 sha1 6509f46a2f32df697d966bcafd72ec3d631a3ac5 flags verified ) ) game ( - name "Rokumon Tengai Mon-Colle-Knight GB (Japan)" - description "Rokumon Tengai Mon-Colle-Knight GB (Japan)" - rom ( name "Rokumon Tengai Mon-Colle-Knight GB (Japan).gbc" size 2097152 crc e48adf8d sha1 ab0a9630c16407549da28ff47ac4da33579975e4 ) + name "X-Men - Mutant Academy (USA, Europe) (Rev 1)" + description "X-Men - Mutant Academy (USA, Europe) (Rev 1)" + rom ( name "X-Men - Mutant Academy (USA, Europe) (Rev 1).gbc" size 1048576 crc 234e1e9c sha1 167770befb087c0f95cfe3c3efa3540c5f55a799 flags verified ) ) game ( - name "Roland Garros French Open (Europe) (En,Fr,De,Es,It,Nl)" - description "Roland Garros French Open (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Roland Garros French Open (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 10dbde7c sha1 86ab2d43e62f8a765992bdebe38b41a8d95ef5cb flags verified ) + name "X-Men - Mutant Wars (USA, Europe)" + description "X-Men - Mutant Wars (USA, Europe)" + rom ( name "X-Men - Mutant Wars (USA, Europe).gbc" size 1048576 crc 921999e2 sha1 0adaeef76db5a6df2786a45231e0934840f6eb44 ) ) game ( - name "Ronaldo V-Football (Europe) (En,Fr,De,Es,It,Nl,Pt) (GB Compatible)" - description "Ronaldo V-Football (Europe) (En,Fr,De,Es,It,Nl,Pt) (GB Compatible)" - rom ( name "Ronaldo V-Football (Europe) (En,Fr,De,Es,It,Nl,Pt) (GB Compatible).gbc" size 1048576 crc a856c066 sha1 33350360394904a03c069261cc53ab1381f326b7 ) + name "X-Men - Wolverine's Rage (Europe)" + description "X-Men - Wolverine's Rage (Europe)" + rom ( name "X-Men - Wolverine's Rage (Europe).gbc" size 1048576 crc 83ad5b99 sha1 6eeef0a72a453c26fa8c772c4036004986dc68f2 ) ) game ( - name "Ronaldo V-Soccer (USA) (En,Fr,Es,Pt) (GB Compatible)" - description "Ronaldo V-Soccer (USA) (En,Fr,Es,Pt) (GB Compatible)" - rom ( name "Ronaldo V-Soccer (USA) (En,Fr,Es,Pt) (GB Compatible).gbc" size 1048576 crc d0204f10 sha1 4558565434fb3527178a183d6c4c4fb1a132e3d2 ) + name "X-Men - Wolverine's Rage (USA)" + description "X-Men - Wolverine's Rage (USA)" + rom ( name "X-Men - Wolverine's Rage (USA).gbc" size 1048576 crc 12fc1a6e sha1 b7143367d71932ad525c5db94f5295686e6c58e5 ) ) game ( - name "Roswell Conspiracies - Aliens, Myths & Legends (Europe) (En,Fr,De)" - description "Roswell Conspiracies - Aliens, Myths & Legends (Europe) (En,Fr,De)" - rom ( name "Roswell Conspiracies - Aliens, Myths & Legends (Europe) (En,Fr,De).gbc" size 1048576 crc 49101556 sha1 9e0a431d3b9d046cc9e2339624631f756e2bc68e ) + name "Xena - Warrior Princess (USA, Europe) (En,Fr,De,Es,It,Nl)" + description "Xena - Warrior Princess (USA, Europe) (En,Fr,De,Es,It,Nl)" + rom ( name "Xena - Warrior Princess (USA, Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc f0de3ce7 sha1 1de53d445d898aa25b0472c604d5cfb052812070 ) ) game ( - name "Roswell Conspiracies - Aliens, Myths & Legends (USA) (En,Fr,De)" - description "Roswell Conspiracies - Aliens, Myths & Legends (USA) (En,Fr,De)" - rom ( name "Roswell Conspiracies - Aliens, Myths & Legends (USA) (En,Fr,De).gbc" size 1048576 crc 1f5ec131 sha1 ec27e608b2787dc18184be7a5a713a1d88403afd ) + name "Xian Dan Chaoren - Ultraman (Taiwan) (Unl)" + description "Xian Dan Chaoren - Ultraman (Taiwan) (Unl)" + rom ( name "Xian Dan Chaoren - Ultraman (Taiwan) (Unl).gbc" size 2097152 crc e81701e8 sha1 2a96a6f2164d80aa81eebdebc0d8f2ff45c3180f ) ) game ( - name "Rox (Japan) (En) (GB Compatible)" - description "Rox (Japan) (En) (GB Compatible)" - rom ( name "Rox (Japan) (En) (GB Compatible).gbc" size 262144 crc 4bd73d99 sha1 196eff1c40b3dc552e6fac9e16cc0f5f0e293434 ) + name "Xiao Taiji - Shenhua Lixian (Taiwan) (Unl)" + description "Xiao Taiji - Shenhua Lixian (Taiwan) (Unl)" + rom ( name "Xiao Taiji - Shenhua Lixian (Taiwan) (Unl).gbc" size 2097152 crc 322c3816 sha1 c89f8d19a52ab5f183a03d65680bf80d1af4a0ee ) ) game ( - name "Rox (USA, Europe) (GB Compatible)" - description "Rox (USA, Europe) (GB Compatible)" - rom ( name "Rox (USA, Europe) (GB Compatible).gbc" size 262144 crc 2e944775 sha1 86cb1f29e5d061431978d6dc48d7278b9c290cda ) + name "Xin Fengkuang A Gei Pao Pao Tang (Taiwan) (Unl)" + description "Xin Fengkuang A Gei Pao Pao Tang (Taiwan) (Unl)" + rom ( name "Xin Fengkuang A Gei Pao Pao Tang (Taiwan) (Unl).gbc" size 2097152 crc e40f757f sha1 6d1332456e10e9da78726415640117262fe53e99 ) ) game ( - name "RPG Tsukuru GB (Japan)" - description "RPG Tsukuru GB (Japan)" - rom ( name "RPG Tsukuru GB (Japan).gbc" size 2097152 crc 0b614307 sha1 119a0ab3d82fabbaff5949dacd6b77e20c7a8fb0 flags verified ) + name "Xin Fengshenbang (Taiwan) (Unl)" + description "Xin Fengshenbang (Taiwan) (Unl)" + rom ( name "Xin Fengshenbang (Taiwan) (Unl).gbc" size 2097152 crc cf8bd780 sha1 99344231bfe3f73dfb95766e0d02a43fbf2e4acc ) ) game ( - name "RPG Tsukuru GB (Japan) (Rev 1) (Possible Proto) (NP)" - description "RPG Tsukuru GB (Japan) (Rev 1) (Possible Proto) (NP)" - rom ( name "RPG Tsukuru GB (Japan) (Rev 1) (Possible Proto) (NP).gbc" size 2097152 crc 57f82031 sha1 f4c36b3cbb13d3cbaaa81e97b0636c4515ce501e ) + name "Xin Guangming Yu Hei'an 2 - Zhushen de Yichan (Taiwan) (Unl)" + description "Xin Guangming Yu Hei'an 2 - Zhushen de Yichan (Taiwan) (Unl)" + rom ( name "Xin Guangming Yu Hei'an 2 - Zhushen de Yichan (Taiwan) (Unl).gbc" size 1048576 crc 0881ed84 sha1 c1985e8a7a241af5a35748528b3e6a9d49b788e7 ) ) game ( - name "Ruby & Rusty Save the Crows (World) (Beta 1) (GB Compatible) (Aftermarket) (Unl)" - description "Ruby & Rusty Save the Crows (World) (Beta 1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Ruby & Rusty Save the Crows (World) (Beta 1) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc a46baa15 sha1 87dd5a6ccb5db59dae09f1953062420977ad2d92 ) + name "Xin Shediao Yingxiong Chuan (Taiwan) (Unl)" + description "Xin Shediao Yingxiong Chuan (Taiwan) (Unl)" + rom ( name "Xin Shediao Yingxiong Chuan (Taiwan) (Unl).gbc" size 1048576 crc 20e40d8f sha1 a11aa648810f3e69d3678d2c53137575bfbd34d6 ) ) game ( - name "Ruby & Rusty Save the Crows (World) (Beta 2) (GB Compatible) (Aftermarket) (Unl)" - description "Ruby & Rusty Save the Crows (World) (Beta 2) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Ruby & Rusty Save the Crows (World) (Beta 2) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 5602ca84 sha1 49d692796a6d0f3dcfc988648b446c0934f0e794 ) + name "Xin Shiqi Shidai (Taiwan) (Unl)" + description "Xin Shiqi Shidai (Taiwan) (Unl)" + rom ( name "Xin Shiqi Shidai (Taiwan) (Unl).gbc" size 2097152 crc f55342ca sha1 d51300e59c67f88dd2281ca53ae7c035489a723c ) ) game ( - name "Ruby & Rusty Save the Crows (World) (Beta 3) (GB Compatible) (Aftermarket) (Unl)" - description "Ruby & Rusty Save the Crows (World) (Beta 3) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Ruby & Rusty Save the Crows (World) (Beta 3) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc b2547aa6 sha1 981a464d6e1c9e5ac59549845b41dae4817ed3b8 ) + name "Xingqiu Dazhan II - Kelong Ren Zhanyi (Taiwan) (Unl)" + description "Xingqiu Dazhan II - Kelong Ren Zhanyi (Taiwan) (Unl)" + rom ( name "Xingqiu Dazhan II - Kelong Ren Zhanyi (Taiwan) (Unl).gbc" size 2097152 crc 6df86db6 sha1 b6089f2d1064d1851a89ffb20f8e2f8aeb5fe732 ) ) game ( - name "Ruby & Rusty Save the Crows (World) (v2.6) (GB Compatible) (Aftermarket) (Unl)" - description "Ruby & Rusty Save the Crows (World) (v2.6) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Ruby & Rusty Save the Crows (World) (v2.6) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c18f82cb sha1 bd8cd5822dcc61f7eb0cf2584c9a5b5a94bde14a ) + name "Xintiao Huiyi (Taiwan) (Unl)" + description "Xintiao Huiyi (Taiwan) (Unl)" + rom ( name "Xintiao Huiyi (Taiwan) (Unl).gbc" size 4194304 crc 104968e7 sha1 86e2b619976d22818e4a7c23d7f8a97e9358e51e ) ) game ( - name "Rugrats - Time Travelers (USA, Europe) (GB Compatible)" - description "Rugrats - Time Travelers (USA, Europe) (GB Compatible)" - rom ( name "Rugrats - Time Travelers (USA, Europe) (GB Compatible).gbc" size 1048576 crc 9c743f03 sha1 680b38692f9cbd1e9e37ccfe45c5f65817164ec2 flags verified ) + name "Xiyou Ji (Taiwan) (Unl)" + description "Xiyou Ji (Taiwan) (Unl)" + rom ( name "Xiyou Ji (Taiwan) (Unl).gbc" size 524288 crc f2fc4884 sha1 1f1bb35c47b8bd51edf9511513bb5e5e5e07eec1 ) ) game ( - name "Rugrats - Totally Angelica (USA, Europe)" - description "Rugrats - Totally Angelica (USA, Europe)" - rom ( name "Rugrats - Totally Angelica (USA, Europe).gbc" size 1048576 crc fc6195ef sha1 d4396a974aee16f74a5a80f4845c24dde5a083d6 flags verified ) + name "Xploder GB (Germany) (v1.2.2G) (GB Compatible) (Unl)" + description "Xploder GB (Germany) (v1.2.2G) (GB Compatible) (Unl)" + rom ( name "Xploder GB (Germany) (v1.2.2G) (GB Compatible) (Unl).gbc" size 131072 crc 7c69b507 sha1 44c1cf6f27239df825190f2ace803a9808534306 ) ) game ( - name "Rugrats - Typisch Angelica (Germany)" - description "Rugrats - Typisch Angelica (Germany)" - rom ( name "Rugrats - Typisch Angelica (Germany).gbc" size 1048576 crc 026c4794 sha1 a00f5eac5e6d50cf38bc3114a9d0d30a02d93e7c ) + name "Xploder GB (Europe) (v1.2.3E) (GB Compatible) (Unl)" + description "Xploder GB (Europe) (v1.2.3E) (GB Compatible) (Unl)" + rom ( name "Xploder GB (Europe) (v1.2.3E) (GB Compatible) (Unl).gbc" size 131072 crc 440bee17 sha1 80d46f4b105ec7b6ee7b062736d1d91db0f9575a ) ) game ( - name "Rugrats en Paris - La pelicula (Spain) (En,Es)" - description "Rugrats en Paris - La pelicula (Spain) (En,Es)" - rom ( name "Rugrats en Paris - La pelicula (Spain) (En,Es).gbc" size 1048576 crc 35323432 sha1 5aa140068f3460f027f155566534b19500ad30e9 ) + name "Xtreme Sports (USA)" + description "Xtreme Sports (USA)" + rom ( name "Xtreme Sports (USA).gbc" size 4194304 crc 19828751 sha1 ffca13207e6284a3cc16f7f130b68fca87663d08 ) ) game ( - name "Rugrats in Paris - The Movie (USA, Europe)" - description "Rugrats in Paris - The Movie (USA, Europe)" - rom ( name "Rugrats in Paris - The Movie (USA, Europe).gbc" size 1048576 crc 8b195237 sha1 f4cdc771299e9e6539443a9c9d62d3842877e618 flags verified ) + name "Xtreme Sports (World) (Switch)" + description "Xtreme Sports (World) (Switch)" + rom ( name "Xtreme Sports (World) (Switch).gbc" size 4194304 crc c0437e08 sha1 5da3ad1c5354f29a74c571c2b598da96213afbe1 flags verified ) ) game ( - name "Rugrats Movie, The (Europe) (SGB Enhanced) (GB Compatible)" - description "Rugrats Movie, The (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Rugrats Movie, The (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b4091600 sha1 29953d2d41fcb6ba4a78853a328dd01a6918ef8f flags verified ) + name "Xtreme Sports (World) (Limited Run Games)" + description "Xtreme Sports (World) (Limited Run Games)" + rom ( name "Xtreme Sports (World) (Limited Run Games).gbc" size 4194304 crc b8a3ecdd sha1 7ec1e0e88f4827c421dc91cff03ad7932bd652f5 ) ) game ( - name "Rugrats Movie, The (USA) (SGB Enhanced) (GB Compatible)" - description "Rugrats Movie, The (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Rugrats Movie, The (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc febe2606 sha1 c64ddf11c12d34f13d86e4a468b1eedacb698081 ) + name "Xtreme Wheels (Europe)" + description "Xtreme Wheels (Europe)" + rom ( name "Xtreme Wheels (Europe).gbc" size 1048576 crc e101246f sha1 7c1b43ac8f1e136b159f957613c1d4cda8a9360a ) ) game ( - name "Rumble & Tumble (USA) (Demo) (E3 2001)" - description "Rumble & Tumble (USA) (Demo) (E3 2001)" - rom ( name "Rumble & Tumble (USA) (Demo) (E3 2001).gbc" size 131072 crc 4400496d sha1 2429581d154ac04a12c99a24c2fd2c1b45a90807 ) + name "Xtreme Wheels (USA)" + description "Xtreme Wheels (USA)" + rom ( name "Xtreme Wheels (USA).gbc" size 1048576 crc 129465db sha1 07c1dc116c369b3ff73588251e0d09d50d040474 ) ) game ( - name "Runelords (USA) (Proto)" - description "Runelords (USA) (Proto)" - rom ( name "Runelords (USA) (Proto).gbc" size 4194304 crc 392af730 sha1 2bdcf8208cd0530c75195fd23f2f7839a3480bff ) + name "Xtreme Wheels (Japan) (Possible Proto) (NP)" + description "Xtreme Wheels (Japan) (Possible Proto) (NP)" + rom ( name "Xtreme Wheels (Japan) (Possible Proto) (NP).gbc" size 1048576 crc 30132ab8 sha1 a9f67640d20771e64b1474144fcca9beebdde85d ) ) game ( - name "RunieStory (World) (GB Showdown) (Aftermarket) (Unl)" - description "RunieStory (World) (GB Showdown) (Aftermarket) (Unl)" - rom ( name "RunieStory (World) (GB Showdown) (Aftermarket) (Unl).gbc" size 2097152 crc 96b1ceec sha1 771135edfbc64f7332a9cbd0d72af7a9d0d71f82 ) + name "Yakouchuu GB (Japan)" + description "Yakouchuu GB (Japan)" + rom ( name "Yakouchuu GB (Japan).gbc" size 2097152 crc e0a06018 sha1 a7efd41d0ad17892132788bd90cdfb9df6806a78 ) ) game ( - name "RunieStory (World) (Aftermarket) (Unl)" - description "RunieStory (World) (Aftermarket) (Unl)" - rom ( name "RunieStory (World) (Aftermarket) (Unl).gbc" size 2097152 crc 2249b449 sha1 0f6a391d7e05f66092a98e411069fab8e3f24221 ) + name "Yars' Revenge (USA, Europe) (GB Compatible)" + description "Yars' Revenge (USA, Europe) (GB Compatible)" + rom ( name "Yars' Revenge (USA, Europe) (GB Compatible).gbc" size 1048576 crc d6a26444 sha1 45fb176d539ae4a65af1f6340a9bd398dd7956d2 ) ) game ( - name "Runner (World) (Aftermarket) (Unl)" - description "Runner (World) (Aftermarket) (Unl)" - rom ( name "Runner (World) (Aftermarket) (Unl).gbc" size 262144 crc 4cd8ccb2 sha1 da735d415ed463a953bac45f4793342bd9be2e96 ) + name "Yin Ban Zhongwen RPG Zhanlve + Dongzuo + Yizhi 12 in 1 (Taiwan) (Unl)" + description "Yin Ban Zhongwen RPG Zhanlve + Dongzuo + Yizhi 12 in 1 (Taiwan) (Unl)" + rom ( name "Yin Ban Zhongwen RPG Zhanlve + Dongzuo + Yizhi 12 in 1 (Taiwan) (Unl).gbc" size 8388608 crc dc3171ad sha1 bfb93e7b4b523ef21c2b98ba9dcb15eb7d4f07e4 ) ) game ( - name "Saban's Power Rangers - Lightspeed Rescue (USA, Europe)" - description "Saban's Power Rangers - Lightspeed Rescue (USA, Europe)" - rom ( name "Saban's Power Rangers - Lightspeed Rescue (USA, Europe).gbc" size 1048576 crc 99869172 sha1 e7d0f2f21cdcda49516f682092d0b2017e82d379 ) + name "Yinghan Zidian (Taiwan) (Unl)" + description "Yinghan Zidian (Taiwan) (Unl)" + rom ( name "Yinghan Zidian (Taiwan) (Unl).gbc" size 1048576 crc 87158db6 sha1 5d42f3b769176df569a99c167c67e685c70501e1 ) ) game ( - name "Saban's Power Rangers - Time Force (USA, Europe)" - description "Saban's Power Rangers - Time Force (USA, Europe)" - rom ( name "Saban's Power Rangers - Time Force (USA, Europe).gbc" size 1048576 crc 17e51443 sha1 9c383013c5ec0e1f2c33b95d66cd93a3d0743928 flags verified ) + name "Yingxiong Jian 2 (Taiwan) (Unl)" + description "Yingxiong Jian 2 (Taiwan) (Unl)" + rom ( name "Yingxiong Jian 2 (Taiwan) (Unl).gbc" size 2097152 crc 786eb7a4 sha1 3920e7d5a900981d6877ef99b5f3bed8a061c31f ) ) game ( - name "Sabrina - The Animated Series - Spooked! (USA, Europe)" - description "Sabrina - The Animated Series - Spooked! (USA, Europe)" - rom ( name "Sabrina - The Animated Series - Spooked! (USA, Europe).gbc" size 1048576 crc 2cf48188 sha1 7a219159ef46c5ef88eb6b478667c2ec80194edc flags verified ) + name "Yingxiong Tianxia (Taiwan) (Zh) (Unl)" + description "Yingxiong Tianxia (Taiwan) (Zh) (Unl)" + rom ( name "Yingxiong Tianxia (Taiwan) (Zh) (Unl).gbc" size 2097152 crc 5f2d6317 sha1 41f5f0c11e4e99b7d2d1433b09922a0fd2c48d7f ) ) game ( - name "Sabrina - The Animated Series - Zapped! (Europe) (En,Fr,De)" - description "Sabrina - The Animated Series - Zapped! (Europe) (En,Fr,De)" - rom ( name "Sabrina - The Animated Series - Zapped! (Europe) (En,Fr,De).gbc" size 2097152 crc 818f3af6 sha1 d2e207a07ffa7cd0cc5b168c95ad409cd3df3fa3 ) + name "Yinyang (Taiwan) (De) (Unl)" + description "Yinyang (Taiwan) (De) (Unl)" + rom ( name "Yinyang (Taiwan) (De) (Unl).gbc" size 2097152 crc 1dd042ab sha1 2da9f06d57dcd397d0333b5d85a26a593acea8b3 ) ) game ( - name "Sabrina - The Animated Series - Zapped! (USA, Europe)" - description "Sabrina - The Animated Series - Zapped! (USA, Europe)" - rom ( name "Sabrina - The Animated Series - Zapped! (USA, Europe).gbc" size 2097152 crc 5d39a9b0 sha1 099e2ec855f47344f5d188cc57f540c88cdb33fd ) + name "Yixing VS Tiexue Zhanshi (Taiwan) (Unl)" + description "Yixing VS Tiexue Zhanshi (Taiwan) (Unl)" + rom ( name "Yixing VS Tiexue Zhanshi (Taiwan) (Unl).gbc" size 2097152 crc 45b048ee sha1 5ab50c386a0d9644f0d0337b6a1db22f5cb6ceb9 ) ) game ( - name "Sakata Gorou Kudan no Renju Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible)" - description "Sakata Gorou Kudan no Renju Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Sakata Gorou Kudan no Renju Kyoushitsu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc b5412c6f sha1 f2330533b10c22e98c140bb550827618985253cb ) + name "Yogi Bear - Great Balloon Blast (USA)" + description "Yogi Bear - Great Balloon Blast (USA)" + rom ( name "Yogi Bear - Great Balloon Blast (USA).gbc" size 1048576 crc f817e978 sha1 ef3583e3b4092726d1875c4613f65c65fcbd26e6 ) ) game ( - name "Sakura Taisen GB - Geki Hana Gumi Nyuutai! (Japan)" - description "Sakura Taisen GB - Geki Hana Gumi Nyuutai! (Japan)" - rom ( name "Sakura Taisen GB - Geki Hana Gumi Nyuutai! (Japan).gbc" size 4194304 crc ef503d50 sha1 4e30a9b06b5048449057376c8f37b3f687fabd18 ) + name "Yongzhe Dou E Long VIII (Taiwan) (Unl)" + description "Yongzhe Dou E Long VIII (Taiwan) (Unl)" + rom ( name "Yongzhe Dou E Long VIII (Taiwan) (Unl).gbc" size 2097152 crc 8b8b84ec sha1 d71788eabb4d2535e31773338523a721e2784bb5 ) ) game ( - name "Sakura Taisen GB 2 - Thunderbolt Sakusen (Japan)" - description "Sakura Taisen GB 2 - Thunderbolt Sakusen (Japan)" - rom ( name "Sakura Taisen GB 2 - Thunderbolt Sakusen (Japan).gbc" size 4194304 crc 47636a2c sha1 13092603ea1d54264bc48f02c2796947badb462c ) + name "Yu-Gi-Oh! - Dark Duel Stories (Europe)" + description "Yu-Gi-Oh! - Dark Duel Stories (Europe)" + rom ( name "Yu-Gi-Oh! - Dark Duel Stories (Europe).gbc" size 4194304 crc 338e2cda sha1 86d3dfc1b852c34df1be90a24a41b5d4d5c4ca54 ) ) game ( - name "Sam the Optimistic Hedgehog (World) (2023-01-16) (GB Compatible) (Aftermarket) (Unl)" - description "Sam the Optimistic Hedgehog (World) (2023-01-16) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Sam the Optimistic Hedgehog (World) (2023-01-16) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 4e4af60b sha1 ab8d49a99d02eb5c97d75f62dfb3720eec2b5abd ) + name "Yu-Gi-Oh! - Dark Duel Stories (USA)" + description "Yu-Gi-Oh! - Dark Duel Stories (USA)" + rom ( name "Yu-Gi-Oh! - Dark Duel Stories (USA).gbc" size 4194304 crc 803a56ae sha1 1952d343bdfb5625bd23a8569cde6fd61a911502 flags verified ) ) game ( - name "Sam the Optimistic Hedgehog (World) (2023-01-21) (GB Compatible) (Aftermarket) (Unl)" - description "Sam the Optimistic Hedgehog (World) (2023-01-21) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Sam the Optimistic Hedgehog (World) (2023-01-21) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 40dc168d sha1 af25acc86f0eef4ce72199383b96fcb4c9f0115e ) + name "Yu-Gi-Oh! - Dark Duel Stories (Europe) (Beta)" + description "Yu-Gi-Oh! - Dark Duel Stories (Europe) (Beta)" + rom ( name "Yu-Gi-Oh! - Dark Duel Stories (Europe) (Beta).gbc" size 4194304 crc 1a60f198 sha1 f16e2d8d2ce20149c208621c3aa1309f80ce2390 ) ) game ( - name "Samurai Kid (Japan)" - description "Samurai Kid (Japan)" - rom ( name "Samurai Kid (Japan).gbc" size 1048576 crc 44a9ddfb sha1 42834c6a1ea9a0e1d73bb01ac83a4bc504c86c4e ) + name "Yu-Gi-Oh! - Das Dunkle Duell (Germany)" + description "Yu-Gi-Oh! - Das Dunkle Duell (Germany)" + rom ( name "Yu-Gi-Oh! - Das Dunkle Duell (Germany).gbc" size 4194304 crc 6ca75ba0 sha1 55391ae4c27efc4efe0a43bda8e791bbbb888dd8 flags verified ) ) game ( - name "San Francisco Rush - Extreme Racing (USA) (Proto)" - description "San Francisco Rush - Extreme Racing (USA) (Proto)" - rom ( name "San Francisco Rush - Extreme Racing (USA) (Proto).gbc" size 524288 crc 4d26ea38 sha1 4d48a6cd886543bae555d0dc4b8012e13c7cdb55 ) + name "Yu-Gi-Oh! - Duel des Tenebres (France)" + description "Yu-Gi-Oh! - Duel des Tenebres (France)" + rom ( name "Yu-Gi-Oh! - Duel des Tenebres (France).gbc" size 4194304 crc 5b72bab5 sha1 566e9c4a02efd2e15c8758d0a6aab4519b6af102 flags verified ) ) game ( - name "San Francisco Rush 2049 (USA, Europe)" - description "San Francisco Rush 2049 (USA, Europe)" - rom ( name "San Francisco Rush 2049 (USA, Europe).gbc" size 1048576 crc ef368f16 sha1 b783b770e6680745dcc0b599199a4429957c874e flags verified ) + name "Yu-Gi-Oh! - Duel des Tenebres (France) (Beta)" + description "Yu-Gi-Oh! - Duel des Tenebres (France) (Beta)" + rom ( name "Yu-Gi-Oh! - Duel des Tenebres (France) (Beta).gbc" size 4194304 crc c0dd1b26 sha1 7b44bee756fa5c81e050438f81f97fe56884a45d ) ) game ( - name "San Guo Wushang 5 (Taiwan) (Unl)" - description "San Guo Wushang 5 (Taiwan) (Unl)" - rom ( name "San Guo Wushang 5 (Taiwan) (Unl).gbc" size 2097152 crc 8a64c933 sha1 e97508fa49564d56550ad467f4c543f3f218db76 ) + name "Yu-Gi-Oh! - Duelo en las Tinieblas (Spain)" + description "Yu-Gi-Oh! - Duelo en las Tinieblas (Spain)" + rom ( name "Yu-Gi-Oh! - Duelo en las Tinieblas (Spain).gbc" size 4194304 crc dc160f10 sha1 73bc0b9ce57ac806bfefcd830c44eec42a3e7adf ) ) game ( - name "Sangokushi - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Sangokushi - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Sangokushi - Game Boy Ban 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e787b44c sha1 ec6089ff2cfcb17faf6a8ea9a4171869b3c7289b ) + name "Yu-Gi-Oh! - Monster Capsule GB (Japan) (SGB Enhanced) (GB Compatible)" + description "Yu-Gi-Oh! - Monster Capsule GB (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Yu-Gi-Oh! - Monster Capsule GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1371e872 sha1 4ed5607dd83ebe7975c492b08d36870f8dd6e302 ) ) game ( - name "Sanguozhi - Aoshi Tianxia (Taiwan) (Unl)" - description "Sanguozhi - Aoshi Tianxia (Taiwan) (Unl)" - rom ( name "Sanguozhi - Aoshi Tianxia (Taiwan) (Unl).gbc" size 1048576 crc 728255e5 sha1 d9a978c6b4745d964128eb0eced022337849467c ) + name "Yu-Gi-Oh! - Racconti Oscuri (Italy)" + description "Yu-Gi-Oh! - Racconti Oscuri (Italy)" + rom ( name "Yu-Gi-Oh! - Racconti Oscuri (Italy).gbc" size 4194304 crc 8a6b0948 sha1 bf4d4e4450fbbc97efface042684341947e626a9 ) ) game ( - name "Sanguozhi Wudai (Taiwan) (Unl)" - description "Sanguozhi Wudai (Taiwan) (Unl)" - rom ( name "Sanguozhi Wudai (Taiwan) (Unl).gbc" size 2097152 crc de136996 sha1 8e476e9db9caceb52d048b28163227d987a09a21 ) + name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Jounouchi Deck (Japan)" + description "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Jounouchi Deck (Japan)" + rom ( name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Jounouchi Deck (Japan).gbc" size 4194304 crc 298bd054 sha1 2fdf56c2b52ba83fee778f3c2961a90ab69ea899 flags verified ) ) game ( - name "Sanrio Timenet - Kako Hen (Japan) (SGB Enhanced) (GB Compatible)" - description "Sanrio Timenet - Kako Hen (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Sanrio Timenet - Kako Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 458b579d sha1 8421e0d0fc356b25df62cde1967e7775a91983c2 ) + name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Kaiba Deck (Japan)" + description "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Kaiba Deck (Japan)" + rom ( name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Kaiba Deck (Japan).gbc" size 4194304 crc a4d06001 sha1 ee769a23750e48c5ba4949f83236b18814316de2 flags verified ) ) game ( - name "Sanrio Timenet - Kako Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Sanrio Timenet - Kako Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Sanrio Timenet - Kako Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6555b740 sha1 b3b80b4a48faec9cc71d80a6b08b12b3541b4c1b flags verified ) + name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Yuugi Deck (Japan)" + description "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Yuugi Deck (Japan)" + rom ( name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Yuugi Deck (Japan).gbc" size 4194304 crc 4d6105f6 sha1 3199283039089fdf1e1b3cbb5b95fe7b26c6765f flags verified ) ) game ( - name "Sanrio Timenet - Mirai Hen (Japan) (SGB Enhanced) (GB Compatible)" - description "Sanrio Timenet - Mirai Hen (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Sanrio Timenet - Mirai Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc efe51e17 sha1 65c4113401336784be4c53a51fe8d9b4b3d287da flags verified ) + name "Yu-Gi-Oh! Duel Monsters II - Dark Duel Stories (Japan) (SGB Enhanced) (GB Compatible)" + description "Yu-Gi-Oh! Duel Monsters II - Dark Duel Stories (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Yu-Gi-Oh! Duel Monsters II - Dark Duel Stories (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc ba7182c3 sha1 6a96c30c1f9ecc207f962ec156f6d22a652ae41d flags verified ) ) game ( - name "Sanrio Timenet - Mirai Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Sanrio Timenet - Mirai Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Sanrio Timenet - Mirai Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 179da7f3 sha1 5ccaf8450862dab90b45b06ab2df291d72ea6033 flags verified ) + name "Yu-Gi-Oh! Duel Monsters III - Tri Holy God Advant (Japan)" + description "Yu-Gi-Oh! Duel Monsters III - Tri Holy God Advant (Japan)" + rom ( name "Yu-Gi-Oh! Duel Monsters III - Tri Holy God Advant (Japan).gbc" size 4194304 crc 9f9dbab4 sha1 dc4753a2f12360d921a147287673b4448394a9d3 flags verified ) ) game ( - name "Santa Claus Junior (Europe)" - description "Santa Claus Junior (Europe)" - rom ( name "Santa Claus Junior (Europe).gbc" size 1048576 crc a744df64 sha1 ab74474cd63a2c74bf9617907270d26b5d183b89 ) + name "Yuenan Zhanyi - Chong Jian Tian Ri (Taiwan) (Unl)" + description "Yuenan Zhanyi - Chong Jian Tian Ri (Taiwan) (Unl)" + rom ( name "Yuenan Zhanyi - Chong Jian Tian Ri (Taiwan) (Unl).gbc" size 2097152 crc c19b912a sha1 09b0f8fe8c7948e847ad01f24d05513c49b77ad5 ) ) game ( - name "Sapphire Hotel - The Little Tales of (World) (v1.2) (Demo) (MBC5) (GB Compatible) (Aftermarket) (Unl)" - description "Sapphire Hotel - The Little Tales of (World) (v1.2) (Demo) (MBC5) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Sapphire Hotel - The Little Tales of (World) (v1.2) (Demo) (MBC5) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc db928e22 sha1 e175d35e6112c347ecd1e0a379e98f430823ba94 ) + name "Yuenan Zhanyi 3 (Taiwan) (Unl)" + description "Yuenan Zhanyi 3 (Taiwan) (Unl)" + rom ( name "Yuenan Zhanyi 3 (Taiwan) (Unl).gbc" size 2097152 crc 9268bb9f sha1 17ceb35582c89303f206eb7e93cbfe8a4c2b5aaa ) ) game ( - name "Saru Puncher (Japan) (SGB Enhanced) (GB Compatible)" - description "Saru Puncher (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Saru Puncher (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b02564fc sha1 db7cc42b4e2a181c31caa4ae8635ec33b5a09f73 ) + name "Yuenan Zhanyi X - Shenru Dihou (Taiwan) (Unl)" + description "Yuenan Zhanyi X - Shenru Dihou (Taiwan) (Unl)" + rom ( name "Yuenan Zhanyi X - Shenru Dihou (Taiwan) (Unl).gbc" size 2097152 crc 602951a6 sha1 6703e9f68b989c976e93bd2eb63f884ceaff63f1 ) ) game ( - name "Scooby-Doo! - Classic Creep Capers (USA, Europe)" - description "Scooby-Doo! - Classic Creep Capers (USA, Europe)" - rom ( name "Scooby-Doo! - Classic Creep Capers (USA, Europe).gbc" size 1048576 crc e3704755 sha1 f45b42e92e9a570658a2790854578d3766f8c14f flags verified ) + name "Zebco Fishing! (USA) (Rumble Version)" + description "Zebco Fishing! (USA) (Rumble Version)" + rom ( name "Zebco Fishing! (USA) (Rumble Version).gbc" size 1048576 crc 3cc6b1f9 sha1 9b6c536b403c62af102e3800658c9dec258be249 flags verified ) ) game ( - name "Scrabble (Europe)" - description "Scrabble (Europe)" - rom ( name "Scrabble (Europe).gbc" size 1048576 crc 998657b7 sha1 ae24e07e8906bae07661cf5b8f50cd9b86a5c94d ) + name "Zelda no Densetsu - Fushigi no Kinomi - Daichi no Shou (Japan)" + description "Zelda no Densetsu - Fushigi no Kinomi - Daichi no Shou (Japan)" + rom ( name "Zelda no Densetsu - Fushigi no Kinomi - Daichi no Shou (Japan).gbc" size 1048576 crc e42538f0 sha1 08bf49d7e225c695f64d38131cb720decb84b663 flags verified ) ) game ( - name "SD Hiryuu no Ken EX (Japan) (SGB Enhanced) (GB Compatible)" - description "SD Hiryuu no Ken EX (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "SD Hiryuu no Ken EX (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 365bf43f sha1 bed7b913a395ae4b62eac39ff8d6b3093529ed45 ) + name "Zelda no Densetsu - Fushigi no Kinomi - Jikuu no Shou (Japan)" + description "Zelda no Densetsu - Fushigi no Kinomi - Jikuu no Shou (Japan)" + rom ( name "Zelda no Densetsu - Fushigi no Kinomi - Jikuu no Shou (Japan).gbc" size 1048576 crc 3272e6f9 sha1 596aa066ccee9fae71643576f7526baa22d26d6d flags verified ) ) game ( - name "Sea-Doo HydroCross (USA) (Proto)" - description "Sea-Doo HydroCross (USA) (Proto)" - rom ( name "Sea-Doo HydroCross (USA) (Proto).gbc" size 1048576 crc fb1783f3 sha1 3612e549ba2a71585fc9a57033c97562386cdea4 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (SGB Enhanced) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d974abea sha1 b810925bf9d9f4f6cd97c5e46c94c1a9dd61a113 ) ) game ( - name "Second Edition Harry Boy, The - The Secret of the Chamber of Secrets (USA) (Unl)" - description "Second Edition Harry Boy, The - The Secret of the Chamber of Secrets (USA) (Unl)" - rom ( name "Second Edition Harry Boy, The - The Secret of the Chamber of Secrets (USA) (Unl).gbc" size 2097152 crc cba2c784 sha1 99d852998fa84c8c0160cc9dfb2e2165a94756ca ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc bd8a1041 sha1 d3de302d44bdb240bcf55a5dc70f491f5456d721 flags verified ) ) game ( - name "Sei Hai Densetsu (Japan) (SGB Enhanced) (GB Compatible)" - description "Sei Hai Densetsu (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Sei Hai Densetsu (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 8804f856 sha1 0840846bd0a3956fc49b5c7aec598ade93e3ff77 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (SGB Enhanced) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (SGB Enhanced) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e998e595 sha1 5fdffae3caef63a9fb295bcbd38f923190254e01 flags verified ) ) game ( - name "Seme COM Dungeon - Drururuaga (Japan) (GB Compatible)" - description "Seme COM Dungeon - Drururuaga (Japan) (GB Compatible)" - rom ( name "Seme COM Dungeon - Drururuaga (Japan) (GB Compatible).gbc" size 2097152 crc 0b1b928c sha1 24b9bea003a5653ff592d3d63f5ac116c1de2d60 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-30) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-30) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-30) (GB Compatible).gbc" size 1048576 crc f46f0ced sha1 99d587b4baf363a798fdb8c1fca42fe1be061c2f ) ) game ( - name "Senkai Ibunroku Juntei Taisen - TV Animation Senkaiden Houshin Engi Yori (Japan) (SGB Enhanced) (GB Compatible)" - description "Senkai Ibunroku Juntei Taisen - TV Animation Senkaiden Houshin Engi Yori (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Senkai Ibunroku Juntei Taisen - TV Animation Senkaiden Houshin Engi Yori (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 23fa5f53 sha1 c10249ef96a1989c3532a48917862b4dd8bad12a ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T180056) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T180056) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T180056) (GB Compatible).gbc" size 1048576 crc 11290c31 sha1 8d7ab85686ced1642b9519bcb6a3e157c6bd8938 ) ) game ( - name "Sesame Street - Elmo's 123s (Europe) (GB Compatible)" - description "Sesame Street - Elmo's 123s (Europe) (GB Compatible)" - rom ( name "Sesame Street - Elmo's 123s (Europe) (GB Compatible).gbc" size 1048576 crc 3bf7fcd4 sha1 841bda2e2c1542c44b45c98a390ba3320ef735cc ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T215532) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T215532) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T215532) (GB Compatible).gbc" size 1048576 crc 3c63e083 sha1 a068abd403a1dad70bd9b53d215995f8159aea47 ) ) game ( - name "Sesame Street - Elmo's 123s (USA) (GB Compatible)" - description "Sesame Street - Elmo's 123s (USA) (GB Compatible)" - rom ( name "Sesame Street - Elmo's 123s (USA) (GB Compatible).gbc" size 262144 crc 1833fb38 sha1 0aca4297ec6dc582b668681452f1805aab991bec ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-07) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-07) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-07) (GB Compatible).gbc" size 1048576 crc 879cdf7d sha1 0b6f595e5f306099d5c1bd7aab1156c2a9c917a1 ) ) game ( - name "Sesame Street - Elmo's ABCs (USA) (GB Compatible)" - description "Sesame Street - Elmo's ABCs (USA) (GB Compatible)" - rom ( name "Sesame Street - Elmo's ABCs (USA) (GB Compatible).gbc" size 262144 crc cc1fb2a9 sha1 c63ea7ff94250f1f7514a01250bbd5f04a5d2037 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T022124) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T022124) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T022124) (GB Compatible).gbc" size 1048576 crc 13c76902 sha1 08dea3565740a4b5bd5c13e82adb61e3d5669a31 ) ) game ( - name "Sesame Street - Elmo's ABCs (Europe) (GB Compatible)" - description "Sesame Street - Elmo's ABCs (Europe) (GB Compatible)" - rom ( name "Sesame Street - Elmo's ABCs (Europe) (GB Compatible).gbc" size 1048576 crc 20158fbc sha1 e98d4d4179ca13c22d0205f118470ecc795928b1 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-02) (SGB Enhanced)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-02) (SGB Enhanced)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-02) (SGB Enhanced).gbc" size 1048576 crc 34ff47ba sha1 5ccc4c05123b4c38d0d93916ae8a0c93fb63f23f ) ) game ( - name "Sesame Street - The Adventures of Elmo in Grouchland (Europe) (GB Compatible)" - description "Sesame Street - The Adventures of Elmo in Grouchland (Europe) (GB Compatible)" - rom ( name "Sesame Street - The Adventures of Elmo in Grouchland (Europe) (GB Compatible).gbc" size 1048576 crc 41228ee7 sha1 af1c3912da946d858f9eeb10a3b9d95cbb6a00d8 flags verified ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-03) (SGB Enhanced)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-03) (SGB Enhanced)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-03) (SGB Enhanced).gbc" size 1048576 crc ac0ef411 sha1 5aeb68b00a3a4f391afb324d9513311cb796a51f ) ) game ( - name "Sesame Street - The Adventures of Elmo in Grouchland (USA) (GB Compatible)" - description "Sesame Street - The Adventures of Elmo in Grouchland (USA) (GB Compatible)" - rom ( name "Sesame Street - The Adventures of Elmo in Grouchland (USA) (GB Compatible).gbc" size 262144 crc 2c4c2a5f sha1 60f240476d2fac81b1efb83e1128e6223c766f15 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-04) (SGB Enhanced)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-04) (SGB Enhanced)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-04) (SGB Enhanced).gbc" size 1048576 crc 260bd98a sha1 ce1e48c82a09de0f93d5a60016318a9116331ccb ) ) game ( - name "Sesame Street Sports (USA)" - description "Sesame Street Sports (USA)" - rom ( name "Sesame Street Sports (USA).gbc" size 1048576 crc 4ed4aafa sha1 c5f4d432f37a261da5d11426a36893718ef94b86 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced).gbc" size 1048576 crc 883ef4ef sha1 87ca50396ba25914131866c74633afbe0007b2fb ) ) game ( - name "Sesame Street Sports (Europe)" - description "Sesame Street Sports (Europe)" - rom ( name "Sesame Street Sports (Europe).gbc" size 1048576 crc 55be1a6e sha1 2cf168dbaa51c1a0d49e6ab776872a0d2d5ced42 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced).gbc" size 1048576 crc 89a4a355 sha1 48931a00f5fec39492c264e9979646e88242c53e ) ) game ( - name "Sewing Machine Operation Software (USA) (En,Fr,Es) (GB Compatible)" - description "Sewing Machine Operation Software (USA) (En,Fr,Es) (GB Compatible)" - rom ( name "Sewing Machine Operation Software (USA) (En,Fr,Es) (GB Compatible).gbc" size 1048576 crc e42fd7c4 sha1 a05a67f2d29bf29c56c9533c172da02ee0ad26b1 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt).gbc" size 1048576 crc e5312966 sha1 fedd0fa70bbf5039dfec37b8e27674be839c47ca ) ) game ( - name "Sewing Machine Operation Software (Europe) (En,Fr,De,It) (GB Compatible)" - description "Sewing Machine Operation Software (Europe) (En,Fr,De,It) (GB Compatible)" - rom ( name "Sewing Machine Operation Software (Europe) (En,Fr,De,It) (GB Compatible).gbc" size 1048576 crc d8433dee sha1 4b12589fb14932381afa8433130d684120c5e3cd flags verified ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt 2)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt 2)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt 2).gbc" size 1048576 crc 1c374afd sha1 800db3d07a7abcca2138a0c7808cf25386e87712 ) ) game ( - name "Sewing Machine Operation Software (Europe) (En,De,It,Nl) (Proto) (GB Compatible)" - description "Sewing Machine Operation Software (Europe) (En,De,It,Nl) (Proto) (GB Compatible)" - rom ( name "Sewing Machine Operation Software (Europe) (En,De,It,Nl) (Proto) (GB Compatible).gbc" size 1048576 crc 9f1dbedd sha1 35d242fbbde2f6f1fb869fd68396e6be4aad8f9b ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible).gbc" size 1048576 crc 3fd6c8fc sha1 017b81b26fc37db662063482e3947dfc2d814390 ) ) game ( - name "Sewing Machine Operation Software (Europe) (En,Fr,Es,Pt) (Proto) (GB Compatible)" - description "Sewing Machine Operation Software (Europe) (En,Fr,Es,Pt) (Proto) (GB Compatible)" - rom ( name "Sewing Machine Operation Software (Europe) (En,Fr,Es,Pt) (Proto) (GB Compatible).gbc" size 1048576 crc e34b5ce8 sha1 500439c5e14400ef2bc45cacf5ff834b70c2acd4 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible) (Alt)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible) (Alt)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible) (Alt).gbc" size 1048576 crc 9367653b sha1 544b803db49d8f312e193e4c105f0762d9e3fbf4 ) ) game ( - name "SGB Test Program (World) (1994.4) (Demo) (SGB Enhanced)" - description "SGB Test Program (World) (1994.4) (Demo) (SGB Enhanced)" - rom ( name "SGB Test Program (World) (1994.4) (Demo) (SGB Enhanced).gbc" size 49152 crc 8960ac1d sha1 a310a9629ce6ad0a607ac9e985056fe257f305b5 ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T181500) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T181500) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T181500) (GB Compatible).gbc" size 1048576 crc 2f884286 sha1 a7cb241de2139ddac5d1172a6ef1184b5fbb827e ) ) game ( - name "Sgt. Rock - On the Frontline (USA)" - description "Sgt. Rock - On the Frontline (USA)" - rom ( name "Sgt. Rock - On the Frontline (USA).gbc" size 1048576 crc 521a2f77 sha1 53d7fa6fdac65519f8a78f4a42e79e56162589ad ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-11-09) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-11-09) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-11-09) (GB Compatible).gbc" size 1048576 crc 3e5216c3 sha1 0fe1c48e36cb8e6e975c5421bf881c550746d29c ) ) game ( - name "Shadowgate Classic (USA, Europe) (En,Fr,De,Es,Sv) (GB Compatible)" - description "Shadowgate Classic (USA, Europe) (En,Fr,De,Es,Sv) (GB Compatible)" - rom ( name "Shadowgate Classic (USA, Europe) (En,Fr,De,Es,Sv) (GB Compatible).gbc" size 1048576 crc f6a876a5 sha1 4e0c0e15beac73913320f8ab68001f90f52beb92 flags verified ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 1) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 1) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 1) (GB Compatible).gbc" size 1048576 crc e05757f6 sha1 ee2df3c8449187fcd82f2fc830386bfe8144b387 ) ) game ( - name "Shadowgate Classic (Europe) (En,Fr,De,Es,Sv) (Rev 1) (GB Compatible)" - description "Shadowgate Classic (Europe) (En,Fr,De,Es,Sv) (Rev 1) (GB Compatible)" - rom ( name "Shadowgate Classic (Europe) (En,Fr,De,Es,Sv) (Rev 1) (GB Compatible).gbc" size 1048576 crc d337f450 sha1 b7343c9ce3343fa618a6c208969446b964dde5f5 flags verified ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 2) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 2) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 2) (GB Compatible).gbc" size 1048576 crc e6101132 sha1 515f8d2fcaebe9495fb21f46ec32cce877c35e56 ) ) game ( - name "Shadowgate Return (Japan) (GB Compatible)" - description "Shadowgate Return (Japan) (GB Compatible)" - rom ( name "Shadowgate Return (Japan) (GB Compatible).gbc" size 1048576 crc 1bcd7d70 sha1 15c4a88e7fbbeed6f529b86601285794e92ccf0c ) + name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" + description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" + rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible).gbc" size 1015808 crc c07979bf sha1 4a9ce5ced2234fa668dace888bd5d6130e375985 ) ) game ( - name "Shaman King Card Game - Chou Senjiryakketsu - Funbari Hen (Japan)" - description "Shaman King Card Game - Chou Senjiryakketsu - Funbari Hen (Japan)" - rom ( name "Shaman King Card Game - Chou Senjiryakketsu - Funbari Hen (Japan).gbc" size 4194304 crc ef10272e sha1 7b5aabc533784634ca210a2ed2b44ba136dc7276 ) + name "Zen-Nihon Shounen Soccer Taikai - Mezase Nihon Ichi! (Japan)" + description "Zen-Nihon Shounen Soccer Taikai - Mezase Nihon Ichi! (Japan)" + rom ( name "Zen-Nihon Shounen Soccer Taikai - Mezase Nihon Ichi! (Japan).gbc" size 2097152 crc efad8b34 sha1 bffe5fdb803f0872d1c0de9d152eb626c5b36147 ) ) game ( - name "Shaman King Card Game - Chou Senjiryakketsu - Meramera Hen (Japan)" - description "Shaman King Card Game - Chou Senjiryakketsu - Meramera Hen (Japan)" - rom ( name "Shaman King Card Game - Chou Senjiryakketsu - Meramera Hen (Japan).gbc" size 4194304 crc 5730393d sha1 03901428fe3a791a0078c9295aa4e41994282013 ) + name "Zhen Sanguo Wushuang 2 - Shin Sangokumusou (Taiwan) (Unl)" + description "Zhen Sanguo Wushuang 2 - Shin Sangokumusou (Taiwan) (Unl)" + rom ( name "Zhen Sanguo Wushuang 2 - Shin Sangokumusou (Taiwan) (Unl).gbc" size 2097152 crc 95c322c9 sha1 e6ab58d212de83cb18e9eadac4cee5d0f6e4e31f ) ) game ( - name "Shamus (USA, Europe) (GB Compatible)" - description "Shamus (USA, Europe) (GB Compatible)" - rom ( name "Shamus (USA, Europe) (GB Compatible).gbc" size 1048576 crc efb9196d sha1 66349abf080e85738875f22a86e0453e5b68f425 ) + name "Zhihuan Wang - Shoubu Qu (Taiwan) (Zh) (Unl)" + description "Zhihuan Wang - Shoubu Qu (Taiwan) (Zh) (Unl)" + rom ( name "Zhihuan Wang - Shoubu Qu (Taiwan) (Zh) (Unl).gbc" size 2097152 crc 8160b3f5 sha1 97d7e0d05205b02c6cb69e68978a3f0fd2e3fde0 ) ) game ( - name "Shanghai Pocket (Europe) (SGB Enhanced) (GB Compatible)" - description "Shanghai Pocket (Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Shanghai Pocket (Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 9401ba47 sha1 6436b152924a8612d7cd28fef09f10a81ec91ad7 ) + name "Zhihuan Wang 2 (China) (Zh) (Unl)" + description "Zhihuan Wang 2 (China) (Zh) (Unl)" + rom ( name "Zhihuan Wang 2 (China) (Zh) (Unl).gbc" size 524288 crc e6748d1f sha1 108c318a859b39e88d15b2e3dc4d26002286305f ) ) game ( - name "Shanghai Pocket (Europe) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Shanghai Pocket (Europe) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Shanghai Pocket (Europe) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d8fac36c sha1 adbf1a18dea69e46c3dbccec03e09668912f12a7 ) + name "Zhizhu Xia III - Dianying Ban (Taiwan) (Unl)" + description "Zhizhu Xia III - Dianying Ban (Taiwan) (Unl)" + rom ( name "Zhizhu Xia III - Dianying Ban (Taiwan) (Unl).gbc" size 2097152 crc d311efcc sha1 9eb0c468d5f898ef7b4d6ff74d7ff497b8c7818d ) ) game ( - name "Shanghai Pocket (USA) (SGB Enhanced) (GB Compatible)" - description "Shanghai Pocket (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Shanghai Pocket (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a5e3ece9 sha1 2058964274d8bd596bb81bc24e9cfe306411c803 ) + name "Zhong Zhuang Ji Bing (China) (Pirate)" + description "Zhong Zhuang Ji Bing (China) (Pirate)" + rom ( name "Zhong Zhuang Ji Bing (China) (Pirate).gbc" size 2097152 crc ad626c50 sha1 c3b3d8d43495ded5e4aff1b9416fe4d43b8e7453 ) ) game ( - name "Shanghai Pocket (USA) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible)" - description "Shanghai Pocket (USA) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible)" - rom ( name "Shanghai Pocket (USA) (Rev 1) (Proto) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d529dafd sha1 b36edbb0721fb71aafecd6f48609c14c1107e3f0 ) + name "Zidane - Football Generation (Europe) (En,Fr,De,Es,It)" + description "Zidane - Football Generation (Europe) (En,Fr,De,Es,It)" + rom ( name "Zidane - Football Generation (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc e96dbfb5 sha1 06385470bb0b4ef6c743ab6a5e7f8d7a97f6100b ) ) game ( - name "Shantae (USA)" - description "Shantae (USA)" - rom ( name "Shantae (USA).gbc" size 4194304 crc e994b59b sha1 520e48c50f6e997fcd841ca368fc9abc1dbddec1 flags verified ) + name "Zidane - Football Generation (Europe) (En,Fr,De,Es,It) (Beta)" + description "Zidane - Football Generation (Europe) (En,Fr,De,Es,It) (Beta)" + rom ( name "Zidane - Football Generation (Europe) (En,Fr,De,Es,It) (Beta).gbc" size 1048576 crc c2fde3c4 sha1 cba5d2fc5dbbe184e9ed58afe8525044bd8ea040 ) ) game ( - name "Shantae (USA) (Beta)" - description "Shantae (USA) (Beta)" - rom ( name "Shantae (USA) (Beta).gbc" size 4194304 crc 3b4d6c50 sha1 141dc57955e84d51f0099c0709a0626d43ab8fa7 ) + name "Zoboomafoo - Playtime in Zobooland (USA)" + description "Zoboomafoo - Playtime in Zobooland (USA)" + rom ( name "Zoboomafoo - Playtime in Zobooland (USA).gbc" size 1048576 crc 38d91885 sha1 a85a113bc266325f807f110daaf30feeea4b2738 ) ) game ( - name "Shantae (World) (Switch)" - description "Shantae (World) (Switch)" - rom ( name "Shantae (World) (Switch).gbc" size 4194304 crc 5009b832 sha1 e1cc66f1950d585d5b644bf9720c87a356354e6a ) + name "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (SGB Enhanced) (GB Compatible)" + description "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (SGB Enhanced) (GB Compatible)" + rom ( name "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc f36c874d sha1 4ddb1d66d909d453374bd195a4a7dbe328ed41be ) ) game ( - name "Shantae (World) (GBA Enhanced) (Switch)" - description "Shantae (World) (GBA Enhanced) (Switch)" - rom ( name "Shantae (World) (GBA Enhanced) (Switch).gbc" size 4194304 crc 1ef9fa6b sha1 d14e8b0029b0aff52134a4fa6794eea72f25f4a6 ) + name "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + description "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" + rom ( name "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 96461918 sha1 bfe8cdb8a8da37d5c8d9db57e8a5eeedee24d4cc flags verified ) ) game ( - name "Shaolin Shisan Gun - Ying Xiong Jiu Zhu (Taiwan) (Zh) (Unl)" - description "Shaolin Shisan Gun - Ying Xiong Jiu Zhu (Taiwan) (Zh) (Unl)" - rom ( name "Shaolin Shisan Gun - Ying Xiong Jiu Zhu (Taiwan) (Zh) (Unl).gbc" size 2097152 crc 25a857af sha1 2fbbf4e3a40eda75b0876d207502727f8dacca11 ) + name "Zoids - Shirogane no Juukishin Liger Zero (Japan)" + description "Zoids - Shirogane no Juukishin Liger Zero (Japan)" + rom ( name "Zoids - Shirogane no Juukishin Liger Zero (Japan).gbc" size 2097152 crc 530705a1 sha1 a5623ab4e026aa546b345f2bd5638cfdfed68c04 ) ) game ( - name "Shaoling Legend - Hero, the Saver (Taiwan) (En) (Unl)" - description "Shaoling Legend - Hero, the Saver (Taiwan) (En) (Unl)" - rom ( name "Shaoling Legend - Hero, the Saver (Taiwan) (En) (Unl).gbc" size 2097152 crc a321ff7d sha1 b1194edd0962c50cf909262004a102f01f556723 ) + name "Zok Zok Heroes (Japan)" + description "Zok Zok Heroes (Japan)" + rom ( name "Zok Zok Heroes (Japan).gbc" size 2097152 crc c09f9e1b sha1 91ab908fddebd926e7db8d61295a40955b2adc39 ) ) game ( - name "Shark Attack (World) (Aftermarket) (Unl)" - description "Shark Attack (World) (Aftermarket) (Unl)" - rom ( name "Shark Attack (World) (Aftermarket) (Unl).gbc" size 262144 crc cf80a2ba sha1 291f453a185f836fcafbd7e41945a409638980c0 ) + name "Zook Z (USA) (Unl)" + description "Zook Z (USA) (Unl)" + rom ( name "Zook Z (USA) (Unl).gbc" size 1048576 crc a7b09e70 sha1 243cc40cfc6bcbd3b6106870773a72edff079904 ) ) -game ( - name "Shaun Palmer's Pro Snowboarder (USA, Australia)" - description "Shaun Palmer's Pro Snowboarder (USA, Australia)" - rom ( name "Shaun Palmer's Pro Snowboarder (USA, Australia).gbc" size 2097152 crc 709cda93 sha1 3563d3085198bf40ba92c4de40093e5fa2d422d5 flags verified ) +clrmamepro ( + name "Nintendo - Game Boy Color (Aftermarket)" + description "Nintendo - Game Boy Color (Aftermarket)" + version 20240810-021134 + author "akubi, Arctic Circle System, Aringon, baldjared, Bent, BigFred, bikerspade, BitLooter, C. V. Reynolds, chillerecke, coraz, darthcloud, DeadSkullzJr, Densetsu, DeriLoko3, Flashfire42, foxe, fuzzball, Gefflon, gordonj, Hiccup, hking0036, InternalLoss, Just001Kim, kazumi213, Lesserkuma, Madeline, Money_114, NESBrew12, NGEfreak, nnssxx, norkmetnoil577, NovaAurora, omonim2007, PPLToast, Psychofox11, psykopat, rarenight, relax, Rifu, sCZther, SonGoku, Tauwasser, togemet2, UnlockerPT, Whovian9369, xprism, xuom2, zg" + homepage No-Intro + url "https://www.no-intro.org" + forcenodump required +) + +emulator ( + name "datafile" ) game ( - name "Shelly Club (Europe) (En,Fr,De,Es,It)" - description "Shelly Club (Europe) (En,Fr,De,Es,It)" - rom ( name "Shelly Club (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 767caa42 sha1 f81fe7427484d9c2af043819690fae9b81b29813 flags verified ) + name "20 Second Platformer, A (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "20 Second Platformer, A (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "20 Second Platformer, A (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 2edc4684 sha1 a00b40a3f31bd875f4a0376d22099c3822c9ef98 ) ) game ( - name "Sheng Shou Wuyu - Shenlong Chuanshuo (Taiwan) (Unl)" - description "Sheng Shou Wuyu - Shenlong Chuanshuo (Taiwan) (Unl)" - rom ( name "Sheng Shou Wuyu - Shenlong Chuanshuo (Taiwan) (Unl).gbc" size 1048576 crc 99a6e58a sha1 13bd97249b68eb824858a9d7a6061edf94140ac3 ) + name "20 Second Platformer, A (World) (GB Compatible) (Aftermarket) (Unl)" + description "20 Second Platformer, A (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "20 Second Platformer, A (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc ff0a848b sha1 837cbb4cf3a92266833099fa06b95edfcdb1865f ) ) game ( - name "Shenghuo Jiangmo Lu Waizhuan (Taiwan) (Unl)" - description "Shenghuo Jiangmo Lu Waizhuan (Taiwan) (Unl)" - rom ( name "Shenghuo Jiangmo Lu Waizhuan (Taiwan) (Unl).gbc" size 2097152 crc 1066ec96 sha1 394709afedc0632c09fee33785b0c4f00a45d3e6 ) + name "2123 (World) (Aftermarket) (Unl)" + description "2123 (World) (Aftermarket) (Unl)" + rom ( name "2123 (World) (Aftermarket) (Unl).gbc" size 262144 crc 22836942 sha1 eb9a2aff6485962f1a7773b7138f3c4208fa36e4 ) ) game ( - name "Shenghuo Jiangmo Lu Waizhuan - Guang Yu An De Lunhui (Taiwan) (Unl)" - description "Shenghuo Jiangmo Lu Waizhuan - Guang Yu An De Lunhui (Taiwan) (Unl)" - rom ( name "Shenghuo Jiangmo Lu Waizhuan - Guang Yu An De Lunhui (Taiwan) (Unl).gbc" size 2097152 crc 808f19d7 sha1 62620a2cb01fe93388adc42da0b7cbaf53c11ba8 ) + name "3D Quasars (World) (Aftermarket) (Unl)" + description "3D Quasars (World) (Aftermarket) (Unl)" + rom ( name "3D Quasars (World) (Aftermarket) (Unl).gbc" size 262144 crc 1fd94e67 sha1 3f32226538d8c7f0c866c4b73e9f828265f2bb5b ) ) game ( - name "Shengui Diguo Zhi Emo Cheng (Taiwan) (Unl)" - description "Shengui Diguo Zhi Emo Cheng (Taiwan) (Unl)" - rom ( name "Shengui Diguo Zhi Emo Cheng (Taiwan) (Unl).gbc" size 2097152 crc 1823e24d sha1 3fc2533f71cea3aec6310f5f7c33fa7eac427b99 ) + name "5 Minutes until Goodbye (World) (GB Compatible) (Aftermarket) (Unl)" + description "5 Minutes until Goodbye (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "5 Minutes until Goodbye (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 48f0b5f2 sha1 fcb0161c637cd3d0f1ae66d032917f94aea11047 ) ) game ( - name "Shi Mian Maifu - Fengyun Pian (Taiwan) (Unl)" - description "Shi Mian Maifu - Fengyun Pian (Taiwan) (Unl)" - rom ( name "Shi Mian Maifu - Fengyun Pian (Taiwan) (Unl).gbc" size 1048576 crc a5f686c3 sha1 68798ac090df9f5fb1ea9c409adf3dc639bc9842 ) + name "60 Minutes til Rot (World) (v1.6b) (GB Compatible) (Aftermarket) (Unl)" + description "60 Minutes til Rot (World) (v1.6b) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "60 Minutes til Rot (World) (v1.6b) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 9a10228a sha1 43ee50322e45c533fe67972db9a9d56f91a6a99b ) ) game ( - name "Shikong Xing Shou (Taiwan) (Unl)" - description "Shikong Xing Shou (Taiwan) (Unl)" - rom ( name "Shikong Xing Shou (Taiwan) (Unl).gbc" size 2097152 crc ec970863 sha1 bc43036da01bb1aef4daa9e7316907193285011f ) + name "Aardvark (World) (Aftermarket) (Unl)" + description "Aardvark (World) (Aftermarket) (Unl)" + rom ( name "Aardvark (World) (Aftermarket) (Unl).gbc" size 262144 crc 270d45b9 sha1 34a8d00af6be9083409e6fccd0825c6f185d135d flags verified ) ) game ( - name "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (SGB Enhanced) (GB Compatible)" - description "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc f90c4977 sha1 b15cbd01a21048d0fd022f0e023ab5d91faaf442 flags verified ) + name "Ack Ack Attack (World) (Aftermarket) (Unl)" + description "Ack Ack Attack (World) (Aftermarket) (Unl)" + rom ( name "Ack Ack Attack (World) (Aftermarket) (Unl).gbc" size 262144 crc c5bedd2e sha1 2a5c7cfb58ccb233a4e688f007ff1436c6c9a208 ) ) game ( - name "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Shin Megami Tensei Devil Children - Aka no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc c1e27556 sha1 e9a3edd28503ee94db8ec4ea48832dc2ba0264d9 flags verified ) + name "Adulting! Soundtrack (World) (GB Compatible) (Aftermarket) (Unl)" + description "Adulting! Soundtrack (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Adulting! Soundtrack (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 1b5b9e64 sha1 c5dad32be800c36814a0f9b940e99b5eada34150 ) ) game ( - name "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (SGB Enhanced) (GB Compatible)" - description "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 55b9af51 sha1 b6177175ab34b8301ce146306dc95c3702b38ca6 flags verified ) + name "Adventure (World) (Aftermarket) (Unl)" + description "Adventure (World) (Aftermarket) (Unl)" + rom ( name "Adventure (World) (Aftermarket) (Unl).gbc" size 262144 crc c23d33c9 sha1 d579a1753d7875413f9e0022285b5741665e4abc ) ) game ( - name "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Shin Megami Tensei Devil Children - Kuro no Sho (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 3d4ae536 sha1 421d20bf556e28d07801d808ecfef45daf86a974 ) + name "Adventures in Carnal Hell, The (World) (En) (v1.02) (GB Compatible) (Aftermarket) (Unl)" + description "Adventures in Carnal Hell, The (World) (En) (v1.02) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Adventures in Carnal Hell, The (World) (En) (v1.02) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 9f81e7a0 sha1 895148bc0a3b6f9ec59bebae43413d1f4eafd21a ) ) game ( - name "Shin Megami Tensei Devil Children - Shiro no Sho (Japan)" - description "Shin Megami Tensei Devil Children - Shiro no Sho (Japan)" - rom ( name "Shin Megami Tensei Devil Children - Shiro no Sho (Japan).gbc" size 2097152 crc 39a10855 sha1 0ad803e30cd4653855a0c878e4c7a63f1183e369 flags verified ) + name "Adventures in Carnal Hell, The (World) (Ja) (v1.01) (GB Compatible) (Aftermarket) (Unl)" + description "Adventures in Carnal Hell, The (World) (Ja) (v1.01) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Adventures in Carnal Hell, The (World) (Ja) (v1.01) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc a5d0d1ec sha1 bc6367f77c235640cea5a1230cee253c99f846e5 ) ) game ( - name "Shin Megami Tensei Devil Children - Shiro no Sho (Japan) (Rev 1) (Proto)" - description "Shin Megami Tensei Devil Children - Shiro no Sho (Japan) (Rev 1) (Proto)" - rom ( name "Shin Megami Tensei Devil Children - Shiro no Sho (Japan) (Rev 1) (Proto).gbc" size 2097152 crc 79ea53f4 sha1 6ba2a43d6975340852eb2ce85f36f35855b36eaf ) + name "Adventures in Carnal Hell, The (World) (Ja) (v1.02) (GB Compatible) (Aftermarket) (Unl)" + description "Adventures in Carnal Hell, The (World) (Ja) (v1.02) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Adventures in Carnal Hell, The (World) (Ja) (v1.02) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 3c9b424f sha1 7bd924752dca6fd772f6df9360117bd4b006ad88 ) ) game ( - name "Shin Megami Tensei Trading Card - Card Summoner (Japan)" - description "Shin Megami Tensei Trading Card - Card Summoner (Japan)" - rom ( name "Shin Megami Tensei Trading Card - Card Summoner (Japan).gbc" size 2097152 crc 85264877 sha1 67daaf5aad65d91109b122e61c1eb3a864437fd4 ) + name "Adventures in Carnal Hell, The (World) (Es) (v1.02) (GB Compatible) (Aftermarket) (Unl)" + description "Adventures in Carnal Hell, The (World) (Es) (v1.02) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Adventures in Carnal Hell, The (World) (Es) (v1.02) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 2f758976 sha1 2aa834c26a06771d53ce35bb0b5b1b9c87e9e2ce ) ) game ( - name "Shinseiki Evangelion - Mahjong Hokan Keikaku (Japan)" - description "Shinseiki Evangelion - Mahjong Hokan Keikaku (Japan)" - rom ( name "Shinseiki Evangelion - Mahjong Hokan Keikaku (Japan).gbc" size 2097152 crc 5337ff55 sha1 f9b048c7c18148197ad82ec9dec65ce124d663e1 ) + name "AF+ER (World) (GB Compatible) (Aftermarket) (Unl)" + description "AF+ER (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "AF+ER (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc f689b91e sha1 e55e427819916bb02189efe3883fb1dab3d80d35 ) ) game ( - name "Shishang Chaoqiang RPG + Gedou + Yizhi Ban Zuhe Ka 18 in 1 (Taiwan) (Unl)" - description "Shishang Chaoqiang RPG + Gedou + Yizhi Ban Zuhe Ka 18 in 1 (Taiwan) (Unl)" - rom ( name "Shishang Chaoqiang RPG + Gedou + Yizhi Ban Zuhe Ka 18 in 1 (Taiwan) (Unl).gbc" size 16777216 crc 28519ab1 sha1 b4c81c2b1d7f787ee92f38d45c86fe602c0aba22 ) + name "Agency (World) (Aftermarket) (Unl)" + description "Agency (World) (Aftermarket) (Unl)" + rom ( name "Agency (World) (Aftermarket) (Unl).gbc" size 1048576 crc 0d1bb2f7 sha1 5266589244fab2e9ff047af9f72641cda91e1d90 ) ) game ( - name "Shougi 2 (Japan) (GB Compatible)" - description "Shougi 2 (Japan) (GB Compatible)" - rom ( name "Shougi 2 (Japan) (GB Compatible).gbc" size 262144 crc a7748d2b sha1 7c89cebc4dfcf8713c94b0553e4f4d4f8945052f flags verified ) + name "Agent B (World) (GB Compatible) (Aftermarket) (Unl)" + description "Agent B (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Agent B (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 31b6e3fa sha1 11b3ce59c4eb86cee05873eb473dbf262cf986bd ) ) game ( - name "Shougi 3 (Japan) (GB Compatible)" - description "Shougi 3 (Japan) (GB Compatible)" - rom ( name "Shougi 3 (Japan) (GB Compatible).gbc" size 262144 crc 64b479fa sha1 6927c466f838a913850a7eecb86fe75840f1cf09 ) + name "Agent B (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Agent B (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Agent B (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ae767ad7 sha1 1a332aac66b24381f16819d1145fd4a917f2e0f3 ) ) game ( - name "Shrek - Fairy Tale Freakdown (USA, Europe) (En,Fr,De,Es,It)" - description "Shrek - Fairy Tale Freakdown (USA, Europe) (En,Fr,De,Es,It)" - rom ( name "Shrek - Fairy Tale Freakdown (USA, Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 387e6459 sha1 e6a728cafd14a4df952467f2a7434ff14e53e268 flags verified ) + name "Airwolf 16 (World) (Aftermarket) (Unl)" + description "Airwolf 16 (World) (Aftermarket) (Unl)" + rom ( name "Airwolf 16 (World) (Aftermarket) (Unl).gbc" size 262144 crc 6ecfd234 sha1 968355e655492a9aa5c36faacac9d34b289132bd ) ) game ( - name "Shuihu Shenshou (Taiwan) (Unl)" - description "Shuihu Shenshou (Taiwan) (Unl)" - rom ( name "Shuihu Shenshou (Taiwan) (Unl).gbc" size 2097152 crc ef18774d sha1 ca240c132de7a56d037776a85e2d2bba1037924e ) + name "All Humans Must Die! (World) (GB Compatible) (Aftermarket) (Unl)" + description "All Humans Must Die! (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "All Humans Must Die! (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc b4d50eed sha1 f4513fc525cbcfa4a2804b55ce20c809e01d1c87 ) ) game ( - name "Shuihu Shenshou (Taiwan) (Unl) (Alt)" - description "Shuihu Shenshou (Taiwan) (Unl) (Alt)" - rom ( name "Shuihu Shenshou (Taiwan) (Unl) (Alt).gbc" size 2097152 crc 618080cd sha1 93aaddc93941cf53978acd9a88e6525b61c7ea24 ) + name "Alley Cat (World) (Aftermarket) (Unl)" + description "Alley Cat (World) (Aftermarket) (Unl)" + rom ( name "Alley Cat (World) (Aftermarket) (Unl).gbc" size 262144 crc edb3ac37 sha1 a9aa1ecad6b67a6e5096fb1c10e39899c00a96a0 ) ) game ( - name "Shuihu Zhuan - Jingdian Ban (Taiwan) (Unl)" - description "Shuihu Zhuan - Jingdian Ban (Taiwan) (Unl)" - rom ( name "Shuihu Zhuan - Jingdian Ban (Taiwan) (Unl).gbc" size 1048576 crc 4a083b6e sha1 c40a80ab26a2a5d884434c215e649dbfebf64fc3 ) + name "Android Nim (World) (Aftermarket) (Unl)" + description "Android Nim (World) (Aftermarket) (Unl)" + rom ( name "Android Nim (World) (Aftermarket) (Unl).gbc" size 262144 crc bd1e0cd7 sha1 efe551c498f6fdb3089a5b453b043fb61246e777 ) ) game ( - name "Shuihu Zhuan Zhi Qunmo Fengyun Lu (China) (Unl)" - description "Shuihu Zhuan Zhi Qunmo Fengyun Lu (China) (Unl)" - rom ( name "Shuihu Zhuan Zhi Qunmo Fengyun Lu (China) (Unl).gbc" size 1048576 crc a4ad3678 sha1 408930e31489dd69570088c5bbbf8bce9b574a34 ) + name "Another Adventure (World) (En,Es) (GB Compatible) (Aftermarket) (Unl)" + description "Another Adventure (World) (En,Es) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Another Adventure (World) (En,Es) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc dfcd02ef sha1 041473b2381dd9e11b3cbda5858f9841324327af ) ) game ( - name "Shuma Baobei - Chao Mengmeng Fanji Zhan (Taiwan) (Zh) (Unl)" - description "Shuma Baobei - Chao Mengmeng Fanji Zhan (Taiwan) (Zh) (Unl)" - rom ( name "Shuma Baobei - Chao Mengmeng Fanji Zhan (Taiwan) (Zh) (Unl).gbc" size 524288 crc fc844e0e sha1 6abec431a861315fb1b284ff964c2abf933444ae ) + name "Apollo Mission (World) (Aftermarket) (Unl)" + description "Apollo Mission (World) (Aftermarket) (Unl)" + rom ( name "Apollo Mission (World) (Aftermarket) (Unl).gbc" size 262144 crc bec9d9a2 sha1 b2bcc61bcf269c0f5c0ce2a6e0bb1c7015dc9ff9 ) ) game ( - name "Shuma Baobei - Hai Zhi Shen (Taiwan) (Zh) (Unl)" - description "Shuma Baobei - Hai Zhi Shen (Taiwan) (Zh) (Unl)" - rom ( name "Shuma Baobei - Hai Zhi Shen (Taiwan) (Zh) (Unl).gbc" size 524288 crc c3cedaed sha1 4e7b7b361302e5e400047c9e668f23cbc885a9e0 ) + name "Arena 3000 (World) (Aftermarket) (Unl)" + description "Arena 3000 (World) (Aftermarket) (Unl)" + rom ( name "Arena 3000 (World) (Aftermarket) (Unl).gbc" size 262144 crc 9c17c15c sha1 007d23f73f68de01c250ec3d07403679137851ff ) ) game ( - name "Shuma Baobei - Huojian Bingtuan (Taiwan) (Unl)" - description "Shuma Baobei - Huojian Bingtuan (Taiwan) (Unl)" - rom ( name "Shuma Baobei - Huojian Bingtuan (Taiwan) (Unl).gbc" size 524288 crc b0d45b6a sha1 5e16517d7d4f9ade3c1a65dfc52ab9d6985a821a ) + name "Astral Possession (World) (GB Compatible) (Aftermarket) (Unl)" + description "Astral Possession (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Astral Possession (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 788043b5 sha1 0d5e4098b62e93c68108cfd5b767d45241ec6963 ) ) game ( - name "Shuma Baobei DX6 (Taiwan) (Unl)" - description "Shuma Baobei DX6 (Taiwan) (Unl)" - rom ( name "Shuma Baobei DX6 (Taiwan) (Unl).gbc" size 2097152 crc 23c19a4d sha1 f08a5470667be1bb232866b4cb4dfa974752e1a0 ) + name "Astro Plumber (World) (Aftermarket) (Unl)" + description "Astro Plumber (World) (Aftermarket) (Unl)" + rom ( name "Astro Plumber (World) (Aftermarket) (Unl).gbc" size 262144 crc d746db41 sha1 bf46ab2a3a1ffc3b712b9ae5cfa05441781ac9e4 ) ) game ( - name "Shuma Baolong - Diannao Pian (Taiwan) (Zh) (Unl)" - description "Shuma Baolong - Diannao Pian (Taiwan) (Zh) (Unl)" - rom ( name "Shuma Baolong - Diannao Pian (Taiwan) (Zh) (Unl).gbc" size 1048576 crc 363808b4 sha1 bac6e8b313e87c06dd4838ebc5098e0ef6383925 ) + name "Astro-Jump - The Sequel (World) (GB Compatible) (Aftermarket) (Unl)" + description "Astro-Jump - The Sequel (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Astro-Jump - The Sequel (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc e6a96130 sha1 2cd0ef086c4b89497d9497a17d871a6568a9e2d3 ) ) game ( - name "Shuma Baolong - Koudai Ban (Taiwan) (Unl) (Alt)" - description "Shuma Baolong - Koudai Ban (Taiwan) (Unl) (Alt)" - rom ( name "Shuma Baolong - Koudai Ban (Taiwan) (Unl) (Alt).gbc" size 524288 crc 16b85ca2 sha1 9f20bfb1dbe01ef3d00588a2fbb14c27ef9a4b30 ) + name "Atop the Witch's Tower (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Atop the Witch's Tower (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Atop the Witch's Tower (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 0d60b100 sha1 9cc1a5140b96ad072d36151f5d99ff6eb699e605 ) ) game ( - name "Shuma Baolong - Koudai Ban (Taiwan) (Unl)" - description "Shuma Baolong - Koudai Ban (Taiwan) (Unl)" - rom ( name "Shuma Baolong - Koudai Ban (Taiwan) (Unl).gbc" size 524288 crc 9507e5d3 sha1 99d5c7ad319158735597432e195615c9df09840c ) + name "Auto Zone (World) (Aftermarket) (Unl)" + description "Auto Zone (World) (Aftermarket) (Unl)" + rom ( name "Auto Zone (World) (Aftermarket) (Unl).gbc" size 524288 crc 2a86d386 sha1 83a37fb5c5d82e0ff06bb22b63761af996e4ad61 ) ) game ( - name "Shuma Baolong - Shuijing Ban (Taiwan) (Vast Fame) (Unl)" - description "Shuma Baolong - Shuijing Ban (Taiwan) (Vast Fame) (Unl)" - rom ( name "Shuma Baolong - Shuijing Ban (Taiwan) (Vast Fame) (Unl).gbc" size 1048576 crc 10bf11a4 sha1 a0f81548e3d4184c146d0df1cc9e18930bedf644 ) + name "Autobahn (World) (Aftermarket) (Unl)" + description "Autobahn (World) (Aftermarket) (Unl)" + rom ( name "Autobahn (World) (Aftermarket) (Unl).gbc" size 262144 crc d2fee5f1 sha1 6de35bd07f46720372ede9b5175399f2055e593d ) ) game ( - name "Shuma Baolong - Shuijing Ban (Taiwan) (Li Cheng) (Unl)" - description "Shuma Baolong - Shuijing Ban (Taiwan) (Li Cheng) (Unl)" - rom ( name "Shuma Baolong - Shuijing Ban (Taiwan) (Li Cheng) (Unl).gbc" size 1048576 crc ba03bd71 sha1 39d8ebe977cf139be398d87be735ea4f7e6885f7 ) + name "Autumn With You, An (World) (GB Compatible) (Aftermarket) (Unl)" + description "Autumn With You, An (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Autumn With You, An (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc eac459fa sha1 68a5520be76c52a4936ad1756ea274667f2ac0e3 ) ) game ( - name "Shuma Baolong - Shuijing Ban II (Taiwan) (Unl)" - description "Shuma Baolong - Shuijing Ban II (Taiwan) (Unl)" - rom ( name "Shuma Baolong - Shuijing Ban II (Taiwan) (Unl).gbc" size 2097152 crc b67999ae sha1 435c26f47c4e244e8adb3b7f18f2b1d129e163e9 ) + name "Back to Nature (World) (Aftermarket) (Unl)" + description "Back to Nature (World) (Aftermarket) (Unl)" + rom ( name "Back to Nature (World) (Aftermarket) (Unl).gbc" size 262144 crc 861f9a63 sha1 3f4a6cd105d4c8af0312bef482c08784bbbfb0eb ) ) game ( - name "Shuma Baolong 02 4 (Taiwan) (Unl)" - description "Shuma Baolong 02 4 (Taiwan) (Unl)" - rom ( name "Shuma Baolong 02 4 (Taiwan) (Unl).gbc" size 1048576 crc 2ee18ab2 sha1 839f0880749735ba2113e437f8efede171b7474d ) + name "Bandits at Zero (World) (Aftermarket) (Unl)" + description "Bandits at Zero (World) (Aftermarket) (Unl)" + rom ( name "Bandits at Zero (World) (Aftermarket) (Unl).gbc" size 524288 crc c70f413e sha1 c885e109fbb53445db9618c6768c2259e6135921 ) ) game ( - name "Shuma Baolong 02 4 (China) (Unl)" - description "Shuma Baolong 02 4 (China) (Unl)" - rom ( name "Shuma Baolong 02 4 (China) (Unl).gbc" size 1048576 crc 6f67dfc6 sha1 5c5d1675188a5f618f9babf2b3848942ce08c659 ) + name "Basketbrawl (World) (Aftermarket) (Unl)" + description "Basketbrawl (World) (Aftermarket) (Unl)" + rom ( name "Basketbrawl (World) (Aftermarket) (Unl).gbc" size 1048576 crc 51efcd7b sha1 3c626d9fec2eb252a50c5022be46525103560fde ) ) game ( - name "Shuma Baolong 02 5 (China) (Unl)" - description "Shuma Baolong 02 5 (China) (Unl)" - rom ( name "Shuma Baolong 02 5 (China) (Unl).gbc" size 1048576 crc 5ba9f8b5 sha1 c441fcbdb343e0c3c76803aa55ceb728158a8948 ) + name "Basketbrawl - Deluxe Edition (World) (Aftermarket) (Unl)" + description "Basketbrawl - Deluxe Edition (World) (Aftermarket) (Unl)" + rom ( name "Basketbrawl - Deluxe Edition (World) (Aftermarket) (Unl).gbc" size 1048576 crc 3da834f2 sha1 a627c03f958bc13b11e1832b6ab53fe298167ebc ) ) game ( - name "Shuma Baolong 2 (China) (Unl)" - description "Shuma Baolong 2 (China) (Unl)" - rom ( name "Shuma Baolong 2 (China) (Unl).gbc" size 1048576 crc acbfc58f sha1 76b1eccf666ea01320134d88d6f7558c24016ca8 ) + name "Battle Star (World) (Aftermarket) (Unl)" + description "Battle Star (World) (Aftermarket) (Unl)" + rom ( name "Battle Star (World) (Aftermarket) (Unl).gbc" size 524288 crc b2fd062f sha1 ac4206129704e31386c9c0a1c961a148398f0ba3 ) ) game ( - name "Shuma Baolong 3 (China) (Unl)" - description "Shuma Baolong 3 (China) (Unl)" - rom ( name "Shuma Baolong 3 (China) (Unl).gbc" size 1048576 crc dab66d8c sha1 3902ecd4b233d0dff168a285788843de0b6df05e ) + name "Berks (World) (Aftermarket) (Unl)" + description "Berks (World) (Aftermarket) (Unl)" + rom ( name "Berks (World) (Aftermarket) (Unl).gbc" size 262144 crc 10ded9ab sha1 8b4c282cf973cdd9926a69ae1d8fcbaf79f8552b ) ) game ( - name "Shuma Baolong 9 - Baolong Pian (Taiwan) (Zh) (Unl)" - description "Shuma Baolong 9 - Baolong Pian (Taiwan) (Zh) (Unl)" - rom ( name "Shuma Baolong 9 - Baolong Pian (Taiwan) (Zh) (Unl).gbc" size 1048576 crc c10fa909 sha1 bdc4a2ca7170f41bc10b89a2e6e96fb990a44f0b ) + name "BIG2SMALL (World) (Digital) (GB Compatible) (Aftermarket) (Unl)" + description "BIG2SMALL (World) (Digital) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "BIG2SMALL (World) (Digital) (GB Compatible) (Aftermarket) (Unl).gbc" size 65536 crc b0401d96 sha1 ee5f2db597bb2fa06efe4a279a887b97bf23cac6 ) ) game ( - name "Shuma Baolong Zhuanji 10 in 1 (Taiwan) (Unl)" - description "Shuma Baolong Zhuanji 10 in 1 (Taiwan) (Unl)" - rom ( name "Shuma Baolong Zhuanji 10 in 1 (Taiwan) (Unl).gbc" size 4194304 crc 37603b3a sha1 37366ff0b3a722da867327c62cae6ad0e51d4a12 ) + name "Bitterroot (World) (En) (GB Compatible) (Aftermarket) (Unl)" + description "Bitterroot (World) (En) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Bitterroot (World) (En) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 0d464785 sha1 790b9d231f6e66027e76264ef646c7a7cb9c878c ) ) game ( - name "Shutokou Racing, The (Japan) (SGB Enhanced) (GB Compatible)" - description "Shutokou Racing, The (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Shutokou Racing, The (Japan) (SGB Enhanced) (GB Compatible).gbc" size 131072 crc 36e781cd sha1 0f29818190ea9ce8c242b648ba64d50cc5408e5a ) + name "Bitterroot (World) (Es) (GB Compatible) (Aftermarket) (Unl)" + description "Bitterroot (World) (Es) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Bitterroot (World) (Es) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 936443e2 sha1 b874c45d4866d5ef0c0d9837502ae42dd0ea3787 ) ) game ( - name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-09) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-09) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-09) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 599132ec sha1 762087df0e5820f1e50da2a22f9ee3b8d16c3e49 ) + name "Black Tape (World) (GB Compatible) (Aftermarket) (Unl)" + description "Black Tape (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Black Tape (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 45c5f990 sha1 ec8c467e955d69b2084805f11a954e0d90855461 ) ) game ( - name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-04-16) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-04-16) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-04-16) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 5370b1bf sha1 966e2d79ab4930039c3d6c43fdbb8cdc068ba347 ) + name "Blaze (World) (Aftermarket) (Unl)" + description "Blaze (World) (Aftermarket) (Unl)" + rom ( name "Blaze (World) (Aftermarket) (Unl).gbc" size 262144 crc 7d2519c7 sha1 f9b1422a91cc1f3a55526ef8ba81b7a8297fc55e ) ) game ( - name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-08-24) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-08-24) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-08-24) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 16f34bcc sha1 c34e744b9120e3a1b2b054d3708e4ab594726c5a ) + name "Blinky's Revenge (World) (Aftermarket) (Unl)" + description "Blinky's Revenge (World) (Aftermarket) (Unl)" + rom ( name "Blinky's Revenge (World) (Aftermarket) (Unl).gbc" size 262144 crc 2d2f9c2b sha1 1c39cc02396c74e7b0b282ead510e94c77ff7f1e ) ) game ( - name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-09-13) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-09-13) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-09-13) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 31ce3f27 sha1 c33d685d5ea5cd6cd954af3bc9ee92719b9578b1 ) + name "Block Droppin' (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Block Droppin' (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Block Droppin' (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 7e8ec278 sha1 6e8577c68402888a3244f153909a959f701eca0e ) ) game ( - name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-11-07) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-11-07) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-11-07) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc d54b53cb sha1 08948befa0227b795d00fe60e9eede6a1f56597b ) + name "Block Droppin' (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + description "Block Droppin' (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Block Droppin' (World) (v1.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 5a0f9578 sha1 37743ac843330cfc8350e67238fdd395174ca1d4 ) ) game ( - name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-03) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-03) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-03) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 314be6b5 sha1 37978f85ae92e7d9a53611659513fd360f57a5b1 ) + name "Board (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Board (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Board (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 440a2260 sha1 8472981264122ea588d991628c51020545779926 ) ) game ( - name "Silent Hill 2 - Born From a Wish (World) (2023-10-03) (Demo) (Aftermarket) (Unl)" - description "Silent Hill 2 - Born From a Wish (World) (2023-10-03) (Demo) (Aftermarket) (Unl)" - rom ( name "Silent Hill 2 - Born From a Wish (World) (2023-10-03) (Demo) (Aftermarket) (Unl).gbc" size 524288 crc 7ebcdd4e sha1 b99f43719155cafbc3dbd7df0ade281c3c7ba171 ) + name "Boing! (World) (Aftermarket) (Unl)" + description "Boing! (World) (Aftermarket) (Unl)" + rom ( name "Boing! (World) (Aftermarket) (Unl).gbc" size 2097152 crc 91961796 sha1 09fde4065941784bab4cf8f624a0398049ed4add ) ) game ( - name "Simpsons, The - Night of the Living Treehouse of Horror (USA, Europe)" - description "Simpsons, The - Night of the Living Treehouse of Horror (USA, Europe)" - rom ( name "Simpsons, The - Night of the Living Treehouse of Horror (USA, Europe).gbc" size 1048576 crc ebaf4888 sha1 a5be079336e48552e53706f0380f35829d91b3c0 ) + name "Bomb Runner 1-2 (World) (Aftermarket) (Unl)" + description "Bomb Runner 1-2 (World) (Aftermarket) (Unl)" + rom ( name "Bomb Runner 1-2 (World) (Aftermarket) (Unl).gbc" size 262144 crc d4c95ac0 sha1 3d020eb6e118b431899d79ce4a7bda9bc571c3a0 ) ) game ( - name "Skelby (World) (Aftermarket) (Unl)" - description "Skelby (World) (Aftermarket) (Unl)" - rom ( name "Skelby (World) (Aftermarket) (Unl).gbc" size 524288 crc 6ec6c18c sha1 887555aa7e2e61b68a21020237b7d508bb71aded ) + name "Booga-Boo (World) (Aftermarket) (Unl)" + description "Booga-Boo (World) (Aftermarket) (Unl)" + rom ( name "Booga-Boo (World) (Aftermarket) (Unl).gbc" size 262144 crc 7fa7fe54 sha1 00323df5a855f1499810dfe959a58d105daf6871 ) ) game ( - name "Skycon (World) (Aftermarket) (Unl)" - description "Skycon (World) (Aftermarket) (Unl)" - rom ( name "Skycon (World) (Aftermarket) (Unl).gbc" size 524288 crc 195dbc30 sha1 df29ece6c5f5b14840663495230135dd79c5163a ) + name "Booty (World) (Aftermarket) (Unl)" + description "Booty (World) (Aftermarket) (Unl)" + rom ( name "Booty (World) (Aftermarket) (Unl).gbc" size 262144 crc ef6c39c8 sha1 3c487ddc03d935b583e186d1cc395966ef490412 ) ) game ( - name "Sludge & Sorcery (World) (GB Compatible) (Aftermarket) (Unl)" - description "Sludge & Sorcery (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Sludge & Sorcery (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c906c5af sha1 0e0d472b282e3ea590e0f126baf633ef0d9298fa ) + name "Borbo's Quest (World) (GB Compatible) (Aftermarket) (Unl)" + description "Borbo's Quest (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Borbo's Quest (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc e92ce3d4 sha1 1ddf864188dfd741ccda0b0715e75e162d212605 ) ) game ( - name "Smurfs Nightmare, The (Europe) (En,Fr,De,Es)" - description "Smurfs Nightmare, The (Europe) (En,Fr,De,Es)" - rom ( name "Smurfs Nightmare, The (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 6f97b043 sha1 fe9f70d6ff58174f533a08b556358d916eda8a1e flags verified ) + name "Boxed In (World) (GB Compatible) (Aftermarket) (Unl)" + description "Boxed In (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Boxed In (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ee1c2e1d sha1 b95dfdf10820671ab5f734ed7180cbf1967ca277 ) ) game ( - name "Smurfs Nightmare, The (USA)" - description "Smurfs Nightmare, The (USA)" - rom ( name "Smurfs Nightmare, The (USA).gbc" size 1048576 crc b50cafe4 sha1 1d0d3512f32176b7035f9c2a77d4636b1d08b349 ) + name "Boxing Master (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Boxing Master (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Boxing Master (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc d1fc5295 sha1 cd336de23457b30cf7a5bf6ae62e8c606507a5a5 ) ) game ( - name "Snail DX, The (World) (GB Compatible) (Aftermarket) (Unl)" - description "Snail DX, The (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Snail DX, The (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 1aecd096 sha1 8ce256d963a55badf71fd45047c173a74d76a92c ) + name "Bub-O Escape - Tournament Edition (World) (Aftermarket) (Unl)" + description "Bub-O Escape - Tournament Edition (World) (Aftermarket) (Unl)" + rom ( name "Bub-O Escape - Tournament Edition (World) (Aftermarket) (Unl).gbc" size 524288 crc 437a2973 sha1 9c219e2c489f5140314e89fbdc0bb387e1f1eed0 ) ) game ( - name "Snail DX, The (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" - description "Snail DX, The (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Snail DX, The (World) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 6cf39388 sha1 9cf5a1d3e8119303a1f4b04b8f4d8b683aee699e ) + name "Bubble Frog (World) (GB Compatible) (Aftermarket) (Unl)" + description "Bubble Frog (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Bubble Frog (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 0fd51f93 sha1 e4894fd9392a9e1c42d432bc73681ca5bccfe9a8 ) ) game ( - name "Snobow Champion (Japan)" - description "Snobow Champion (Japan)" - rom ( name "Snobow Champion (Japan).gbc" size 1048576 crc 846fea2b sha1 e99284640d67643102e68aca25bf56d78a1a0d39 ) + name "Bubble Trouble (World) (Aftermarket) (Unl)" + description "Bubble Trouble (World) (Aftermarket) (Unl)" + rom ( name "Bubble Trouble (World) (Aftermarket) (Unl).gbc" size 262144 crc 3374918b sha1 892388f81f7815ea3bca17632a6a9a33a6edafac ) ) game ( - name "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl)" - description "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 8c2d9b43 sha1 e51347bb82e44a2ecefeb3f220a0b3def6daf514 ) + name "Bubblegum Attack (World) (GB Compatible) (Aftermarket) (Unl)" + description "Bubblegum Attack (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Bubblegum Attack (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc e3f64fec sha1 51e302fd27d579c9a4e8109e6ea4af3275d475dd ) ) game ( - name "Snoopy Tennis (Japan)" - description "Snoopy Tennis (Japan)" - rom ( name "Snoopy Tennis (Japan).gbc" size 1048576 crc d088eefd sha1 66b78ec7de2d407b3b4fac0323ad6c6df223c744 ) + name "Bug Byte (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Bug Byte (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Bug Byte (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc ee41d61b sha1 68f5712ca543c9f02b731e6dc8ec042fc790f839 ) ) game ( - name "Snoopy Tennis (USA) (En,Fr,Es)" - description "Snoopy Tennis (USA) (En,Fr,Es)" - rom ( name "Snoopy Tennis (USA) (En,Fr,Es).gbc" size 1048576 crc d882eccc sha1 a07b8fe92b4fee98586a09fdd5a8dd4c8345bf16 ) + name "Buried Behind the Cabin (World) (GB Compatible) (Aftermarket) (Unl)" + description "Buried Behind the Cabin (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Buried Behind the Cabin (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc a5d6cd6a sha1 7464af8e6d9d0a4b11f510d22789a6830cd4c272 ) ) game ( - name "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - description "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - rom ( name "Snoopy Tennis (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 1048576 crc 49db04a6 sha1 03adc2731945bc86588fffedfee2050a00679ce6 ) + name "Bygone Choices (World) (GB Compatible) (Aftermarket) (Unl)" + description "Bygone Choices (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Bygone Choices (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 4194304 crc dbaec8ec sha1 699b752e8a4a21b7f814f59e35260e0b82fc6795 ) ) game ( - name "Snooze (World) (GB Compatible) (Aftermarket) (Unl)" - description "Snooze (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Snooze (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc b246095f sha1 b7fdcc006c9c06dd391ee26d44b278d9d3793f6d ) + name "Cancer Culture VS The Illuminati (World) (2023-05-03) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Cancer Culture VS The Illuminati (World) (2023-05-03) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Cancer Culture VS The Illuminati (World) (2023-05-03) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 52da152b sha1 1bb4a376c03af67ca1e8426375fe1a644499d9ae ) ) game ( - name "Snow White and the Seven Dwarfs (Europe) (En,Fr,De,Es,It,Nl,Sv,No,Da)" - description "Snow White and the Seven Dwarfs (Europe) (En,Fr,De,Es,It,Nl,Sv,No,Da)" - rom ( name "Snow White and the Seven Dwarfs (Europe) (En,Fr,De,Es,It,Nl,Sv,No,Da).gbc" size 1048576 crc c9c68471 sha1 bcb5f2141bdfa0bd055e7e94301cf0aff00971a0 ) + name "Candy Quest (World) (v2) (Demo) (Aftermarket) (Unl)" + description "Candy Quest (World) (v2) (Demo) (Aftermarket) (Unl)" + rom ( name "Candy Quest (World) (v2) (Demo) (Aftermarket) (Unl).gbc" size 1048576 crc 1f2823cb sha1 8906832db7816be01ed37728f6e5a23e981e7e38 ) ) game ( - name "Snow White and the Seven Dwarfs (USA)" - description "Snow White and the Seven Dwarfs (USA)" - rom ( name "Snow White and the Seven Dwarfs (USA).gbc" size 1048576 crc 8dd38534 sha1 865e5bd17e336b4696fb891bc21c966ef2e186c9 ) + name "Canoe Slalom (World) (Aftermarket) (Unl)" + description "Canoe Slalom (World) (Aftermarket) (Unl)" + rom ( name "Canoe Slalom (World) (Aftermarket) (Unl).gbc" size 262144 crc 38ce9e68 sha1 9fc025682ea0f19f975aa492dd51c5710d8b04a7 ) ) game ( - name "SnowCross (Europe) (En,Fr,De,Es,It,Pt)" - description "SnowCross (Europe) (En,Fr,De,Es,It,Pt)" - rom ( name "SnowCross (Europe) (En,Fr,De,Es,It,Pt).gbc" size 1048576 crc 4ba47dbc sha1 436bed2117772f4632a37d54a83e2310dddf1121 ) + name "Cappimon (World) (v1.1) (Demo) (Aftermarket) (Unl)" + description "Cappimon (World) (v1.1) (Demo) (Aftermarket) (Unl)" + rom ( name "Cappimon (World) (v1.1) (Demo) (Aftermarket) (Unl).gbc" size 262144 crc ee6da010 sha1 a9d24cc03a6892035eaa448fea9c54ba16569b2d ) ) game ( - name "Soccer Manager (Europe) (En,Fr,De,Es)" - description "Soccer Manager (Europe) (En,Fr,De,Es)" - rom ( name "Soccer Manager (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 237ecef9 sha1 353eb6aaf40a78ebf1bca9298726d068a5986efa ) + name "Cappimon (World) (v1.0) (Demo) (Aftermarket) (Unl)" + description "Cappimon (World) (v1.0) (Demo) (Aftermarket) (Unl)" + rom ( name "Cappimon (World) (v1.0) (Demo) (Aftermarket) (Unl).gbc" size 262144 crc 46201a19 sha1 c641e81c551158a2cf3a43403ddb384a7d76bab4 ) ) game ( - name "Sofia the Witch - Curse of the Monster Moon (World) (Demo) (Aftermarket) (Unl)" - description "Sofia the Witch - Curse of the Monster Moon (World) (Demo) (Aftermarket) (Unl)" - rom ( name "Sofia the Witch - Curse of the Monster Moon (World) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc 9e864f1c sha1 ce5dc23c04ff18dfac2367e53d241e81c4bbc3a3 ) + name "Capybara Quest (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + description "Capybara Quest (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Capybara Quest (World) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc b4719bab sha1 5e952ffe5136fd818d8663047f195f20dad9c3f6 ) ) game ( - name "Solomon (Japan)" - description "Solomon (Japan)" - rom ( name "Solomon (Japan).gbc" size 1048576 crc 6aee0958 sha1 0c8da92984888a2c4eea29a3cb05dc75f35efaaa ) + name "Capybara Quest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Capybara Quest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Capybara Quest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 10854c85 sha1 7c4cdccc471ccf925a9ccf258c3e862681c3d1e9 ) ) game ( - name "Sonic Adventure 7 (Taiwan) (En) (Unl)" - description "Sonic Adventure 7 (Taiwan) (En) (Unl)" - rom ( name "Sonic Adventure 7 (Taiwan) (En) (Unl).gbc" size 524288 crc dec1260e sha1 d3ea57e8df8f8d3a80581eaf8e807e359c9059df ) + name "Capybara Quest (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + description "Capybara Quest (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Capybara Quest (World) (v1.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 0795de60 sha1 7bed040a4bd916d04a9b251d14c89c9c1361cf09 ) ) game ( - name "Sonic Adventure 8 (Taiwan) (En) (Rumble Version) (Unl)" - description "Sonic Adventure 8 (Taiwan) (En) (Rumble Version) (Unl)" - rom ( name "Sonic Adventure 8 (Taiwan) (En) (Rumble Version) (Unl).gbc" size 524288 crc c5d8b776 sha1 2fc703f8c8e3768b6ad90b4d5898a79bb3e8fa38 ) + name "Capybara Village (World) (v1.1) (Proto) (Aftermarket) (Unl)" + description "Capybara Village (World) (v1.1) (Proto) (Aftermarket) (Unl)" + rom ( name "Capybara Village (World) (v1.1) (Proto) (Aftermarket) (Unl).gbc" size 524288 crc b761bac5 sha1 9c299efb05516075a67516875ecfe47a32d04ef0 ) ) game ( - name "Soreike! Anpanman - 5-tsu no Tou no Ousama (Japan)" - description "Soreike! Anpanman - 5-tsu no Tou no Ousama (Japan)" - rom ( name "Soreike! Anpanman - 5-tsu no Tou no Ousama (Japan).gbc" size 1048576 crc c9a25b0c sha1 e3e4d1e2d1fe6d0683db9d17356080542e1a6905 ) + name "Capybara Village (World) (v1.0) (Proto) (Cozy Spring Jam) (Aftermarket) (Unl)" + description "Capybara Village (World) (v1.0) (Proto) (Cozy Spring Jam) (Aftermarket) (Unl)" + rom ( name "Capybara Village (World) (v1.0) (Proto) (Cozy Spring Jam) (Aftermarket) (Unl).gbc" size 524288 crc 44deeab3 sha1 057ade8edd41efbfb168ad709e95222c7c0118fa ) ) game ( - name "Soreike! Anpanman - Fushigi na Nikoniko Album (Japan) (SGB Enhanced) (GB Compatible)" - description "Soreike! Anpanman - Fushigi na Nikoniko Album (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Soreike! Anpanman - Fushigi na Nikoniko Album (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc a80eeead sha1 fe75b7b7a904ce76130d65b67d24e291ba3c2693 ) + name "Cargo (World) (GB Compatible) (Aftermarket) (Unl)" + description "Cargo (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Cargo (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc a65d66f4 sha1 83c35ad553bde5ce3a6af418d7f8ad1fbe73b0f6 ) ) game ( - name "Soukoban Densetsu - Hikari to Yami no Kuni (Japan) (SGB Enhanced) (GB Compatible)" - description "Soukoban Densetsu - Hikari to Yami no Kuni (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Soukoban Densetsu - Hikari to Yami no Kuni (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 081d7fcb sha1 cb249bd50dc8c7d503544383af6fb5df0e874ae5 ) + name "Castlevania - Demon Castle (World) (Aftermarket) (Unl)" + description "Castlevania - Demon Castle (World) (Aftermarket) (Unl)" + rom ( name "Castlevania - Demon Castle (World) (Aftermarket) (Unl).gbc" size 4194304 crc af20c186 sha1 8b593ebcb4c30f7709ca97ec977e8680df9b5fb7 ) ) game ( - name "Soul Getter - Houkago Bouken RPG (Japan) (GB Compatible)" - description "Soul Getter - Houkago Bouken RPG (Japan) (GB Compatible)" - rom ( name "Soul Getter - Houkago Bouken RPG (Japan) (GB Compatible).gbc" size 2097152 crc 3ffcd45b sha1 ded83fde342a5dc9e56cdbb91acad2cd5f4ac754 ) + name "Cat Boy's Stellar Journey (World) (GB Compatible) (Aftermarket) (Unl)" + description "Cat Boy's Stellar Journey (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Cat Boy's Stellar Journey (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 280937cc sha1 9ec53942f0136076b6468671562764e1ab9dee3b ) ) game ( - name "South Park (USA) (Proto)" - description "South Park (USA) (Proto)" - rom ( name "South Park (USA) (Proto).gbc" size 524288 crc e79d411a sha1 ad9240b30e381cd7b260f5fc78aaaeed00c6b43d ) + name "Cat Jumper (World) (GB Compatible) (Aftermarket) (Unl)" + description "Cat Jumper (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Cat Jumper (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc cde77e9d sha1 1acc8a49751cd45a84e53a435ddeed0357b87894 ) ) game ( - name "Space Baby (USA) (Unl)" - description "Space Baby (USA) (Unl)" - rom ( name "Space Baby (USA) (Unl).gbc" size 2097152 crc 509f1bb5 sha1 8bdf15e4160e87f83667ecfdbab26ef111a5d5d2 ) + name "Cave Fighter (World) (Aftermarket) (Unl)" + description "Cave Fighter (World) (Aftermarket) (Unl)" + rom ( name "Cave Fighter (World) (Aftermarket) (Unl).gbc" size 262144 crc 6f4641f0 sha1 05b441e3542452b1724017d20e2db602d0997773 ) ) game ( - name "Space Invaders (USA, Europe) (GB Compatible)" - description "Space Invaders (USA, Europe) (GB Compatible)" - rom ( name "Space Invaders (USA, Europe) (GB Compatible).gbc" size 1048576 crc dab7460c sha1 392a8087633969ed0be05e7da628d6e92befb711 flags verified ) + name "Cave Hunter (World) (GB Compatible) (Aftermarket) (Unl)" + description "Cave Hunter (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Cave Hunter (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc defb3151 sha1 94770d13bd9b1b52224fe753f94ec580e1b4017c ) ) game ( - name "Space Invaders X (Japan) (En) (GB Compatible)" - description "Space Invaders X (Japan) (En) (GB Compatible)" - rom ( name "Space Invaders X (Japan) (En) (GB Compatible).gbc" size 1048576 crc c016bc79 sha1 40d16062bf170647cdf060359fc65ff02350f40a ) + name "Cavelon (World) (Aftermarket) (Unl)" + description "Cavelon (World) (Aftermarket) (Unl)" + rom ( name "Cavelon (World) (Aftermarket) (Unl).gbc" size 262144 crc 9fdd01f6 sha1 ff40729d06a6ce91446347b4bd69deaa6ba7d8b4 ) ) game ( - name "Space Invasion (Europe) (Unl)" - description "Space Invasion (Europe) (Unl)" - rom ( name "Space Invasion (Europe) (Unl).gbc" size 131072 crc 2b2d9868 sha1 bcf0940375a23bca6957eec2ab8e49af695aeb32 ) + name "Chase the Chuck Wagon (World) (Aftermarket) (Unl)" + description "Chase the Chuck Wagon (World) (Aftermarket) (Unl)" + rom ( name "Chase the Chuck Wagon (World) (Aftermarket) (Unl).gbc" size 262144 crc 3c3d653c sha1 27b462be532a37c15798eba0fd48154eff596753 ) ) game ( - name "Space Invasion & Karate Joe (Europe) (Unl)" - description "Space Invasion & Karate Joe (Europe) (Unl)" - rom ( name "Space Invasion & Karate Joe (Europe) (Unl).gbc" size 524288 crc 6a184c55 sha1 96918cbd3648b227eb43e5a9711d1a9939541bea flags verified ) + name "Chester's Big Ol' Day (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Chester's Big Ol' Day (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Chester's Big Ol' Day (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 490a874a sha1 92567a6a58739a38e0d7b35d1327ccb999527fa0 ) ) game ( - name "Space Invasion & Painter (Europe) (Unl)" - description "Space Invasion & Painter (Europe) (Unl)" - rom ( name "Space Invasion & Painter (Europe) (Unl).gbc" size 524288 crc bd4c1065 sha1 a5bf26ed894576dada84f6925cc659980cf150a0 ) + name "Chopper War (World) (Aftermarket) (Unl)" + description "Chopper War (World) (Aftermarket) (Unl)" + rom ( name "Chopper War (World) (Aftermarket) (Unl).gbc" size 524288 crc eb0f4f3e sha1 26970bb0753e792aaeb328e0f88d650acd413a9d ) ) game ( - name "Space Marauder (USA)" - description "Space Marauder (USA)" - rom ( name "Space Marauder (USA).gbc" size 1048576 crc 4f83b35e sha1 e6738767434f53af8221fb06513c0758ab228a94 ) + name "Choro-Q (World) (Aftermarket) (Unl)" + description "Choro-Q (World) (Aftermarket) (Unl)" + rom ( name "Choro-Q (World) (Aftermarket) (Unl).gbc" size 262144 crc e40e99bd sha1 8534c4fe58aef32b8cfd4812fa1f2c1094e6b129 ) ) game ( - name "Space-Net - Cosmo Blue (Japan)" - description "Space-Net - Cosmo Blue (Japan)" - rom ( name "Space-Net - Cosmo Blue (Japan).gbc" size 2097152 crc f606d369 sha1 9d662a4b95f8b562406eb89fad8cade1edaca954 ) + name "Chromanoids (World) (v1.1) (Aftermarket) (Unl)" + description "Chromanoids (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Chromanoids (World) (v1.1) (Aftermarket) (Unl).gbc" size 262144 crc 05d5d28f sha1 2885e9bfeca429a261f0871e31fdd3c5e682bd33 ) ) game ( - name "Space-Net - Cosmo Neo (Japan) (Proto)" - description "Space-Net - Cosmo Neo (Japan) (Proto)" - rom ( name "Space-Net - Cosmo Neo (Japan) (Proto).gbc" size 2097152 crc 3a9d791b sha1 077006fce23059c40bc7135d195766504e376aa8 ) + name "Chromanoids (World) (v1.0) (Aftermarket) (Unl)" + description "Chromanoids (World) (v1.0) (Aftermarket) (Unl)" + rom ( name "Chromanoids (World) (v1.0) (Aftermarket) (Unl).gbc" size 262144 crc 50c4585f sha1 2d1dc090806463a6ff8c2fc17c32061a9e731d6f ) ) game ( - name "Space-Net - Cosmo Red (Japan)" - description "Space-Net - Cosmo Red (Japan)" - rom ( name "Space-Net - Cosmo Red (Japan).gbc" size 2097152 crc 01f96353 sha1 aa4669d5a6d1c3a53de889543d8477adae6f3ed4 ) + name "Chrome and Blood (World) (v1.02) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Chrome and Blood (World) (v1.02) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Chrome and Blood (World) (v1.02) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 5c3f27d7 sha1 cda9b333b019dbe460f2a5cebe71c0cae258d7cd ) ) game ( - name "Spacestation Silicon Valley (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - description "Spacestation Silicon Valley (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - rom ( name "Spacestation Silicon Valley (Europe) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 2097152 crc 63353c0f sha1 1dbfa27ebc11c63b86cb36075b807b24426dcfd5 ) + name "Chrome and Blood (World) (v1.00) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Chrome and Blood (World) (v1.00) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Chrome and Blood (World) (v1.00) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 15cb5c58 sha1 a0d441f71caed08a52a41813d74031f13fd49d49 ) ) game ( - name "Spawn (USA)" - description "Spawn (USA)" - rom ( name "Spawn (USA).gbc" size 2097152 crc 72fcb0ad sha1 4f816eec1b5dc79928ade9f3a3c687b8aa5b2f87 ) + name "Chumbles Bumbles (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + description "Chumbles Bumbles (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Chumbles Bumbles (World) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 0ff2779c sha1 976790e64ce929a48a756cd1df46f325a7819f31 ) ) game ( - name "Spectipede (World) (Aftermarket) (Unl)" - description "Spectipede (World) (Aftermarket) (Unl)" - rom ( name "Spectipede (World) (Aftermarket) (Unl).gbc" size 262144 crc 9c33f76e sha1 834a450d9ceb78b9d89d551300d4d0ea08cd8a6a ) + name "Church of Pastor Chuck (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Church of Pastor Chuck (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Church of Pastor Chuck (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc b9ca1669 sha1 d86af4b9288df8dc175a4c5647bc010328aab257 ) ) game ( - name "Speedy Gonzales - Aztec Adventure (USA, Europe) (GB Compatible)" - description "Speedy Gonzales - Aztec Adventure (USA, Europe) (GB Compatible)" - rom ( name "Speedy Gonzales - Aztec Adventure (USA, Europe) (GB Compatible).gbc" size 1048576 crc ae82afa4 sha1 95f868358979c5bbdfa70920fb35b7d4e00bf8cc ) + name "Climb It (World) (Aftermarket) (Unl)" + description "Climb It (World) (Aftermarket) (Unl)" + rom ( name "Climb It (World) (Aftermarket) (Unl).gbc" size 262144 crc e7210290 sha1 19f3b825eada3eda3135350bd0ddca6a20a5281f ) ) game ( - name "Speedy Gonzales - Aztec Adventure (Japan) (Proto) (GB Compatible)" - description "Speedy Gonzales - Aztec Adventure (Japan) (Proto) (GB Compatible)" - rom ( name "Speedy Gonzales - Aztec Adventure (Japan) (Proto) (GB Compatible).gbc" size 1048576 crc c97d74f5 sha1 b65cd4a60014ecef55b1daca7e17379987f1d983 ) + name "Clockmaker's Tale, A (World) (GB Compatible) (Aftermarket) (Unl)" + description "Clockmaker's Tale, A (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Clockmaker's Tale, A (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c4b00adb sha1 07e4254c7f74b9d4caa6a1231558b2430dff163a flags verified ) ) game ( - name "Spider-Man (France)" - description "Spider-Man (France)" - rom ( name "Spider-Man (France).gbc" size 1048576 crc f6334dc5 sha1 4bff8a1324c6530b719e99f91bf6d46b2483c9e9 ) + name "Closet Monsters (World) (GB Compatible) (Aftermarket) (Unl)" + description "Closet Monsters (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Closet Monsters (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 57b5d189 sha1 42e8694bb746df0b61662238d81369b15e26e6de ) ) game ( - name "Spider-Man (Japan)" - description "Spider-Man (Japan)" - rom ( name "Spider-Man (Japan).gbc" size 1048576 crc 5a83dfc4 sha1 ef05291a6197e5f1d9790422466e2663e76f64d4 ) + name "Cold Nights (World) (Aftermarket) (Unl)" + description "Cold Nights (World) (Aftermarket) (Unl)" + rom ( name "Cold Nights (World) (Aftermarket) (Unl).gbc" size 524288 crc cdca8a46 sha1 5a2222da34e7cf9166502f9a6bea13a713744e89 ) ) game ( - name "Spider-Man (USA, Europe)" - description "Spider-Man (USA, Europe)" - rom ( name "Spider-Man (USA, Europe).gbc" size 1048576 crc 34e2b3ba sha1 ea432c3f2b0d92b4cf03d762e273abc68f45f072 ) + name "Commando (World) (Aftermarket) (Unl)" + description "Commando (World) (Aftermarket) (Unl)" + rom ( name "Commando (World) (Aftermarket) (Unl).gbc" size 262144 crc 5381b103 sha1 414bb6bdc1ed5647707d7d49f194c387d4098f00 ) ) game ( - name "Spider-Man 2 - The Sinister Six (USA, Europe)" - description "Spider-Man 2 - The Sinister Six (USA, Europe)" - rom ( name "Spider-Man 2 - The Sinister Six (USA, Europe).gbc" size 1048576 crc a7faaccf sha1 22c63fa198df68edb9cbe22e35cbd307174c9eb9 ) + name "Cookie Monster Munch (World) (Aftermarket) (Unl)" + description "Cookie Monster Munch (World) (Aftermarket) (Unl)" + rom ( name "Cookie Monster Munch (World) (Aftermarket) (Unl).gbc" size 262144 crc 420db35c sha1 0584d434503040f3922595250c9b311f62483e70 ) ) game ( - name "Spider-Man 3 - Movie Version (USA) (Unl)" - description "Spider-Man 3 - Movie Version (USA) (Unl)" - rom ( name "Spider-Man 3 - Movie Version (USA) (Unl).gbc" size 2097152 crc 2c0d43a9 sha1 8a6b6a1300db59b86ddf87599cfc8edd2e52e2b0 ) + name "Cookie's Bakery (World) (v1.0.3) (GB Compatible) (Aftermarket) (Unl)" + description "Cookie's Bakery (World) (v1.0.3) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Cookie's Bakery (World) (v1.0.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc c53ace00 sha1 02fdc52bc934b80aa41520d92cf0340753d8f668 ) ) game ( - name "Spiky Harold (World) (Aftermarket) (Unl)" - description "Spiky Harold (World) (Aftermarket) (Unl)" - rom ( name "Spiky Harold (World) (Aftermarket) (Unl).gbc" size 262144 crc 7e9eda35 sha1 486d294b8cf226876581d543e3a08018321bc402 ) + name "Cops and Robbers (World) (Aftermarket) (Unl)" + description "Cops and Robbers (World) (Aftermarket) (Unl)" + rom ( name "Cops and Robbers (World) (Aftermarket) (Unl).gbc" size 262144 crc 3c185eca sha1 8f8bbd15c0ab85345f3a3ae7e737e596311c19a1 ) ) game ( - name "Spirou - The Robot Invasion (Europe) (En,Fr,De,Es,It,Nl,Da)" - description "Spirou - The Robot Invasion (Europe) (En,Fr,De,Es,It,Nl,Da)" - rom ( name "Spirou - The Robot Invasion (Europe) (En,Fr,De,Es,It,Nl,Da).gbc" size 1048576 crc 3e9bc90b sha1 ae46ebe1d5a8bd13e9d7533b1fe3b04392630e41 ) + name "Coria and the Sunken City (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Coria and the Sunken City (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Coria and the Sunken City (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc fe1bdae6 sha1 00d86bbdbc228ff3ea0684984a261cadbed5fb0a ) ) game ( - name "SpongeBob SquarePants - Legend of the Lost Spatula (USA, Europe)" - description "SpongeBob SquarePants - Legend of the Lost Spatula (USA, Europe)" - rom ( name "SpongeBob SquarePants - Legend of the Lost Spatula (USA, Europe).gbc" size 1048576 crc 81230564 sha1 d3bea58987c9904056587242bf3ad26f91b4ef34 ) + name "Cosmo Knight ZiON (World) (En) (v0.24) (Demo) (Aftermarket) (Unl)" + description "Cosmo Knight ZiON (World) (En) (v0.24) (Demo) (Aftermarket) (Unl)" + rom ( name "Cosmo Knight ZiON (World) (En) (v0.24) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc 1780b904 sha1 fcbe2c2389e6c51a38eb17eb80ffb2e51955c7f2 ) ) game ( - name "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv)" - description "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv)" - rom ( name "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv).gbc" size 1048576 crc 713c6c17 sha1 574c90cc4ef318d76a76392e5165351dbc9a1ab0 flags verified ) + name "Cosmo Knight ZiON (World) (En,Es) (v0.47) (Demo) (Aftermarket) (Unl)" + description "Cosmo Knight ZiON (World) (En,Es) (v0.47) (Demo) (Aftermarket) (Unl)" + rom ( name "Cosmo Knight ZiON (World) (En,Es) (v0.47) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc e983a31f sha1 1d811dd440572243f9e95527d970f3ffa91ddbdf ) ) game ( - name "Spy vs Spy (Japan)" - description "Spy vs Spy (Japan)" - rom ( name "Spy vs Spy (Japan).gbc" size 1048576 crc 0e783117 sha1 0167b0d74004aa9ace10069c5d4bf51adfe7297b ) + name "Cosmo Knight ZiON (World) (En,Es) (v2.38) (Demo) (Aftermarket) (Unl)" + description "Cosmo Knight ZiON (World) (En,Es) (v2.38) (Demo) (Aftermarket) (Unl)" + rom ( name "Cosmo Knight ZiON (World) (En,Es) (v2.38) (Demo) (Aftermarket) (Unl).gbc" size 1048576 crc 936752aa sha1 68e31afa8bc49f8b5e7ba9d978896539669cf3d1 ) ) game ( - name "Spy vs Spy (USA)" - description "Spy vs Spy (USA)" - rom ( name "Spy vs Spy (USA).gbc" size 1048576 crc f0463d51 sha1 7249cdaf769f959f527a6e01435420bb8102df7a ) + name "Crazy Golf (World) (Aftermarket) (Unl)" + description "Crazy Golf (World) (Aftermarket) (Unl)" + rom ( name "Crazy Golf (World) (Aftermarket) (Unl).gbc" size 262144 crc f7fe3d01 sha1 b06f47a713b66efa9133be43653c7c4cb5ebc93c ) ) game ( - name "Spy vs Spy (Japan) (Rev 1) (NP)" - description "Spy vs Spy (Japan) (Rev 1) (NP)" - rom ( name "Spy vs Spy (Japan) (Rev 1) (NP).gbc" size 1048576 crc eb47d63b sha1 9e203f04857cd84ec49b0e6c6d4917b1a5cc199e ) + name "Crest RPG (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Crest RPG (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Crest RPG (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc c28f1ec5 sha1 2dd0b6a18e265653d382414de009ec8f154880da ) ) game ( - name "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto)" - description "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto)" - rom ( name "Spy vs Spy (Europe) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto).gbc" size 1048576 crc 6ca71209 sha1 ec249546a4652ef9375b67ddbac882b13ed4a807 ) + name "Cult of Blood, The (World) (Demo 4) (GB Compatible) (Aftermarket) (Unl)" + description "Cult of Blood, The (World) (Demo 4) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Cult of Blood, The (World) (Demo 4) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 5064aa20 sha1 2700521c7ff492fb015cc8dd453672a5989b80a7 ) ) game ( - name "Spy vs Spy (USA) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto)" - description "Spy vs Spy (USA) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto)" - rom ( name "Spy vs Spy (USA) (En,Fr,De,Es,It,Nl,Sv) (Rev 1) (Proto).gbc" size 1048576 crc 549bf1e4 sha1 38dd0c729c0d878ea05df7de0b3aba2d098d2975 ) + name "Cult of Blood, The (World) (Demo 1) (GB Compatible) (Aftermarket) (Unl)" + description "Cult of Blood, The (World) (Demo 1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Cult of Blood, The (World) (Demo 1) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 9015c454 sha1 60b41b89cc9bce22ea06595ee332c3c1549db935 ) ) game ( - name "Star Heritage (Europe) (Proto) (SRAM Version)" - description "Star Heritage (Europe) (Proto) (SRAM Version)" - rom ( name "Star Heritage (Europe) (Proto) (SRAM Version).gbc" size 1048576 crc c72e6dfe sha1 4eb7ad40520e21f1b371b06ac2adb6f2e1b507a9 ) + name "Cuthbert Enters the Tombs of Doom (World) (Aftermarket) (Unl)" + description "Cuthbert Enters the Tombs of Doom (World) (Aftermarket) (Unl)" + rom ( name "Cuthbert Enters the Tombs of Doom (World) (Aftermarket) (Unl).gbc" size 524288 crc 149a2951 sha1 2e7d760cd0836599bbc4222c66dddb4643183f07 ) ) game ( - name "Star Heritage (Europe) (Proto) (Password Version)" - description "Star Heritage (Europe) (Proto) (Password Version)" - rom ( name "Star Heritage (Europe) (Proto) (Password Version).gbc" size 1048576 crc b39b4532 sha1 6eb2c27e2eedb22b4055ded87fce0621d460fe5b ) + name "Cuthbert in Space (World) (Aftermarket) (Unl)" + description "Cuthbert in Space (World) (Aftermarket) (Unl)" + rom ( name "Cuthbert in Space (World) (Aftermarket) (Unl).gbc" size 262144 crc c64000f3 sha1 6818167c491863cb19c2308c177203e38e0338d9 ) ) game ( - name "Star Hunt (World) (GB Compatible) (Aftermarket) (Unl)" - description "Star Hunt (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Star Hunt (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 29320841 sha1 890fda255106ea64bac4973e2e9f4b31bb925d35 ) + name "Cuthbert in the Cooler (World) (Aftermarket) (Unl)" + description "Cuthbert in the Cooler (World) (Aftermarket) (Unl)" + rom ( name "Cuthbert in the Cooler (World) (Aftermarket) (Unl).gbc" size 262144 crc 30204c4e sha1 d6fb35f3bdd44429f88c10551692e1adf14356ab ) ) game ( - name "Star Ocean - Blue Sphere (Japan) (SGB Enhanced) (GB Compatible)" - description "Star Ocean - Blue Sphere (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Star Ocean - Blue Sphere (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 8c7ddbda sha1 3d07ae53ba21eda4923bf4da6c938e2a407c990c ) + name "Daisu-ki (World) (v1.2.1) (Aftermarket) (Unl)" + description "Daisu-ki (World) (v1.2.1) (Aftermarket) (Unl)" + rom ( name "Daisu-ki (World) (v1.2.1) (Aftermarket) (Unl).gbc" size 262144 crc 502385c4 sha1 3a310be21d5cc077da6eb8e3afa99ccff2eda84e ) ) game ( - name "Star Trek (Europe) (Proto)" - description "Star Trek (Europe) (Proto)" - rom ( name "Star Trek (Europe) (Proto).gbc" size 65536 crc 4d423347 sha1 8f708ef7249a72f27a7037651f588fb5daf4c8fb ) + name "Daisu-ki (World) (v1.1) (Aftermarket) (Unl)" + description "Daisu-ki (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Daisu-ki (World) (v1.1) (Aftermarket) (Unl).gbc" size 262144 crc a504b906 sha1 4634631f2c0b4a618aeefc114e5b8e4ba9c7ee04 ) ) game ( - name "Star Wars - Yoda Stories (USA, Europe) (GB Compatible)" - description "Star Wars - Yoda Stories (USA, Europe) (GB Compatible)" - rom ( name "Star Wars - Yoda Stories (USA, Europe) (GB Compatible).gbc" size 1048576 crc 6314da32 sha1 f0dd388373e863f91a05cf6f2df00a56e26d3b18 ) + name "Daisu-ki (World) (v1.1.1) (Aftermarket) (Unl)" + description "Daisu-ki (World) (v1.1.1) (Aftermarket) (Unl)" + rom ( name "Daisu-ki (World) (v1.1.1) (Aftermarket) (Unl).gbc" size 262144 crc a9714871 sha1 7d5b22d1c528603007e340f9d3562c1e53f10796 ) ) game ( - name "Star Wars Episode I - Obi-Wan's Adventures (Europe) (En,Fr,De,Es,It)" - description "Star Wars Episode I - Obi-Wan's Adventures (Europe) (En,Fr,De,Es,It)" - rom ( name "Star Wars Episode I - Obi-Wan's Adventures (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc e584dfc2 sha1 f6a4f115e553f67512373fc5fcbf295c1d6d9fcd ) + name "Daisu-ki (World) (v1.2) (Aftermarket) (Unl)" + description "Daisu-ki (World) (v1.2) (Aftermarket) (Unl)" + rom ( name "Daisu-ki (World) (v1.2) (Aftermarket) (Unl).gbc" size 262144 crc 26d3fe7a sha1 36c9649d4e99fdcaa4cf590963d0c49a3cf8084e ) ) game ( - name "Star Wars Episode I - Obi-Wan's Adventures (USA)" - description "Star Wars Episode I - Obi-Wan's Adventures (USA)" - rom ( name "Star Wars Episode I - Obi-Wan's Adventures (USA).gbc" size 1048576 crc 0e697582 sha1 fb15a0ae700a11f0925113e5f5c9cb5c655acdb5 ) + name "Daisu-ki - Jam Edition (World) (GB Compatible) (Aftermarket) (Unl)" + description "Daisu-ki - Jam Edition (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Daisu-ki - Jam Edition (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc d34b719a sha1 446ca937d3e54ce33a49d1fff4692b3b906b539e ) ) game ( - name "Star Wars Episode I - Racer (USA, Europe) (Rumble Version)" - description "Star Wars Episode I - Racer (USA, Europe) (Rumble Version)" - rom ( name "Star Wars Episode I - Racer (USA, Europe) (Rumble Version).gbc" size 2097152 crc 0ebc5758 sha1 c0613d654a4382f0c50fd4d389d3a6aeef4d5207 flags verified ) + name "Dark Winter Wander, A (World) (GB Compatible) (Aftermarket) (Unl)" + description "Dark Winter Wander, A (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dark Winter Wander, A (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc df19aa9f sha1 412f18ba08f2f2a2afbf3bfb5281e360d7aba31d ) ) game ( - name "StarFox - Grounded (World) (GB Compatible) (Aftermarket) (Unl)" - description "StarFox - Grounded (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "StarFox - Grounded (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 82658661 sha1 dd45b0e3f346ce33668d49092b29a44597686061 ) + name "Darklite (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Darklite (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Darklite (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 98a264a8 sha1 4cbd2cc8779698deb61f39ca255c6f45db7bd3b9 ) ) game ( - name "Stars of Zureon (World) (Proto 2) (GB Compatible) (Aftermarket) (Unl)" - description "Stars of Zureon (World) (Proto 2) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Stars of Zureon (World) (Proto 2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc ce90a95b sha1 75457c5affd0c126f2c916e857950b5cde46a95e ) + name "Dawn Will Come (World) (GB Compatible) (Aftermarket) (Unl)" + description "Dawn Will Come (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dawn Will Come (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc bb64f51c sha1 1611ddfdb9af72f20ddeca4133d8eebd0f14e424 ) ) game ( - name "Stars of Zureon (World) (Proto 1) (GB Compatible) (Aftermarket) (Unl)" - description "Stars of Zureon (World) (Proto 1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Stars of Zureon (World) (Proto 1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc b3a04b44 sha1 b16f21b46dfe4e6ce0368e3c5a3fae397274ebbf ) + name "Days Without (World) (Multiple Endings) (Aftermarket) (Unl)" + description "Days Without (World) (Multiple Endings) (Aftermarket) (Unl)" + rom ( name "Days Without (World) (Multiple Endings) (Aftermarket) (Unl).gbc" size 262144 crc 57ca8f69 sha1 8992f14f02bd37e11cb05511c17fff3d253ccf25 ) ) game ( - name "Startled 911 (Taiwan) (En) (Unl)" - description "Startled 911 (Taiwan) (En) (Unl)" - rom ( name "Startled 911 (Taiwan) (En) (Unl).gbc" size 2097152 crc 7273a4f4 sha1 14154ba420826a406890079d7cc0b420a042e34f ) + name "Days Without (World) (Aftermarket) (Unl)" + description "Days Without (World) (Aftermarket) (Unl)" + rom ( name "Days Without (World) (Aftermarket) (Unl).gbc" size 262144 crc 437b4921 sha1 cb21c1bca18d750ecde91dc3adb6b599c2ad75fa ) ) game ( - name "Stellar Wars (World) (Aftermarket) (Unl)" - description "Stellar Wars (World) (Aftermarket) (Unl)" - rom ( name "Stellar Wars (World) (Aftermarket) (Unl).gbc" size 262144 crc e0b96256 sha1 ba2d10a2a5f3f073aea11e26ae5c53c9cf7866f8 ) + name "Death Race 16 (World) (Aftermarket) (Unl)" + description "Death Race 16 (World) (Aftermarket) (Unl)" + rom ( name "Death Race 16 (World) (Aftermarket) (Unl).gbc" size 262144 crc 7b9488ec sha1 56b8a2d7117b12ff5e709e6a258f9a0b3b0ebe24 ) ) game ( - name "Stranded Kids (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - description "Stranded Kids (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible)" - rom ( name "Stranded Kids (Europe) (En,Fr,De) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 816a4d94 sha1 5c1d738f23a68cce8d2561f91f06c9998e0fe5a9 ) + name "Deisanebe (World) (GB Compatible) (Aftermarket) (Unl)" + description "Deisanebe (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Deisanebe (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 7cff943e sha1 065b5325d44cb0e40f7b7803d707b8c1ea9ea5b2 ) ) game ( - name "Street Fighter Alpha - Warriors' Dreams (Europe)" - description "Street Fighter Alpha - Warriors' Dreams (Europe)" - rom ( name "Street Fighter Alpha - Warriors' Dreams (Europe).gbc" size 1048576 crc 28a3ab3a sha1 8baad8f1fe999d1ee352d534b1dbe6e10c0281fe ) + name "Descent (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Descent (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Descent (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 7d3ce321 sha1 1a42289186a7722a8ccdbd35bcd704f832dc3c04 ) ) game ( - name "Street Fighter Alpha - Warriors' Dreams (Japan)" - description "Street Fighter Alpha - Warriors' Dreams (Japan)" - rom ( name "Street Fighter Alpha - Warriors' Dreams (Japan).gbc" size 1048576 crc 32739b34 sha1 c0086c92381b1561153fbe97fa455fc8c6573c1d ) + name "Dia de Sol Noite de Lua (World) (GB Compatible) (Aftermarket) (Unl)" + description "Dia de Sol Noite de Lua (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dia de Sol Noite de Lua (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc c6b965b9 sha1 ac43f43bdcfc0347f24a0a70de213a4b701d8155 ) ) game ( - name "Street Fighter Alpha - Warriors' Dreams (USA)" - description "Street Fighter Alpha - Warriors' Dreams (USA)" - rom ( name "Street Fighter Alpha - Warriors' Dreams (USA).gbc" size 1048576 crc aa5f14d2 sha1 ca26852ee2c0e691cd0fc30a44de84fd1465b4de ) + name "Dicee! (World) (v1.4) (GB Compatible) (Aftermarket) (Unl)" + description "Dicee! (World) (v1.4) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dicee! (World) (v1.4) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc b7f0a85f sha1 6911854fe18000b0fe6015863240d0664d914547 ) ) game ( - name "Street Fighter Alpha - Warriors' Dreams (Europe) (Rev 1) (Proto)" - description "Street Fighter Alpha - Warriors' Dreams (Europe) (Rev 1) (Proto)" - rom ( name "Street Fighter Alpha - Warriors' Dreams (Europe) (Rev 1) (Proto).gbc" size 1048576 crc cdf56f1a sha1 b7c04a24e7f0355a0113109b5e97ad044057a006 ) + name "Dicee! (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Dicee! (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dicee! (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 08b37ad8 sha1 27e7a34d44640162a4aec02e28b93d295d78180b ) ) game ( - name "Street Hero (Taiwan) (En) (1B-004, EB-004, Sachen) (Unl)" - description "Street Hero (Taiwan) (En) (1B-004, EB-004, Sachen) (Unl)" - rom ( name "Street Hero (Taiwan) (En) (1B-004, EB-004, Sachen) (Unl).gbc" size 393216 crc b580cb1f sha1 f80ffcaf0757f16ce0e6940a2ec786ebd7549458 flags verified ) + name "Disco Elysium - Game Boy Edition (World) (Music) (GB Compatible) (Aftermarket) (Unl)" + description "Disco Elysium - Game Boy Edition (World) (Music) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Disco Elysium - Game Boy Edition (World) (Music) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc ef349515 sha1 06fe25086432c82f1e4b4c44473dd5b487a8af05 ) ) game ( - name "Stuart Little - The Journey Home (Europe) (Fr,De)" - description "Stuart Little - The Journey Home (Europe) (Fr,De)" - rom ( name "Stuart Little - The Journey Home (Europe) (Fr,De).gbc" size 1048576 crc acb08666 sha1 153f8ffab32e78dd4a6c2eec4560b2cf6509774d ) + name "Disco Elysium - Game Boy Edition (World) (No Music) (GB Compatible) (Aftermarket) (Unl)" + description "Disco Elysium - Game Boy Edition (World) (No Music) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Disco Elysium - Game Boy Edition (World) (No Music) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 7c0f52cc sha1 8bc16b70838f9245b7e37c6dbe57159b294fbf81 ) ) game ( - name "Stuart Little - The Journey Home (USA, Europe)" - description "Stuart Little - The Journey Home (USA, Europe)" - rom ( name "Stuart Little - The Journey Home (USA, Europe).gbc" size 1048576 crc eb273887 sha1 d3c31e41709c54af328787036db1b98997f508ea ) + name "Diver 94 (World) (GB Compatible) (Aftermarket) (Unl)" + description "Diver 94 (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Diver 94 (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc f4ff5eb0 sha1 6b421505acc626a34bb9306a3d88e1964a4502f3 ) ) game ( - name "Suicide Run (World) (GB Compatible) (Aftermarket) (Unl)" - description "Suicide Run (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Suicide Run (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 2dc3fdae sha1 a551d904c4af661bd4b6e88063cb5541900117b0 ) + name "Don't Forget About Me (World) (GB Compatible) (Aftermarket) (Unl)" + description "Don't Forget About Me (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Don't Forget About Me (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 52cf7153 sha1 74e6246405dd52d4c5c2eabc417946550c637164 ) ) game ( - name "Suicide Run (World) (Aftermarket) (Unl)" - description "Suicide Run (World) (Aftermarket) (Unl)" - rom ( name "Suicide Run (World) (Aftermarket) (Unl).gbc" size 262144 crc d29ab1aa sha1 df373f58e51155e32fb81825a9082150f6d263c8 ) + name "Don't Forget About Me (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Don't Forget About Me (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Don't Forget About Me (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 8ca9dbe0 sha1 cf6eaac37c4ae1b3cfc4ed8d2ce73a143635b525 ) ) game ( - name "Super 16 in 1 (Taiwan) (En) (Sachen) (Unl)" - description "Super 16 in 1 (Taiwan) (En) (Sachen) (Unl)" - rom ( name "Super 16 in 1 (Taiwan) (En) (Sachen) (Unl).gbc" size 2097152 crc 6a99a079 sha1 bcb683600278094e4d40a7da0226b83ec1f92c81 ) + name "Don't Forget About Me (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + description "Don't Forget About Me (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Don't Forget About Me (World) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 3d87efd8 sha1 83201c43e9fc89f4393678ade8c6107b4cfdb628 ) ) game ( - name "Super 21 in 1 - New GB Rumble (Taiwan) (Unl)" - description "Super 21 in 1 - New GB Rumble (Taiwan) (Unl)" - rom ( name "Super 21 in 1 - New GB Rumble (Taiwan) (Unl).gbc" size 2097152 crc 21746216 sha1 829cc0fcd4b96cf5cac909a7c0697583f4c62241 ) + name "Dork's Dilemma (World) (Aftermarket) (Unl)" + description "Dork's Dilemma (World) (Aftermarket) (Unl)" + rom ( name "Dork's Dilemma (World) (Aftermarket) (Unl).gbc" size 524288 crc 77b8b43b sha1 bd525f97cc316fed3f6271ed0929414df4c0389c ) ) game ( - name "Super 6 in 1 (Taiwan) (En,Zh) (6B-001, Sachen) (Unl)" - description "Super 6 in 1 (Taiwan) (En,Zh) (6B-001, Sachen) (Unl)" - rom ( name "Super 6 in 1 (Taiwan) (En,Zh) (6B-001, Sachen) (Unl).gbc" size 2097152 crc fb60d1c5 sha1 8670282e7ea22235e374d5dcd1beb5ac54b35fe6 ) + name "Downer (World) (GB Compatible) (Aftermarket) (Unl)" + description "Downer (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Downer (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 7a1c9a9f sha1 70044dca1282f4445fe05305586ecc69f4e52304 ) ) game ( - name "Super Black Bass - Real Fight (Japan) (Rumble Version)" - description "Super Black Bass - Real Fight (Japan) (Rumble Version)" - rom ( name "Super Black Bass - Real Fight (Japan) (Rumble Version).gbc" size 4194304 crc b7f77b6a sha1 8c587086f3dec061027322da305081e3aa06ff60 ) + name "Dracula - Dark Reign (World) (Demo) (Aftermarket) (Unl)" + description "Dracula - Dark Reign (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Dracula - Dark Reign (World) (Demo) (Aftermarket) (Unl).gbc" size 524288 crc 4cfb1db2 sha1 6052c794b2c30a0538f57af0ab5253c626c860c5 ) ) game ( - name "Super Black Bass Pocket 3 (Japan) (SGB Enhanced) (GB Compatible)" - description "Super Black Bass Pocket 3 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Super Black Bass Pocket 3 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ae466545 sha1 b416f8fe1d229bd4e90259f2e6a7d78dd1f7bf3e ) + name "Dragonborne DX (World) (v1.0.2) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Dragonborne DX (World) (v1.0.2) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dragonborne DX (World) (v1.0.2) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 4194304 crc 9f30b891 sha1 9974d28975a2d8e1e41ce8f32351c6eef144919d ) ) game ( - name "Super Bombliss DX (Japan) (En) (SGB Enhanced) (GB Compatible)" - description "Super Bombliss DX (Japan) (En) (SGB Enhanced) (GB Compatible)" - rom ( name "Super Bombliss DX (Japan) (En) (SGB Enhanced) (GB Compatible).gbc" size 262144 crc 34c8a4a5 sha1 44070e77eb2b56b67f979e444d404e56b67edbb0 ) + name "Dragonmaster (World) (Aftermarket) (Unl)" + description "Dragonmaster (World) (Aftermarket) (Unl)" + rom ( name "Dragonmaster (World) (Aftermarket) (Unl).gbc" size 262144 crc 4aaf9f58 sha1 6400de1108f1c3e5fca15de47f62299bfc66a938 ) ) game ( - name "Super Breakout! (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - description "Super Breakout! (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - rom ( name "Super Breakout! (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 524288 crc 6833923d sha1 5bd06600b35cd2b2e8d51ede6f79db76ba97e78e ) + name "Dragonyhm (World) (v1.0.0) (Demo) (SGB Enhanced) (GB Compatible) (Aftermarket) (Unl)" + description "Dragonyhm (World) (v1.0.0) (Demo) (SGB Enhanced) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dragonyhm (World) (v1.0.0) (Demo) (SGB Enhanced) (GB Compatible) (Aftermarket) (Unl).gbc" size 4194304 crc 96f9b7c0 sha1 2b74d076cabff92e5935d922e8f37202a723aaf0 flags verified ) ) game ( - name "Super Breakout! (USA) (GB Compatible)" - description "Super Breakout! (USA) (GB Compatible)" - rom ( name "Super Breakout! (USA) (GB Compatible).gbc" size 1048576 crc 52f51cb5 sha1 8c795b6d8ebc3a796821a6b2879f3e5cebf9215c ) + name "Dragonyhm (World) (v1.1.0) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Dragonyhm (World) (v1.1.0) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dragonyhm (World) (v1.1.0) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 4194304 crc cad7369d sha1 0058096f8fcbb2774f908811aaa0b1ee54111493 ) ) game ( - name "Super Bunny Mission (World) (GB Compatible) (Aftermarket) (Unl)" - description "Super Bunny Mission (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Super Bunny Mission (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc c47330e2 sha1 6151286e93b2e2fb92f583371e650e36ab91aaf7 ) + name "Dungeon Crystal (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Dungeon Crystal (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dungeon Crystal (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 028a6e47 sha1 3fb673067aee3c50b65f0f8316bfff46a76c19bb ) ) game ( - name "Super Chinese Fighter EX (Japan)" - description "Super Chinese Fighter EX (Japan)" - rom ( name "Super Chinese Fighter EX (Japan).gbc" size 1048576 crc dcdaa333 sha1 0296d0a60933c798b21399195789d10eb319872f ) + name "Dungeon Crystal (World) (v1.0) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Dungeon Crystal (World) (v1.0) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dungeon Crystal (World) (v1.0) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 0eaeeca3 sha1 0b452000a244cd9757c4bb158d997785a13b0d1e ) ) game ( - name "Super Doll Licca-chan - Kisekae Daisakusen (Japan)" - description "Super Doll Licca-chan - Kisekae Daisakusen (Japan)" - rom ( name "Super Doll Licca-chan - Kisekae Daisakusen (Japan).gbc" size 1048576 crc df50473f sha1 8becf5a8834285f2aff42812c8e44d864ee46d02 ) + name "Dusky Dungeon (World) (v0.1.0) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Dusky Dungeon (World) (v0.1.0) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dusky Dungeon (World) (v0.1.0) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 7c41cef6 sha1 e2df238887da0b6cf79513c7799ad707740eae30 ) ) game ( - name "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl)" - description "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl)" - rom ( name "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl).gbc" size 524288 crc d44c9806 sha1 c761dca73b520711b3205e11091e2bf8d4fd7549 flags verified ) + name "Dusky Dungeon (World) (v0.2.0) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Dusky Dungeon (World) (v0.2.0) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Dusky Dungeon (World) (v0.2.0) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc abb154db sha1 f3b456d6318bee05150403efa5a933996e1d744a ) ) game ( - name "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl) (Alt)" - description "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl) (Alt)" - rom ( name "Super Donkey Kong 5 (Taiwan) (En) (Rumble Version) (Unl) (Alt).gbc" size 524288 crc 33093c28 sha1 f5b556a15a1929cbcd21f0f2fc0da7bf23b99bd4 ) + name "Egbert (World) (Aftermarket) (Unl)" + description "Egbert (World) (Aftermarket) (Unl)" + rom ( name "Egbert (World) (Aftermarket) (Unl).gbc" size 262144 crc a0e904fc sha1 ead756b54b2c1462708b4509ac35503f04e482cf ) ) game ( - name "Super Fighters 99 (Taiwan) (SGB Enhanced) (Unl)" - description "Super Fighters 99 (Taiwan) (SGB Enhanced) (Unl)" - rom ( name "Super Fighters 99 (Taiwan) (SGB Enhanced) (Unl).gbc" size 2097152 crc ce41b1bb sha1 e5af8afdce844f02c4128748067933840a759773 ) + name "Elementaria - Orientational Waltz (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Elementaria - Orientational Waltz (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Elementaria - Orientational Waltz (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc bffec2e1 sha1 a25cc6ee07e524f9a7121786bd0e513a1c6c2a8d ) ) game ( - name "Super Fighters S (Taiwan) (GB Compatible) (Unl)" - description "Super Fighters S (Taiwan) (GB Compatible) (Unl)" - rom ( name "Super Fighters S (Taiwan) (GB Compatible) (Unl).gbc" size 2097152 crc 64db799a sha1 ef0bf0feaf9e2bdfb10acd469e915266655adb43 ) + name "Empire of Dreams, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Empire of Dreams, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Empire of Dreams, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 9ca3cf6c sha1 d3f4d21bf543431672268b476802693b2da9b6b9 ) ) game ( - name "Super Gals! Kotobuki Ran (Japan)" - description "Super Gals! Kotobuki Ran (Japan)" - rom ( name "Super Gals! Kotobuki Ran (Japan).gbc" size 4194304 crc 90379c16 sha1 fc18f5137d6063ca1afe20f5d3ed544e527e6bcf flags verified ) + name "Escape from Vostok (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Escape from Vostok (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Escape from Vostok (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 5d19bbcb sha1 6bb0ddd2b05d0ae6c7d2538f68f4b587901c29fd ) ) game ( - name "Super Gals! Kotobuki Ran 2 - Miracle Getting (Japan)" - description "Super Gals! Kotobuki Ran 2 - Miracle Getting (Japan)" - rom ( name "Super Gals! Kotobuki Ran 2 - Miracle Getting (Japan).gbc" size 4194304 crc e77fa0f2 sha1 a724c6dd33b84ae9120d041fc49d66692c798dd0 ) + name "Everlasting Summer (World) (Proto) (Aftermarket) (Unl)" + description "Everlasting Summer (World) (Proto) (Aftermarket) (Unl)" + rom ( name "Everlasting Summer (World) (Proto) (Aftermarket) (Unl).gbc" size 262144 crc e45f6923 sha1 a4d7b12c71faf37a6703ded4d8a39844cf4f0395 ) ) game ( - name "Super Gran (World) (Aftermarket) (Unl)" - description "Super Gran (World) (Aftermarket) (Unl)" - rom ( name "Super Gran (World) (Aftermarket) (Unl).gbc" size 262144 crc 98ee2e8a sha1 5afe9c7ab1b9d86048a570e7a37a0c244cb84e43 ) + name "Expiration Date (World) (v1.5) (GB Compatible) (Aftermarket) (Unl)" + description "Expiration Date (World) (v1.5) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Expiration Date (World) (v1.5) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f222b03b sha1 c14f008cfc182f35fe670e14b57052ae4f8d1c60 ) ) game ( - name "Super Impostor Bros. (World) (GB Compatible) (Aftermarket) (Unl)" - description "Super Impostor Bros. (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Super Impostor Bros. (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc a38d702f sha1 301f93da4e5b0cd8dc3f1bf3e66e38176b8a909b ) + name "Expiration Date (World) (GB Compatible) (Aftermarket) (Unl)" + description "Expiration Date (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Expiration Date (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 050caa5e sha1 e4b61c220b046e2287272f9b1bef85ad2d835fe3 ) ) game ( - name "Super Jacked Up Tomato Face Johnson (World) (v2.2) (Aftermarket) (Unl)" - description "Super Jacked Up Tomato Face Johnson (World) (v2.2) (Aftermarket) (Unl)" - rom ( name "Super Jacked Up Tomato Face Johnson (World) (v2.2) (Aftermarket) (Unl).gbc" size 524288 crc 8e1f6bb0 sha1 27522a35211b0f015fa9550c2520f1da1c346886 ) + name "Exploits of Fingers Malone, The (World) (Aftermarket) (Unl)" + description "Exploits of Fingers Malone, The (World) (Aftermarket) (Unl)" + rom ( name "Exploits of Fingers Malone, The (World) (Aftermarket) (Unl).gbc" size 524288 crc 20fe84af sha1 18056b5b032955099c606651f26164de131e54a6 ) ) game ( - name "Super Jacked Up Tomato Face Johnson (World) (v2.3) (Aftermarket) (Unl)" - description "Super Jacked Up Tomato Face Johnson (World) (v2.3) (Aftermarket) (Unl)" - rom ( name "Super Jacked Up Tomato Face Johnson (World) (v2.3) (Aftermarket) (Unl).gbc" size 524288 crc f9731ee2 sha1 23855b95d04a6c7c6d2ce7977bb31dbe6c0e68a0 ) + name "Far After (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Far After (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Far After (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc bdaf8f3f sha1 d1ed0fb4d926f4c337399ca342644f89cf00790a ) ) game ( - name "Super Jacked Up Tomato Face Johnson (World) (Jam Version) (Aftermarket) (Unl)" - description "Super Jacked Up Tomato Face Johnson (World) (Jam Version) (Aftermarket) (Unl)" - rom ( name "Super Jacked Up Tomato Face Johnson (World) (Jam Version) (Aftermarket) (Unl).gbc" size 524288 crc 87956ddf sha1 b23320d5d3fde2a55b301f7bea324833c31c32d5 ) + name "Far After (World) (v1.01) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Far After (World) (v1.01) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Far After (World) (v1.01) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc e61c1dc2 sha1 d7a88a68ec65d9cf3f9521fc9ad9d3f4b51bac5d flags verified ) ) game ( - name "Super JetPak DX (World) (GB Compatible) (Aftermarket)" - description "Super JetPak DX (World) (GB Compatible) (Aftermarket)" - rom ( name "Super JetPak DX (World) (GB Compatible) (Aftermarket).gbc" size 131072 crc 22def6f9 sha1 e7438db01fbbdeea2404dbf3d093370421ec4e1c flags verified ) + name "Featherless Cake Delivery (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" + description "Featherless Cake Delivery (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Featherless Cake Delivery (World) (v2.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 63c6c960 sha1 b62ec7a341ea9a0bfe8f0b014da971b73606a86e ) ) game ( - name "Super Mario Bros. Deluxe (Japan) (NP)" - description "Super Mario Bros. Deluxe (Japan) (NP)" - rom ( name "Super Mario Bros. Deluxe (Japan) (NP).gbc" size 1048576 crc 866b1212 sha1 94466f48d8b4f811608ce8641de5f82315cd60b5 ) + name "Featherless Cake Delivery (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + description "Featherless Cake Delivery (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Featherless Cake Delivery (World) (v1.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc de373eba sha1 dbf2228017515b407ed9f4a9b3bf01bc2a5f7b0f ) ) game ( - name "Super Mario Bros. Deluxe (USA, Europe)" - description "Super Mario Bros. Deluxe (USA, Europe)" - rom ( name "Super Mario Bros. Deluxe (USA, Europe).gbc" size 1048576 crc a4cd26ff sha1 f84f26f22751b58ed57bd332274e18131660729a flags verified ) + name "Feed IT Souls (World) (v1.3) (Aftermarket) (Unl)" + description "Feed IT Souls (World) (v1.3) (Aftermarket) (Unl)" + rom ( name "Feed IT Souls (World) (v1.3) (Aftermarket) (Unl).gbc" size 1048576 crc 701847f5 sha1 aba3fecd55c0cee7fbe49506b367b7e94b56b81c ) ) game ( - name "Super Mario Bros. Deluxe (USA, Europe) (Rev 1)" - description "Super Mario Bros. Deluxe (USA, Europe) (Rev 1)" - rom ( name "Super Mario Bros. Deluxe (USA, Europe) (Rev 1).gbc" size 1048576 crc 90ab047b sha1 07295cd60ae44183ebecb013930727e0404169d5 flags verified ) + name "Feed IT Souls (World) (v1.4) (Aftermarket) (Unl)" + description "Feed IT Souls (World) (v1.4) (Aftermarket) (Unl)" + rom ( name "Feed IT Souls (World) (v1.4) (Aftermarket) (Unl).gbc" size 1048576 crc f87760b3 sha1 ea0dd170812d1bcc38de1cabe12a372cd2178c95 ) ) game ( - name "Super Mario Bros. Deluxe (Europe) (Rev 2)" - description "Super Mario Bros. Deluxe (Europe) (Rev 2)" - rom ( name "Super Mario Bros. Deluxe (Europe) (Rev 2).gbc" size 1048576 crc 62bbae83 sha1 254f2254e9d54e2501e3e4ebe09491e03573a6a4 ) + name "Feed The Monster (World) (GB Compatible) (Aftermarket) (Pirate)" + description "Feed The Monster (World) (GB Compatible) (Aftermarket) (Pirate)" + rom ( name "Feed The Monster (World) (GB Compatible) (Aftermarket) (Pirate).gbc" size 524288 crc 7bec6553 sha1 bdcadc0f98d8c9061cbe83c53a047719280b6e09 ) ) game ( - name "Super Mario Bros. Deluxe (Japan) (Rev 1) (NP)" - description "Super Mario Bros. Deluxe (Japan) (Rev 1) (NP)" - rom ( name "Super Mario Bros. Deluxe (Japan) (Rev 1) (NP).gbc" size 1048576 crc f4e91f63 sha1 e61d564e1ff19eb4b7c62a6cd96214f2bca4b01d ) + name "Fighter on the Path of Glory (World) (En,Ja) (v1.00) (GB Compatible) (Aftermarket) (Unl)" + description "Fighter on the Path of Glory (World) (En,Ja) (v1.00) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Fighter on the Path of Glory (World) (En,Ja) (v1.00) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 38f208f3 sha1 a4034a72dfacfe33fc924ab689f9a9303656c43d ) ) game ( - name "Super Mario Special 3 (Taiwan) (En) (Unl)" - description "Super Mario Special 3 (Taiwan) (En) (Unl)" - rom ( name "Super Mario Special 3 (Taiwan) (En) (Unl).gbc" size 524288 crc 5e4266a7 sha1 f493da9f707ad84c4d720687ec1ca3f635dc35c6 ) + name "Fillo - Crystal Version (World) (Aftermarket) (Unl)" + description "Fillo - Crystal Version (World) (Aftermarket) (Unl)" + rom ( name "Fillo - Crystal Version (World) (Aftermarket) (Unl).gbc" size 524288 crc 88bb855c sha1 2ffc4199d94f8b29b3f84b7bdb2694154a0bd285 ) ) game ( - name "Super Marrio Sunshine (Taiwan) (En) (Unl)" - description "Super Marrio Sunshine (Taiwan) (En) (Unl)" - rom ( name "Super Marrio Sunshine (Taiwan) (En) (Unl).gbc" size 2097152 crc 031a82dc sha1 cdb5707ee84f7404bfb04d6bd5a4c653b7927e35 ) + name "Find Out (World) (GB Compatible) (Aftermarket) (Unl)" + description "Find Out (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Find Out (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 5f8b660e sha1 3605a96f6713157a88e4d88989d2e2f11b9db42f ) ) game ( - name "Super Me-Mail GB - Me-Mail Bear no Happy Mail Town (Japan)" - description "Super Me-Mail GB - Me-Mail Bear no Happy Mail Town (Japan)" - rom ( name "Super Me-Mail GB - Me-Mail Bear no Happy Mail Town (Japan).gbc" size 1048576 crc 315caa18 sha1 4b96d2447b763f08d079eb07b95b6627d3fc120b ) + name "Finders Keepers (World) (Aftermarket) (Unl)" + description "Finders Keepers (World) (Aftermarket) (Unl)" + rom ( name "Finders Keepers (World) (Aftermarket) (Unl).gbc" size 524288 crc 4cfa0cfd sha1 db002f4a2500a9dc98a9ac7c263293d6e4a72cf1 ) ) game ( - name "Super Nenas, Las - El Malvado Mojo Jojo (Spain)" - description "Super Nenas, Las - El Malvado Mojo Jojo (Spain)" - rom ( name "Super Nenas, Las - El Malvado Mojo Jojo (Spain).gbc" size 2097152 crc efe652bf sha1 286cabc9ea92d1866e59748a788658c5e3d32a35 ) + name "Fire Ant (World) (Aftermarket) (Unl)" + description "Fire Ant (World) (Aftermarket) (Unl)" + rom ( name "Fire Ant (World) (Aftermarket) (Unl).gbc" size 262144 crc 154cc020 sha1 b58ed66838db34fc7f8475ccb670267119d623a5 ) ) game ( - name "Super Nenas, Las - Lucha Con Ese (Spain)" - description "Super Nenas, Las - Lucha Con Ese (Spain)" - rom ( name "Super Nenas, Las - Lucha Con Ese (Spain).gbc" size 2097152 crc 7ba87c11 sha1 06b0835c40d4f27ad45833d54f606a0964e09de0 ) + name "Fireman Fred (World) (Aftermarket) (Unl)" + description "Fireman Fred (World) (Aftermarket) (Unl)" + rom ( name "Fireman Fred (World) (Aftermarket) (Unl).gbc" size 524288 crc 563d9ca7 sha1 e62a9c6b6a39f0cb662fdb07b72669355b706f57 ) ) game ( - name "Super Nenas, Las - Panico en Townsville (Spain)" - description "Super Nenas, Las - Panico en Townsville (Spain)" - rom ( name "Super Nenas, Las - Panico en Townsville (Spain).gbc" size 2097152 crc 03edb574 sha1 34463c99193e4cf99aa1833242fa2b30db9fe522 ) + name "Firemen (World) (Aftermarket) (Unl)" + description "Firemen (World) (Aftermarket) (Unl)" + rom ( name "Firemen (World) (Aftermarket) (Unl).gbc" size 262144 crc 7299401f sha1 84c68614334578f866cfa929df736377f04f5d04 ) ) game ( - name "Super Real Fishing (Japan) (Rumble Version)" - description "Super Real Fishing (Japan) (Rumble Version)" - rom ( name "Super Real Fishing (Japan) (Rumble Version).gbc" size 1048576 crc 00865161 sha1 cbd6ca89332ee11f89b580e53b53285760dd025a ) + name "Fishing for Asteroids (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Fishing for Asteroids (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Fishing for Asteroids (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc aae310ed sha1 b874c82fe582ee34b93cd4f6dcfc16e6fe991efe ) ) game ( - name "Super Robot Pinball (Japan)" - description "Super Robot Pinball (Japan)" - rom ( name "Super Robot Pinball (Japan).gbc" size 2097152 crc 6e330fcd sha1 2dbe45e3d5912b270b8bfacc5d9ffc836fe74284 ) + name "Fishing for Asteroids (World) (v1.0) (Mini Jam 153) (GB Compatible) (Aftermarket) (Unl)" + description "Fishing for Asteroids (World) (v1.0) (Mini Jam 153) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Fishing for Asteroids (World) (v1.0) (Mini Jam 153) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc efbefb4b sha1 966f3f17b7acf5a60212d300c62fd5a4e50047ae ) ) game ( - name "Super Robot Taisen - Link Battler (Japan) (SGB Enhanced) (GB Compatible)" - description "Super Robot Taisen - Link Battler (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Super Robot Taisen - Link Battler (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d24e592d sha1 e6c715042adc4c1b52a7295e082953ada79cf95e ) + name "Fishnet Burn (World) (Demo) (Aftermarket) (Unl)" + description "Fishnet Burn (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Fishnet Burn (World) (Demo) (Aftermarket) (Unl).gbc" size 262144 crc a317673d sha1 3b28ba3bbcb2c387976e98a47650426131823c56 ) ) game ( - name "Supercross Freestyle (Europe) (En,Fr,De,Es,It)" - description "Supercross Freestyle (Europe) (En,Fr,De,Es,It)" - rom ( name "Supercross Freestyle (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 4d3e0f51 sha1 4f4aa8353d230e3a65a7e68dbb3312ad871894df ) + name "Fix It Felix Jr. (World) (GB Compatible) (Aftermarket) (Unl)" + description "Fix It Felix Jr. (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Fix It Felix Jr. (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc c8014615 sha1 7221f5e53f6027183301d06e258c6cb417007b8c ) ) game ( - name "Superman - Battle for Metropolis (Europe) (Proto) (2001-01-12) (GB Compatible)" - description "Superman - Battle for Metropolis (Europe) (Proto) (2001-01-12) (GB Compatible)" - rom ( name "Superman - Battle for Metropolis (Europe) (Proto) (2001-01-12) (GB Compatible).gbc" size 2097152 crc 6606382c sha1 4d9a17deefaf03532e952cd909584fca2d3cdd09 ) + name "Fix My Heart (World) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl)" + description "Fix My Heart (World) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Fix My Heart (World) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 507f9ea2 sha1 28ad64e379dc60d6e1c2617e073f6361c0feb475 flags verified ) ) game ( - name "Supershot Golf Robot (USA) (Proto)" - description "Supershot Golf Robot (USA) (Proto)" - rom ( name "Supershot Golf Robot (USA) (Proto).gbc" size 2097152 crc b6a7f781 sha1 aa1447d78e380d2a936fb5f713521e34420fe68c ) + name "Flashin' (World) (v3.0) (GB Compatible) (Aftermarket) (Unl)" + description "Flashin' (World) (v3.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Flashin' (World) (v3.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc fcc05ec4 sha1 64d31f34e189b3af08bf0c659a93f71dbf83ef71 ) ) game ( - name "Supreme Snowboarding (Europe) (En,Fr,De)" - description "Supreme Snowboarding (Europe) (En,Fr,De)" - rom ( name "Supreme Snowboarding (Europe) (En,Fr,De).gbc" size 2097152 crc 53b1e661 sha1 4f745ffa0146e21bb26408cf7431376887499919 ) + name "Flooder (World) (Aftermarket) (Unl)" + description "Flooder (World) (Aftermarket) (Unl)" + rom ( name "Flooder (World) (Aftermarket) (Unl).gbc" size 32768 crc 253dcbe0 sha1 8fdcd8b02604ac5259fb6aa80e5ba67a03c861fb ) ) game ( - name "Survival Kids (USA) (SGB Enhanced) (GB Compatible)" - description "Survival Kids (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "Survival Kids (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc c46aba56 sha1 0e3d3821710b07f68628edda071b928df0c6a2f2 ) + name "Flooder (World) (Anniversary Edition) (Aftermarket) (Unl)" + description "Flooder (World) (Anniversary Edition) (Aftermarket) (Unl)" + rom ( name "Flooder (World) (Anniversary Edition) (Aftermarket) (Unl).gbc" size 32768 crc cdda76f8 sha1 e5eec8efc032aa5bce1826f7b6b8790c61c96e06 ) ) game ( - name "Survival Kids - Kotou no Boukensha (Japan) (SGB Enhanced) (GB Compatible)" - description "Survival Kids - Kotou no Boukensha (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Survival Kids - Kotou no Boukensha (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 61fa675c sha1 f80abbeaa2cf0631c1cdf812c13f13f1fea41f18 ) + name "Foal's Creek (World) (v1.06) (GB Compatible) (Aftermarket) (Unl)" + description "Foal's Creek (World) (v1.06) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Foal's Creek (World) (v1.06) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 40027de8 sha1 6d4152d0db5c7fdc2d3271ffc9195494e637c85a ) ) game ( - name "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (SGB Enhanced) (GB Compatible)" - description "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc ab8b25d8 sha1 8fd720d5b035939b553910a3ec45c1bd052484eb ) + name "Foal's Creek (World) (v1.05) (GB Compatible) (Aftermarket) (Unl)" + description "Foal's Creek (World) (v1.05) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Foal's Creek (World) (v1.05) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc c0db789e sha1 025e83abce412435c41e77dc7ecc606af96f874b ) ) game ( - name "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (Rev 1) (Possible Proto) (SGB Enhanced, GB Compatible) (NP)" - description "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (Rev 1) (Possible Proto) (SGB Enhanced, GB Compatible) (NP)" - rom ( name "Survival Kids 2 - Dasshutsu!! Futago-Jima! (Japan) (Rev 1) (Possible Proto) (SGB Enhanced, GB Compatible) (NP).gbc" size 1048576 crc bd366d22 sha1 505ffc930057719cf28560333342dfd6944c15da ) + name "Forest of Fallen Knights (World) (GB Compatible) (Aftermarket) (Unl)" + description "Forest of Fallen Knights (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Forest of Fallen Knights (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc fa2d92a1 sha1 24f02d116aafb7b55d6cfd6d263b7595986af843 ) ) game ( - name "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 1)" - description "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 1)" - rom ( name "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 1).gbc" size 524288 crc 617d7667 sha1 b215146fe8e2a5836d0ac6fa4785f95db464fc1a ) + name "Forest of Fallen Knights (World) (Beta) (GB Compatible) (Aftermarket) (Unl)" + description "Forest of Fallen Knights (World) (Beta) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Forest of Fallen Knights (World) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 4c21e563 sha1 f6f84f1a44d41fa7d26a9195ddf791fae53dfcdf ) ) game ( - name "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 2)" - description "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 2)" - rom ( name "Suske en Wiske - De Tijdtemmers ~ Bob et Bobette - Les Dompteurs du Temps (Europe) (Fr,Nl) (Beta 2).gbc" size 524288 crc 6bfcfd87 sha1 83c64dd44d3d03e3fd0711b23bf63e2264256dea ) + name "Friday the 13th - The GB Game (World) (GB Compatible) (Aftermarket) (Unl)" + description "Friday the 13th - The GB Game (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Friday the 13th - The GB Game (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 7543586a sha1 397821751ac6464582f61566f3a7c731a46b24ba ) ) game ( - name "Sutte Hakkun GB (Japan) (Proto)" - description "Sutte Hakkun GB (Japan) (Proto)" - rom ( name "Sutte Hakkun GB (Japan) (Proto).gbc" size 524288 crc e0386f84 sha1 6efd637f039d4f3a2240640921724a69a2844cc7 ) + name "Friendly Fire (World) (Aftermarket) (Unl)" + description "Friendly Fire (World) (Aftermarket) (Unl)" + rom ( name "Friendly Fire (World) (Aftermarket) (Unl).gbc" size 262144 crc 5c6dca2b sha1 8f8085010e28aa8bdb312d086b0002b706742282 ) ) game ( - name "Suzuki Alstare Extreme Racing (Europe) (En,Fr,De,Es,It,Nl)" - description "Suzuki Alstare Extreme Racing (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Suzuki Alstare Extreme Racing (Europe) (En,Fr,De,Es,It,Nl).gbc" size 524288 crc 0f7264ba sha1 2489b5c2572246edf3f28f9d62abcda9d63b62bf ) + name "Friendly Fire (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" + description "Friendly Fire (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Friendly Fire (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc d8be10d6 sha1 d09f4d2f799ac2e2731be0171625846d28d0f57e ) ) game ( - name "Suzuki Alstare Extreme Racing (USA) (Proto)" - description "Suzuki Alstare Extreme Racing (USA) (Proto)" - rom ( name "Suzuki Alstare Extreme Racing (USA) (Proto).gbc" size 524288 crc a13cf42e sha1 b2816e8585e03b7d547e8acfda716b7adddf3b41 ) + name "From Below Pocket (World) (Aftermarket) (Unl)" + description "From Below Pocket (World) (Aftermarket) (Unl)" + rom ( name "From Below Pocket (World) (Aftermarket) (Unl).gbc" size 131072 crc 35ad9b5a sha1 c0e072bfb88c84dc68b2eded1f9c088d75ffa5ed ) ) game ( - name "Sweet Ange (Japan) (SGB Enhanced) (GB Compatible)" - description "Sweet Ange (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Sweet Ange (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 4be9b159 sha1 5b6f268d945bcdb070195459582f01b434c01495 ) + name "Fugazim (World) (Pt) (GB Compatible) (Aftermarket) (Unl)" + description "Fugazim (World) (Pt) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Fugazim (World) (Pt) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 85edfba4 sha1 8a95571a32c5a23bd6be4edf6429f630d7a1a15a ) ) game ( - name "Swing (Germany)" - description "Swing (Germany)" - rom ( name "Swing (Germany).gbc" size 1048576 crc 7041929d sha1 c681530a49a5287ef59b4bae02cb1f9e82c72386 ) + name "Fury (World) (Aftermarket) (Unl)" + description "Fury (World) (Aftermarket) (Unl)" + rom ( name "Fury (World) (Aftermarket) (Unl).gbc" size 262144 crc 7217c41d sha1 ef532b587eb438f1a39a77086ac0b8bbae23a16d ) ) game ( - name "Swing (Europe) (En,Fr,De,Es,It) (Proto)" - description "Swing (Europe) (En,Fr,De,Es,It) (Proto)" - rom ( name "Swing (Europe) (En,Fr,De,Es,It) (Proto).gbc" size 1048576 crc 60d06df9 sha1 576d4338665f159a88875819f0681fdc49443fe4 ) + name "G-Man (World) (Aftermarket) (Unl)" + description "G-Man (World) (Aftermarket) (Unl)" + rom ( name "G-Man (World) (Aftermarket) (Unl).gbc" size 524288 crc ff3beab1 sha1 cb9486ca9a6ad3903662963aa966145257ef92a6 ) ) game ( - name "SWiV (Europe) (En,Fr,De,Es,It)" - description "SWiV (Europe) (En,Fr,De,Es,It)" - rom ( name "SWiV (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 44d30b7a sha1 7e037008eabf01fa647cdfb0d5c88766a6f77423 ) + name "G.B Corp. (World) (Beta) (GB Compatible) (Aftermarket) (Unl)" + description "G.B Corp. (World) (Beta) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "G.B Corp. (World) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc fd2e40f4 sha1 e442316132506ff223a9e5f33d874b71ec09d71a flags verified ) ) game ( - name "Swordbird Song - The Iron Owl Tower (World) (v3.1) (GB Compatible) (Aftermarket) (Unl)" - description "Swordbird Song - The Iron Owl Tower (World) (v3.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Swordbird Song - The Iron Owl Tower (World) (v3.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 64921bb1 sha1 b36ec89e0299c19767cc5c6467fa3664abbc3017 ) + name "Game Boy Camera Gallery - Mystery Show (World) (v1.4) (Digital) (GB Compatible) (Aftermarket) (Unl)" + description "Game Boy Camera Gallery - Mystery Show (World) (v1.4) (Digital) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Game Boy Camera Gallery - Mystery Show (World) (v1.4) (Digital) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc aba1f99a sha1 8278abbe74202537bdc42f2e00875a12e77c9115 ) ) game ( - name "Swordbird Song - The Iron Owl Tower (World) (v3.0) (GB Compatible) (Aftermarket) (Unl)" - description "Swordbird Song - The Iron Owl Tower (World) (v3.0) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Swordbird Song - The Iron Owl Tower (World) (v3.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc b2b5dc4b sha1 aaa66863b2e68865359d1c0db2047bab6f64f9ee ) + name "Game Boy Camera Gallery - Mystery Show (World) (v1.2) (Digital) (GB Compatible) (Aftermarket) (Unl)" + description "Game Boy Camera Gallery - Mystery Show (World) (v1.2) (Digital) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Game Boy Camera Gallery - Mystery Show (World) (v1.2) (Digital) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc b3629b4a sha1 649678adc47eeb1386a90084ddb2fbf99b08ca4c ) ) game ( - name "Sylvanian Families - Otogi no Kuni no Pendant (Japan) (SGB Enhanced) (GB Compatible)" - description "Sylvanian Families - Otogi no Kuni no Pendant (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Sylvanian Families - Otogi no Kuni no Pendant (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc c6fe4497 sha1 440d0010386f3f2d658740cc6584558f546482a6 ) + name "Game Boy Camera Gallery 2022, The (World) (GB Compatible) (Aftermarket) (Unl)" + description "Game Boy Camera Gallery 2022, The (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Game Boy Camera Gallery 2022, The (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc f1948966 sha1 14849ab5831c71949ec3a1fe7657050057d2cf29 ) ) game ( - name "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan)" - description "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan)" - rom ( name "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan).gbc" size 2097152 crc f82d391f sha1 16f5d02e0272fbb2b0a3c219487484c7013ba4fb ) + name "Game with The Cerulean Blob, The (World) (Demo) (Aftermarket) (Unl)" + description "Game with The Cerulean Blob, The (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Game with The Cerulean Blob, The (World) (Demo) (Aftermarket) (Unl).gbc" size 524288 crc be05262e sha1 9fff6703a876d19027f8d8c590d1223d0e931420 ) ) game ( - name "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan) (Rev 1) (Possible Proto)" - description "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan) (Rev 1) (Possible Proto)" - rom ( name "Sylvanian Families 2 - Irozuku Mori no Fantasy (Japan) (Rev 1) (Possible Proto).gbc" size 2097152 crc ad6f3bdf sha1 c96044d57a2367ffb7b2325aa8d0c9b659e0aaba ) + name "Gamer Boy Mission (World) (GB Compatible) (Aftermarket) (Unl)" + description "Gamer Boy Mission (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Gamer Boy Mission (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 96721e5d sha1 90fad94433a5b0dbcf73f4a2d4ebb75d7ab065c4 ) ) game ( - name "Sylvanian Families 3 - Hoshi Furu Yoru no Sunadokei (Japan)" - description "Sylvanian Families 3 - Hoshi Furu Yoru no Sunadokei (Japan)" - rom ( name "Sylvanian Families 3 - Hoshi Furu Yoru no Sunadokei (Japan).gbc" size 2097152 crc abf32b8b sha1 ab279c72758cd2ca41a5f41ce3c9cad9490aaca3 ) + name "Gamer Boy Mission (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Gamer Boy Mission (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Gamer Boy Mission (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc a02d2ae2 sha1 7eb6865c5c265193763ec0bf751d26964e870120 ) ) game ( - name "Sylvanian Melodies - Mori no Nakama to Odori Masho! (Japan) (SGB Enhanced) (GB Compatible)" - description "Sylvanian Melodies - Mori no Nakama to Odori Masho! (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Sylvanian Melodies - Mori no Nakama to Odori Masho! (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6dd8ac91 sha1 55230e865958f7301076a4354b6b8b083a494bae ) + name "GB-Wordyl (World) (Pt-BR) (GB Compatible) (Aftermarket) (Unl)" + description "GB-Wordyl (World) (Pt-BR) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "GB-Wordyl (World) (Pt-BR) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc f20c0097 sha1 691af25434a09931a302ced52c757d28b9b06619 ) ) game ( - name "Sylvester & Tweety - Breakfast on the Run (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - description "Sylvester & Tweety - Breakfast on the Run (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - rom ( name "Sylvester & Tweety - Breakfast on the Run (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc 6bb3b0dc sha1 8999a54b27b51a078fb3776ec7842c56287f05df flags verified ) + name "GB-Wordyl (World) (Ca) (GB Compatible) (Aftermarket) (Unl)" + description "GB-Wordyl (World) (Ca) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "GB-Wordyl (World) (Ca) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 164999eb sha1 197d3d194d4cb6cae9a358f7fb53d6de649e7c5f ) ) game ( - name "Tabaluga (Germany) (GB Compatible)" - description "Tabaluga (Germany) (GB Compatible)" - rom ( name "Tabaluga (Germany) (GB Compatible).gbc" size 1048576 crc f09f92d7 sha1 d23fe68a0d95a8efb5d4536b03c0a3fc250e8258 ) + name "GB-Wordyl (World) (De) (GB Compatible) (Aftermarket) (Unl)" + description "GB-Wordyl (World) (De) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "GB-Wordyl (World) (De) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 60b075d1 sha1 0a66254b2327b48657de64d6102ac05f1e8700e7 ) ) game ( - name "Taikong Baobei (Taiwan) (Sintax) (Unl)" - description "Taikong Baobei (Taiwan) (Sintax) (Unl)" - rom ( name "Taikong Baobei (Taiwan) (Sintax) (Unl).gbc" size 2097152 crc f2d0f0ae sha1 bb2f4b475b6a7f355913267f02722f3b15bd0858 ) + name "GB-Wordyl (World) (Es) (GB Compatible) (Aftermarket) (Unl)" + description "GB-Wordyl (World) (Es) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "GB-Wordyl (World) (Es) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 1a169897 sha1 0636b968e8e24fe7c1910f61db6e94fa84824494 ) ) game ( - name "Taikong Baobei (Taiwan) (Li Cheng) (Unl)" - description "Taikong Baobei (Taiwan) (Li Cheng) (Unl)" - rom ( name "Taikong Baobei (Taiwan) (Li Cheng) (Unl).gbc" size 4194304 crc 23f291b3 sha1 278b484fa26f13a98ae5bbe06d19a5c47ccfcd34 ) + name "GB-Wordyl (World) (Fr) (GB Compatible) (Aftermarket) (Unl)" + description "GB-Wordyl (World) (Fr) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "GB-Wordyl (World) (Fr) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 593965ff sha1 75d566045a680aaed4d40b83b6418cbfab5b4422 ) ) game ( - name "Taikong Zhanshi - Jingdian Ban (Taiwan) (Unl)" - description "Taikong Zhanshi - Jingdian Ban (Taiwan) (Unl)" - rom ( name "Taikong Zhanshi - Jingdian Ban (Taiwan) (Unl).gbc" size 1048576 crc 8b9f30d7 sha1 8f7272ed851844e78d1920614f5de94f0f0cecde ) + name "GB-Wordyl (World) (It) (GB Compatible) (Aftermarket) (Unl)" + description "GB-Wordyl (World) (It) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "GB-Wordyl (World) (It) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc d81ab567 sha1 1dfd3c4508ffb6598662bcf1b16ec109a9282dd5 ) ) game ( - name "Taikong Zhanshi DX3 - Zuizhong Huanxiang (Taiwan) (Unl)" - description "Taikong Zhanshi DX3 - Zuizhong Huanxiang (Taiwan) (Unl)" - rom ( name "Taikong Zhanshi DX3 - Zuizhong Huanxiang (Taiwan) (Unl).gbc" size 2097152 crc ddf36a27 sha1 0a62b484c5730a3a1f8b32cc2ed97af128d2130c ) + name "GB-Wordyl (World) (Kw) (GB Compatible) (Aftermarket) (Unl)" + description "GB-Wordyl (World) (Kw) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "GB-Wordyl (World) (Kw) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc f795689c sha1 9a332127182e8155d1a3dc53e1382a6c9dde6aeb ) ) game ( - name "Taisen Tsume Shougi (Japan) (NP) (GB Compatible)" - description "Taisen Tsume Shougi (Japan) (NP) (GB Compatible)" - rom ( name "Taisen Tsume Shougi (Japan) (NP) (GB Compatible).gbc" size 1048576 crc 95310c8b sha1 813b97785076d2a17b19fa48ee2e0047c54259e0 ) + name "GB-Wordyl (World) (Es-XL) (GB Compatible) (Aftermarket) (Unl)" + description "GB-Wordyl (World) (Es-XL) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "GB-Wordyl (World) (Es-XL) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 660ed37b sha1 0792fbef010cac21c12cbcb8b3c85b3af30faec4 ) ) game ( - name "Taito Memorial - Bubble Bobble (Japan) (SGB Enhanced) (GB Compatible)" - description "Taito Memorial - Bubble Bobble (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Taito Memorial - Bubble Bobble (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 388c6760 sha1 6a30d328417e085dcd10588d0a5af90ff4bfa40d ) + name "GB-Wordyl (World) (Nl) (GB Compatible) (Aftermarket) (Unl)" + description "GB-Wordyl (World) (Nl) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "GB-Wordyl (World) (Nl) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 6dc4faaa sha1 7617083f9b13b2f95bdf1b0b327ffb4f8ccbe3c9 ) ) game ( - name "Taito Memorial - Chase H.Q. - Secret Police (Japan) (SGB Enhanced) (GB Compatible)" - description "Taito Memorial - Chase H.Q. - Secret Police (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Taito Memorial - Chase H.Q. - Secret Police (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6a0c272d sha1 d6d90667ebf295016f01b4604ab03ab5b1876d00 ) + name "GB-Wordyl (World) (En) (GB Compatible) (Aftermarket) (Unl)" + description "GB-Wordyl (World) (En) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "GB-Wordyl (World) (En) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 8780e125 sha1 7163bfbaa2cae2f9d41c472128f69a4fa5879180 ) ) game ( - name "Tales of Monsterland (World) (v2.83) (GB Compatible) (Aftermarket) (Unl)" - description "Tales of Monsterland (World) (v2.83) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Tales of Monsterland (World) (v2.83) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc a685f89a sha1 15a709d4300464b03ede4d774ce69cfb699c0fcf ) + name "Ghost of the Arcade (World) (v1.7) (Aftermarket) (Unl)" + description "Ghost of the Arcade (World) (v1.7) (Aftermarket) (Unl)" + rom ( name "Ghost of the Arcade (World) (v1.7) (Aftermarket) (Unl).gbc" size 1048576 crc 4aa9a9c2 sha1 ac697bc27a126c1389e6bef94a2c83404e8819f2 ) ) game ( - name "Tales of Phantasia - Narikiri Dungeon (Japan) (SGB Enhanced) (GB Compatible)" - description "Tales of Phantasia - Narikiri Dungeon (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Tales of Phantasia - Narikiri Dungeon (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 725cf31c sha1 ef322f4160ceebd8da67758ebd73225190af6d23 flags verified ) + name "Ghost of the Arcade (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" + description "Ghost of the Arcade (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Ghost of the Arcade (World) (v1.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 32e2ea48 sha1 ee11d5397316b69eee5ae3023de08c3b919c93df ) ) game ( - name "Tamarindo's Freaking Dinner DX (World) (Aftermarket) (Unl)" - description "Tamarindo's Freaking Dinner DX (World) (Aftermarket) (Unl)" - rom ( name "Tamarindo's Freaking Dinner DX (World) (Aftermarket) (Unl).gbc" size 262144 crc 257d9201 sha1 d78e0b03a3915531e780057c4ad7ed2b3f849825 ) + name "Ghost of the Arcade (World) (GB Compo 2023) (GB Compatible) (Aftermarket) (Unl)" + description "Ghost of the Arcade (World) (GB Compo 2023) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Ghost of the Arcade (World) (GB Compo 2023) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc ea87ad5d sha1 433e25df1421e77cdc807296e1ed662d9e43d685 ) ) game ( - name "Tanimura Hitoshi Ryuu Pachinko Kouryaku Daisakusen - Don Quijote ga Iku (Japan) (SGB Enhanced) (GB Compatible)" - description "Tanimura Hitoshi Ryuu Pachinko Kouryaku Daisakusen - Don Quijote ga Iku (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Tanimura Hitoshi Ryuu Pachinko Kouryaku Daisakusen - Don Quijote ga Iku (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc ce8ae58c sha1 f752e96602274a29006425a06086d8ab45e1075c ) + name "Ghost Town (World) (Aftermarket) (Unl)" + description "Ghost Town (World) (Aftermarket) (Unl)" + rom ( name "Ghost Town (World) (Aftermarket) (Unl).gbc" size 262144 crc 52efcc35 sha1 1a4a7846d6c87f0bd8b267aa6a8aa98e797fedf8 ) ) game ( - name "Tank Attack (World) (Aftermarket) (Unl)" - description "Tank Attack (World) (Aftermarket) (Unl)" - rom ( name "Tank Attack (World) (Aftermarket) (Unl).gbc" size 262144 crc c77dc518 sha1 4751a6999f4dbe7e66b997372588f6bd15e4d9d0 ) + name "Gods of the Universe (World) (Aftermarket) (Unl)" + description "Gods of the Universe (World) (Aftermarket) (Unl)" + rom ( name "Gods of the Universe (World) (Aftermarket) (Unl).gbc" size 262144 crc 27b87354 sha1 74eb8cd698097290b93fb08d9b19486d05411877 ) ) game ( - name "Tarzan (France)" - description "Tarzan (France)" - rom ( name "Tarzan (France).gbc" size 2097152 crc c503afbb sha1 9a4821570f565f7a1b3c7aba3c7cd2e1c1a0b570 flags verified ) + name "Gopher (World) (Aftermarket) (Unl)" + description "Gopher (World) (Aftermarket) (Unl)" + rom ( name "Gopher (World) (Aftermarket) (Unl).gbc" size 262144 crc 22802c30 sha1 e629199b6bd492bd5efa77c0d4d467e053d44877 ) ) game ( - name "Tarzan (Germany)" - description "Tarzan (Germany)" - rom ( name "Tarzan (Germany).gbc" size 2097152 crc 39d04581 sha1 ac8fc45cddb749b471a9b3f234b72731363c3b14 ) + name "Gorf the Ghost Saves Halloween (World) (GB Compatible) (Aftermarket) (Unl)" + description "Gorf the Ghost Saves Halloween (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Gorf the Ghost Saves Halloween (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ab10cec6 sha1 9dcaa6824fab806683737bdf1c76609c68c451a5 ) ) game ( - name "Tarzan (Japan)" - description "Tarzan (Japan)" - rom ( name "Tarzan (Japan).gbc" size 2097152 crc f2005973 sha1 920c9aa99a6dd0ca53694e2553de6388b2d22eac ) + name "GPC Rally (World) (v1.1) (Aftermarket) (Unl)" + description "GPC Rally (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "GPC Rally (World) (v1.1) (Aftermarket) (Unl).gbc" size 262144 crc 2ed2487c sha1 a711bbb2d7dc2b0c377ecd7b20f4862330961b51 ) ) game ( - name "Tarzan (USA, Europe)" - description "Tarzan (USA, Europe)" - rom ( name "Tarzan (USA, Europe).gbc" size 2097152 crc 4224f930 sha1 ce23eaa9aef5909883252d1340cf94e3483652b3 flags verified ) + name "GPC Rally (World) (v1.0) (Aftermarket) (Unl)" + description "GPC Rally (World) (v1.0) (Aftermarket) (Unl)" + rom ( name "GPC Rally (World) (v1.0) (Aftermarket) (Unl).gbc" size 262144 crc 3b15bdb8 sha1 b6500b0250d8358644e41e26ed8fb92c5b24535d ) ) game ( - name "Tasmanian Devil - Munching Madness (Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "Tasmanian Devil - Munching Madness (Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Tasmanian Devil - Munching Madness (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc 683752a0 sha1 e96ce1658bb9063042c64a161130f95f925f215b ) + name "Grave Encounter, A (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" + description "Grave Encounter, A (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Grave Encounter, A (World) (v1.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc a5ad3c0b sha1 1cf0cf6d1da5c5337856ecc0a60d2e9fb3c98f58 ) ) game ( - name "Tasmanian Devil - Munching Madness (USA) (En,Fr,De,Es,It) (GB Compatible)" - description "Tasmanian Devil - Munching Madness (USA) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Tasmanian Devil - Munching Madness (USA) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc 3611d0d8 sha1 e8c2465d0503fd02bcc50b81cb1040fff63bf513 ) + name "Grave Encounter, A (World) (v1.21) (GB Compatible) (Aftermarket) (Unl)" + description "Grave Encounter, A (World) (v1.21) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Grave Encounter, A (World) (v1.21) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc b29fc03f sha1 2f979202a4bf4f98f3026a7548a8b6c7008806bf ) ) game ( - name "Taxi 2 (France)" - description "Taxi 2 (France)" - rom ( name "Taxi 2 (France).gbc" size 1048576 crc 0fd9fff0 sha1 76927fbf52a4c53dcd58208439eb3f285ec568fb ) + name "Gravitorque (World) (GB Compatible) (Aftermarket) (Unl)" + description "Gravitorque (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Gravitorque (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc a0e998e1 sha1 ab656383e9aaaa2991aa344bdc8f21370f0eda36 ) ) game ( - name "Taxi 2 (Europe) (En,Fr,De,Es,It,Nl) (Proto)" - description "Taxi 2 (Europe) (En,Fr,De,Es,It,Nl) (Proto)" - rom ( name "Taxi 2 (Europe) (En,Fr,De,Es,It,Nl) (Proto).gbc" size 1048576 crc 288bef6e sha1 28d245a6504694443ddff5f85ba2bfaecf794ff1 ) + name "Gridtrap (World) (Aftermarket) (Unl)" + description "Gridtrap (World) (Aftermarket) (Unl)" + rom ( name "Gridtrap (World) (Aftermarket) (Unl).gbc" size 262144 crc 5a5453f6 sha1 b43d05eddcd1ab2d5934dd2a722f145a3084c4ad ) ) game ( - name "Taxi 3 (France)" - description "Taxi 3 (France)" - rom ( name "Taxi 3 (France).gbc" size 1048576 crc 2838996f sha1 e43817c673d47b7587f542dcc9f74190c63629ff ) + name "Grimace's Birthday (World) (Aftermarket) (Unl)" + description "Grimace's Birthday (World) (Aftermarket) (Unl)" + rom ( name "Grimace's Birthday (World) (Aftermarket) (Unl).gbc" size 1048576 crc 7f4386e9 sha1 d6358d100ea65d34d95588f800635b64927baf82 ) ) game ( - name "Tazz (World) (2022-10-13) (Aftermarket) (Unl)" - description "Tazz (World) (2022-10-13) (Aftermarket) (Unl)" - rom ( name "Tazz (World) (2022-10-13) (Aftermarket) (Unl).gbc" size 262144 crc 1d97b754 sha1 39226ed715ae8d94f9187c3e5e8a849eac92ca26 ) + name "Grimace's Birthday (World) (v1.1) (Aftermarket) (Unl)" + description "Grimace's Birthday (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Grimace's Birthday (World) (v1.1) (Aftermarket) (Unl).gbc" size 1048576 crc 7744f551 sha1 035b7417e03c4e264a90212f2a3811012f03c2a2 flags verified ) ) game ( - name "Tazz (World) (2022-10-17) (Aftermarket) (Unl)" - description "Tazz (World) (2022-10-17) (Aftermarket) (Unl)" - rom ( name "Tazz (World) (2022-10-17) (Aftermarket) (Unl).gbc" size 262144 crc 6fb0ba23 sha1 543118e54b166ea2b8b5979f8468cc2f5662161f ) + name "Grimace's Birthday (World) (v1.2) (Aftermarket) (Unl)" + description "Grimace's Birthday (World) (v1.2) (Aftermarket) (Unl)" + rom ( name "Grimace's Birthday (World) (v1.2) (Aftermarket) (Unl).gbc" size 1048576 crc 9dee42fe sha1 071fa179df96950c3c92b0abbe32092b1816ec40 flags verified ) ) game ( - name "Tech Deck Skateboarding (USA, Europe)" - description "Tech Deck Skateboarding (USA, Europe)" - rom ( name "Tech Deck Skateboarding (USA, Europe).gbc" size 1048576 crc c07ebe70 sha1 cd8d7f3eea5df5dcc257d07932c453303d0c64e1 flags verified ) + name "Grimace's Birthday (World) (v1.4) (Aftermarket) (Unl)" + description "Grimace's Birthday (World) (v1.4) (Aftermarket) (Unl)" + rom ( name "Grimace's Birthday (World) (v1.4) (Aftermarket) (Unl).gbc" size 1048576 crc 9baa5f46 sha1 d247c03119ac14f97fdeeaa6bf0defa98e35fa17 flags verified ) ) game ( - name "Telefang - Power Version (Taiwan) (Unl)" - description "Telefang - Power Version (Taiwan) (Unl)" - rom ( name "Telefang - Power Version (Taiwan) (Unl).gbc" size 2097152 crc 1d505ada sha1 f59b8e282a5bad67f023d5ee00fbd859b64c0270 ) + name "Grimace's Birthday (World) (v1.3) (Aftermarket) (Unl)" + description "Grimace's Birthday (World) (v1.3) (Aftermarket) (Unl)" + rom ( name "Grimace's Birthday (World) (v1.3) (Aftermarket) (Unl).gbc" size 1048576 crc ab41a9ef sha1 d8e727745e285f5e467f5eccbfd30ee175bafc2e flags verified ) ) game ( - name "Terrifying 911 (China) (En) (Unl)" - description "Terrifying 911 (China) (En) (Unl)" - rom ( name "Terrifying 911 (China) (En) (Unl).gbc" size 2097152 crc 188b06f8 sha1 a16c065525f52a90d7081f253e613452f7ed757a ) + name "Grimace's Birthday (World) (v1.5) (Aftermarket) (Unl)" + description "Grimace's Birthday (World) (v1.5) (Aftermarket) (Unl)" + rom ( name "Grimace's Birthday (World) (v1.5) (Aftermarket) (Unl).gbc" size 1048576 crc f8e8e1f3 sha1 a3fdfe3981e800fa7c73ff989bc06426f668c331 flags verified ) ) game ( - name "Test Drive 2001 (USA)" - description "Test Drive 2001 (USA)" - rom ( name "Test Drive 2001 (USA).gbc" size 2097152 crc bb894ec7 sha1 8b34597b90d048c3d483acba60ebb49f86bd93cc ) + name "Grimace's Birthday (World) (v1.6) (Aftermarket) (Unl)" + description "Grimace's Birthday (World) (v1.6) (Aftermarket) (Unl)" + rom ( name "Grimace's Birthday (World) (v1.6) (Aftermarket) (Unl).gbc" size 1048576 crc a7b59d7b sha1 295fdc3218d1699dea6d5832d068b721fccf9bd4 flags verified ) ) game ( - name "Test Drive 6 (Europe) (En,Fr,De,Es,It) (GB Compatible)" - description "Test Drive 6 (Europe) (En,Fr,De,Es,It) (GB Compatible)" - rom ( name "Test Drive 6 (Europe) (En,Fr,De,Es,It) (GB Compatible).gbc" size 1048576 crc 13691ceb sha1 92e5b9911032e0b810fcb0b76a94bb117bcf107e ) + name "Grimace's Birthday (World) (v1.7) (Aftermarket) (Unl)" + description "Grimace's Birthday (World) (v1.7) (Aftermarket) (Unl)" + rom ( name "Grimace's Birthday (World) (v1.7) (Aftermarket) (Unl).gbc" size 1048576 crc f3879ef0 sha1 27d7ee2f31bf575185711217c3cc9e08cbc5928a flags verified ) ) game ( - name "Test Drive 6 (Europe) (En,Fr,De,Es,It) (Sample) (GB Compatible)" - description "Test Drive 6 (Europe) (En,Fr,De,Es,It) (Sample) (GB Compatible)" - rom ( name "Test Drive 6 (Europe) (En,Fr,De,Es,It) (Sample) (GB Compatible).gbc" size 1048576 crc 2f179045 sha1 f50415339a36ecea8a1207b6c197086372e29ab7 ) + name "Gun Law (World) (Aftermarket) (Unl)" + description "Gun Law (World) (Aftermarket) (Unl)" + rom ( name "Gun Law (World) (Aftermarket) (Unl).gbc" size 262144 crc 3a0b6823 sha1 c49f7e0a5055f836528a7bc0cb6f45f221c76475 ) ) game ( - name "Test Drive 6 (USA) (GB Compatible)" - description "Test Drive 6 (USA) (GB Compatible)" - rom ( name "Test Drive 6 (USA) (GB Compatible).gbc" size 1048576 crc 5ce00547 sha1 43ea5758fc6747014f024b567f5768ef43d5c841 ) + name "Gunslinger (World) (Aftermarket) (Unl)" + description "Gunslinger (World) (Aftermarket) (Unl)" + rom ( name "Gunslinger (World) (Aftermarket) (Unl).gbc" size 262144 crc 0dfd765f sha1 8410ef1558649f9badc71629827ba1500510d221 ) ) game ( - name "Test Drive 6 (USA) (Rev 1) (Proto)" - description "Test Drive 6 (USA) (Rev 1) (Proto)" - rom ( name "Test Drive 6 (USA) (Rev 1) (Proto).gbc" size 1048576 crc 5333c5db sha1 f9519940ed05bdb59cd3878db8c479760d93a5bd ) + name "Gunther the Monster and His Friends (World) (Aftermarket) (Unl)" + description "Gunther the Monster and His Friends (World) (Aftermarket) (Unl)" + rom ( name "Gunther the Monster and His Friends (World) (Aftermarket) (Unl).gbc" size 524288 crc 2d9b59bf sha1 d89fe1cd97d1ef2c457aa90b1c00e7b473c57270 ) ) game ( - name "Test Drive Cycles (USA)" - description "Test Drive Cycles (USA)" - rom ( name "Test Drive Cycles (USA).gbc" size 1048576 crc e32bb06f sha1 e9242949661fb34ce6d6fd521b04eb1926ead070 ) + name "Guzzler (World) (Aftermarket) (Unl)" + description "Guzzler (World) (Aftermarket) (Unl)" + rom ( name "Guzzler (World) (Aftermarket) (Unl).gbc" size 524288 crc 3684abd0 sha1 e36cd02fe2b697901843c4cbf6d83da8a9b7b923 ) ) game ( - name "Test Drive Le Mans (USA) (En,Fr,Es)" - description "Test Drive Le Mans (USA) (En,Fr,Es)" - rom ( name "Test Drive Le Mans (USA) (En,Fr,Es).gbc" size 1048576 crc e6d6ac8f sha1 bf007bf9c22633d67b7b46aef656d136dd2d9b25 ) + name "Halo - Combat Devolved (World) (GB Compatible) (Aftermarket) (Unl)" + description "Halo - Combat Devolved (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Halo - Combat Devolved (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c7297c31 sha1 c38cc0e80a2e04693e3a86574c03f23f3e472c88 flags verified ) ) game ( - name "Test Drive Off-Road 3 (USA) (Rumble Version) (SGB Enhanced) (GB Compatible)" - description "Test Drive Off-Road 3 (USA) (Rumble Version) (SGB Enhanced) (GB Compatible)" - rom ( name "Test Drive Off-Road 3 (USA) (Rumble Version) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 0fdd5b9e sha1 71b425cbc02fa20b1f28a7612e7ac259bd1338b0 ) + name "Harbour Attack (World) (Aftermarket) (Unl)" + description "Harbour Attack (World) (Aftermarket) (Unl)" + rom ( name "Harbour Attack (World) (Aftermarket) (Unl).gbc" size 262144 crc 7455782e sha1 1d0b3779007ba8f34e11b189552955dbf5c75a28 ) ) game ( - name "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan)" - description "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan)" - rom ( name "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan).gbc" size 1048576 crc eaf6e4f2 sha1 aa7dd2044a7e1535da67d7b9439e9771f736086a flags verified ) + name "Hat Boy (World) (GB Compatible) (Aftermarket) (Unl)" + description "Hat Boy (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Hat Boy (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 81d24d61 sha1 7265cad6c8e253d3cf6d1f0dcb218316f10ca091 ) ) game ( - name "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan) (Rev 1)" - description "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan) (Rev 1)" - rom ( name "Tetris Adventure - Susume Mickey to Nakama-tachi (Japan) (Rev 1).gbc" size 1048576 crc b7c0831f sha1 a8842e85f2c6de4db40b47c9640dad59ae9d1c51 ) + name "Haunted (World) (GB Compatible) (Aftermarket) (Unl)" + description "Haunted (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Haunted (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 4b3670bd sha1 f245b8e21716a400769488b852f15d276f3549a6 ) ) game ( - name "Tetris DX (World) (SGB Enhanced) (GB Compatible)" - description "Tetris DX (World) (SGB Enhanced) (GB Compatible)" - rom ( name "Tetris DX (World) (SGB Enhanced) (GB Compatible).gbc" size 524288 crc 69989152 sha1 7183bcb54dd35f3a07d8fe63339b768f13b8168d flags verified ) + name "Hauntsfield (World) (GB Compatible) (Aftermarket) (Unl)" + description "Hauntsfield (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Hauntsfield (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 287afc75 sha1 42ccc76883c041bc5c6c25a2e61ccc939c14811f ) ) game ( - name "Tezhong Budui (Taiwan) (Unl)" - description "Tezhong Budui (Taiwan) (Unl)" - rom ( name "Tezhong Budui (Taiwan) (Unl).gbc" size 1048576 crc a658d85e sha1 3b5e765dbda9b355a6ea9ab7920d31f4169fa1d3 ) + name "Hauntsfield (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" + description "Hauntsfield (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Hauntsfield (World) (v2.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 6e484d6a sha1 7282ef5cc2354345c8832b4dde66a559de74f73f ) ) game ( - name "Tezhong Budui (Taiwan) (Unl) (Alt) [b]" - description "Tezhong Budui (Taiwan) (Unl) (Alt) [b]" - rom ( name "Tezhong Budui (Taiwan) (Unl) (Alt) [b].gbc" size 1048576 crc bf0028d9 sha1 99f536400bb99892b736f66305e1b11d8229c668 flags baddump ) + name "Heebie Jeebies (World) (Aftermarket) (Unl)" + description "Heebie Jeebies (World) (Aftermarket) (Unl)" + rom ( name "Heebie Jeebies (World) (Aftermarket) (Unl).gbc" size 262144 crc 73762d53 sha1 d427f18cb854e1387d93c19b88cb7193975e6472 ) ) game ( - name "Tezhong Budui 2 - Jidi (Taiwan) (Unl)" - description "Tezhong Budui 2 - Jidi (Taiwan) (Unl)" - rom ( name "Tezhong Budui 2 - Jidi (Taiwan) (Unl).gbc" size 2097152 crc a2c4f7b3 sha1 5b516c6ce57eed1791a9c20184357c583febdcb8 ) + name "Hidden Gems (World) (GB Compo 2023) (GB Compatible) (Aftermarket) (Unl)" + description "Hidden Gems (World) (GB Compo 2023) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Hidden Gems (World) (GB Compo 2023) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 6f430dda sha1 e0cfe038063b1cd601a5f1b5af047efc705a7aaa ) ) game ( - name "TG Rally 2 (United Kingdom)" - description "TG Rally 2 (United Kingdom)" - rom ( name "TG Rally 2 (United Kingdom).gbc" size 1048576 crc 795a9992 sha1 906f886c19c4800a7ac2612951e03a092665b22c ) + name "Hidden Gems (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Hidden Gems (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Hidden Gems (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 7296d7e0 sha1 ae0fd7bcda2a3d7c1c342157ecb801ba8e380b5f ) ) game ( - name "Three Lions (United Kingdom) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - description "Three Lions (United Kingdom) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible)" - rom ( name "Three Lions (United Kingdom) (En,Fr,De,Es,It,Nl,Sv) (GB Compatible).gbc" size 1048576 crc 1cbea1aa sha1 d6d4eb47595b72c9c3ad77b5f9fa85b76f0acf4c ) + name "High Noon (World) (Aftermarket) (Unl)" + description "High Noon (World) (Aftermarket) (Unl)" + rom ( name "High Noon (World) (Aftermarket) (Unl).gbc" size 262144 crc 1d00e48d sha1 21d5e871ed009a674659344d3d768fb2389c0d04 ) ) game ( - name "Thunder Blast Man (Europe) (Sachen) (Unl)" - description "Thunder Blast Man (Europe) (Sachen) (Unl)" - rom ( name "Thunder Blast Man (Europe) (Sachen) (Unl).gbc" size 262144 crc 1a719ead sha1 676b5f0a304fb83bc04921bc617b7485af529b38 flags verified ) + name "Hightail (World) (Demo 4F) (Aftermarket) (Unl)" + description "Hightail (World) (Demo 4F) (Aftermarket) (Unl)" + rom ( name "Hightail (World) (Demo 4F) (Aftermarket) (Unl).gbc" size 524288 crc f199c768 sha1 c794f30bedc69aa4d3567ab8f06f4ad651d5be24 ) ) game ( - name "Thunderbirds (Europe)" - description "Thunderbirds (Europe)" - rom ( name "Thunderbirds (Europe).gbc" size 2097152 crc b5bececf sha1 4df8353cbb74d368cc139899eabe5288e59adaeb ) + name "Hightail (World) (Demo 4A) (Aftermarket) (Unl)" + description "Hightail (World) (Demo 4A) (Aftermarket) (Unl)" + rom ( name "Hightail (World) (Demo 4A) (Aftermarket) (Unl).gbc" size 262144 crc 8f01efcb sha1 bbf1f2af7594862f94b72f2f5a7be54040aa8569 ) ) game ( - name "Thunderbirds (Europe) (En,Fr,De,Es,It)" - description "Thunderbirds (Europe) (En,Fr,De,Es,It)" - rom ( name "Thunderbirds (Europe) (En,Fr,De,Es,It).gbc" size 2097152 crc 36536324 sha1 8c7585e41b8e38f4bc76ba315dc5e7a768c0c516 ) + name "Hime's Quest (World) (Aftermarket) (Unl)" + description "Hime's Quest (World) (Aftermarket) (Unl)" + rom ( name "Hime's Quest (World) (Aftermarket) (Unl).gbc" size 2097152 crc 546f578a sha1 ff90ca3ec7fb5d02865ae3cfd807ad3541dd21fc ) ) game ( - name "Tiger Woods PGA Tour 2000 (USA, Europe) (GB Compatible)" - description "Tiger Woods PGA Tour 2000 (USA, Europe) (GB Compatible)" - rom ( name "Tiger Woods PGA Tour 2000 (USA, Europe) (GB Compatible).gbc" size 1048576 crc a6dfb1d9 sha1 46e81d5e7d4f41b3b0a0ab8b55a3592abe6911f3 flags verified ) + name "Hime's Quest (World) (Digital) (Aftermarket) (Unl)" + description "Hime's Quest (World) (Digital) (Aftermarket) (Unl)" + rom ( name "Hime's Quest (World) (Digital) (Aftermarket) (Unl).gbc" size 2097152 crc de5c21c2 sha1 7b6672c46c23aaa282bd4fded0713c6dfae2eb66 ) ) game ( - name "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De) (Beta)" - description "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De) (Beta)" - rom ( name "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De) (Beta).gbc" size 1048576 crc 94aed620 sha1 8c29d9135fcf3c74397da8b0898af07d0b3b7955 ) + name "Hopp It (World) (Aftermarket) (Unl)" + description "Hopp It (World) (Aftermarket) (Unl)" + rom ( name "Hopp It (World) (Aftermarket) (Unl).gbc" size 262144 crc 675fbae3 sha1 cc10828f99675068eb79310b629f1365540b2979 ) ) game ( - name "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De)" - description "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De)" - rom ( name "Tintin - Le Temple Du Soleil (Europe) (En,Fr,De).gbc" size 1048576 crc b2205d49 sha1 34ab01951490a9510a3e0d3493d25a2547761aea ) + name "Host, The (World) (Aftermarket) (Unl)" + description "Host, The (World) (Aftermarket) (Unl)" + rom ( name "Host, The (World) (Aftermarket) (Unl).gbc" size 524288 crc 5f783000 sha1 05cc1f1e52167c6985ebb0a3e67af1fc2fbff93c ) ) game ( - name "Tintin au Tibet (Europe) (En,Fr,De,Es,It,Nl,Sv)" - description "Tintin au Tibet (Europe) (En,Fr,De,Es,It,Nl,Sv)" - rom ( name "Tintin au Tibet (Europe) (En,Fr,De,Es,It,Nl,Sv).gbc" size 1048576 crc 6832f38a sha1 eef17d4a827efab90c03083edb0bee534cd64188 ) + name "Hugo (World) (Aftermarket) (Unl)" + description "Hugo (World) (Aftermarket) (Unl)" + rom ( name "Hugo (World) (Aftermarket) (Unl).gbc" size 524288 crc 6581c78a sha1 390d2665f34ceaa5e34cc9f8f7c26d9e7583a92b ) ) game ( - name "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.4) (GB Compatible) (Aftermarket) (Unl)" - description "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.4) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.4) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc af13e718 sha1 307e51664db2101755b6c617f3d81ee58676c485 ) + name "Hunt the Gwumbus (World) (v2.1) (Aftermarket) (Unl)" + description "Hunt the Gwumbus (World) (v2.1) (Aftermarket) (Unl)" + rom ( name "Hunt the Gwumbus (World) (v2.1) (Aftermarket) (Unl).gbc" size 524288 crc 956f1e5d sha1 66769e2feb53ad70503849f271146c6f830bc2fe ) ) game ( - name "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.2) (GB Compatible) (Aftermarket) (Unl)" - description "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.2) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 0518f5aa sha1 85e5cd0cf7a6cc4a5946c93fa8665235a686e554 ) + name "Hunter in the Lost Forest (World) (En) (GB Compatible) (Aftermarket) (Unl)" + description "Hunter in the Lost Forest (World) (En) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Hunter in the Lost Forest (World) (En) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc feac2611 sha1 1b10f2ec15d25584da2f2c123ecc97df7f7a0af0 ) ) game ( - name "Tiny Toon Adventures - Buster Saves the Day (Europe) (En,Fr,De,Es,It)" - description "Tiny Toon Adventures - Buster Saves the Day (Europe) (En,Fr,De,Es,It)" - rom ( name "Tiny Toon Adventures - Buster Saves the Day (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 7aa371ed sha1 3a30dc722739fbaa9924c855c83be311befc8ff2 ) + name "Hunter in the Lost Forest (World) (Ja) (GB Compatible) (Aftermarket) (Unl)" + description "Hunter in the Lost Forest (World) (Ja) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Hunter in the Lost Forest (World) (Ja) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ee633b7b sha1 6fc0ab0c6dffc8925ceb538ffc78cc70cd4ac0e4 ) ) game ( - name "Tiny Toon Adventures - Buster Saves the Day (USA)" - description "Tiny Toon Adventures - Buster Saves the Day (USA)" - rom ( name "Tiny Toon Adventures - Buster Saves the Day (USA).gbc" size 1048576 crc 800efb3d sha1 a3953e9ade5367558f7d430d2dfb83d06c361170 ) + name "Infall (World) (Aftermarket) (Unl)" + description "Infall (World) (Aftermarket) (Unl)" + rom ( name "Infall (World) (Aftermarket) (Unl).gbc" size 131072 crc d9d90319 sha1 aafaf33fa43c7f0fd65cc8af03a42df25361fc74 ) ) game ( - name "Tiny Toon Adventures - Dizzy's Candy Quest (Europe) (En,Fr,De,Es,It,Nl)" - description "Tiny Toon Adventures - Dizzy's Candy Quest (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Tiny Toon Adventures - Dizzy's Candy Quest (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 5a0d41aa sha1 cf8948c148af76c00e7b6b557c5451d9be364f55 ) + name "Inscryption (World) (v0.5) (Aftermarket) (Unl)" + description "Inscryption (World) (v0.5) (Aftermarket) (Unl)" + rom ( name "Inscryption (World) (v0.5) (Aftermarket) (Unl).gbc" size 524288 crc ae0a1c16 sha1 480ce539500d814fd3822fed7525c21027ac361b ) ) game ( - name "Tiny Toon Adventures - Dizzy's Candy Quest (USA) (Proto)" - description "Tiny Toon Adventures - Dizzy's Candy Quest (USA) (Proto)" - rom ( name "Tiny Toon Adventures - Dizzy's Candy Quest (USA) (Proto).gbc" size 1048576 crc 23bb87a5 sha1 4eb0359a278173ae6c12e9452a7a2a9573a58c77 ) + name "Inspector Waffles Early Days (World) (v1.0.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Inspector Waffles Early Days (World) (v1.0.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Inspector Waffles Early Days (World) (v1.0.1) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc fea1cdb9 sha1 ac10ca63f15ca78af9f7d0eabb85eef8733aef50 ) ) game ( - name "Tir Na Nog (World) (Aftermarket) (Unl)" - description "Tir Na Nog (World) (Aftermarket) (Unl)" - rom ( name "Tir Na Nog (World) (Aftermarket) (Unl).gbc" size 1048576 crc 44524c90 sha1 ac712228460e9d4268f90ec4cf9ac2137fa667c4 ) + name "Iron Cor - Stainless (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" + description "Iron Cor - Stainless (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Iron Cor - Stainless (World) (v2.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc d6c1c1ac sha1 d722e95155455cf146a97222ccbc2237bea86509 ) ) game ( - name "Titi - Le Tour du Monde en 80 Chats (France)" - description "Titi - Le Tour du Monde en 80 Chats (France)" - rom ( name "Titi - Le Tour du Monde en 80 Chats (France).gbc" size 1048576 crc ce55ed18 sha1 1b3e161dcde3709cc4b26d6d753cb879ab75c8c0 ) + name "Jayro's Game Boy Test Cartridge (World) (v1.18) (GB Compatible) (Aftermarket) (Unl)" + description "Jayro's Game Boy Test Cartridge (World) (v1.18) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Jayro's Game Boy Test Cartridge (World) (v1.18) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 9e97ac30 sha1 c07237d0f9c13b36ac2fcc5324b6e81122b0e189 ) ) game ( - name "Titus the Fox (Europe) (GB Compatible)" - description "Titus the Fox (Europe) (GB Compatible)" - rom ( name "Titus the Fox (Europe) (GB Compatible).gbc" size 1048576 crc 2f9f19de sha1 b595c2e0a11bf843e91e9128e38252222133659b ) + name "Jet Set Willy (World) (Aftermarket) (Unl)" + description "Jet Set Willy (World) (Aftermarket) (Unl)" + rom ( name "Jet Set Willy (World) (Aftermarket) (Unl).gbc" size 262144 crc 659295ee sha1 bcb5a0e4566572aeb6cddea0897903ba207dc54f ) ) game ( - name "Titus the Fox (USA) (GB Compatible)" - description "Titus the Fox (USA) (GB Compatible)" - rom ( name "Titus the Fox (USA) (GB Compatible).gbc" size 1048576 crc ba70d28f sha1 3ec16a3ce1cfdc03b6f3b04a455c8b5c54a37eee ) + name "Jet Set Willy II - The Final Frontier (World) (Aftermarket) (Unl)" + description "Jet Set Willy II - The Final Frontier (World) (Aftermarket) (Unl)" + rom ( name "Jet Set Willy II - The Final Frontier (World) (Aftermarket) (Unl).gbc" size 524288 crc 8a4c58fa sha1 2e5b5a943b9f449bccb968b52ebc3dc8a4b3cb83 ) ) game ( - name "TNN Outdoors Fishing Champ (USA) (SGB Enhanced) (GB Compatible)" - description "TNN Outdoors Fishing Champ (USA) (SGB Enhanced) (GB Compatible)" - rom ( name "TNN Outdoors Fishing Champ (USA) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 00a14d18 sha1 acfe7c9edd20f7d6b155deebc9428703edf28978 ) + name "Judy's Adventure (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Judy's Adventure (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Judy's Adventure (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 8884d532 sha1 a41195443613fb4414d8536b1f3494677f6f253d ) ) game ( - name "Tobu Tobu Girl Deluxe (World) (GB Compatible) (Aftermarket) (Unl)" - description "Tobu Tobu Girl Deluxe (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Tobu Tobu Girl Deluxe (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 16650a8b sha1 fe6eef70d48dda741f7ad3b6cc5e753e8cd13239 ) + name "Judy's Adventure (World) (v11.3) (GB Compatible) (Aftermarket) (Unl)" + description "Judy's Adventure (World) (v11.3) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Judy's Adventure (World) (v11.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 570a8043 sha1 1ccbf555412a417135acea0b7b185a7f795a89da ) ) game ( - name "TOCA Touring Car Championship (USA, Europe)" - description "TOCA Touring Car Championship (USA, Europe)" - rom ( name "TOCA Touring Car Championship (USA, Europe).gbc" size 1048576 crc b509892b sha1 8a759a627b436c2b3941c3aa480e38488ad16197 ) + name "Junior Maths 2 (World) (Aftermarket) (Unl)" + description "Junior Maths 2 (World) (Aftermarket) (Unl)" + rom ( name "Junior Maths 2 (World) (Aftermarket) (Unl).gbc" size 262144 crc 72c67d63 sha1 648273123a1bb64cd7fda7f611bb9cf53a5b0214 ) ) game ( - name "Toki Tori (USA, Europe) (En,Ja,Fr,De,Es)" - description "Toki Tori (USA, Europe) (En,Ja,Fr,De,Es)" - rom ( name "Toki Tori (USA, Europe) (En,Ja,Fr,De,Es).gbc" size 1048576 crc 0a0f9289 sha1 2025275bb55710594e990ab61cde622947a2fa8d ) + name "Kero Kero Cowboy (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Kero Kero Cowboy (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Kero Kero Cowboy (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 6a5abba1 sha1 0b3deef7a27201e81b4d39bc0bd10ff7ec73e380 ) ) game ( - name "Tokimeki Memorial Pocket - Culture Hen - Komorebi no Melody (Japan) (SGB Enhanced) (GB Compatible)" - description "Tokimeki Memorial Pocket - Culture Hen - Komorebi no Melody (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Tokimeki Memorial Pocket - Culture Hen - Komorebi no Melody (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 4be4a8ed sha1 0f64c4afe74b6cfd693b6c65f0168dcb26224443 ) + name "Kikstart (World) (Aftermarket) (Unl)" + description "Kikstart (World) (Aftermarket) (Unl)" + rom ( name "Kikstart (World) (Aftermarket) (Unl).gbc" size 524288 crc 9a9f483b sha1 bc472506f73f0c1a3f0a610c0136b324b7635c7f ) ) game ( - name "Tokimeki Memorial Pocket - Sport Hen - Koutei no Photograph (Japan) (SGB Enhanced) (GB Compatible)" - description "Tokimeki Memorial Pocket - Sport Hen - Koutei no Photograph (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Tokimeki Memorial Pocket - Sport Hen - Koutei no Photograph (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 78e14fa9 sha1 ce39fcf903bb3b0529205cab4a412bfa0e8a2ebf ) + name "Knit-Wit (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Knit-Wit (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Knit-Wit (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f19d5e86 sha1 0f0e01a143182a9784c80a882ac206d02d8679d7 ) ) game ( - name "Tokoro-san no Setagaya C.C. (Japan) (GB Compatible)" - description "Tokoro-san no Setagaya C.C. (Japan) (GB Compatible)" - rom ( name "Tokoro-san no Setagaya C.C. (Japan) (GB Compatible).gbc" size 1048576 crc 9139e307 sha1 f38d776ff74d02c2edce0dcbc84edd5601ee315a ) + name "KnockOut (World) (Aftermarket) (Unl)" + description "KnockOut (World) (Aftermarket) (Unl)" + rom ( name "KnockOut (World) (Aftermarket) (Unl).gbc" size 131072 crc a060e59f sha1 164e078fce73674e3a5ad1cfd9e881813ce7a210 ) ) game ( - name "Tom and Jerry (USA, Europe)" - description "Tom and Jerry (USA, Europe)" - rom ( name "Tom and Jerry (USA, Europe).gbc" size 1048576 crc b97c0bd9 sha1 86d841e84c68e4d15f4bbf72f1aa0fddc86dcd34 ) + name "Larion's Tinker Toys (World) (Proto 2) (Aftermarket) (Unl)" + description "Larion's Tinker Toys (World) (Proto 2) (Aftermarket) (Unl)" + rom ( name "Larion's Tinker Toys (World) (Proto 2) (Aftermarket) (Unl).gbc" size 262144 crc fe421365 sha1 545551a382899d3689e2a501ccaccf500b9291df ) ) game ( - name "Tom and Jerry - Mouse Hunt (USA) (En,Fr,Es)" - description "Tom and Jerry - Mouse Hunt (USA) (En,Fr,Es)" - rom ( name "Tom and Jerry - Mouse Hunt (USA) (En,Fr,Es).gbc" size 1048576 crc 5fc6bec0 sha1 99c71a51921d802a0fcaea1f67b54ef4ec653900 ) + name "Larion's Tinker Toys (World) (Proto 1) (Aftermarket) (Unl)" + description "Larion's Tinker Toys (World) (Proto 1) (Aftermarket) (Unl)" + rom ( name "Larion's Tinker Toys (World) (Proto 1) (Aftermarket) (Unl).gbc" size 262144 crc 317d6e20 sha1 1867920232b32cf95eedfd47d9935e2d482c567d ) ) game ( - name "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It)" - description "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It)" - rom ( name "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 3e17d04a sha1 6f837075d7493adcbd5b18ba1e27386b6fc31e62 ) + name "Laser Squad Alter (World) (Aftermarket) (Unl)" + description "Laser Squad Alter (World) (Aftermarket) (Unl)" + rom ( name "Laser Squad Alter (World) (Aftermarket) (Unl).gbc" size 1048576 crc 32f24248 sha1 26f4efe636214e72ec724f8887ca79fbc8abad80 ) ) game ( - name "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It) (Rev 1)" - description "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It) (Rev 1)" - rom ( name "Tom and Jerry - Mousehunt (Europe) (En,Fr,De,Es,It) (Rev 1).gbc" size 1048576 crc 4b4553e0 sha1 bf5faf4c5c2aabe9636f8f5afbbf526aba59e21d ) + name "Last Crown Warriors (World) (v1.0.1) (Demo) (Kickstarter) (GB Compatible) (Aftermarket) (Unl)" + description "Last Crown Warriors (World) (v1.0.1) (Demo) (Kickstarter) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Last Crown Warriors (World) (v1.0.1) (Demo) (Kickstarter) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 4a58315b sha1 5a234e33f7429b48f4374b5989e6df4d20352b4c ) ) game ( - name "Tom and Jerry in - Mouse Attacks! (Europe) (En,Fr,De,Es,It,Nl,Da)" - description "Tom and Jerry in - Mouse Attacks! (Europe) (En,Fr,De,Es,It,Nl,Da)" - rom ( name "Tom and Jerry in - Mouse Attacks! (Europe) (En,Fr,De,Es,It,Nl,Da).gbc" size 2097152 crc 9d9c84f4 sha1 ff3a39ccdf4e9802b38c3095d4a2ae056defc476 ) + name "Last Crown Warriors (World) (v2.1.0) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Last Crown Warriors (World) (v2.1.0) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Last Crown Warriors (World) (v2.1.0) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 5c405584 sha1 3ee043ba17f46a6afbbba8ac05f35d093b817fbc ) ) game ( - name "Tom and Jerry in - Mouse Attacks! (USA)" - description "Tom and Jerry in - Mouse Attacks! (USA)" - rom ( name "Tom and Jerry in - Mouse Attacks! (USA).gbc" size 2097152 crc 38ce3f76 sha1 a58215e2c6240b42779665d85484f02b79a0f9d8 ) + name "Last Crown Warriors (World) (v2.1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Last Crown Warriors (World) (v2.1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Last Crown Warriors (World) (v2.1.1) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 9a134100 sha1 75b5188a5b8a720ff08894379147c7870ac8825d ) ) game ( - name "Tom and Jerry in - Mouse Attacks! (USA) (Rev 1)" - description "Tom and Jerry in - Mouse Attacks! (USA) (Rev 1)" - rom ( name "Tom and Jerry in - Mouse Attacks! (USA) (Rev 1).gbc" size 2097152 crc ce4ca7b1 sha1 89374d81045a3bedf24e42b58ce403b0a5fbcddb ) + name "Leaper (World) (Aftermarket) (Unl)" + description "Leaper (World) (Aftermarket) (Unl)" + rom ( name "Leaper (World) (Aftermarket) (Unl).gbc" size 524288 crc ed8cd385 sha1 425db2916263121f4aee91a8cab6286e39364f87 ) ) game ( - name "Tom Clancy's Rainbow Six (USA, Europe) (En,Fr,De)" - description "Tom Clancy's Rainbow Six (USA, Europe) (En,Fr,De)" - rom ( name "Tom Clancy's Rainbow Six (USA, Europe) (En,Fr,De).gbc" size 1048576 crc e72f2683 sha1 7e9e21db84d1bfdab3c604c9e3328f624f86a9b1 flags verified ) + name "Lee Carvallo's Putting Challenge II (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + description "Lee Carvallo's Putting Challenge II (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Lee Carvallo's Putting Challenge II (World) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc e8f402e2 sha1 16633011144af9519037672f67f42c9a9459bb65 ) ) game ( - name "Tomb Raider (USA, Europe) (En,Fr,De,Es,It)" - description "Tomb Raider (USA, Europe) (En,Fr,De,Es,It)" - rom ( name "Tomb Raider (USA, Europe) (En,Fr,De,Es,It).gbc" size 4194304 crc 2988fc78 sha1 208b054ca63c43f32befa989c75e8de96847f4fe flags verified ) + name "Lee Carvallo's Putting Challenge II (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Lee Carvallo's Putting Challenge II (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Lee Carvallo's Putting Challenge II (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 67f5a155 sha1 9f25aaf58f440cc62992b3268d239399fb5b377b ) ) game ( - name "Tomb Raider (USA, Europe) (En,Fr,De,Es,It) (Beta)" - description "Tomb Raider (USA, Europe) (En,Fr,De,Es,It) (Beta)" - rom ( name "Tomb Raider (USA, Europe) (En,Fr,De,Es,It) (Beta).gbc" size 4194304 crc 58590868 sha1 3f7259e9def8be46e9b1f2956182084276f105ed ) + name "Lee Carvallo's Putting Challenge II (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + description "Lee Carvallo's Putting Challenge II (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Lee Carvallo's Putting Challenge II (World) (v1.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 915b7710 sha1 10d60a8d381b547e622e84859ee6ae7f19995818 ) ) game ( - name "Tomb Raider (Taiwan) (Unl)" - description "Tomb Raider (Taiwan) (Unl)" - rom ( name "Tomb Raider (Taiwan) (Unl).gbc" size 4194304 crc 269f0852 sha1 a4728de2368561ffeb8ecec6077494df64b463d4 ) + name "Legacy of Verintia (World) (2023-05-15) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Legacy of Verintia (World) (2023-05-15) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Legacy of Verintia (World) (2023-05-15) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 953e25d1 sha1 018c7cada41e693a02b9c596d307b0aa9207eef4 ) ) game ( - name "Tomb Raider - Curse of the Sword (USA, Europe)" - description "Tomb Raider - Curse of the Sword (USA, Europe)" - rom ( name "Tomb Raider - Curse of the Sword (USA, Europe).gbc" size 4194304 crc 02c1035a sha1 c84db1eaf7403ba292be020d410ab453342ab737 flags verified ) + name "Legacy of Verintia (World) (2023-05-31) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Legacy of Verintia (World) (2023-05-31) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Legacy of Verintia (World) (2023-05-31) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 1096252a sha1 c22cc79b25a05afad66e769dc0365b7c25f1bb85 ) ) game ( - name "Tomb Raider 2 (Taiwan) (Unl)" - description "Tomb Raider 2 (Taiwan) (Unl)" - rom ( name "Tomb Raider 2 (Taiwan) (Unl).gbc" size 4194304 crc 717a5d19 sha1 5b9325b6e322a806677c6ea37a0054381609b99e ) + name "Legend of Carrot (World) (Aftermarket) (Unl)" + description "Legend of Carrot (World) (Aftermarket) (Unl)" + rom ( name "Legend of Carrot (World) (Aftermarket) (Unl).gbc" size 131072 crc 965a02af sha1 fa404e1b2b4544b4969c14ec41f81e87304234c8 ) ) game ( - name "Tomte Trouble (World) (Aftermarket) (Unl)" - description "Tomte Trouble (World) (Aftermarket) (Unl)" - rom ( name "Tomte Trouble (World) (Aftermarket) (Unl).gbc" size 262144 crc a43d6b82 sha1 99730fe00703d655b1c806f49c9e3c2fb3dec58e flags verified ) + name "Let's Bee Friends (World) (GB Compatible) (Aftermarket) (Unl)" + description "Let's Bee Friends (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Let's Bee Friends (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc a91a698f sha1 26f38b3908c086b3e349324da32bc37213975030 ) ) game ( - name "Tonic Trouble (Europe) (En,Fr,De,Es,It,Nl)" - description "Tonic Trouble (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Tonic Trouble (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc a8628f7a sha1 d9ed647746cf23f2f9c7448d682ac34bb7f2ec1c ) + name "Liberator (World) (Aftermarket) (Unl)" + description "Liberator (World) (Aftermarket) (Unl)" + rom ( name "Liberator (World) (Aftermarket) (Unl).gbc" size 262144 crc ebe70d3d sha1 e3afce5a2357732ed15d7f3c0900f7b48113efdc ) ) game ( - name "Tonka Construction Site (USA)" - description "Tonka Construction Site (USA)" - rom ( name "Tonka Construction Site (USA).gbc" size 1048576 crc 8142a3e8 sha1 19e6fb8b61ec20025061b2703079db926be93c96 ) + name "Lightseeker (World) (GB Compatible) (Aftermarket) (Unl)" + description "Lightseeker (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Lightseeker (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc b8dd8409 sha1 281abb583ec0039e2c981c2e95f7a92002da081b ) ) game ( - name "Tonka Construction Site (USA) (Beta)" - description "Tonka Construction Site (USA) (Beta)" - rom ( name "Tonka Construction Site (USA) (Beta).gbc" size 1048576 crc 901faa34 sha1 16fc094ef9a0af8376fedd6b7e6179d33c4f78bf ) + name "Loco-coco (World) (Aftermarket) (Unl)" + description "Loco-coco (World) (Aftermarket) (Unl)" + rom ( name "Loco-coco (World) (Aftermarket) (Unl).gbc" size 262144 crc f6b9fe4e sha1 8a8972ff3e208280a746a2015a20f67248180a1c ) ) game ( - name "Tonka Raceway (Europe)" - description "Tonka Raceway (Europe)" - rom ( name "Tonka Raceway (Europe).gbc" size 1048576 crc e108b2c2 sha1 ec52838e58d33a3ed36cd0f80f287ef72a578624 ) + name "Love is Dead (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Love is Dead (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Love is Dead (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc dd537a3b sha1 f3e44fea9faed10c0aebaf11dd2f7821076a7315 ) ) game ( - name "Tonka Raceway (USA)" - description "Tonka Raceway (USA)" - rom ( name "Tonka Raceway (USA).gbc" size 1048576 crc bc07f4fb sha1 9159b2ffe1ecf2a1a8f6af976e2737c0b22cea6d ) + name "Lunar Docking (World) (2021-12-30) (Aftermarket) (Unl)" + description "Lunar Docking (World) (2021-12-30) (Aftermarket) (Unl)" + rom ( name "Lunar Docking (World) (2021-12-30) (Aftermarket) (Unl).gbc" size 262144 crc 9edd066c sha1 4d43a38e8b5df41309f5b6ec13e4829db739d980 ) ) game ( - name "Tonka Raceway (USA) (Rumble Version)" - description "Tonka Raceway (USA) (Rumble Version)" - rom ( name "Tonka Raceway (USA) (Rumble Version).gbc" size 1048576 crc a5af4b28 sha1 6a86b7172c53a8e67f3d72f953116991640f6e71 ) + name "Lunar Docking (World) (2022-08-07) (Aftermarket) (Unl)" + description "Lunar Docking (World) (2022-08-07) (Aftermarket) (Unl)" + rom ( name "Lunar Docking (World) (2022-08-07) (Aftermarket) (Unl).gbc" size 262144 crc de5d5c0b sha1 5f038ef3657d3fbfb3be6917b24c3f933363ad4c ) ) game ( - name "Tony Hawk's Pro Skater (USA, Europe)" - description "Tony Hawk's Pro Skater (USA, Europe)" - rom ( name "Tony Hawk's Pro Skater (USA, Europe).gbc" size 1048576 crc 8d8bb5c4 sha1 44236627939371a6db564852f0536f969b21595e flags verified ) + name "Lunatic Tower (World) (Aftermarket) (Unl)" + description "Lunatic Tower (World) (Aftermarket) (Unl)" + rom ( name "Lunatic Tower (World) (Aftermarket) (Unl).gbc" size 524288 crc 6edacbb3 sha1 ee706a5f6272bda950a5d80ffc071453a9880fb6 ) ) game ( - name "Tony Hawk's Pro Skater (Japan) (Proto)" - description "Tony Hawk's Pro Skater (Japan) (Proto)" - rom ( name "Tony Hawk's Pro Skater (Japan) (Proto).gbc" size 1048576 crc 48f17f97 sha1 e399c7d67e3bb1f466002f24f60b9c036e234c4e ) + name "Machine, The (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Machine, The (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Machine, The (World) (v1.1) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc f55a9d95 sha1 2b22fbd76e11e6e45053b1e6989de303e3033c9e ) ) game ( - name "Tony Hawk's Pro Skater 2 (USA, Europe)" - description "Tony Hawk's Pro Skater 2 (USA, Europe)" - rom ( name "Tony Hawk's Pro Skater 2 (USA, Europe).gbc" size 2097152 crc 2c27c61f sha1 300fe89f98711853bee86ccd81481d55b5097b2d flags verified ) + name "Machine, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Machine, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Machine, The (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 5662865e sha1 a5ac99a4087bd5ea45417e5b4a7c9af10433911a ) ) game ( - name "Tony Hawk's Pro Skater 3 (USA, Europe)" - description "Tony Hawk's Pro Skater 3 (USA, Europe)" - rom ( name "Tony Hawk's Pro Skater 3 (USA, Europe).gbc" size 1048576 crc fd5290a1 sha1 bd210707df413d97eaa1d5b050f3a1b859c30c5e flags verified ) + name "Mage and the Grimoire of Beast (World) (En) (v1.01) (GB Compatible) (Aftermarket) (Unl)" + description "Mage and the Grimoire of Beast (World) (En) (v1.01) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Mage and the Grimoire of Beast (World) (En) (v1.01) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 4197bfd5 sha1 83f15e10963a2991636a382168aa035c7f340b3c ) ) game ( - name "Toobin' (USA)" - description "Toobin' (USA)" - rom ( name "Toobin' (USA).gbc" size 1048576 crc 3d6b598c sha1 ba5a1889f63ac13a1081885f0fcbe4c351c63fea ) + name "Mage and the Grimoire of Beast (World) (Ja) (v1.01) (GB Compatible) (Aftermarket) (Unl)" + description "Mage and the Grimoire of Beast (World) (Ja) (v1.01) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Mage and the Grimoire of Beast (World) (Ja) (v1.01) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 6d8126b4 sha1 89d7df077818f000fef3c59429a6deb1a423aa03 ) ) game ( - name "Toonsylvania (Europe) (En,Fr,De,Es,It,Nl)" - description "Toonsylvania (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Toonsylvania (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 6573b88f sha1 48943f0f5d47444889f78da7ee0472d9b42dbc89 ) + name "Magic & Legend - Time Knights (World) (Demo) (The Retro Room) (GB Compatible) (Aftermarket) (Unl)" + description "Magic & Legend - Time Knights (World) (Demo) (The Retro Room) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Magic & Legend - Time Knights (World) (Demo) (The Retro Room) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c276843d sha1 852697a2952d2e7375b73aba877ebc17aa4f4179 ) ) game ( - name "Toonsylvania (USA)" - description "Toonsylvania (USA)" - rom ( name "Toonsylvania (USA).gbc" size 1048576 crc 096d0c27 sha1 5665f54d1ce0b1e0ef72d8f71a14594920adf81d ) + name "Magician's Curse, The (World) (Aftermarket) (Unl)" + description "Magician's Curse, The (World) (Aftermarket) (Unl)" + rom ( name "Magician's Curse, The (World) (Aftermarket) (Unl).gbc" size 524288 crc f2b1967e sha1 3b5f97f9a0b4d63a3795695b0bda6e969de8e051 ) ) game ( - name "Tootuff (Europe) (En,Fr,De,Es,It,Nl)" - description "Tootuff (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Tootuff (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 1972cbf7 sha1 e38c16213c6bb0c1511ade138e3e8eeabd7b8898 ) + name "Mayhem (World) (Aftermarket) (Unl)" + description "Mayhem (World) (Aftermarket) (Unl)" + rom ( name "Mayhem (World) (Aftermarket) (Unl).gbc" size 262144 crc 4d739ad7 sha1 9f141728a74432820f47cc24d230dc56d6ac099b ) ) game ( - name "Tootuff (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - description "Tootuff (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - rom ( name "Tootuff (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 1048576 crc 709f4ad6 sha1 f71f380f9c68c42fc1461532ca92bffaa301da4d ) + name "Meiji Jingu (World) (Aftermarket) (Unl)" + description "Meiji Jingu (World) (Aftermarket) (Unl)" + rom ( name "Meiji Jingu (World) (Aftermarket) (Unl).gbc" size 262144 crc 56905954 sha1 9656d278857f6cfa08b8820409b665306c3d18aa ) ) game ( - name "Top Gear Pocket (Japan) (En) (Rumble Version)" - description "Top Gear Pocket (Japan) (En) (Rumble Version)" - rom ( name "Top Gear Pocket (Japan) (En) (Rumble Version).gbc" size 1048576 crc ebcca3da sha1 19c861e8ce24c18f8c625c8b920aad8a0acfce64 ) + name "Melanie and the Magic Forest (World) (GB Compatible) (Aftermarket) (Unl)" + description "Melanie and the Magic Forest (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Melanie and the Magic Forest (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f614bdff sha1 7e46c193f6566f620acf20ead3a1fca1d677c221 ) ) game ( - name "Top Gear Pocket (USA) (Rumble Version)" - description "Top Gear Pocket (USA) (Rumble Version)" - rom ( name "Top Gear Pocket (USA) (Rumble Version).gbc" size 1048576 crc 84499fc1 sha1 f875f5a637fb861a0845b1753b90fe053d0a5a95 ) + name "Melanie and the Magic Forest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Melanie and the Magic Forest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Melanie and the Magic Forest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 949c6ab9 sha1 34269af4db6c37b92fdc7f7f914c282174603ba8 ) ) game ( - name "Top Gear Pocket 2 (Japan) (Rumble Version)" - description "Top Gear Pocket 2 (Japan) (Rumble Version)" - rom ( name "Top Gear Pocket 2 (Japan) (Rumble Version).gbc" size 1048576 crc 1845f25a sha1 26a357b6df4484d8f98f9c89a0b1b0357df5cf88 ) + name "Memory Mania Challenge (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" + description "Memory Mania Challenge (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Memory Mania Challenge (World) (v1.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 50618f4b sha1 c8d74af4746313800df3a23c1ad01f931e0e2eca flags verified ) ) game ( - name "Top Gear Pocket 2 (USA)" - description "Top Gear Pocket 2 (USA)" - rom ( name "Top Gear Pocket 2 (USA).gbc" size 1048576 crc efb87f80 sha1 bdbb64d13c3c40992d923829a92d7a15a15aabea ) + name "Meteorite (World) (Aftermarket) (Unl)" + description "Meteorite (World) (Aftermarket) (Unl)" + rom ( name "Meteorite (World) (Aftermarket) (Unl).gbc" size 131072 crc fafbcebf sha1 25a81d916f1ed80a2bca2fe7a555433f06d025e3 ) ) game ( - name "Top Gear Pocket 2 (USA) (Rev 1) (Proto)" - description "Top Gear Pocket 2 (USA) (Rev 1) (Proto)" - rom ( name "Top Gear Pocket 2 (USA) (Rev 1) (Proto).gbc" size 1048576 crc eb0838d6 sha1 5d2ea0b976833f2e3866214e602993ee4653ab96 ) + name "Midterm Moments (World) (2022-05-28) (GB Compatible) (Aftermarket) (Unl)" + description "Midterm Moments (World) (2022-05-28) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Midterm Moments (World) (2022-05-28) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f9a5ed4e sha1 8b3e18287d5adf3b5a711e28a896f843927f22a2 ) ) game ( - name "Top Gear Pocket 2 (Japan) (Rev 1) (Proto) (Rumble Version)" - description "Top Gear Pocket 2 (Japan) (Rev 1) (Proto) (Rumble Version)" - rom ( name "Top Gear Pocket 2 (Japan) (Rev 1) (Proto) (Rumble Version).gbc" size 1048576 crc fc680273 sha1 52354d36a301b26895eb26ecf152bf696656f4b2 ) + name "Midterm Moments (World) (2022-06-15) (GB Compatible) (Aftermarket) (Unl)" + description "Midterm Moments (World) (2022-06-15) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Midterm Moments (World) (2022-06-15) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 177f0b6e sha1 e5fdb741d870de25affdc841c07eaa3000da25f5 ) ) game ( - name "Top Gear Rally (Europe) (Rumble Version)" - description "Top Gear Rally (Europe) (Rumble Version)" - rom ( name "Top Gear Rally (Europe) (Rumble Version).gbc" size 1048576 crc 337e5dd3 sha1 b880f5cfde3724da3ff932bf766cee470c4f664c flags verified ) + name "Mirror Between Us, The (World) (GB Compatible) (Aftermarket) (Unl)" + description "Mirror Between Us, The (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Mirror Between Us, The (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 854f4297 sha1 a1a44ce8052f06349df3cbdf9a6d976609213d68 ) ) game ( - name "Top Gear Rally 2 (Europe)" - description "Top Gear Rally 2 (Europe)" - rom ( name "Top Gear Rally 2 (Europe).gbc" size 1048576 crc 017773cd sha1 5a0ac4ace1d5c2b6dfc0bdd20d6f88f319493558 ) + name "Mission Mars (World) (Aftermarket) (Unl)" + description "Mission Mars (World) (Aftermarket) (Unl)" + rom ( name "Mission Mars (World) (Aftermarket) (Unl).gbc" size 262144 crc f651fcf4 sha1 479c70dd9c63cdcad99ca44720a9e0e2582df119 ) ) game ( - name "Top Gun - Fire Storm (USA, Europe) (En,Fr,De,Es,It,Nl)" - description "Top Gun - Fire Storm (USA, Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Top Gun - Fire Storm (USA, Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc e2ad5a0f sha1 bad3f0770e7595ad7b4fd68d8212a902974fe1e1 ) + name "Mob Creche Parallel Game (World) (En,Ja) (Aftermarket) (Unl)" + description "Mob Creche Parallel Game (World) (En,Ja) (Aftermarket) (Unl)" + rom ( name "Mob Creche Parallel Game (World) (En,Ja) (Aftermarket) (Unl).gbc" size 262144 crc e138c5a5 sha1 9446639471efe21304c0c09c9540010941ae3f9f ) ) game ( - name "Totsugeki! Papparatai (Japan) (SGB Enhanced) (GB Compatible)" - description "Totsugeki! Papparatai (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Totsugeki! Papparatai (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc 0aeae8fb sha1 4c98beab325cd058445102c85d30b3724325f2ce ) + name "Mommy (World) (GB Compatible) (Aftermarket) (Unl)" + description "Mommy (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Mommy (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 5d644d24 sha1 3bc152e2899d54d6c400e2e0a114e0aa67a56a69 ) ) game ( - name "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan)" - description "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan)" - rom ( name "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan).gbc" size 1048576 crc 19eb4516 sha1 fed38c5131a00f0bbf00ff2a974a8e457373aba6 ) + name "Mona and the Witch's Hat Deluxe (World) (GB Compatible) (Aftermarket) (Unl)" + description "Mona and the Witch's Hat Deluxe (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Mona and the Witch's Hat Deluxe (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 39480c79 sha1 4348a7903e538e5367f2a60718f43cbeeccf96df ) ) game ( - name "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan) (Rev 1)" - description "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan) (Rev 1)" - rom ( name "Tottoko Hamutarou - Tomodachi Daisakusen Dechu (Japan) (Rev 1).gbc" size 1048576 crc d549e074 sha1 369f53d1a8bc7e6f2d1ccd101e648c2744c39fc5 flags verified ) + name "Monkey Magic (World) (Aftermarket) (Unl)" + description "Monkey Magic (World) (Aftermarket) (Unl)" + rom ( name "Monkey Magic (World) (Aftermarket) (Unl).gbc" size 262144 crc c9c68715 sha1 bf5dc5593334fe1114461065a2b7284d28b31462 ) ) game ( - name "Tottoko Hamutarou 2 - Hamu-chan Zu Daishuugou Dechu (Japan)" - description "Tottoko Hamutarou 2 - Hamu-chan Zu Daishuugou Dechu (Japan)" - rom ( name "Tottoko Hamutarou 2 - Hamu-chan Zu Daishuugou Dechu (Japan).gbc" size 2097152 crc f1fbcf84 sha1 adb1d5242a62d41c6e435b31082685ea4eec651a flags verified ) + name "Monty on the Run (World) (Aftermarket) (Unl)" + description "Monty on the Run (World) (Aftermarket) (Unl)" + rom ( name "Monty on the Run (World) (Aftermarket) (Unl).gbc" size 524288 crc fd1066ac sha1 8390175e6be4731d9afa91715d7f8dd11693bb69 ) ) game ( - name "Tower of Evil (World) (Aftermarket) (Unl)" - description "Tower of Evil (World) (Aftermarket) (Unl)" - rom ( name "Tower of Evil (World) (Aftermarket) (Unl).gbc" size 524288 crc aeb6e36f sha1 e9a6a007e935afb522c67d355e0354b0fb9af3c6 ) + name "Mount Vesuvius (World) (Aftermarket) (Unl)" + description "Mount Vesuvius (World) (Aftermarket) (Unl)" + rom ( name "Mount Vesuvius (World) (Aftermarket) (Unl).gbc" size 262144 crc 1292ecfb sha1 dd71a1a7282a8a68c70d705d8eab8b2bd73132e3 ) ) game ( - name "Towers - Lord Baniff's Deceit (USA, Europe)" - description "Towers - Lord Baniff's Deceit (USA, Europe)" - rom ( name "Towers - Lord Baniff's Deceit (USA, Europe).gbc" size 1048576 crc 7b9b2468 sha1 e1324e5d7f61225366bd8dcf6079c171d23e89ca ) + name "Mountain Climber (World) (En,Es) (GB Compatible) (Aftermarket) (Unl)" + description "Mountain Climber (World) (En,Es) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Mountain Climber (World) (En,Es) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 362a84ba sha1 b4b3afa2379a07acab6965ae8fcf6d2ba82d6d7e ) ) game ( - name "Towers II - Plight of the Stargazer (USA) (Proto 3) (2001-12-09)" - description "Towers II - Plight of the Stargazer (USA) (Proto 3) (2001-12-09)" - rom ( name "Towers II - Plight of the Stargazer (USA) (Proto 3) (2001-12-09).gbc" size 1048576 crc 909143c0 sha1 da80a5110913422d48dd8d316fcfb9c8310e4501 ) + name "Mr. Angry (World) (Aftermarket) (Unl)" + description "Mr. Angry (World) (Aftermarket) (Unl)" + rom ( name "Mr. Angry (World) (Aftermarket) (Unl).gbc" size 524288 crc b85e63a5 sha1 127ad5315e2bce37614a1e9f8605798e68718926 ) ) game ( - name "Towers II - Plight of the Stargazer (USA) (Proto 1) (2000-05-07)" - description "Towers II - Plight of the Stargazer (USA) (Proto 1) (2000-05-07)" - rom ( name "Towers II - Plight of the Stargazer (USA) (Proto 1) (2000-05-07).gbc" size 1048576 crc 5784bce0 sha1 8072c36e198bd5d102052d5175b88e1a45cca9e8 ) + name "Mud Warriors (World) (GB Compatible) (Aftermarket) (Unl)" + description "Mud Warriors (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Mud Warriors (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 846afc79 sha1 dae84fbc60839da29878714cd845c3704b915323 ) ) game ( - name "Towers II - Plight of the Stargazer (USA) (Proto 2) (2000-08-05)" - description "Towers II - Plight of the Stargazer (USA) (Proto 2) (2000-08-05)" - rom ( name "Towers II - Plight of the Stargazer (USA) (Proto 2) (2000-08-05).gbc" size 1048576 crc 39e4bfd0 sha1 e9db495992490d88a65df1741f0294357bb96998 ) + name "Munch It (World) (Aftermarket) (Unl)" + description "Munch It (World) (Aftermarket) (Unl)" + rom ( name "Munch It (World) (Aftermarket) (Unl).gbc" size 262144 crc 3d7ce6c7 sha1 55b390866d0922685bd1f42e8ee7310f021fa0dc ) ) game ( - name "Toy Story 2 (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Toy Story 2 (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Toy Story 2 (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 47aecb95 sha1 0c8506de2349ecf5241692da2aff239a0c40d862 ) + name "Musical Notes (World) (2023-05-27) (Aftermarket) (Unl)" + description "Musical Notes (World) (2023-05-27) (Aftermarket) (Unl)" + rom ( name "Musical Notes (World) (2023-05-27) (Aftermarket) (Unl).gbc" size 524288 crc ec4f9d49 sha1 357db81755f1f0eb732367dd4090c446eb226ddf ) ) game ( - name "Toy Story Racer (Europe) (En,Fr,De)" - description "Toy Story Racer (Europe) (En,Fr,De)" - rom ( name "Toy Story Racer (Europe) (En,Fr,De).gbc" size 2097152 crc f660ed94 sha1 1d06b1b563ec34014a8eabfd557e20ee03154ff9 ) + name "Musical Notes (World) (2023-05-19) (Aftermarket) (Unl)" + description "Musical Notes (World) (2023-05-19) (Aftermarket) (Unl)" + rom ( name "Musical Notes (World) (2023-05-19) (Aftermarket) (Unl).gbc" size 524288 crc 1ba7d27f sha1 d4c4be65ba469369cd90aaa733d0a8e8af6bcdc1 ) ) game ( - name "Toy Story Racer (USA, Europe)" - description "Toy Story Racer (USA, Europe)" - rom ( name "Toy Story Racer (USA, Europe).gbc" size 2097152 crc d911dd97 sha1 5deb31321a86b260aa84cab5e45a3fa36ce5efbd ) + name "My Friendly Little Island (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" + description "My Friendly Little Island (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "My Friendly Little Island (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 9bff7b15 sha1 1f3aac8a3725cd1d0968529afc1c2031372d8ed1 ) ) game ( - name "Trade & Battle Card Hero (Japan) (SGB Enhanced) (GB Compatible)" - description "Trade & Battle Card Hero (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Trade & Battle Card Hero (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b18cba2a sha1 9787a4583899720ff80a9e478ca096ba5df38fb3 flags verified ) + name "My Friendly Little Island (World) (Aftermarket) (Unl)" + description "My Friendly Little Island (World) (Aftermarket) (Unl)" + rom ( name "My Friendly Little Island (World) (Aftermarket) (Unl).gbc" size 1048576 crc f6bf0584 sha1 81d724ad696084283712145adfef15769648b045 ) ) game ( - name "Trade & Battle Card Hero (Japan) (Rev 1) (3DS Virtual Console) (SGB Enhanced) (GB Compatible)" - description "Trade & Battle Card Hero (Japan) (Rev 1) (3DS Virtual Console) (SGB Enhanced) (GB Compatible)" - rom ( name "Trade & Battle Card Hero (Japan) (Rev 1) (3DS Virtual Console) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc d98a877d sha1 c6c1e0365166b53d25a1f84bc380948a9661df30 ) + name "Neclaus' Quest (World) (GB Compatible) (Aftermarket) (Unl)" + description "Neclaus' Quest (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Neclaus' Quest (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc eedefa0c sha1 e63c16fe987fe655408be66198366a0147ac607c ) ) game ( - name "Traumatarium (World) (Demo) (2023-06-01) (GB Compatible) (Aftermarket) (Unl)" - description "Traumatarium (World) (Demo) (2023-06-01) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Traumatarium (World) (Demo) (2023-06-01) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc b0a32d51 sha1 4c0d639722d1cd8393e008d174b8f7266d089ead ) + name "Neclaus' Quest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Neclaus' Quest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Neclaus' Quest (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 53cf930c sha1 bd3272ca7ead64da3f68f774661a560add433b94 ) ) game ( - name "Treasure Island Color (World) (Aftermarket) (Unl)" - description "Treasure Island Color (World) (Aftermarket) (Unl)" - rom ( name "Treasure Island Color (World) (Aftermarket) (Unl).gbc" size 262144 crc 4ab0eb5a sha1 3ebddd4e1f5b3a87726ef34a5b7d36de8c722f36 ) + name "Neighbor (World) (GB Compatible) (Aftermarket) (Unl)" + description "Neighbor (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Neighbor (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 705b150f sha1 6258cf6ad167c9ae86609a8e620face1674a7ea7 ) ) game ( - name "Trick Boarder (Europe)" - description "Trick Boarder (Europe)" - rom ( name "Trick Boarder (Europe).gbc" size 1048576 crc efe3fc64 sha1 74573ebe3196e600fb180bc4aedafddea4060a2c ) + name "Neonsomnia (World) (v0.1) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Neonsomnia (World) (v0.1) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Neonsomnia (World) (v0.1) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 394ce9cb sha1 3d24808bf0bb1a06212a48309d8affe5d26eeeba ) ) game ( - name "Trick Boarder (USA)" - description "Trick Boarder (USA)" - rom ( name "Trick Boarder (USA).gbc" size 1048576 crc e856dc3d sha1 a5ba3e762a56801e997335eaf1f0b614ec54400c ) + name "Nightmare Hamlet (World) (Aftermarket) (Unl)" + description "Nightmare Hamlet (World) (Aftermarket) (Unl)" + rom ( name "Nightmare Hamlet (World) (Aftermarket) (Unl).gbc" size 131072 crc 574bf5b6 sha1 05d043816bb4eb9cc57b369ab5f966b610ba5c2f ) ) game ( - name "Trickboarder GP (Japan)" - description "Trickboarder GP (Japan)" - rom ( name "Trickboarder GP (Japan).gbc" size 1048576 crc 31740097 sha1 263d8612ecdf651115df6f896737b8c498c970c0 ) + name "Ninja Master (World) (Aftermarket) (Unl)" + description "Ninja Master (World) (Aftermarket) (Unl)" + rom ( name "Ninja Master (World) (Aftermarket) (Unl).gbc" size 262144 crc bc550b84 sha1 0def135723ac40e4981c88f8888afbd40a15bb40 ) ) game ( - name "Triple Play 2001 (USA, Europe)" - description "Triple Play 2001 (USA, Europe)" - rom ( name "Triple Play 2001 (USA, Europe).gbc" size 1048576 crc 74e04c07 sha1 326841285c54476c1fc231886a8cbd9c00e0195c ) + name "Number Builder (World) (Aftermarket) (Unl)" + description "Number Builder (World) (Aftermarket) (Unl)" + rom ( name "Number Builder (World) (Aftermarket) (Unl).gbc" size 262144 crc b8609d43 sha1 92952b752f50af889db891acc9eed8436ac6b87e ) ) game ( - name "Trouballs (USA)" - description "Trouballs (USA)" - rom ( name "Trouballs (USA).gbc" size 524288 crc 260eed04 sha1 dc4d0f608354e7cc32df7501dbacf8c50d70e728 ) + name "Nyghtmare - The Ninth King (World) (v0.2.6) (Beta) (Aftermarket) (Unl)" + description "Nyghtmare - The Ninth King (World) (v0.2.6) (Beta) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - The Ninth King (World) (v0.2.6) (Beta) (Aftermarket) (Unl).gbc" size 1048576 crc e983e8d1 sha1 fc2a58d49327c88c895ae6681bde57e1a2687974 flags verified ) ) game ( - name "Trouble City - Pocket Mission (World) (GB Compatible) (Aftermarket) (Unl)" - description "Trouble City - Pocket Mission (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Trouble City - Pocket Mission (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 4b9143ad sha1 0e51e398d44aaad74a7c622f7818b56a3b34db56 ) + name "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl)" + description "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc ef42955e sha1 485b4d672d9edda40f9191f5f5cc223046000e67 flags verified ) ) game ( - name "True Color 25 in 1 (Taiwan) (Unl)" - description "True Color 25 in 1 (Taiwan) (Unl)" - rom ( name "True Color 25 in 1 (Taiwan) (Unl).gbc" size 2097152 crc c47392ab sha1 0f1f76944ce2e85127df7d96ecb1eef6813af692 ) + name "Nyghtmare - The Ninth King (World) (v0.2.1) (Beta) (Aftermarket) (Unl)" + description "Nyghtmare - The Ninth King (World) (v0.2.1) (Beta) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - The Ninth King (World) (v0.2.1) (Beta) (Aftermarket) (Unl).gbc" size 1048576 crc 581efe4d sha1 125bb0564ee17f8e55046a1c25e53ee9a4254303 ) ) game ( - name "Tsuri Sensei 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Tsuri Sensei 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Tsuri Sensei 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 1be00a6e sha1 ecc0b306501f1a2371a83db808bda38af8bc28ce ) + name "Nyghtmare - The Ninth King (World) (v0.2.3) (Beta) (Aftermarket) (Unl)" + description "Nyghtmare - The Ninth King (World) (v0.2.3) (Beta) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - The Ninth King (World) (v0.2.3) (Beta) (Aftermarket) (Unl).gbc" size 1048576 crc e26ddbbb sha1 853115369b8ca583d038d00c1dde59b6a74b73a2 ) ) game ( - name "Tsuriiko!! (Japan)" - description "Tsuriiko!! (Japan)" - rom ( name "Tsuriiko!! (Japan).gbc" size 2097152 crc 6f2cbd1d sha1 b14cc1e8aca284517d964a909736da6b4540de85 ) + name "Nyghtmare - The Ninth King (World) (v0.2.5) (Beta) (Aftermarket) (Unl)" + description "Nyghtmare - The Ninth King (World) (v0.2.5) (Beta) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - The Ninth King (World) (v0.2.5) (Beta) (Aftermarket) (Unl).gbc" size 1048576 crc 1e8ac5b9 sha1 99c11bef7feb17a9e7212cf9b6593478f671bc32 ) ) game ( - name "Turbo RC Racing (USA) (Proto)" - description "Turbo RC Racing (USA) (Proto)" - rom ( name "Turbo RC Racing (USA) (Proto).gbc" size 262144 crc e1983dfd sha1 494466cfed8e082c61b9e56a7275014c38705694 ) + name "Nyghtmare - The Ninth King (World) (Free Version) (GB Compatible) (Aftermarket) (Unl)" + description "Nyghtmare - The Ninth King (World) (Free Version) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - The Ninth King (World) (Free Version) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc f5df28c2 sha1 7b511444e1eb86fffcf93599a78e0e2c44aecc8a ) ) game ( - name "Turok - Rage Wars (USA, Europe) (En,Fr,De,Es)" - description "Turok - Rage Wars (USA, Europe) (En,Fr,De,Es)" - rom ( name "Turok - Rage Wars (USA, Europe) (En,Fr,De,Es).gbc" size 1048576 crc 786b5ab4 sha1 ce95e00b6e9d7dfb952e8cdf590a4c6948a6340e flags verified ) + name "Nyghtmare - The Ninth King (World) (Rev 1) (Free Version) (Aftermarket) (Unl)" + description "Nyghtmare - The Ninth King (World) (Rev 1) (Free Version) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - The Ninth King (World) (Rev 1) (Free Version) (Aftermarket) (Unl).gbc" size 2097152 crc 63bddc68 sha1 fab777e607bd8aba70eb65829143039dbe6ac08e ) ) game ( - name "Turok 2 - Jikku Senshi (Japan) (GB Compatible)" - description "Turok 2 - Jikku Senshi (Japan) (GB Compatible)" - rom ( name "Turok 2 - Jikku Senshi (Japan) (GB Compatible).gbc" size 1048576 crc f095b446 sha1 08a112f0c3fdc4cd4c14cfb98683d25d5d8475de ) + name "Nyghtmare - The Ninth King (World) (v0.1.0) (Beta) (GB Compatible) (Aftermarket) (Unl)" + description "Nyghtmare - The Ninth King (World) (v0.1.0) (Beta) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - The Ninth King (World) (v0.1.0) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 1f1af42a sha1 ddcdbfa716d716e1b7bb258caaaa7b76d041b5a9 ) ) game ( - name "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (GB Compatible)" - description "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (GB Compatible)" - rom ( name "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (GB Compatible).gbc" size 1048576 crc 6eda6a3a sha1 fb7856af0205cc749174cda9eb51ae137984558c ) + name "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl) (Alt)" + description "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl) (Alt)" + rom ( name "Nyghtmare - The Ninth King (World) (v0.1.2) (Beta) (GB Compatible) (Aftermarket) (Unl) (Alt).gbc" size 524288 crc 834a8021 sha1 d5af2bf38eda4c181993e992764788003509ebfd ) ) game ( - name "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (Beta) (GB Compatible)" - description "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (Beta) (GB Compatible)" - rom ( name "Turok 2 - Seeds of Evil (USA, Europe) (En,Fr,De,Es) (Beta) (GB Compatible).gbc" size 1048576 crc dae30864 sha1 886c73348f4dd50e3ea916f96b8daa2451997dcc ) + name "Nyghtmare - The Ninth King (World) (v0.1.9) (Beta) (GB Compatible) (Aftermarket) (Unl)" + description "Nyghtmare - The Ninth King (World) (v0.1.9) (Beta) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Nyghtmare - The Ninth King (World) (v0.1.9) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 42d9c38c sha1 ae719190cf2f433c359bc425775710f4aa67e860 ) ) game ( - name "Turok 3 - Shadow of Oblivion (USA, Europe) (En,Fr,De,Es)" - description "Turok 3 - Shadow of Oblivion (USA, Europe) (En,Fr,De,Es)" - rom ( name "Turok 3 - Shadow of Oblivion (USA, Europe) (En,Fr,De,Es).gbc" size 1048576 crc 6d48765e sha1 4b240f6b8e3648f2cbafa2fd6ee4e5b508950122 flags verified ) + name "Octopus Stressus (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Octopus Stressus (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Octopus Stressus (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 2c055ef9 sha1 d4fa4e02753a9fe539f70d0927ba5bf9caa02d3c ) ) game ( - name "Tutti Frutti (World) (Aftermarket) (Unl)" - description "Tutti Frutti (World) (Aftermarket) (Unl)" - rom ( name "Tutti Frutti (World) (Aftermarket) (Unl).gbc" size 262144 crc ca377ca6 sha1 53d97b93b9d190de40ed2d81e18b4cbe44f99a23 ) + name "Octopus Stressus (World) (GB Compatible) (Aftermarket) (Unl)" + description "Octopus Stressus (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Octopus Stressus (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 7ed58128 sha1 e543c39f8e55b1788476b94028a54fc2fc9c7ea0 ) ) game ( - name "Tutty (Europe) (Demo)" - description "Tutty (Europe) (Demo)" - rom ( name "Tutty (Europe) (Demo).gbc" size 131072 crc c4655f0a sha1 51883c4cc1469987483f993e3904da22690faeb9 ) + name "Office Combat (World) (GB Compatible) (Aftermarket) (Unl)" + description "Office Combat (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Office Combat (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 9742276d sha1 cd8f18d6e5fabaa130a42e5618e29c5ff26f6a93 ) ) game ( - name "TV-Chan's Great Escape! (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" - description "TV-Chan's Great Escape! (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "TV-Chan's Great Escape! (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 01239312 sha1 4f21c3539ef40a7630581fe50533371e0d1a1ba9 ) + name "Olympic Skier (World) (Aftermarket) (Unl)" + description "Olympic Skier (World) (Aftermarket) (Unl)" + rom ( name "Olympic Skier (World) (Aftermarket) (Unl).gbc" size 524288 crc 5e81cef7 sha1 a7a552a9eb984098a67e063c2eca907eec000fc1 ) ) game ( - name "Tweenies - Doodles' Bones (Europe) (En,De,Es,It)" - description "Tweenies - Doodles' Bones (Europe) (En,De,Es,It)" - rom ( name "Tweenies - Doodles' Bones (Europe) (En,De,Es,It).gbc" size 1048576 crc 9306edd0 sha1 d1ff6fd8772dbc2038af7220845e817396664ae3 ) + name "One Day (World) (GB Compatible) (Aftermarket) (Unl)" + description "One Day (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "One Day (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc fd52acc7 sha1 bdb5590b61791b89e9afa871d32648d7a66ce1f4 ) ) game ( - name "Tweenies - Doodles' Bones (Europe) (En,Nl,Sv,No,Da)" - description "Tweenies - Doodles' Bones (Europe) (En,Nl,Sv,No,Da)" - rom ( name "Tweenies - Doodles' Bones (Europe) (En,Nl,Sv,No,Da).gbc" size 1048576 crc c7b61220 sha1 1e39a4ea0a8c7322a2e0653e522e0e486aa1ac36 ) + name "Opossum Country (World) (GB Compatible) (Aftermarket) (Unl)" + description "Opossum Country (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Opossum Country (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 7348bb32 sha1 e63e06d602473206b21138f5322acf86b5b6b9b8 ) ) game ( - name "Tweety Sekaiisshuu - 80 Hiki no Neko o Sagase! (Japan)" - description "Tweety Sekaiisshuu - 80 Hiki no Neko o Sagase! (Japan)" - rom ( name "Tweety Sekaiisshuu - 80 Hiki no Neko o Sagase! (Japan).gbc" size 1048576 crc 147f427a sha1 cf04dac11119c9be4ca6e247e33b935bd0cdc62d ) + name "Out on a Limb (World) (Aftermarket) (Unl)" + description "Out on a Limb (World) (Aftermarket) (Unl)" + rom ( name "Out on a Limb (World) (Aftermarket) (Unl).gbc" size 262144 crc a6671528 sha1 f21cb71adcea1029151930eb98c4e9b446e4cfee ) ) game ( - name "Tweety's High-Flying Adventure (Europe) (En,Es,It)" - description "Tweety's High-Flying Adventure (Europe) (En,Es,It)" - rom ( name "Tweety's High-Flying Adventure (Europe) (En,Es,It).gbc" size 1048576 crc ca9e5385 sha1 e0c3ab341a825b297f9970b00f1d911e48492a72 ) + name "Outta Time (World) (Aftermarket) (Unl)" + description "Outta Time (World) (Aftermarket) (Unl)" + rom ( name "Outta Time (World) (Aftermarket) (Unl).gbc" size 262144 crc 18522ba7 sha1 e9ef4c1d24e42ba7920bf8e7d72f804f058b93c6 ) ) game ( - name "Tweety's High-Flying Adventure (Europe) (En,Fr,De)" - description "Tweety's High-Flying Adventure (Europe) (En,Fr,De)" - rom ( name "Tweety's High-Flying Adventure (Europe) (En,Fr,De).gbc" size 1048576 crc 7361d6bc sha1 94b4e1953b230d862e8f6173e82c822acb7ff02e ) + name "Outward (World) (Aftermarket) (Unl)" + description "Outward (World) (Aftermarket) (Unl)" + rom ( name "Outward (World) (Aftermarket) (Unl).gbc" size 131072 crc c554bf64 sha1 6cfb29fed8ce82384d9051424a4b55673c182c8f ) ) game ( - name "Tweety's High-Flying Adventure (USA)" - description "Tweety's High-Flying Adventure (USA)" - rom ( name "Tweety's High-Flying Adventure (USA).gbc" size 1048576 crc 4e226396 sha1 9702aeea4a92625d2c19aa7f606b589cb7531613 ) + name "Pacifist, The (World) (GB Compatible) (Aftermarket) (Unl)" + description "Pacifist, The (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Pacifist, The (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc c6e83f41 sha1 44b117d94a80617a77abbdcc76d9d69b66efe56b ) ) game ( - name "Tycoon Tex (World) (Aftermarket) (Unl)" - description "Tycoon Tex (World) (Aftermarket) (Unl)" - rom ( name "Tycoon Tex (World) (Aftermarket) (Unl).gbc" size 262144 crc fa8436ba sha1 d37bcd93d647ac7efb761c539785a4ef570cdcc8 ) + name "Pacifist, The (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" + description "Pacifist, The (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Pacifist, The (World) (GB Showdown) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 69483f81 sha1 4d162c9637a20cfc7c92e6ea7a61fad0ed22137a ) ) game ( - name "Tynesoft Commodore 16 Classics (World) (Aftermarket) (Unl)" - description "Tynesoft Commodore 16 Classics (World) (Aftermarket) (Unl)" - rom ( name "Tynesoft Commodore 16 Classics (World) (Aftermarket) (Unl).gbc" size 2097152 crc 8067298a sha1 e44280161ca9d482fae08de844ccc9754abf68b0 ) + name "Pact, The (World) (GB Showdown) (Aftermarket) (Unl)" + description "Pact, The (World) (GB Showdown) (Aftermarket) (Unl)" + rom ( name "Pact, The (World) (GB Showdown) (Aftermarket) (Unl).gbc" size 262144 crc 0db301c2 sha1 58ec8f209ed6e33adfb253014ea69ae1ee53c145 ) ) game ( - name "Tynesoft Commodore 16 Classics II (World) (Aftermarket) (Unl)" - description "Tynesoft Commodore 16 Classics II (World) (Aftermarket) (Unl)" - rom ( name "Tynesoft Commodore 16 Classics II (World) (Aftermarket) (Unl).gbc" size 1048576 crc 0ce45101 sha1 f61677146ef67b026c636742f0109b8c478d0942 ) + name "Pact, The (World) (Aftermarket) (Unl)" + description "Pact, The (World) (Aftermarket) (Unl)" + rom ( name "Pact, The (World) (Aftermarket) (Unl).gbc" size 262144 crc 304df19a sha1 97af064f9063cd353e55ac0e1f6d1ca8b4a6d2b9 ) ) game ( - name "Tyrannosaurus Tex (USA) (Proto)" - description "Tyrannosaurus Tex (USA) (Proto)" - rom ( name "Tyrannosaurus Tex (USA) (Proto).gbc" size 2097152 crc 1bd4e588 sha1 e2fcc7fcc643f9d7fc61acce6c5ed1f8abc13fa0 ) + name "Paku Paku GB (World) (GB Compatible) (Aftermarket) (Unl)" + description "Paku Paku GB (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Paku Paku GB (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 62b5a15f sha1 2b85528aef01cb5caab4cff898c2bc66e211b3bf ) ) game ( - name "Tyrannosaurus Tex (World) (Aftermarket) (Unl)" - description "Tyrannosaurus Tex (World) (Aftermarket) (Unl)" - rom ( name "Tyrannosaurus Tex (World) (Aftermarket) (Unl).gbc" size 2097152 crc e90504c1 sha1 7e41e92f92ff06101e48dee758420f1bd3959013 ) + name "Pancho (World) (Aftermarket) (Unl)" + description "Pancho (World) (Aftermarket) (Unl)" + rom ( name "Pancho (World) (Aftermarket) (Unl).gbc" size 524288 crc d32d46c5 sha1 2f46974e6d92f5deb277818d95426a4507b3701d ) ) game ( - name "Tyrian 2000 (USA) (Proto) (GB Compatible)" - description "Tyrian 2000 (USA) (Proto) (GB Compatible)" - rom ( name "Tyrian 2000 (USA) (Proto) (GB Compatible).gbc" size 524288 crc 1fb6b290 sha1 1cfe1c97c50155844a349b7ca4ef8c77985adac2 ) + name "Panik!16 (World) (Aftermarket) (Unl)" + description "Panik!16 (World) (Aftermarket) (Unl)" + rom ( name "Panik!16 (World) (Aftermarket) (Unl).gbc" size 262144 crc 7b31122d sha1 98d74fd64e4f7e835f1101b05816b8938a34a416 ) ) game ( - name "Uchuujin Tanaka Tarou de - RPG Tsukuru GB 2 (Japan)" - description "Uchuujin Tanaka Tarou de - RPG Tsukuru GB 2 (Japan)" - rom ( name "Uchuujin Tanaka Tarou de - RPG Tsukuru GB 2 (Japan).gbc" size 4194304 crc 219e42e3 sha1 aa090449e93e4dcfa0437e7cdba695e90cfa9509 ) + name "Phantom Fright (World) (GB Compatible) (Aftermarket) (Unl)" + description "Phantom Fright (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Phantom Fright (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 154cb547 sha1 3b217c595e6a5b115dc7130123a321049cf01d22 ) ) game ( - name "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl)" - description "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 4b314d4b sha1 56e5f0e62b65a265c85e1a88882b18139f26b94d ) + name "Pilgrim's Peril (World) (Demo 1) (GB Compatible) (Aftermarket) (Unl)" + description "Pilgrim's Peril (World) (Demo 1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Pilgrim's Peril (World) (Demo 1) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 3c2bafdc sha1 d38f3f5e491dbaed84e88099987712449db9b33d ) ) game ( - name "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - description "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta)" - rom ( name "UEFA 2000 (Europe) (En,Fr,De,Es,It,Nl) (Beta).gbc" size 1048576 crc 03380957 sha1 9f44aa3230aba33c9c38c5e17f9cef2e9a10747e ) + name "Pilgrim's Peril (World) (Demo 2) (GB Compatible) (Aftermarket) (Unl)" + description "Pilgrim's Peril (World) (Demo 2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Pilgrim's Peril (World) (Demo 2) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc cdded15b sha1 2b85eb77ab2dcea4f645abcc1a66dbce54a6ebaa ) ) game ( - name "Ultimate Fighting Championship (Europe)" - description "Ultimate Fighting Championship (Europe)" - rom ( name "Ultimate Fighting Championship (Europe).gbc" size 1048576 crc 92a5a1ad sha1 5036626b97238e17b8fc203c44453e79b108cd2e flags verified ) + name "Pine Creek (World) (En-US,Es-MX,Pt-BR) (Beta) (GB Compatible) (Aftermarket) (Unl)" + description "Pine Creek (World) (En-US,Es-MX,Pt-BR) (Beta) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Pine Creek (World) (En-US,Es-MX,Pt-BR) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 189aa999 sha1 2cf46a36502eaf22ac9572fe1136d369fcbe9e46 ) ) game ( - name "Ultimate Fighting Championship (USA)" - description "Ultimate Fighting Championship (USA)" - rom ( name "Ultimate Fighting Championship (USA).gbc" size 1048576 crc d5f036ce sha1 8a02015e399a0311c15f0a8ca31744aa0be0f5e6 ) + name "Pinecone Pizza Party (World) (Prototype) (GB Compatible) (Aftermarket) (Unl)" + description "Pinecone Pizza Party (World) (Prototype) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Pinecone Pizza Party (World) (Prototype) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 1601d6fa sha1 87b4edf0398f0154d7556e3cd96f97b19e699a40 ) ) game ( - name "Ultimate Paintball (USA, Europe)" - description "Ultimate Paintball (USA, Europe)" - rom ( name "Ultimate Paintball (USA, Europe).gbc" size 1048576 crc 6dcfdfe2 sha1 7765398db980c145062f2c0ac92b1f8f4ba40236 ) + name "PlayTime (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "PlayTime (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "PlayTime (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 29415ff7 sha1 89b3fd633e8cef3b8523b1ef2a0072db2d7416d7 ) ) game ( - name "Ultimate Surfing (Europe)" - description "Ultimate Surfing (Europe)" - rom ( name "Ultimate Surfing (Europe).gbc" size 1048576 crc b3398a9b sha1 15426e79cf1c0cafbf8972501b8478951023c21a ) + name "Pogo Pete (World) (Aftermarket) (Unl)" + description "Pogo Pete (World) (Aftermarket) (Unl)" + rom ( name "Pogo Pete (World) (Aftermarket) (Unl).gbc" size 262144 crc 3001ed1b sha1 f9dab150843c2b8f300d36b1dd53dd1a22b481a3 ) ) game ( - name "Ultimate Surfing (USA)" - description "Ultimate Surfing (USA)" - rom ( name "Ultimate Surfing (USA).gbc" size 1048576 crc e84df1f0 sha1 264c19ab212d938839306f7e8230d5caee3cf3e7 ) + name "Pokettohiro! (World) (v2.0) (Demo) (Aftermarket) (Unl)" + description "Pokettohiro! (World) (v2.0) (Demo) (Aftermarket) (Unl)" + rom ( name "Pokettohiro! (World) (v2.0) (Demo) (Aftermarket) (Unl).gbc" size 1048576 crc 42298fd8 sha1 90c535bf70e2ca7b91af67b8f08865f423c3034f ) ) game ( - name "Unearthed (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" - description "Unearthed (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Unearthed (World) (v1.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 29bb9238 sha1 39fbfb220e9be0120090f770249049b3f3583f64 ) + name "Pokettohiro! (World) (v1.0) (Demo) (Aftermarket) (Unl)" + description "Pokettohiro! (World) (v1.0) (Demo) (Aftermarket) (Unl)" + rom ( name "Pokettohiro! (World) (v1.0) (Demo) (Aftermarket) (Unl).gbc" size 1048576 crc b9e724ef sha1 28a01fd6ea95a146008435c5bc27b51b607bb86b ) ) game ( - name "Ungrateful Son, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "Ungrateful Son, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Ungrateful Son, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 977b54f4 sha1 016dde406896d827dcad682d40b52d0e9eeefa88 ) + name "Pokettohiro! (World) (v3.0) (Demo) (Aftermarket) (Unl)" + description "Pokettohiro! (World) (v3.0) (Demo) (Aftermarket) (Unl)" + rom ( name "Pokettohiro! (World) (v3.0) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc b9b4e3c0 sha1 a8ba9c09ef0889640e41d79838bcd98b7bc4e5d4 ) ) game ( - name "Unholy Friend (World) (GB Compatible) (Aftermarket) (Unl)" - description "Unholy Friend (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Unholy Friend (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 36e4ff4c sha1 b5c9b5f07e31729678637d883b2564c1448b0e57 ) + name "Pomape Castle (World) (GB Compatible) (Aftermarket) (Unl)" + description "Pomape Castle (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Pomape Castle (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 9350c71d sha1 a0f449e270b72de56bfea151b5ac271c0c7e3c93 ) ) game ( - name "Uno (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - description "Uno (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible)" - rom ( name "Uno (Europe) (En,Fr,De,Es,It,Nl) (GB Compatible).gbc" size 1048576 crc 70760cce sha1 b33214a4cd05f58dd019a77b1260bf557293c826 ) + name "Postie (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Postie (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Postie (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 50393a65 sha1 2c2c6ed8be7a13bf279e435c5984f175c8affcad ) ) game ( - name "Uno (USA) (GB Compatible)" - description "Uno (USA) (GB Compatible)" - rom ( name "Uno (USA) (GB Compatible).gbc" size 1048576 crc f026d509 sha1 20868148461618d1195570775b183a065781ce35 ) + name "Postie (World) (GB Compatible) (Aftermarket) (Unl)" + description "Postie (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Postie (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ff6bbc83 sha1 3ff236972d1e344eb50e696db3cc090f2b5d28b1 ) ) game ( - name "UXB (World) (Aftermarket) (Unl)" - description "UXB (World) (Aftermarket) (Unl)" - rom ( name "UXB (World) (Aftermarket) (Unl).gbc" size 262144 crc dd42be4c sha1 6ef7abb689b1c75f613ed253644fbb0f377b7a95 ) + name "Postman Pat's Trail Game (World) (Aftermarket) (Unl)" + description "Postman Pat's Trail Game (World) (Aftermarket) (Unl)" + rom ( name "Postman Pat's Trail Game (World) (Aftermarket) (Unl).gbc" size 262144 crc ad31b512 sha1 135977fe71677e3c49450e2c6ff63105d10dfaac ) ) game ( - name "V-Rally - Championship Edition (Europe) (En,Fr,De,Es)" - description "V-Rally - Championship Edition (Europe) (En,Fr,De,Es)" - rom ( name "V-Rally - Championship Edition (Europe) (En,Fr,De,Es).gbc" size 1048576 crc 1312b3f7 sha1 5447f2c317deee8ca6da8f098a7d78f52b87e0cb ) + name "Potbound (World) (2022-09-27) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Potbound (World) (2022-09-27) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Potbound (World) (2022-09-27) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 6da19041 sha1 eb581935ad9223d723fdbc8339c03436df051947 ) ) game ( - name "V-Rally - Championship Edition (Japan)" - description "V-Rally - Championship Edition (Japan)" - rom ( name "V-Rally - Championship Edition (Japan).gbc" size 1048576 crc fab9d941 sha1 c05473dcf45fd4e185f9f3aec3f4e429e4f12bbd ) + name "Potbound (World) (2022-09-26) (Proto) (GBJam 10) (GB Compatible) (Aftermarket) (Unl)" + description "Potbound (World) (2022-09-26) (Proto) (GBJam 10) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Potbound (World) (2022-09-26) (Proto) (GBJam 10) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc d0d8386d sha1 fbddf81a1663388ff0efeeb9051e68e0c323c839 ) ) game ( - name "V-Rally - Edition 99 (USA) (En,Fr,Es)" - description "V-Rally - Edition 99 (USA) (En,Fr,Es)" - rom ( name "V-Rally - Edition 99 (USA) (En,Fr,Es).gbc" size 1048576 crc da300c6c sha1 638266c9d2d16486c2ed00510176112071b05e2c ) + name "POWA! (World) (En) (GB Compatible) (Aftermarket) (Unl)" + description "POWA! (World) (En) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "POWA! (World) (En) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f0191467 sha1 3876f1aa896759f427ad2dc88a48788817e60c06 flags verified ) ) game ( - name "Varmit (World) (Aftermarket) (Unl)" - description "Varmit (World) (Aftermarket) (Unl)" - rom ( name "Varmit (World) (Aftermarket) (Unl).gbc" size 2097152 crc e4827006 sha1 b61876c714c47f62a77304b79f6e34b8d0e7f8a2 ) + name "POWA! (World) (Ja) (GB Compatible) (Aftermarket) (Unl)" + description "POWA! (World) (Ja) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "POWA! (World) (Ja) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc e8f68acc sha1 156d315b7a2a035d5cd429fb8c7e051e67e83c93 flags verified ) ) game ( - name "Vegas Games (Europe) (En,Fr,De)" - description "Vegas Games (Europe) (En,Fr,De)" - rom ( name "Vegas Games (Europe) (En,Fr,De).gbc" size 1048576 crc 81b2bb8d sha1 9b110d6ee12241aa5c061a1bb5f66e9cab93842f ) + name "POWA! (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "POWA! (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "POWA! (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 592b6097 sha1 874d5e4ffc7d36259bef6ec6a86a1de8289b8d54 ) ) game ( - name "Vegas Games (USA)" - description "Vegas Games (USA)" - rom ( name "Vegas Games (USA).gbc" size 1048576 crc 40b5ea96 sha1 c73423444cc5900518fbd163ec7421dc3e5a7ca2 ) + name "Power Ball - Monster's Quest (World) (v1.04) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Power Ball - Monster's Quest (World) (v1.04) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Power Ball - Monster's Quest (World) (v1.04) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc b01c4ff1 sha1 898dbf10550af7e39b8f7a0818a78083ae40f4fe ) ) game ( - name "Vegas Games (USA) (En,Fr,De) (Rev 1) (Proto)" - description "Vegas Games (USA) (En,Fr,De) (Rev 1) (Proto)" - rom ( name "Vegas Games (USA) (En,Fr,De) (Rev 1) (Proto).gbc" size 1048576 crc 4167cf29 sha1 658cc13bc436a9ec613400b91288831900e3443e ) + name "Princess Poffin and the Spider Invasion! (World) (2023-06-04) (GB Compatible) (Aftermarket) (Unl)" + description "Princess Poffin and the Spider Invasion! (World) (2023-06-04) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Princess Poffin and the Spider Invasion! (World) (2023-06-04) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc a86cada1 sha1 b02096c489c0f36582061d6eb62beb17e8294b61 ) ) game ( - name "Vigilante 8 (USA) (Rumble Version)" - description "Vigilante 8 (USA) (Rumble Version)" - rom ( name "Vigilante 8 (USA) (Rumble Version).gbc" size 1048576 crc d1a188dc sha1 4e4ce54c06e8f71ba6e0d8fc8550c177dcf660fd flags verified ) + name "Princess Poffin and the Spider Invasion! (World) (2023-06-06) (GB Compatible) (Aftermarket) (Unl)" + description "Princess Poffin and the Spider Invasion! (World) (2023-06-06) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Princess Poffin and the Spider Invasion! (World) (2023-06-06) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc e171f327 sha1 b03df48f48529ac1be79699d6f34f324adcfb436 ) ) game ( - name "VIP (Europe) (En,Fr,De,Es,It)" - description "VIP (Europe) (En,Fr,De,Es,It)" - rom ( name "VIP (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc dbdd6d85 sha1 4da103b9a5c9e9649b26876fcbd70555bd8fd042 flags verified ) + name "Proof of Destruction (World) (Aftermarket) (Unl)" + description "Proof of Destruction (World) (Aftermarket) (Unl)" + rom ( name "Proof of Destruction (World) (Aftermarket) (Unl).gbc" size 262144 crc fa528f88 sha1 5062f16346c31cae1b13e469cb610ce84d4eecb2 ) ) game ( - name "VIP (USA) (En,Fr,Es)" - description "VIP (USA) (En,Fr,Es)" - rom ( name "VIP (USA) (En,Fr,Es).gbc" size 1048576 crc 436c87d4 sha1 3ecff5c68e457ee34c42af6349f9ab2a6845b5de ) + name "Purple Turtles (World) (Aftermarket) (Unl)" + description "Purple Turtles (World) (Aftermarket) (Unl)" + rom ( name "Purple Turtles (World) (Aftermarket) (Unl).gbc" size 262144 crc 471277df sha1 a73cb69d1fb42f45f3649c4d1b4775e98fe35b78 ) ) game ( - name "Visiteurs, Les (France) (GB Compatible)" - description "Visiteurs, Les (France) (GB Compatible)" - rom ( name "Visiteurs, Les (France) (GB Compatible).gbc" size 1048576 crc d843f898 sha1 307b5d80fd7def049d446bf3406ec8d57dfee93d ) + name "Quartet (World) (GB Compatible) (Aftermarket) (Unl)" + description "Quartet (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Quartet (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc 46743216 sha1 bf866b438a602af386f8fad02727b4084edf6047 ) ) game ( - name "VOX (World) (Aftermarket) (Unl)" - description "VOX (World) (Aftermarket) (Unl)" - rom ( name "VOX (World) (Aftermarket) (Unl).gbc" size 262144 crc 346561fb sha1 54a03c77653a19eb1b0d8a6ac82f498f83f35ef2 ) + name "Quest Arrest (World) (v1.1) (Digital) (GB Compatible) (Aftermarket) (Unl)" + description "Quest Arrest (World) (v1.1) (Digital) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Quest Arrest (World) (v1.1) (Digital) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 9ac546d5 sha1 25b3a21135bfc7587c096b10f4a20d8b3095d721 ) ) game ( - name "VR Sports - Powerboat Racing (USA) (Proto)" - description "VR Sports - Powerboat Racing (USA) (Proto)" - rom ( name "VR Sports - Powerboat Racing (USA) (Proto).gbc" size 1048576 crc cff671f1 sha1 1c77f032cdd373bfa108ea82c463f8f9f6874c71 ) + name "Quest of the MX-129 Wizard (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Quest of the MX-129 Wizard (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Quest of the MX-129 Wizard (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 776ab9fd sha1 65d98bae58e5e4f723b1ec838ad4e1f2036c4468 ) ) game ( - name "Wacky Painter (World) (Aftermarket) (Unl)" - description "Wacky Painter (World) (Aftermarket) (Unl)" - rom ( name "Wacky Painter (World) (Aftermarket) (Unl).gbc" size 262144 crc 09daa18d sha1 5425dc675101d63bea03b1c8f46f86fe200ad392 ) + name "Raffles (World) (Aftermarket) (Unl)" + description "Raffles (World) (Aftermarket) (Unl)" + rom ( name "Raffles (World) (Aftermarket) (Unl).gbc" size 262144 crc e41d6472 sha1 4b5eb518ff52c235c674e0695fdde2b8b01f58fa ) ) game ( - name "Wacky Races (Europe) (En,Fr,De,Es,It,Nl)" - description "Wacky Races (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Wacky Races (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc 37ea6093 sha1 dba18064c886cebe4c4be80f941622f377adab98 ) + name "Ravenia (World) (GB Compatible) (Aftermarket) (Unl)" + description "Ravenia (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Ravenia (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 09196a32 sha1 8218ad22b29fb32c66430a17a97775dd30b2f34b flags verified ) ) game ( - name "Wacky Races (USA) (En,Fr,Es)" - description "Wacky Races (USA) (En,Fr,Es)" - rom ( name "Wacky Races (USA) (En,Fr,Es).gbc" size 1048576 crc 543abb1b sha1 3ec148027d0e5a075d7a4597232e64215c060fa7 ) + name "Remi's Pizzaria (World) (GB Compatible) (Aftermarket) (Unl)" + description "Remi's Pizzaria (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Remi's Pizzaria (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f7a4fcfb sha1 fdc8c8a1bab2dfcfe3e43175e830382fe63d5c7d ) ) game ( - name "Wai Xing Tanxian Zhi Xingqiu Dazhan (Taiwan) (Unl)" - description "Wai Xing Tanxian Zhi Xingqiu Dazhan (Taiwan) (Unl)" - rom ( name "Wai Xing Tanxian Zhi Xingqiu Dazhan (Taiwan) (Unl).gbc" size 2097152 crc 4e600093 sha1 32067be39f0bdc354c31a7a02f24ba00b61ae4f1 flags verified ) + name "Repugnant Bounty (World) (Demo) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl)" + description "Repugnant Bounty (World) (Demo) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Repugnant Bounty (World) (Demo) (GB Compo 2021) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc e92034d8 sha1 14b9614cea9be7d5c6e12aece692582ba2ca2b75 flags verified ) ) game ( - name "Walt Disney World Quest - Magical Racing Tour (Europe) (Fr,De,Es)" - description "Walt Disney World Quest - Magical Racing Tour (Europe) (Fr,De,Es)" - rom ( name "Walt Disney World Quest - Magical Racing Tour (Europe) (Fr,De,Es).gbc" size 2097152 crc e54b22b9 sha1 95dbef19504368e73b97cd785e2b19e3c71710f4 flags verified ) + name "Repugnant Bounty (World) (v0.1.023) (Beta) (GB Compatible) (Aftermarket) (Unl)" + description "Repugnant Bounty (World) (v0.1.023) (Beta) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Repugnant Bounty (World) (v0.1.023) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 3a1b1d83 sha1 4dda0cce6907de94eeae3f11a40238c3f5155ca7 ) ) game ( - name "Walt Disney World Quest - Magical Racing Tour (USA, Europe)" - description "Walt Disney World Quest - Magical Racing Tour (USA, Europe)" - rom ( name "Walt Disney World Quest - Magical Racing Tour (USA, Europe).gbc" size 2097152 crc 56beb694 sha1 529289ccfd21397405d08305409c5d9b2119505e ) + name "Repugnant Bounty (World) (Demo) (Aftermarket) (Unl)" + description "Repugnant Bounty (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Repugnant Bounty (World) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc f8c7f180 sha1 07674d42f5d4efaec14750ae56d8f28c4b54c020 flags verified ) ) game ( - name "Wangzu Tiantang (Taiwan) (Unl)" - description "Wangzu Tiantang (Taiwan) (Unl)" - rom ( name "Wangzu Tiantang (Taiwan) (Unl).gbc" size 2097152 crc dee597fc sha1 4e01c94ab55f2d299bd0bea83c0ef500fb9e738c ) + name "Retro Quiz Tower (World) (GB Compatible) (Aftermarket) (Unl)" + description "Retro Quiz Tower (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Retro Quiz Tower (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 8bd98942 sha1 3a5dbafa829e57089de8cfc93c806f7ee023ff1b ) ) game ( - name "Warau Inu no Bouken - Silly Go Lucky! (Japan)" - description "Warau Inu no Bouken - Silly Go Lucky! (Japan)" - rom ( name "Warau Inu no Bouken - Silly Go Lucky! (Japan).gbc" size 1048576 crc e93f1582 sha1 3c337b71aeba3b937caada4c84f2b29add517d03 ) + name "Retro Quiz Tower (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + description "Retro Quiz Tower (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Retro Quiz Tower (World) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c761189c sha1 f7f18d83218b66b9d1cd7267d6d4acfd4eded6c7 ) ) game ( - name "Wario Land 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "Wario Land 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Wario Land 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc b30fdbf5 sha1 cd6266e48df816219fb38d223b0ec6760259616d flags verified ) + name "Rig Attack (World) (Aftermarket) (Unl)" + description "Rig Attack (World) (Aftermarket) (Unl)" + rom ( name "Rig Attack (World) (Aftermarket) (Unl).gbc" size 262144 crc d013d775 sha1 90bfd921c986abff4555b761cedc90ec36c43fff ) ) game ( - name "Wario Land 3 (World) (En,Ja)" - description "Wario Land 3 (World) (En,Ja)" - rom ( name "Wario Land 3 (World) (En,Ja).gbc" size 2097152 crc 480d0259 sha1 bb7877309834441fd03adb7fa65738e5d5b2d7ba flags verified ) + name "Ripjack (World) (GB Compatible) (Aftermarket) (Unl)" + description "Ripjack (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Ripjack (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 218b54ec sha1 624cb4afcabd03f4f2f4bea95f9998a6a04ae42b ) ) game ( - name "Wario Land II (USA, Europe) (SGB Enhanced) (GB Compatible)" - description "Wario Land II (USA, Europe) (SGB Enhanced) (GB Compatible)" - rom ( name "Wario Land II (USA, Europe) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 047bdf80 sha1 ae37915058035df4ceedd72d709f91efb4878eff flags verified ) + name "River Styx Round-Up (World) (GB Compatible) (Aftermarket) (Unl)" + description "River Styx Round-Up (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "River Styx Round-Up (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ae3f980b sha1 67f63517eacfea22922d07be0efc5fc8f8b8a1d2 ) ) game ( - name "Warlocked (USA)" - description "Warlocked (USA)" - rom ( name "Warlocked (USA).gbc" size 2097152 crc cfa0df0f sha1 2f9c05f74476368bd6dbba7d675e7870cf8ca27c flags verified ) + name "Robin to the Rescue (World) (Aftermarket) (Unl)" + description "Robin to the Rescue (World) (Aftermarket) (Unl)" + rom ( name "Robin to the Rescue (World) (Aftermarket) (Unl).gbc" size 262144 crc 9cd52c18 sha1 ef3bea9ed0de41e311b5f15fccbb0f451848d56c ) ) game ( - name "Warp Coin Catastrophe, The (World) (GB Compatible) (Aftermarket) (Unl)" - description "Warp Coin Catastrophe, The (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Warp Coin Catastrophe, The (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 1bfe1bf9 sha1 fae12dbbb75ae024e96a7ee21ad4077fdb5ed9a1 ) + name "Robo Knight (World) (Aftermarket) (Unl)" + description "Robo Knight (World) (Aftermarket) (Unl)" + rom ( name "Robo Knight (World) (Aftermarket) (Unl).gbc" size 524288 crc 8d4507f0 sha1 6012f9a3ae6201e363f46a75e0100552ecb91335 ) ) game ( - name "Warp Coin Catastrophe, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - description "Warp Coin Catastrophe, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Warp Coin Catastrophe, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc a381c914 sha1 adf37c5d2f706743b2a4946378df49ed19212039 ) + name "Rockets Vs Cars (World) (GB Compatible) (Aftermarket) (Unl)" + description "Rockets Vs Cars (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Rockets Vs Cars (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc eaae6f3e sha1 446e688f42e886c51c74719b93a326ae5b56920d ) ) game ( - name "Warp Coin Catastrophe, The (World) (v1.1.2) (GB Compatible) (Aftermarket) (Unl)" - description "Warp Coin Catastrophe, The (World) (v1.1.2) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Warp Coin Catastrophe, The (World) (v1.1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 5519c167 sha1 04a53af6a77b884af91f8047d70fc0331bf23913 ) + name "Rockman (World) (Aftermarket) (Unl)" + description "Rockman (World) (Aftermarket) (Unl)" + rom ( name "Rockman (World) (Aftermarket) (Unl).gbc" size 262144 crc 490b5676 sha1 6f78200acb6698e268e26c1912d64a002cbd3d89 ) ) game ( - name "Warriors of Might and Magic (USA) (En,Fr,De)" - description "Warriors of Might and Magic (USA) (En,Fr,De)" - rom ( name "Warriors of Might and Magic (USA) (En,Fr,De).gbc" size 1048576 crc ef9f5bea sha1 06163acad95d6ab87ffcd56f18b37c8c9e37a6ec ) + name "Rootin' Tootin' Cowboy Wizard Lizards (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Rootin' Tootin' Cowboy Wizard Lizards (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Rootin' Tootin' Cowboy Wizard Lizards (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 1fcdc59e sha1 e741ac0918ce14df473600d34836f744c2507fa0 ) ) game ( - name "Watashi no Kitchen (Japan)" - description "Watashi no Kitchen (Japan)" - rom ( name "Watashi no Kitchen (Japan).gbc" size 1048576 crc bc767b25 sha1 7aa55d3cdd7ab505c62f4e3654256391f3590bf6 ) + name "Ruby & Rusty Save the Crows (World) (Beta 1) (GB Compatible) (Aftermarket) (Unl)" + description "Ruby & Rusty Save the Crows (World) (Beta 1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Ruby & Rusty Save the Crows (World) (Beta 1) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc a46baa15 sha1 87dd5a6ccb5db59dae09f1953062420977ad2d92 ) ) game ( - name "Watashi no Kitchen (Japan) (Rev 1)" - description "Watashi no Kitchen (Japan) (Rev 1)" - rom ( name "Watashi no Kitchen (Japan) (Rev 1).gbc" size 1048576 crc 584669e4 sha1 effd0d198bac35abee1a8a6481382a1f2b14ead3 ) + name "Ruby & Rusty Save the Crows (World) (Beta 2) (GB Compatible) (Aftermarket) (Unl)" + description "Ruby & Rusty Save the Crows (World) (Beta 2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Ruby & Rusty Save the Crows (World) (Beta 2) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 5602ca84 sha1 49d692796a6d0f3dcfc988648b446c0934f0e794 ) ) game ( - name "Watashi no Restaurant (Japan)" - description "Watashi no Restaurant (Japan)" - rom ( name "Watashi no Restaurant (Japan).gbc" size 1048576 crc 395003ef sha1 d66f728006aaa37c2776b6ade7d1c8cdc2101a57 ) + name "Ruby & Rusty Save the Crows (World) (Beta 3) (GB Compatible) (Aftermarket) (Unl)" + description "Ruby & Rusty Save the Crows (World) (Beta 3) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Ruby & Rusty Save the Crows (World) (Beta 3) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc b2547aa6 sha1 981a464d6e1c9e5ac59549845b41dae4817ed3b8 ) ) game ( - name "Watashi no Restaurant (Japan) (Beta 1)" - description "Watashi no Restaurant (Japan) (Beta 1)" - rom ( name "Watashi no Restaurant (Japan) (Beta 1).gbc" size 1048576 crc 5ff6b852 sha1 384f1f68e7331f992f1d311f1433ea9f205eddcb ) + name "Ruby & Rusty Save the Crows (World) (v2.6) (GB Compatible) (Aftermarket) (Unl)" + description "Ruby & Rusty Save the Crows (World) (v2.6) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Ruby & Rusty Save the Crows (World) (v2.6) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c18f82cb sha1 bd8cd5822dcc61f7eb0cf2584c9a5b5a94bde14a ) ) game ( - name "Watashi no Restaurant (Japan) (Beta 2)" - description "Watashi no Restaurant (Japan) (Beta 2)" - rom ( name "Watashi no Restaurant (Japan) (Beta 2).gbc" size 1048576 crc 8571099f sha1 98ff6b68b7c79229100f58311ee41e3fec4802e0 ) + name "Ruin Run (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Ruin Run (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Ruin Run (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ddbfb0ce sha1 fb4730afe4e10529015513cc1dec8889c00cb373 ) ) game ( - name "Watashi no Restaurant (Japan) (Beta 3)" - description "Watashi no Restaurant (Japan) (Beta 3)" - rom ( name "Watashi no Restaurant (Japan) (Beta 3).gbc" size 1048576 crc a0ed2859 sha1 343bf8ebb6fa3ce89501f7c4c219fb7e864c38a3 ) + name "RunieStory (World) (GB Showdown) (Aftermarket) (Unl)" + description "RunieStory (World) (GB Showdown) (Aftermarket) (Unl)" + rom ( name "RunieStory (World) (GB Showdown) (Aftermarket) (Unl).gbc" size 2097152 crc 96b1ceec sha1 771135edfbc64f7332a9cbd0d72af7a9d0d71f82 ) ) game ( - name "Water Grandprix (World) (Aftermarket) (Unl)" - description "Water Grandprix (World) (Aftermarket) (Unl)" - rom ( name "Water Grandprix (World) (Aftermarket) (Unl).gbc" size 262144 crc 82f54e7e sha1 4029e003870b2afb78a3644e24397d80fc5a3210 ) + name "RunieStory (World) (Aftermarket) (Unl)" + description "RunieStory (World) (Aftermarket) (Unl)" + rom ( name "RunieStory (World) (Aftermarket) (Unl).gbc" size 2097152 crc 2249b449 sha1 0f6a391d7e05f66092a98e411069fab8e3f24221 ) ) game ( - name "Waternet (World) (GB Compatible) (Aftermarket) (Unl)" - description "Waternet (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Waternet (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc ef202121 sha1 a11f931b18ba42f48a91e817b7117fa0e3e79518 ) + name "RunieStory (World) (v1.1) (Aftermarket) (Unl)" + description "RunieStory (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "RunieStory (World) (v1.1) (Aftermarket) (Unl).gbc" size 2097152 crc dd81f722 sha1 f2ad05b15a4ed1611b0d5b52525d16a5f00867bc ) ) game ( - name "Waternet (World) (Batteryless Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl)" - description "Waternet (World) (Batteryless Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Waternet (World) (Batteryless Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 75591760 sha1 e04b01ada17e6924503029cd09a107b7f5d06f17 ) + name "RunieStory (World) (Aftermarket) (Unl) (Alt)" + description "RunieStory (World) (Aftermarket) (Unl) (Alt)" + rom ( name "RunieStory (World) (Aftermarket) (Unl) (Alt).gbc" size 2097152 crc 367c802d sha1 b9ec81a8c71ea13b553b478535071715a2ab07d9 ) ) game ( - name "Waternet (World) (Batteryless Generic Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl)" - description "Waternet (World) (Batteryless Generic Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Waternet (World) (Batteryless Generic Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc f8402dc5 sha1 6feb4178589e87c6267683078201f0630cca23d6 ) + name "Runner (World) (Aftermarket) (Unl)" + description "Runner (World) (Aftermarket) (Unl)" + rom ( name "Runner (World) (Aftermarket) (Unl).gbc" size 262144 crc 4cd8ccb2 sha1 da735d415ed463a953bac45f4793342bd9be2e96 ) ) game ( - name "WCW Mayhem (USA, Europe)" - description "WCW Mayhem (USA, Europe)" - rom ( name "WCW Mayhem (USA, Europe).gbc" size 1048576 crc 9f8620d1 sha1 ec4e5ab0b78b3a72778700907cccab6306bfd0ea ) + name "Sam the Optimistic Hedgehog (World) (2023-01-16) (GB Compatible) (Aftermarket) (Unl)" + description "Sam the Optimistic Hedgehog (World) (2023-01-16) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Sam the Optimistic Hedgehog (World) (2023-01-16) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 4e4af60b sha1 ab8d49a99d02eb5c97d75f62dfb3720eec2b5abd ) ) game ( - name "WDL - World Destruction League - Thunder Tanks (USA) (En,Fr,De)" - description "WDL - World Destruction League - Thunder Tanks (USA) (En,Fr,De)" - rom ( name "WDL - World Destruction League - Thunder Tanks (USA) (En,Fr,De).gbc" size 1048576 crc 1a0bf4d7 sha1 665d34621b4d51d4f1cee882a453f5e278e2b5da ) + name "Sam the Optimistic Hedgehog (World) (2023-01-21) (GB Compatible) (Aftermarket) (Unl)" + description "Sam the Optimistic Hedgehog (World) (2023-01-21) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Sam the Optimistic Hedgehog (World) (2023-01-21) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 40dc168d sha1 af25acc86f0eef4ce72199383b96fcb4c9f0115e ) ) game ( - name "WDL - World Destruction League - Thunder Tanks (USA) (Beta)" - description "WDL - World Destruction League - Thunder Tanks (USA) (Beta)" - rom ( name "WDL - World Destruction League - Thunder Tanks (USA) (Beta).gbc" size 1048576 crc 41df1c79 sha1 126b3626fb4752312834ac42bb5b873c22a3aea3 ) + name "Sapphire Hotel - The Little Tales of (World) (v1.2) (Demo) (MBC5) (GB Compatible) (Aftermarket) (Unl)" + description "Sapphire Hotel - The Little Tales of (World) (v1.2) (Demo) (MBC5) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Sapphire Hotel - The Little Tales of (World) (v1.2) (Demo) (MBC5) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc db928e22 sha1 e175d35e6112c347ecd1e0a379e98f430823ba94 ) ) game ( - name "Wendy - Der Traum von Arizona (Germany)" - description "Wendy - Der Traum von Arizona (Germany)" - rom ( name "Wendy - Der Traum von Arizona (Germany).gbc" size 2097152 crc df7c18bc sha1 21141e9e0302ead50456af7b55a1391679455662 ) + name "Sergio Kidd (World) (En,Es) (v2.013) (Aftermarket) (Unl)" + description "Sergio Kidd (World) (En,Es) (v2.013) (Aftermarket) (Unl)" + rom ( name "Sergio Kidd (World) (En,Es) (v2.013) (Aftermarket) (Unl).gbc" size 1048576 crc e23bc705 sha1 986708b9cb96c56e3592030d45dc5433d3aa63c5 ) ) game ( - name "Wendy - Der Traum von Arizona (Germany) (Beta)" - description "Wendy - Der Traum von Arizona (Germany) (Beta)" - rom ( name "Wendy - Der Traum von Arizona (Germany) (Beta).gbc" size 2097152 crc 20bdca55 sha1 fd39cb84f71ea414c0165a58bac98357739bc406 ) + name "Sergio Kidd (World) (En,Es) (v1.995) (Aftermarket) (Unl)" + description "Sergio Kidd (World) (En,Es) (v1.995) (Aftermarket) (Unl)" + rom ( name "Sergio Kidd (World) (En,Es) (v1.995) (Aftermarket) (Unl).gbc" size 1048576 crc 1d871322 sha1 e57357be09657bc42e5ccee937edcf1653468402 ) ) game ( - name "Wendy - Every Witch Way (USA, Europe)" - description "Wendy - Every Witch Way (USA, Europe)" - rom ( name "Wendy - Every Witch Way (USA, Europe).gbc" size 1048576 crc 4ac6907b sha1 8ca45ed882c23df714bda46b227a857deddc899f flags verified ) + name "Shark Attack (World) (Aftermarket) (Unl)" + description "Shark Attack (World) (Aftermarket) (Unl)" + rom ( name "Shark Attack (World) (Aftermarket) (Unl).gbc" size 262144 crc cf80a2ba sha1 291f453a185f836fcafbd7e41945a409638980c0 ) ) game ( - name "Wetrix (Europe) (En,Fr,De)" - description "Wetrix (Europe) (En,Fr,De)" - rom ( name "Wetrix (Europe) (En,Fr,De).gbc" size 1048576 crc 9cbfaa3d sha1 6de683dc99feaf7fb0440046668d36a229513ab5 ) + name "Shoot It (World) (Aftermarket) (Unl)" + description "Shoot It (World) (Aftermarket) (Unl)" + rom ( name "Shoot It (World) (Aftermarket) (Unl).gbc" size 262144 crc 54afa0ff sha1 f3c574e274d1531e3f53511da0d57751e989a665 ) ) game ( - name "Wetrix GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Wetrix GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Wetrix GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 6215c5b3 sha1 92944052b6e4448abf0103f085998662e0140825 ) + name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-09) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-09) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-09) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 599132ec sha1 762087df0e5820f1e50da2a22f9ee3b8d16c3e49 ) ) game ( - name "What Friends Are For (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" - description "What Friends Are For (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "What Friends Are For (World) (v2.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 776fc18e sha1 5c4a227c0b2f53e4a349e482c5ba87cb83404f8e ) + name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-04-16) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-04-16) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-04-16) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 5370b1bf sha1 966e2d79ab4930039c3d6c43fdbb8cdc068ba347 ) ) game ( - name "What's Updog (World) (2022-11-23) (GB Compatible) (Aftermarket) (Unl)" - description "What's Updog (World) (2022-11-23) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "What's Updog (World) (2022-11-23) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 2c3d5cbf sha1 a235c0915ac2b826eeb5884d0eccd321236fdb0c ) + name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-08-24) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-08-24) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-08-24) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 16f34bcc sha1 c34e744b9120e3a1b2b054d3708e4ab594726c5a ) ) game ( - name "Where's My Cake (World) (GB Compatible) (Aftermarket) (Unl)" - description "Where's My Cake (World) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Where's My Cake (World) (GB Compatible) (Aftermarket) (Unl).GBC" size 65536 crc 28114b89 sha1 05b90f0a7e92d42b3008c749d5edeab2a2eae973 ) + name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-09-13) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-09-13) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-09-13) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 31ce3f27 sha1 c33d685d5ea5cd6cd954af3bc9ee92719b9578b1 ) ) game ( - name "Who Wants to Be a Millionaire - 2nd Edition (USA)" - description "Who Wants to Be a Millionaire - 2nd Edition (USA)" - rom ( name "Who Wants to Be a Millionaire - 2nd Edition (USA).gbc" size 1048576 crc 6830b7af sha1 1fd2c608231e6f919fee05da91418e05c502ef61 ) + name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-11-07) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-11-07) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-11-07) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc d54b53cb sha1 08948befa0227b795d00fe60e9eede6a1f56597b ) ) game ( - name "Wild Thornberrys, The - Rambler (USA)" - description "Wild Thornberrys, The - Rambler (USA)" - rom ( name "Wild Thornberrys, The - Rambler (USA).gbc" size 1048576 crc 0e1465cb sha1 0e806f0e6c1a41e764683850a3c15a80ac7fc9a5 ) + name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-03) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-03) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Silent Hill 2 - 20th Anniversary Demake (World) (2021-12-03) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 314be6b5 sha1 37978f85ae92e7d9a53611659513fd360f57a5b1 ) ) game ( - name "Wing Warriors (World) (En,Fr,Es) (Beta) (GB Compatible) (Aftermarket) (Unl)" - description "Wing Warriors (World) (En,Fr,Es) (Beta) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Wing Warriors (World) (En,Fr,Es) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 04e04980 sha1 574cf911d6d8f73699203cd6db42ceec777f7f93 ) + name "Silent Hill 2 - Born From a Wish (World) (2023-10-03) (Demo) (Aftermarket) (Unl)" + description "Silent Hill 2 - Born From a Wish (World) (2023-10-03) (Demo) (Aftermarket) (Unl)" + rom ( name "Silent Hill 2 - Born From a Wish (World) (2023-10-03) (Demo) (Aftermarket) (Unl).gbc" size 524288 crc 7ebcdd4e sha1 b99f43719155cafbc3dbd7df0ade281c3c7ba171 ) ) game ( - name "Wing Warriors (World) (En,Fr,Es) (GB Compatible) (Aftermarket) (Unl)" - description "Wing Warriors (World) (En,Fr,Es) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Wing Warriors (World) (En,Fr,Es) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 7328cfb6 sha1 039874148f27ffe533de4ef086f29e724a3217a9 ) + name "Sir Knight (World) (Aftermarket) (Unl)" + description "Sir Knight (World) (Aftermarket) (Unl)" + rom ( name "Sir Knight (World) (Aftermarket) (Unl).gbc" size 262144 crc 8c31c136 sha1 d8be26e0688301a76def8f5fbc246a9c9005862e ) ) game ( - name "Wings of Fury (Europe) (En,Fr,De) (GB Compatible)" - description "Wings of Fury (Europe) (En,Fr,De) (GB Compatible)" - rom ( name "Wings of Fury (Europe) (En,Fr,De) (GB Compatible).gbc" size 1048576 crc 6d59104f sha1 d3f21ea1a1d83546dffcd63ec089cfac04212a03 ) + name "Skelby (World) (Aftermarket) (Unl)" + description "Skelby (World) (Aftermarket) (Unl)" + rom ( name "Skelby (World) (Aftermarket) (Unl).gbc" size 524288 crc 6ec6c18c sha1 887555aa7e2e61b68a21020237b7d508bb71aded ) ) game ( - name "Wings of Fury (USA) (GB Compatible)" - description "Wings of Fury (USA) (GB Compatible)" - rom ( name "Wings of Fury (USA) (GB Compatible).gbc" size 1048576 crc c94a413a sha1 ae217bd12f42ce6297282227b7e2d21e6337420c ) + name "Skull Nightmare (World) (Aftermarket) (Unl)" + description "Skull Nightmare (World) (Aftermarket) (Unl)" + rom ( name "Skull Nightmare (World) (Aftermarket) (Unl).gbc" size 131072 crc c36941d3 sha1 49f03694965f79688aef724308c83988e71fd374 ) ) game ( - name "Winnie the Pooh - Adventures in the 100 Acre Wood (Europe) (En,Fr,De,Es,It,Nl,Da)" - description "Winnie the Pooh - Adventures in the 100 Acre Wood (Europe) (En,Fr,De,Es,It,Nl,Da)" - rom ( name "Winnie the Pooh - Adventures in the 100 Acre Wood (Europe) (En,Fr,De,Es,It,Nl,Da).gbc" size 2097152 crc 1db0840c sha1 b97b33e7423a712b3f77a2bf9a419f78ec5d30be ) + name "Skycon (World) (Aftermarket) (Unl)" + description "Skycon (World) (Aftermarket) (Unl)" + rom ( name "Skycon (World) (Aftermarket) (Unl).gbc" size 524288 crc 195dbc30 sha1 df29ece6c5f5b14840663495230135dd79c5163a ) ) game ( - name "Winnie the Pooh - Adventures in the 100 Acre Wood (USA)" - description "Winnie the Pooh - Adventures in the 100 Acre Wood (USA)" - rom ( name "Winnie the Pooh - Adventures in the 100 Acre Wood (USA).gbc" size 2097152 crc 066a2196 sha1 5ff68bc5ec735d090b24aab79a787f77f26afb08 ) + name "Slime Dungeon (World) (GB Compatible) (Aftermarket) (Unl)" + description "Slime Dungeon (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Slime Dungeon (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 3967fb31 sha1 926e584b8952aba86761b430daedc5b91177e408 ) ) game ( - name "Wizard of Wor (World) (Aftermarket) (Unl)" - description "Wizard of Wor (World) (Aftermarket) (Unl)" - rom ( name "Wizard of Wor (World) (Aftermarket) (Unl).gbc" size 524288 crc 492a9529 sha1 a391646d259a39e7026574145e0a2bacf5f6937b ) + name "Slime's Adventure (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Slime's Adventure (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Slime's Adventure (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 61b14549 sha1 87b84c85bb32a1d0874053cdf749f8391a275324 ) ) game ( - name "Wizardry Empire (Japan)" - description "Wizardry Empire (Japan)" - rom ( name "Wizardry Empire (Japan).gbc" size 1048576 crc 7adc90e1 sha1 041c125115c83c6fef1b888761ba0b2b1f9bd291 ) + name "Sludge & Sorcery (World) (GB Compatible) (Aftermarket) (Unl)" + description "Sludge & Sorcery (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Sludge & Sorcery (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc c906c5af sha1 0e0d472b282e3ea590e0f126baf633ef0d9298fa ) ) game ( - name "Wizardry Empire (Japan) (Rev 1)" - description "Wizardry Empire (Japan) (Rev 1)" - rom ( name "Wizardry Empire (Japan) (Rev 1).gbc" size 1048576 crc fa82620f sha1 f5f4e8bead0fe45075141133a530a0eb116ea78c ) + name "Smickeonn - The Game 2 - Virtual Boy Edition (World) (Aftermarket) (Unl)" + description "Smickeonn - The Game 2 - Virtual Boy Edition (World) (Aftermarket) (Unl)" + rom ( name "Smickeonn - The Game 2 - Virtual Boy Edition (World) (Aftermarket) (Unl).gbc" size 1048576 crc 71ed0db8 sha1 e7b39b17e3e8e7ac1cf2e0b179e2c14874533835 ) ) game ( - name "Wizardry Empire - Fukkatsu no Tsue (Japan)" - description "Wizardry Empire - Fukkatsu no Tsue (Japan)" - rom ( name "Wizardry Empire - Fukkatsu no Tsue (Japan).gbc" size 1048576 crc 1a10552b sha1 07a197f0b5e2ab6379faa95eb1e7a519e1306e09 ) + name "Smickeonn - The Game Boy Adventure (World) (Aftermarket) (Unl)" + description "Smickeonn - The Game Boy Adventure (World) (Aftermarket) (Unl)" + rom ( name "Smickeonn - The Game Boy Adventure (World) (Aftermarket) (Unl).gbc" size 1048576 crc 96efbfb9 sha1 3900ab947af4c582cd34cec7f2977219115d65e4 ) ) game ( - name "Wizardry I - Proving Grounds of the Mad Overlord (Japan)" - description "Wizardry I - Proving Grounds of the Mad Overlord (Japan)" - rom ( name "Wizardry I - Proving Grounds of the Mad Overlord (Japan).gbc" size 1048576 crc a99a33dc sha1 ecc073882d09a90fa1f02448c9ae44d43c8b81dc ) + name "Smickeonn - The Game Deluxe (World) (GB Compatible) (Aftermarket) (Unl)" + description "Smickeonn - The Game Deluxe (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Smickeonn - The Game Deluxe (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 02bb005e sha1 0c1bf424968530a70ecbe382d002fc6bd629962c ) ) game ( - name "Wizardry II - Llylgamyn no Isan (Japan)" - description "Wizardry II - Llylgamyn no Isan (Japan)" - rom ( name "Wizardry II - Llylgamyn no Isan (Japan).gbc" size 1048576 crc dd727f1a sha1 2ebfcf6de50f1dea2b96730967b2351e5aa58be9 ) + name "Snail DX, The (World) (GB Compatible) (Aftermarket) (Unl)" + description "Snail DX, The (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Snail DX, The (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 1aecd096 sha1 8ce256d963a55badf71fd45047c173a74d76a92c ) ) game ( - name "Wizardry III - Diamond no Kishi (Japan)" - description "Wizardry III - Diamond no Kishi (Japan)" - rom ( name "Wizardry III - Diamond no Kishi (Japan).gbc" size 1048576 crc d44d3596 sha1 f850ddbbfc8a77d53948de805819b4457380b390 ) + name "Snail DX, The (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + description "Snail DX, The (World) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Snail DX, The (World) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 6cf39388 sha1 9cf5a1d3e8119303a1f4b04b8f4d8b683aee699e ) ) game ( - name "Woody Woodpecker (Europe) (En,Fr,De,Es,It)" - description "Woody Woodpecker (Europe) (En,Fr,De,Es,It)" - rom ( name "Woody Woodpecker (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc 2612f8c4 sha1 363111c56bd301a4a4f3b921b5d1ddc65b856699 ) + name "Snooze (World) (GB Compatible) (Aftermarket) (Unl)" + description "Snooze (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Snooze (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc b246095f sha1 b7fdcc006c9c06dd391ee26d44b278d9d3793f6d ) ) game ( - name "Woody Woodpecker (USA)" - description "Woody Woodpecker (USA)" - rom ( name "Woody Woodpecker (USA).gbc" size 1048576 crc bd2d1f8b sha1 09a6363d98f441b57adb725cabde7feff74466e3 ) + name "Sofia the Witch - Curse of the Monster Moon (World) (Demo) (Aftermarket) (Unl)" + description "Sofia the Witch - Curse of the Monster Moon (World) (Demo) (Aftermarket) (Unl)" + rom ( name "Sofia the Witch - Curse of the Monster Moon (World) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc 9e864f1c sha1 ce5dc23c04ff18dfac2367e53d241e81c4bbc3a3 ) ) -game ( - name "Woody Woodpecker no Go! Go! Racing (Japan)" - description "Woody Woodpecker no Go! Go! Racing (Japan)" - rom ( name "Woody Woodpecker no Go! Go! Racing (Japan).gbc" size 1048576 crc f59daa99 sha1 42d841bdead319aa43d6bc09d88b4c32b4304ced ) +game ( + name "Space Fleet (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Space Fleet (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Space Fleet (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc d9244730 sha1 6987a43315abca95b85d84c278a6b1ae5dea185a ) ) game ( - name "Woody Woodpecker Racing (Europe)" - description "Woody Woodpecker Racing (Europe)" - rom ( name "Woody Woodpecker Racing (Europe).gbc" size 1048576 crc b0f43498 sha1 47fbfbfb8af15ae388e8dbe2ac521960c2f835ae ) + name "Space War (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Space War (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Space War (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc c54f07e1 sha1 de6107573654309805bbb0ac86a748311ae70d4e ) ) game ( - name "Woody Woodpecker Racing (USA)" - description "Woody Woodpecker Racing (USA)" - rom ( name "Woody Woodpecker Racing (USA).gbc" size 1048576 crc 0424cf43 sha1 be98d0a54aedcf59cddc111c72db66105aea1375 ) + name "Spectipede (World) (Aftermarket) (Unl)" + description "Spectipede (World) (Aftermarket) (Unl)" + rom ( name "Spectipede (World) (Aftermarket) (Unl).gbc" size 262144 crc 9c33f76e sha1 834a450d9ceb78b9d89d551300d4d0ea08cd8a6a ) ) game ( - name "World Cup (World) (Aftermarket) (Unl)" - description "World Cup (World) (Aftermarket) (Unl)" - rom ( name "World Cup (World) (Aftermarket) (Unl).gbc" size 262144 crc 56b3ab5f sha1 075890510b3ef205ca50ebbbcf7c0a0c56032cb9 ) + name "Spiky Harold (World) (Aftermarket) (Unl)" + description "Spiky Harold (World) (Aftermarket) (Unl)" + rom ( name "Spiky Harold (World) (Aftermarket) (Unl).gbc" size 262144 crc 7e9eda35 sha1 486d294b8cf226876581d543e3a08018321bc402 ) ) game ( - name "World Soccer GB 2 (Japan) (SGB Enhanced) (GB Compatible)" - description "World Soccer GB 2 (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "World Soccer GB 2 (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc dd18db5f sha1 b58c969510aab4930a1846d857f58d57ed342592 ) + name "Star Hunt (World) (GB Compatible) (Aftermarket) (Unl)" + description "Star Hunt (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Star Hunt (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 29320841 sha1 890fda255106ea64bac4973e2e9f4b31bb925d35 ) ) game ( - name "World Soccer GB 2000 (Japan)" - description "World Soccer GB 2000 (Japan)" - rom ( name "World Soccer GB 2000 (Japan).gbc" size 2097152 crc 6775b29e sha1 22433fae69d7dd5b1ff351db579a1ee9e883f06f ) + name "StarFox - Grounded (World) (GB Compatible) (Aftermarket) (Unl)" + description "StarFox - Grounded (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "StarFox - Grounded (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 82658661 sha1 dd45b0e3f346ce33668d49092b29a44597686061 ) ) game ( - name "Worms Armageddon (Europe) (En,Fr,De,Es,It,Nl)" - description "Worms Armageddon (Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Worms Armageddon (Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc cb04f34d sha1 0bff9f46f2c455e98a5f0d9c0d560eda88d939de flags verified ) + name "Stars of Zureon (World) (Proto 2) (GB Compatible) (Aftermarket) (Unl)" + description "Stars of Zureon (World) (Proto 2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Stars of Zureon (World) (Proto 2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc ce90a95b sha1 75457c5affd0c126f2c916e857950b5cde46a95e ) ) game ( - name "Worms Armageddon (USA) (En,Fr,Es)" - description "Worms Armageddon (USA) (En,Fr,Es)" - rom ( name "Worms Armageddon (USA) (En,Fr,Es).gbc" size 1048576 crc e241edde sha1 ec587a3660298f95bf85f4471a626727b5fe6d7c ) + name "Stars of Zureon (World) (Proto 1) (GB Compatible) (Aftermarket) (Unl)" + description "Stars of Zureon (World) (Proto 1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Stars of Zureon (World) (Proto 1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc b3a04b44 sha1 b16f21b46dfe4e6ce0368e3c5a3fae397274ebbf ) ) game ( - name "Worms Armageddon (Europe) (Beta)" - description "Worms Armageddon (Europe) (Beta)" - rom ( name "Worms Armageddon (Europe) (Beta).gbc" size 1048576 crc 66fda365 sha1 b0b14b13ec7cffb04efbf0dcdd93a2eea679ea0c ) + name "Starseed (World) (GB Compatible) (Aftermarket) (Unl)" + description "Starseed (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Starseed (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc e21ff9e0 sha1 3479e222263814374a557870034bc215aea3408d ) ) game ( - name "WWF Attitude (USA, Europe)" - description "WWF Attitude (USA, Europe)" - rom ( name "WWF Attitude (USA, Europe).gbc" size 1048576 crc d5fdf68a sha1 d5c37eabe3311666123b22f44a973c06d96bfce0 ) + name "Starseed 2 (World) (GB Compatible) (Aftermarket) (Unl)" + description "Starseed 2 (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Starseed 2 (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc dd4528d2 sha1 43a02f79fd5da23cfeccc13aa5970265f428dddc ) ) game ( - name "WWF Betrayal (USA, Europe)" - description "WWF Betrayal (USA, Europe)" - rom ( name "WWF Betrayal (USA, Europe).gbc" size 1048576 crc 6c28bcb5 sha1 27773b6396ccb55051227ce7ce81d01c33ea75d1 ) + name "Stellar Wars (World) (Aftermarket) (Unl)" + description "Stellar Wars (World) (Aftermarket) (Unl)" + rom ( name "Stellar Wars (World) (Aftermarket) (Unl).gbc" size 262144 crc e0b96256 sha1 ba2d10a2a5f3f073aea11e26ae5c53c9cf7866f8 ) ) game ( - name "WWF WrestleMania 2000 (USA, Europe) (GB Compatible)" - description "WWF WrestleMania 2000 (USA, Europe) (GB Compatible)" - rom ( name "WWF WrestleMania 2000 (USA, Europe) (GB Compatible).gbc" size 1048576 crc fcba12ae sha1 ee9a375a16ca77883b7e30c92fc6beb8f772df5f flags verified ) + name "Stratacombo (World) (v1.2) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Stratacombo (World) (v1.2) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Stratacombo (World) (v1.2) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 43c70a69 sha1 9931a9e3a0e4a0edcd336acfb433713991a50ad2 ) ) game ( - name "X-Men - Mutant Academy (Japan)" - description "X-Men - Mutant Academy (Japan)" - rom ( name "X-Men - Mutant Academy (Japan).gbc" size 1048576 crc 8162adc1 sha1 3de082556a1ddd99149fa10ce4e219d64caf98f3 ) + name "Stratacombo (World) (v1.0) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "Stratacombo (World) (v1.0) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Stratacombo (World) (v1.0) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 06575da1 sha1 3c621c921d7995acb88754634328de8ec32b444b ) ) game ( - name "X-Men - Mutant Academy (USA, Europe)" - description "X-Men - Mutant Academy (USA, Europe)" - rom ( name "X-Men - Mutant Academy (USA, Europe).gbc" size 1048576 crc ec6278a3 sha1 6509f46a2f32df697d966bcafd72ec3d631a3ac5 flags verified ) + name "Stratagem Hero (World) (GB Compatible) (Aftermarket) (Unl)" + description "Stratagem Hero (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Stratagem Hero (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc ff118db9 sha1 f89ff66e8e593729ed9605b0107ed6d12d9b858d ) ) game ( - name "X-Men - Mutant Academy (USA, Europe) (Rev 1)" - description "X-Men - Mutant Academy (USA, Europe) (Rev 1)" - rom ( name "X-Men - Mutant Academy (USA, Europe) (Rev 1).gbc" size 1048576 crc 234e1e9c sha1 167770befb087c0f95cfe3c3efa3540c5f55a799 flags verified ) + name "Suicide Run (World) (GB Compatible) (Aftermarket) (Unl)" + description "Suicide Run (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Suicide Run (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 2dc3fdae sha1 a551d904c4af661bd4b6e88063cb5541900117b0 ) ) game ( - name "X-Men - Mutant Wars (USA, Europe)" - description "X-Men - Mutant Wars (USA, Europe)" - rom ( name "X-Men - Mutant Wars (USA, Europe).gbc" size 1048576 crc 921999e2 sha1 0adaeef76db5a6df2786a45231e0934840f6eb44 ) + name "Suicide Run (World) (Aftermarket) (Unl)" + description "Suicide Run (World) (Aftermarket) (Unl)" + rom ( name "Suicide Run (World) (Aftermarket) (Unl).gbc" size 262144 crc d29ab1aa sha1 df373f58e51155e32fb81825a9082150f6d263c8 ) ) game ( - name "X-Men - Wolverine's Rage (Europe)" - description "X-Men - Wolverine's Rage (Europe)" - rom ( name "X-Men - Wolverine's Rage (Europe).gbc" size 1048576 crc 83ad5b99 sha1 6eeef0a72a453c26fa8c772c4036004986dc68f2 ) + name "Super Bunny Mission (World) (GB Compatible) (Aftermarket) (Unl)" + description "Super Bunny Mission (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Super Bunny Mission (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc c47330e2 sha1 6151286e93b2e2fb92f583371e650e36ab91aaf7 ) ) game ( - name "X-Men - Wolverine's Rage (USA)" - description "X-Men - Wolverine's Rage (USA)" - rom ( name "X-Men - Wolverine's Rage (USA).gbc" size 1048576 crc 12fc1a6e sha1 b7143367d71932ad525c5db94f5295686e6c58e5 ) + name "Super Gran (World) (Aftermarket) (Unl)" + description "Super Gran (World) (Aftermarket) (Unl)" + rom ( name "Super Gran (World) (Aftermarket) (Unl).gbc" size 262144 crc 98ee2e8a sha1 5afe9c7ab1b9d86048a570e7a37a0c244cb84e43 ) ) game ( - name "Xena - Warrior Princess (USA, Europe) (En,Fr,De,Es,It,Nl)" - description "Xena - Warrior Princess (USA, Europe) (En,Fr,De,Es,It,Nl)" - rom ( name "Xena - Warrior Princess (USA, Europe) (En,Fr,De,Es,It,Nl).gbc" size 1048576 crc f0de3ce7 sha1 1de53d445d898aa25b0472c604d5cfb052812070 ) + name "Super Impostor Bros. (World) (GB Compatible) (Aftermarket) (Unl)" + description "Super Impostor Bros. (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Super Impostor Bros. (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc a38d702f sha1 301f93da4e5b0cd8dc3f1bf3e66e38176b8a909b ) ) game ( - name "Xian Dan Chaoren - Ultraman (Taiwan) (Unl)" - description "Xian Dan Chaoren - Ultraman (Taiwan) (Unl)" - rom ( name "Xian Dan Chaoren - Ultraman (Taiwan) (Unl).gbc" size 2097152 crc e81701e8 sha1 2a96a6f2164d80aa81eebdebc0d8f2ff45c3180f ) + name "Super Jacked Up Tomato Face Johnson (World) (v2.2) (Aftermarket) (Unl)" + description "Super Jacked Up Tomato Face Johnson (World) (v2.2) (Aftermarket) (Unl)" + rom ( name "Super Jacked Up Tomato Face Johnson (World) (v2.2) (Aftermarket) (Unl).gbc" size 524288 crc 8e1f6bb0 sha1 27522a35211b0f015fa9550c2520f1da1c346886 ) ) game ( - name "Xiao Taiji - Shenhua Lixian (Taiwan) (Unl)" - description "Xiao Taiji - Shenhua Lixian (Taiwan) (Unl)" - rom ( name "Xiao Taiji - Shenhua Lixian (Taiwan) (Unl).gbc" size 2097152 crc 322c3816 sha1 c89f8d19a52ab5f183a03d65680bf80d1af4a0ee ) + name "Super Jacked Up Tomato Face Johnson (World) (v2.3) (Aftermarket) (Unl)" + description "Super Jacked Up Tomato Face Johnson (World) (v2.3) (Aftermarket) (Unl)" + rom ( name "Super Jacked Up Tomato Face Johnson (World) (v2.3) (Aftermarket) (Unl).gbc" size 524288 crc f9731ee2 sha1 23855b95d04a6c7c6d2ce7977bb31dbe6c0e68a0 ) ) game ( - name "Xin Fengkuang A Gei Pao Pao Tang (Taiwan) (Unl)" - description "Xin Fengkuang A Gei Pao Pao Tang (Taiwan) (Unl)" - rom ( name "Xin Fengkuang A Gei Pao Pao Tang (Taiwan) (Unl).gbc" size 2097152 crc e40f757f sha1 6d1332456e10e9da78726415640117262fe53e99 ) + name "Super Jacked Up Tomato Face Johnson (World) (Jam Version) (Aftermarket) (Unl)" + description "Super Jacked Up Tomato Face Johnson (World) (Jam Version) (Aftermarket) (Unl)" + rom ( name "Super Jacked Up Tomato Face Johnson (World) (Jam Version) (Aftermarket) (Unl).gbc" size 524288 crc 87956ddf sha1 b23320d5d3fde2a55b301f7bea324833c31c32d5 ) ) game ( - name "Xin Fengshenbang (Taiwan) (Unl)" - description "Xin Fengshenbang (Taiwan) (Unl)" - rom ( name "Xin Fengshenbang (Taiwan) (Unl).gbc" size 2097152 crc cf8bd780 sha1 99344231bfe3f73dfb95766e0d02a43fbf2e4acc ) + name "Super JetPak DX (World) (GB Compatible) (Aftermarket) (Unl)" + description "Super JetPak DX (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Super JetPak DX (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 22def6f9 sha1 e7438db01fbbdeea2404dbf3d093370421ec4e1c flags verified ) ) game ( - name "Xin Guangming Yu Hei'an 2 - Zhushen de Yichan (Taiwan) (Unl)" - description "Xin Guangming Yu Hei'an 2 - Zhushen de Yichan (Taiwan) (Unl)" - rom ( name "Xin Guangming Yu Hei'an 2 - Zhushen de Yichan (Taiwan) (Unl).gbc" size 1048576 crc 0881ed84 sha1 c1985e8a7a241af5a35748528b3e6a9d49b788e7 ) + name "Swordbird Song - The Iron Owl Tower (World) (v3.1) (GB Compatible) (Aftermarket) (Unl)" + description "Swordbird Song - The Iron Owl Tower (World) (v3.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Swordbird Song - The Iron Owl Tower (World) (v3.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 64921bb1 sha1 b36ec89e0299c19767cc5c6467fa3664abbc3017 ) ) game ( - name "Xin Shediao Yingxiong Chuan (Taiwan) (Unl)" - description "Xin Shediao Yingxiong Chuan (Taiwan) (Unl)" - rom ( name "Xin Shediao Yingxiong Chuan (Taiwan) (Unl).gbc" size 1048576 crc 20e40d8f sha1 a11aa648810f3e69d3678d2c53137575bfbd34d6 ) + name "Swordbird Song - The Iron Owl Tower (World) (v3.0) (GB Compatible) (Aftermarket) (Unl)" + description "Swordbird Song - The Iron Owl Tower (World) (v3.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Swordbird Song - The Iron Owl Tower (World) (v3.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc b2b5dc4b sha1 aaa66863b2e68865359d1c0db2047bab6f64f9ee ) ) game ( - name "Xin Shiqi Shidai (Taiwan) (Unl)" - description "Xin Shiqi Shidai (Taiwan) (Unl)" - rom ( name "Xin Shiqi Shidai (Taiwan) (Unl).gbc" size 2097152 crc f55342ca sha1 d51300e59c67f88dd2281ca53ae7c035489a723c ) + name "Swordsman on the Eternal Journey (World) (En,Ja) (v1.01) (GB Compatible) (Aftermarket) (Unl)" + description "Swordsman on the Eternal Journey (World) (En,Ja) (v1.01) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Swordsman on the Eternal Journey (World) (En,Ja) (v1.01) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc f2762fb0 sha1 b4d33ac2e410a55d27edb2abe6fc2268ca18ae26 ) ) game ( - name "Xingqiu Dazhan II - Kelong Ren Zhanyi (Taiwan) (Unl)" - description "Xingqiu Dazhan II - Kelong Ren Zhanyi (Taiwan) (Unl)" - rom ( name "Xingqiu Dazhan II - Kelong Ren Zhanyi (Taiwan) (Unl).gbc" size 2097152 crc 6df86db6 sha1 b6089f2d1064d1851a89ffb20f8e2f8aeb5fe732 ) + name "Swordsman on the Eternal Journey (World) (En,Ja) (v1.00) (GB Compatible) (Aftermarket) (Unl)" + description "Swordsman on the Eternal Journey (World) (En,Ja) (v1.00) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Swordsman on the Eternal Journey (World) (En,Ja) (v1.00) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc bc3a78de sha1 54f9f0caa96edac7d336d85548e099a4e5110bdd ) ) game ( - name "Xintiao Huiyi (Taiwan) (Unl)" - description "Xintiao Huiyi (Taiwan) (Unl)" - rom ( name "Xintiao Huiyi (Taiwan) (Unl).gbc" size 4194304 crc 104968e7 sha1 86e2b619976d22818e4a7c23d7f8a97e9358e51e ) + name "Swordsman on the Eternal Journey (World) (It) (v1.01) (GB Compatible) (Aftermarket) (Unl)" + description "Swordsman on the Eternal Journey (World) (It) (v1.01) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Swordsman on the Eternal Journey (World) (It) (v1.01) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 4a733a47 sha1 a45a31e6491a5d8a9288dc64823d7266060681b3 ) ) game ( - name "Xiyou Ji (Taiwan) (Unl)" - description "Xiyou Ji (Taiwan) (Unl)" - rom ( name "Xiyou Ji (Taiwan) (Unl).gbc" size 524288 crc f2fc4884 sha1 1f1bb35c47b8bd51edf9511513bb5e5e5e07eec1 ) + name "Take Your Medicine (World) (En,Pt) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Take Your Medicine (World) (En,Pt) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Take Your Medicine (World) (En,Pt) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 31a6b0ff sha1 baa07cfb71e42487eb57490c5b6cdec72e6893f7 ) ) game ( - name "Xploder GB (Germany) (v1.2.2G) (GB Compatible) (Unl)" - description "Xploder GB (Germany) (v1.2.2G) (GB Compatible) (Unl)" - rom ( name "Xploder GB (Germany) (v1.2.2G) (GB Compatible) (Unl).gbc" size 131072 crc 7c69b507 sha1 44c1cf6f27239df825190f2ace803a9808534306 ) + name "Take Your Medicine (World) (En,Pt) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + description "Take Your Medicine (World) (En,Pt) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Take Your Medicine (World) (En,Pt) (v1.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 255f67de sha1 8c973fafc9576e57a7714bda6425d30cdf7edd2c ) ) game ( - name "Xploder GB (Europe) (v1.2.3E) (GB Compatible) (Unl)" - description "Xploder GB (Europe) (v1.2.3E) (GB Compatible) (Unl)" - rom ( name "Xploder GB (Europe) (v1.2.3E) (GB Compatible) (Unl).gbc" size 131072 crc 440bee17 sha1 80d46f4b105ec7b6ee7b062736d1d91db0f9575a ) + name "Tales of Monsterland (World) (v2.83) (GB Compatible) (Aftermarket) (Unl)" + description "Tales of Monsterland (World) (v2.83) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Tales of Monsterland (World) (v2.83) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc a685f89a sha1 15a709d4300464b03ede4d774ce69cfb699c0fcf ) ) game ( - name "Xtreme Sports (USA)" - description "Xtreme Sports (USA)" - rom ( name "Xtreme Sports (USA).gbc" size 4194304 crc 19828751 sha1 ffca13207e6284a3cc16f7f130b68fca87663d08 ) + name "Tamarindo's Freaking Dinner DX (World) (Aftermarket) (Unl)" + description "Tamarindo's Freaking Dinner DX (World) (Aftermarket) (Unl)" + rom ( name "Tamarindo's Freaking Dinner DX (World) (Aftermarket) (Unl).gbc" size 262144 crc 257d9201 sha1 d78e0b03a3915531e780057c4ad7ed2b3f849825 ) ) game ( - name "Xtreme Sports (World) (Switch)" - description "Xtreme Sports (World) (Switch)" - rom ( name "Xtreme Sports (World) (Switch).gbc" size 4194304 crc c0437e08 sha1 5da3ad1c5354f29a74c571c2b598da96213afbe1 flags verified ) + name "Tank Attack (World) (Aftermarket) (Unl)" + description "Tank Attack (World) (Aftermarket) (Unl)" + rom ( name "Tank Attack (World) (Aftermarket) (Unl).gbc" size 262144 crc c77dc518 sha1 4751a6999f4dbe7e66b997372588f6bd15e4d9d0 ) ) game ( - name "Xtreme Wheels (Europe)" - description "Xtreme Wheels (Europe)" - rom ( name "Xtreme Wheels (Europe).gbc" size 1048576 crc e101246f sha1 7c1b43ac8f1e136b159f957613c1d4cda8a9360a ) + name "Tazz (World) (2022-10-13) (Aftermarket) (Unl)" + description "Tazz (World) (2022-10-13) (Aftermarket) (Unl)" + rom ( name "Tazz (World) (2022-10-13) (Aftermarket) (Unl).gbc" size 262144 crc 1d97b754 sha1 39226ed715ae8d94f9187c3e5e8a849eac92ca26 ) ) game ( - name "Xtreme Wheels (USA)" - description "Xtreme Wheels (USA)" - rom ( name "Xtreme Wheels (USA).gbc" size 1048576 crc 129465db sha1 07c1dc116c369b3ff73588251e0d09d50d040474 ) + name "Tazz (World) (2022-10-17) (Aftermarket) (Unl)" + description "Tazz (World) (2022-10-17) (Aftermarket) (Unl)" + rom ( name "Tazz (World) (2022-10-17) (Aftermarket) (Unl).gbc" size 262144 crc 6fb0ba23 sha1 543118e54b166ea2b8b5979f8468cc2f5662161f ) ) game ( - name "Xtreme Wheels (Japan) (Possible Proto) (NP)" - description "Xtreme Wheels (Japan) (Possible Proto) (NP)" - rom ( name "Xtreme Wheels (Japan) (Possible Proto) (NP).gbc" size 1048576 crc 30132ab8 sha1 a9f67640d20771e64b1474144fcca9beebdde85d ) + name "Tiledentity (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Tiledentity (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Tiledentity (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 678383d3 sha1 a97c2b31ce138e81e0bfabee89aa58426d41e0a9 ) ) game ( - name "Xzap (World) (Aftermarket) (Unl)" - description "Xzap (World) (Aftermarket) (Unl)" - rom ( name "Xzap (World) (Aftermarket) (Unl).gbc" size 262144 crc 68ceec9c sha1 35ae73d3ec93c95fdad9a358ccc34bcfc12445b1 ) + name "Tiledentity (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + description "Tiledentity (World) (v1.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Tiledentity (World) (v1.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc a9a24479 sha1 59b1d66807141ca42809189544e1104bd8d0454b ) ) game ( - name "Yakouchuu GB (Japan)" - description "Yakouchuu GB (Japan)" - rom ( name "Yakouchuu GB (Japan).gbc" size 2097152 crc e0a06018 sha1 a7efd41d0ad17892132788bd90cdfb9df6806a78 ) + name "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.4) (GB Compatible) (Aftermarket) (Unl)" + description "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.4) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.4) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc af13e718 sha1 307e51664db2101755b6c617f3d81ee58676c485 ) ) game ( - name "Yars' Revenge (USA, Europe) (GB Compatible)" - description "Yars' Revenge (USA, Europe) (GB Compatible)" - rom ( name "Yars' Revenge (USA, Europe) (GB Compatible).gbc" size 1048576 crc d6a26444 sha1 45fb176d539ae4a65af1f6340a9bd398dd7956d2 ) + name "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + description "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Tiny Grasshopper Goes Away (World) (En,Hu) (v1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 0518f5aa sha1 85e5cd0cf7a6cc4a5946c93fa8665235a686e554 ) ) game ( - name "Year After, The (World) (En,Fr,Pt) (GB Compatible) (Aftermarket) (Unl)" - description "Year After, The (World) (En,Fr,Pt) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Year After, The (World) (En,Fr,Pt) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc b304833d sha1 c2be46b8230bfcf509d031902c9bf144de97ef58 ) + name "Tir Na Nog (World) (Aftermarket) (Unl)" + description "Tir Na Nog (World) (Aftermarket) (Unl)" + rom ( name "Tir Na Nog (World) (Aftermarket) (Unl).gbc" size 1048576 crc 44524c90 sha1 ac712228460e9d4268f90ec4cf9ac2137fa667c4 ) ) game ( - name "Year After, The (World) (En) (Beta) (GB Compatible) (Aftermarket) (Unl)" - description "Year After, The (World) (En) (Beta) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Year After, The (World) (En) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc f15351c8 sha1 a78ff2eef780287bbdc37df122cfc1c504526662 ) + name "To The Stars (World) (GB Compatible) (Aftermarket) (Unl)" + description "To The Stars (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "To The Stars (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 2e1ca159 sha1 fb8269ff0377ac755b95e8e1ed935ad00d4476ee ) ) game ( - name "Year After, The (World) (Pt) (Beta) (GB Compatible) (Aftermarket) (Unl)" - description "Year After, The (World) (Pt) (Beta) (GB Compatible) (Aftermarket) (Unl)" - rom ( name "Year After, The (World) (Pt) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc b70c1c7f sha1 ce25cdf6a6264586423e76e34dc42779d39a1cb1 ) + name "Tobu Tobu Girl Deluxe (World) (GB Compatible) (Aftermarket) (Unl)" + description "Tobu Tobu Girl Deluxe (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Tobu Tobu Girl Deluxe (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 16650a8b sha1 fe6eef70d48dda741f7ad3b6cc5e753e8cd13239 ) ) game ( - name "Yin Ban Zhongwen RPG Zhanlve + Dongzuo + Yizhi 12 in 1 (Taiwan) (Unl)" - description "Yin Ban Zhongwen RPG Zhanlve + Dongzuo + Yizhi 12 in 1 (Taiwan) (Unl)" - rom ( name "Yin Ban Zhongwen RPG Zhanlve + Dongzuo + Yizhi 12 in 1 (Taiwan) (Unl).gbc" size 8388608 crc dc3171ad sha1 bfb93e7b4b523ef21c2b98ba9dcb15eb7d4f07e4 ) + name "Tomte Trouble (World) (Aftermarket) (Unl)" + description "Tomte Trouble (World) (Aftermarket) (Unl)" + rom ( name "Tomte Trouble (World) (Aftermarket) (Unl).gbc" size 262144 crc a43d6b82 sha1 99730fe00703d655b1c806f49c9e3c2fb3dec58e flags verified ) ) game ( - name "Yinghan Zidian (Taiwan) (Unl)" - description "Yinghan Zidian (Taiwan) (Unl)" - rom ( name "Yinghan Zidian (Taiwan) (Unl).gbc" size 1048576 crc 87158db6 sha1 5d42f3b769176df569a99c167c67e685c70501e1 ) + name "Tools of Nexaura (World) (v0.4) (Demo) (SGB Enhanced) (GB Compatible) (Aftermarket) (Unl)" + description "Tools of Nexaura (World) (v0.4) (Demo) (SGB Enhanced) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Tools of Nexaura (World) (v0.4) (Demo) (SGB Enhanced) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 50707e43 sha1 4a50327514554f075178f4d6342a4497d3122f31 ) ) game ( - name "Yingxiong Jian 2 (Taiwan) (Unl)" - description "Yingxiong Jian 2 (Taiwan) (Unl)" - rom ( name "Yingxiong Jian 2 (Taiwan) (Unl).gbc" size 2097152 crc 786eb7a4 sha1 3920e7d5a900981d6877ef99b5f3bed8a061c31f ) + name "Tower of Evil (World) (Aftermarket) (Unl)" + description "Tower of Evil (World) (Aftermarket) (Unl)" + rom ( name "Tower of Evil (World) (Aftermarket) (Unl).gbc" size 524288 crc aeb6e36f sha1 e9a6a007e935afb522c67d355e0354b0fb9af3c6 ) ) game ( - name "Yingxiong Tianxia (Taiwan) (Zh) (Unl)" - description "Yingxiong Tianxia (Taiwan) (Zh) (Unl)" - rom ( name "Yingxiong Tianxia (Taiwan) (Zh) (Unl).gbc" size 2097152 crc 5f2d6317 sha1 41f5f0c11e4e99b7d2d1433b09922a0fd2c48d7f ) + name "Traumatarium (World) (Demo) (2023-06-01) (GB Compatible) (Aftermarket) (Unl)" + description "Traumatarium (World) (Demo) (2023-06-01) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Traumatarium (World) (Demo) (2023-06-01) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc b0a32d51 sha1 4c0d639722d1cd8393e008d174b8f7266d089ead ) ) game ( - name "Yinyang (Taiwan) (De) (Unl)" - description "Yinyang (Taiwan) (De) (Unl)" - rom ( name "Yinyang (Taiwan) (De) (Unl).gbc" size 2097152 crc 1dd042ab sha1 2da9f06d57dcd397d0333b5d85a26a593acea8b3 ) + name "Treasure Island Color (World) (Aftermarket) (Unl)" + description "Treasure Island Color (World) (Aftermarket) (Unl)" + rom ( name "Treasure Island Color (World) (Aftermarket) (Unl).gbc" size 262144 crc 4ab0eb5a sha1 3ebddd4e1f5b3a87726ef34a5b7d36de8c722f36 ) ) game ( - name "Yixing VS Tiexue Zhanshi (Taiwan) (Unl)" - description "Yixing VS Tiexue Zhanshi (Taiwan) (Unl)" - rom ( name "Yixing VS Tiexue Zhanshi (Taiwan) (Unl).gbc" size 2097152 crc 45b048ee sha1 5ab50c386a0d9644f0d0337b6a1db22f5cb6ceb9 ) + name "Tristam Island (World) (v1.6) (GB Compatible) (Aftermarket) (Unl)" + description "Tristam Island (World) (v1.6) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Tristam Island (World) (v1.6) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc f6449829 sha1 5f1a11c4de8635fd5247ebb7f26273a40048567e flags verified ) ) game ( - name "Yogi Bear - Great Balloon Blast (USA)" - description "Yogi Bear - Great Balloon Blast (USA)" - rom ( name "Yogi Bear - Great Balloon Blast (USA).gbc" size 1048576 crc f817e978 sha1 ef3583e3b4092726d1875c4613f65c65fcbd26e6 ) + name "Trouble City - Pocket Mission (World) (GB Compatible) (Aftermarket) (Unl)" + description "Trouble City - Pocket Mission (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Trouble City - Pocket Mission (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 4b9143ad sha1 0e51e398d44aaad74a7c622f7818b56a3b34db56 ) ) game ( - name "Yongzhe Dou E Long VIII (Taiwan) (Unl)" - description "Yongzhe Dou E Long VIII (Taiwan) (Unl)" - rom ( name "Yongzhe Dou E Long VIII (Taiwan) (Unl).gbc" size 2097152 crc 8b8b84ec sha1 d71788eabb4d2535e31773338523a721e2784bb5 ) + name "Tutti Frutti (World) (Aftermarket) (Unl)" + description "Tutti Frutti (World) (Aftermarket) (Unl)" + rom ( name "Tutti Frutti (World) (Aftermarket) (Unl).gbc" size 262144 crc ca377ca6 sha1 53d97b93b9d190de40ed2d81e18b4cbe44f99a23 ) ) game ( - name "Yu-Gi-Oh! - Dark Duel Stories (Europe)" - description "Yu-Gi-Oh! - Dark Duel Stories (Europe)" - rom ( name "Yu-Gi-Oh! - Dark Duel Stories (Europe).gbc" size 4194304 crc 338e2cda sha1 86d3dfc1b852c34df1be90a24a41b5d4d5c4ca54 ) + name "TV-Chan's Great Escape! (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + description "TV-Chan's Great Escape! (World) (Proto) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "TV-Chan's Great Escape! (World) (Proto) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 01239312 sha1 4f21c3539ef40a7630581fe50533371e0d1a1ba9 ) ) game ( - name "Yu-Gi-Oh! - Dark Duel Stories (USA)" - description "Yu-Gi-Oh! - Dark Duel Stories (USA)" - rom ( name "Yu-Gi-Oh! - Dark Duel Stories (USA).gbc" size 4194304 crc 803a56ae sha1 1952d343bdfb5625bd23a8569cde6fd61a911502 flags verified ) + name "Tycoon Tex (World) (Aftermarket) (Unl)" + description "Tycoon Tex (World) (Aftermarket) (Unl)" + rom ( name "Tycoon Tex (World) (Aftermarket) (Unl).gbc" size 262144 crc fa8436ba sha1 d37bcd93d647ac7efb761c539785a4ef570cdcc8 ) ) game ( - name "Yu-Gi-Oh! - Dark Duel Stories (Europe) (Beta)" - description "Yu-Gi-Oh! - Dark Duel Stories (Europe) (Beta)" - rom ( name "Yu-Gi-Oh! - Dark Duel Stories (Europe) (Beta).gbc" size 4194304 crc 1a60f198 sha1 f16e2d8d2ce20149c208621c3aa1309f80ce2390 ) + name "Tynesoft Commodore 16 Classics (World) (Aftermarket) (Unl)" + description "Tynesoft Commodore 16 Classics (World) (Aftermarket) (Unl)" + rom ( name "Tynesoft Commodore 16 Classics (World) (Aftermarket) (Unl).gbc" size 2097152 crc 8067298a sha1 e44280161ca9d482fae08de844ccc9754abf68b0 ) ) game ( - name "Yu-Gi-Oh! - Das Dunkle Duell (Germany)" - description "Yu-Gi-Oh! - Das Dunkle Duell (Germany)" - rom ( name "Yu-Gi-Oh! - Das Dunkle Duell (Germany).gbc" size 4194304 crc 6ca75ba0 sha1 55391ae4c27efc4efe0a43bda8e791bbbb888dd8 flags verified ) + name "Tynesoft Commodore 16 Classics II (World) (Aftermarket) (Unl)" + description "Tynesoft Commodore 16 Classics II (World) (Aftermarket) (Unl)" + rom ( name "Tynesoft Commodore 16 Classics II (World) (Aftermarket) (Unl).gbc" size 1048576 crc 0ce45101 sha1 f61677146ef67b026c636742f0109b8c478d0942 ) ) game ( - name "Yu-Gi-Oh! - Duel des Tenebres (France)" - description "Yu-Gi-Oh! - Duel des Tenebres (France)" - rom ( name "Yu-Gi-Oh! - Duel des Tenebres (France).gbc" size 4194304 crc 5b72bab5 sha1 566e9c4a02efd2e15c8758d0a6aab4519b6af102 flags verified ) + name "Tyrannosaurus Tex (World) (Aftermarket) (Unl)" + description "Tyrannosaurus Tex (World) (Aftermarket) (Unl)" + rom ( name "Tyrannosaurus Tex (World) (Aftermarket) (Unl).gbc" size 2097152 crc e90504c1 sha1 7e41e92f92ff06101e48dee758420f1bd3959013 ) ) game ( - name "Yu-Gi-Oh! - Duel des Tenebres (France) (Beta)" - description "Yu-Gi-Oh! - Duel des Tenebres (France) (Beta)" - rom ( name "Yu-Gi-Oh! - Duel des Tenebres (France) (Beta).gbc" size 4194304 crc c0dd1b26 sha1 7b44bee756fa5c81e050438f81f97fe56884a45d ) + name "Unearthed (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" + description "Unearthed (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Unearthed (World) (v1.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc 29bb9238 sha1 39fbfb220e9be0120090f770249049b3f3583f64 ) ) game ( - name "Yu-Gi-Oh! - Duelo en las Tinieblas (Spain)" - description "Yu-Gi-Oh! - Duelo en las Tinieblas (Spain)" - rom ( name "Yu-Gi-Oh! - Duelo en las Tinieblas (Spain).gbc" size 4194304 crc dc160f10 sha1 73bc0b9ce57ac806bfefcd830c44eec42a3e7adf ) + name "Ungrateful Son, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Ungrateful Son, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Ungrateful Son, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 977b54f4 sha1 016dde406896d827dcad682d40b52d0e9eeefa88 ) ) game ( - name "Yu-Gi-Oh! - Monster Capsule GB (Japan) (SGB Enhanced) (GB Compatible)" - description "Yu-Gi-Oh! - Monster Capsule GB (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Yu-Gi-Oh! - Monster Capsule GB (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc 1371e872 sha1 4ed5607dd83ebe7975c492b08d36870f8dd6e302 ) + name "Unholy Friend (World) (GB Compatible) (Aftermarket) (Unl)" + description "Unholy Friend (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Unholy Friend (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 36e4ff4c sha1 b5c9b5f07e31729678637d883b2564c1448b0e57 ) ) game ( - name "Yu-Gi-Oh! - Racconti Oscuri (Italy)" - description "Yu-Gi-Oh! - Racconti Oscuri (Italy)" - rom ( name "Yu-Gi-Oh! - Racconti Oscuri (Italy).gbc" size 4194304 crc 8a6b0948 sha1 bf4d4e4450fbbc97efface042684341947e626a9 ) + name "Usurper Ghoul (World) (v1.9) (GB Compatible) (Aftermarket) (Unl)" + description "Usurper Ghoul (World) (v1.9) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Usurper Ghoul (World) (v1.9) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc fc94dbf3 sha1 5be7317929c81780f478f745111f8f45798da866 ) ) game ( - name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Jounouchi Deck (Japan)" - description "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Jounouchi Deck (Japan)" - rom ( name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Jounouchi Deck (Japan).gbc" size 4194304 crc 298bd054 sha1 2fdf56c2b52ba83fee778f3c2961a90ab69ea899 flags verified ) + name "UXB (World) (Aftermarket) (Unl)" + description "UXB (World) (Aftermarket) (Unl)" + rom ( name "UXB (World) (Aftermarket) (Unl).gbc" size 262144 crc dd42be4c sha1 6ef7abb689b1c75f613ed253644fbb0f377b7a95 ) ) game ( - name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Kaiba Deck (Japan)" - description "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Kaiba Deck (Japan)" - rom ( name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Kaiba Deck (Japan).gbc" size 4194304 crc a4d06001 sha1 ee769a23750e48c5ba4949f83236b18814316de2 flags verified ) + name "Varmit (World) (Aftermarket) (Unl)" + description "Varmit (World) (Aftermarket) (Unl)" + rom ( name "Varmit (World) (Aftermarket) (Unl).gbc" size 2097152 crc e4827006 sha1 b61876c714c47f62a77304b79f6e34b8d0e7f8a2 ) ) game ( - name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Yuugi Deck (Japan)" - description "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Yuugi Deck (Japan)" - rom ( name "Yu-Gi-Oh! Duel Monsters 4 - Battle of Great Duelist - Yuugi Deck (Japan).gbc" size 4194304 crc 4d6105f6 sha1 3199283039089fdf1e1b3cbb5b95fe7b26c6765f flags verified ) + name "Vixen (World) (Aftermarket) (Unl)" + description "Vixen (World) (Aftermarket) (Unl)" + rom ( name "Vixen (World) (Aftermarket) (Unl).gbc" size 524288 crc 0c347734 sha1 90f251f8f481f157de5b3efe3c8e3356ed1314b4 ) ) game ( - name "Yu-Gi-Oh! Duel Monsters II - Dark Duel Stories (Japan) (SGB Enhanced) (GB Compatible)" - description "Yu-Gi-Oh! Duel Monsters II - Dark Duel Stories (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Yu-Gi-Oh! Duel Monsters II - Dark Duel Stories (Japan) (SGB Enhanced) (GB Compatible).gbc" size 4194304 crc ba7182c3 sha1 6a96c30c1f9ecc207f962ec156f6d22a652ae41d flags verified ) + name "VOX (World) (Aftermarket) (Unl)" + description "VOX (World) (Aftermarket) (Unl)" + rom ( name "VOX (World) (Aftermarket) (Unl).gbc" size 262144 crc 346561fb sha1 54a03c77653a19eb1b0d8a6ac82f498f83f35ef2 ) ) game ( - name "Yu-Gi-Oh! Duel Monsters III - Tri Holy God Advant (Japan)" - description "Yu-Gi-Oh! Duel Monsters III - Tri Holy God Advant (Japan)" - rom ( name "Yu-Gi-Oh! Duel Monsters III - Tri Holy God Advant (Japan).gbc" size 4194304 crc 9f9dbab4 sha1 dc4753a2f12360d921a147287673b4448394a9d3 flags verified ) + name "Wacky Painter (World) (Aftermarket) (Unl)" + description "Wacky Painter (World) (Aftermarket) (Unl)" + rom ( name "Wacky Painter (World) (Aftermarket) (Unl).gbc" size 262144 crc 09daa18d sha1 5425dc675101d63bea03b1c8f46f86fe200ad392 ) ) game ( - name "Yuenan Zhanyi - Chong Jian Tian Ri (Taiwan) (Unl)" - description "Yuenan Zhanyi - Chong Jian Tian Ri (Taiwan) (Unl)" - rom ( name "Yuenan Zhanyi - Chong Jian Tian Ri (Taiwan) (Unl).gbc" size 2097152 crc c19b912a sha1 09b0f8fe8c7948e847ad01f24d05513c49b77ad5 ) + name "Walaki (World) (Hu) (Aftermarket) (Unl)" + description "Walaki (World) (Hu) (Aftermarket) (Unl)" + rom ( name "Walaki (World) (Hu) (Aftermarket) (Unl).gbc" size 262144 crc 254875ac sha1 388d6c339b8d62db18e540f59a2930af4088ca7e ) ) game ( - name "Yuenan Zhanyi 3 (Taiwan) (Unl)" - description "Yuenan Zhanyi 3 (Taiwan) (Unl)" - rom ( name "Yuenan Zhanyi 3 (Taiwan) (Unl).gbc" size 2097152 crc 9268bb9f sha1 17ceb35582c89303f206eb7e93cbfe8a4c2b5aaa ) + name "Warp Coin Catastrophe, The (World) (GB Compatible) (Aftermarket) (Unl)" + description "Warp Coin Catastrophe, The (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Warp Coin Catastrophe, The (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 1bfe1bf9 sha1 fae12dbbb75ae024e96a7ee21ad4077fdb5ed9a1 ) ) game ( - name "Yuenan Zhanyi X - Shenru Dihou (Taiwan) (Unl)" - description "Yuenan Zhanyi X - Shenru Dihou (Taiwan) (Unl)" - rom ( name "Yuenan Zhanyi X - Shenru Dihou (Taiwan) (Unl).gbc" size 2097152 crc 602951a6 sha1 6703e9f68b989c976e93bd2eb63f884ceaff63f1 ) + name "Warp Coin Catastrophe, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + description "Warp Coin Catastrophe, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Warp Coin Catastrophe, The (World) (v1.1) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc a381c914 sha1 adf37c5d2f706743b2a4946378df49ed19212039 ) ) game ( - name "Zagan Warrior (World) (Aftermarket) (Unl)" - description "Zagan Warrior (World) (Aftermarket) (Unl)" - rom ( name "Zagan Warrior (World) (Aftermarket) (Unl).gbc" size 262144 crc e770f71a sha1 99d9267946e7bf26942a8276863ba50ef0b8f90e ) + name "Warp Coin Catastrophe, The (World) (v1.1.2) (GB Compatible) (Aftermarket) (Unl)" + description "Warp Coin Catastrophe, The (World) (v1.1.2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Warp Coin Catastrophe, The (World) (v1.1.2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 5519c167 sha1 04a53af6a77b884af91f8047d70fc0331bf23913 ) ) game ( - name "Zap'em (World) (Aftermarket) (Unl)" - description "Zap'em (World) (Aftermarket) (Unl)" - rom ( name "Zap'em (World) (Aftermarket) (Unl).gbc" size 262144 crc 66f17c5e sha1 63d44c8c2492dc32bcf632feb2d994e9af25fc97 ) + name "Water Grandprix (World) (Aftermarket) (Unl)" + description "Water Grandprix (World) (Aftermarket) (Unl)" + rom ( name "Water Grandprix (World) (Aftermarket) (Unl).gbc" size 262144 crc 82f54e7e sha1 4029e003870b2afb78a3644e24397d80fc5a3210 ) ) game ( - name "Zebco Fishing! (USA) (Rumble Version)" - description "Zebco Fishing! (USA) (Rumble Version)" - rom ( name "Zebco Fishing! (USA) (Rumble Version).gbc" size 1048576 crc 3cc6b1f9 sha1 9b6c536b403c62af102e3800658c9dec258be249 ) + name "Waternet (World) (GB Compatible) (Aftermarket) (Unl)" + description "Waternet (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Waternet (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 32768 crc ef202121 sha1 a11f931b18ba42f48a91e817b7117fa0e3e79518 ) ) game ( - name "Zelda no Densetsu - Fushigi no Kinomi - Daichi no Shou (Japan)" - description "Zelda no Densetsu - Fushigi no Kinomi - Daichi no Shou (Japan)" - rom ( name "Zelda no Densetsu - Fushigi no Kinomi - Daichi no Shou (Japan).gbc" size 1048576 crc e42538f0 sha1 08bf49d7e225c695f64d38131cb720decb84b663 flags verified ) + name "Waternet (World) (Batteryless Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl)" + description "Waternet (World) (Batteryless Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Waternet (World) (Batteryless Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 75591760 sha1 e04b01ada17e6924503029cd09a107b7f5d06f17 ) ) game ( - name "Zelda no Densetsu - Fushigi no Kinomi - Jikuu no Shou (Japan)" - description "Zelda no Densetsu - Fushigi no Kinomi - Jikuu no Shou (Japan)" - rom ( name "Zelda no Densetsu - Fushigi no Kinomi - Jikuu no Shou (Japan).gbc" size 1048576 crc 3272e6f9 sha1 596aa066ccee9fae71643576f7526baa22d26d6d flags verified ) + name "Waternet (World) (Batteryless Generic Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl)" + description "Waternet (World) (Batteryless Generic Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Waternet (World) (Batteryless Generic Save Flash Cartridge Version) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc f8402dc5 sha1 6feb4178589e87c6267683078201f0630cca23d6 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (SGB Enhanced) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc d974abea sha1 b810925bf9d9f4f6cd97c5e46c94c1a9dd61a113 ) + name "Wayfarer Boo - Pushing Through (World) (v1.1) (Aftermarket) (Unl)" + description "Wayfarer Boo - Pushing Through (World) (v1.1) (Aftermarket) (Unl)" + rom ( name "Wayfarer Boo - Pushing Through (World) (v1.1) (Aftermarket) (Unl).gbc" size 262144 crc 903d1b1a sha1 12b8a0bdadd503f6114fcf28a43652d5d69749f4 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc bd8a1041 sha1 d3de302d44bdb240bcf55a5dc70f491f5456d721 flags verified ) + name "Wayfarer Boo - Pushing Through (World) (v1.0) (Aftermarket) (Unl)" + description "Wayfarer Boo - Pushing Through (World) (v1.0) (Aftermarket) (Unl)" + rom ( name "Wayfarer Boo - Pushing Through (World) (v1.0) (Aftermarket) (Unl).gbc" size 262144 crc b5d0ab10 sha1 7451a93a3a2f17b5187883ad2b59c4dda99a2ac7 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (SGB Enhanced) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (SGB Enhanced) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (SGB Enhanced) (GB Compatible).gbc" size 1048576 crc e998e595 sha1 5fdffae3caef63a9fb295bcbd38f923190254e01 flags verified ) + name "What Friends Are For (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" + description "What Friends Are For (World) (v2.0) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "What Friends Are For (World) (v2.0) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 776fc18e sha1 5c4a227c0b2f53e4a349e482c5ba87cb83404f8e ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-30) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-30) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-30) (GB Compatible).gbc" size 1048576 crc f46f0ced sha1 99d587b4baf363a798fdb8c1fca42fe1be061c2f ) + name "What's Updog (World) (2022-11-23) (GB Compatible) (Aftermarket) (Unl)" + description "What's Updog (World) (2022-11-23) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "What's Updog (World) (2022-11-23) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 2c3d5cbf sha1 a235c0915ac2b826eeb5884d0eccd321236fdb0c ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T180056) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T180056) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T180056) (GB Compatible).gbc" size 1048576 crc 11290c31 sha1 8d7ab85686ced1642b9519bcb6a3e157c6bd8938 ) + name "Where's My Cake (World) (GB Compatible) (Aftermarket) (Unl)" + description "Where's My Cake (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Where's My Cake (World) (GB Compatible) (Aftermarket) (Unl).GBC" size 65536 crc 28114b89 sha1 05b90f0a7e92d42b3008c749d5edeab2a2eae973 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T215532) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T215532) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-05T215532) (GB Compatible).gbc" size 1048576 crc 3c63e083 sha1 a068abd403a1dad70bd9b53d215995f8159aea47 ) + name "Who Dares Wins II (World) (Aftermarket) (Unl)" + description "Who Dares Wins II (World) (Aftermarket) (Unl)" + rom ( name "Who Dares Wins II (World) (Aftermarket) (Unl).gbc" size 262144 crc d12ea4bd sha1 cd91248bc0efd4fd3f182eda4559b1d6b720e3d9 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-07) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-07) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-07) (GB Compatible).gbc" size 1048576 crc 879cdf7d sha1 0b6f595e5f306099d5c1bd7aab1156c2a9c917a1 ) + name "Wicked Plague (World) (v0.1.2) (Proto) (Aftermarket) (Unl)" + description "Wicked Plague (World) (v0.1.2) (Proto) (Aftermarket) (Unl)" + rom ( name "Wicked Plague (World) (v0.1.2) (Proto) (Aftermarket) (Unl).gbc" size 524288 crc 80e43cec sha1 dee4f074029352efb3e6683e0c31c9350bdb8199 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T022124) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T022124) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T022124) (GB Compatible).gbc" size 1048576 crc 13c76902 sha1 08dea3565740a4b5bd5c13e82adb61e3d5669a31 ) + name "Wicked Plague (World) (v0.1.1) (Proto) (Aftermarket) (Unl)" + description "Wicked Plague (World) (v0.1.1) (Proto) (Aftermarket) (Unl)" + rom ( name "Wicked Plague (World) (v0.1.1) (Proto) (Aftermarket) (Unl).gbc" size 524288 crc 4029708f sha1 2279270c9a0d28934c5b5efda9c047ab27ffccb8 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-02) (SGB Enhanced)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-02) (SGB Enhanced)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-02) (SGB Enhanced).gbc" size 1048576 crc 34ff47ba sha1 5ccc4c05123b4c38d0d93916ae8a0c93fb63f23f ) + name "Wing Warriors (World) (En,Fr,Es) (Beta 2) (GB Compatible) (Aftermarket) (Unl)" + description "Wing Warriors (World) (En,Fr,Es) (Beta 2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Wing Warriors (World) (En,Fr,Es) (Beta 2) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 04e04980 sha1 574cf911d6d8f73699203cd6db42ceec777f7f93 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-03) (SGB Enhanced)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-03) (SGB Enhanced)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-03) (SGB Enhanced).gbc" size 1048576 crc ac0ef411 sha1 5aeb68b00a3a4f391afb324d9513311cb796a51f ) + name "Wing Warriors (World) (En,Fr,Es) (EGS) (GB Compatible) (Aftermarket) (Unl)" + description "Wing Warriors (World) (En,Fr,Es) (EGS) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Wing Warriors (World) (En,Fr,Es) (EGS) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 7328cfb6 sha1 039874148f27ffe533de4ef086f29e724a3217a9 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-04) (SGB Enhanced)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-04) (SGB Enhanced)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-04) (SGB Enhanced).gbc" size 1048576 crc 260bd98a sha1 ce1e48c82a09de0f93d5a60016318a9116331ccb ) + name "Wing Warriors (World) (En,Fr,Es) (Beta 1) (GB Compatible) (Aftermarket) (Unl)" + description "Wing Warriors (World) (En,Fr,Es) (Beta 1) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Wing Warriors (World) (En,Fr,Es) (Beta 1) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 6bc9de3d sha1 12d55dad39a9663083f9ad176563576a5cc44069 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-04) (SGB Enhanced).gbc" size 1048576 crc 883ef4ef sha1 87ca50396ba25914131866c74633afbe0007b2fb ) + name "Wing Warriors (World) (En,Fr,Es) (Kitmaker) (GB Compatible) (Aftermarket) (Unl)" + description "Wing Warriors (World) (En,Fr,Es) (Kitmaker) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Wing Warriors (World) (En,Fr,Es) (Kitmaker) (GB Compatible) (Aftermarket) (Unl).gbc" size 131072 crc 5179988b sha1 20e8daa159ceddace966afd3cd19eae71bb3bf6f ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced).gbc" size 1048576 crc 89a4a355 sha1 48931a00f5fec39492c264e9979646e88242c53e ) + name "Witches and Butchers (World) (Demo 2) (GB Compatible) (Aftermarket) (Unl)" + description "Witches and Butchers (World) (Demo 2) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Witches and Butchers (World) (Demo 2) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 321aecca sha1 90541cd5b08f6030b5b2fe4f1e0ac7c0b616e01e ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt).gbc" size 1048576 crc e5312966 sha1 fedd0fa70bbf5039dfec37b8e27674be839c47ca ) + name "Witches and Butchers (World) (Demo 4) (GB Compatible) (Aftermarket) (Unl)" + description "Witches and Butchers (World) (Demo 4) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Witches and Butchers (World) (Demo 4) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 9b53a90f sha1 77210d3c0825d913f4aebf09a10897a84ca23881 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt 2)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt 2)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-08-07) (SGB Enhanced) (Alt 2).gbc" size 1048576 crc 1c374afd sha1 800db3d07a7abcca2138a0c7808cf25386e87712 ) + name "Wizard of Wor (World) (Aftermarket) (Unl)" + description "Wizard of Wor (World) (Aftermarket) (Unl)" + rom ( name "Wizard of Wor (World) (Aftermarket) (Unl).gbc" size 524288 crc 492a9529 sha1 a391646d259a39e7026574145e0a2bacf5f6937b ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible).gbc" size 1048576 crc 3fd6c8fc sha1 017b81b26fc37db662063482e3947dfc2d814390 ) + name "Wolf Pack (World) (Aftermarket) (Unl)" + description "Wolf Pack (World) (Aftermarket) (Unl)" + rom ( name "Wolf Pack (World) (Aftermarket) (Unl).gbc" size 262144 crc ae35b80b sha1 56b20f0ab63a1459c1271e4cd062e8f92f7d10a4 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible) (Alt)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible) (Alt)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-06-15) (GB Compatible) (Alt).gbc" size 1048576 crc 9367653b sha1 544b803db49d8f312e193e4c105f0762d9e3fbf4 ) + name "World Cup (World) (Aftermarket) (Unl)" + description "World Cup (World) (Aftermarket) (Unl)" + rom ( name "World Cup (World) (Aftermarket) (Unl).gbc" size 262144 crc 56b3ab5f sha1 075890510b3ef205ca50ebbbcf7c0a0c56032cb9 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T181500) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T181500) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-07-14T181500) (GB Compatible).gbc" size 1048576 crc 2f884286 sha1 a7cb241de2139ddac5d1172a6ef1184b5fbb827e ) + name "Wrestling Thunder City (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Wrestling Thunder City (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Wrestling Thunder City (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc 4fc94f1c sha1 3c5e6ec96c1110ef9c21a8d92cc24c0c721fddd3 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-11-09) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-11-09) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Beta) (1998-11-09) (GB Compatible).gbc" size 1048576 crc 3e5216c3 sha1 0fe1c48e36cb8e6e975c5421bf881c550746d29c ) + name "Xzap (World) (Aftermarket) (Unl)" + description "Xzap (World) (Aftermarket) (Unl)" + rom ( name "Xzap (World) (Aftermarket) (Unl).gbc" size 262144 crc 68ceec9c sha1 35ae73d3ec93c95fdad9a358ccc34bcfc12445b1 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 1) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 1) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 1) (GB Compatible).gbc" size 1048576 crc e05757f6 sha1 ee2df3c8449187fcd82f2fc830386bfe8144b387 ) + name "Year After, The (World) (En,Fr,Pt) (GB Compatible) (Aftermarket) (Unl)" + description "Year After, The (World) (En,Fr,Pt) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Year After, The (World) (En,Fr,Pt) (GB Compatible) (Aftermarket) (Unl).gbc" size 2097152 crc b304833d sha1 c2be46b8230bfcf509d031902c9bf144de97ef58 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 2) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 2) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 1) (Demo) (Special Version 2) (GB Compatible).gbc" size 1048576 crc e6101132 sha1 515f8d2fcaebe9495fb21f46ec32cce877c35e56 ) + name "Year After, The (World) (En) (Beta) (GB Compatible) (Aftermarket) (Unl)" + description "Year After, The (World) (En) (Beta) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Year After, The (World) (En) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc f15351c8 sha1 a78ff2eef780287bbdc37df122cfc1c504526662 ) ) game ( - name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" - description "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible)" - rom ( name "Zelda no Densetsu - Yume o Miru Shima DX (Japan) (Rev 2) (Beta) (1999-09-22) (SGB Enhanced) (GB Compatible).gbc" size 1015808 crc c07979bf sha1 4a9ce5ced2234fa668dace888bd5d6130e375985 ) + name "Year After, The (World) (Pt) (Beta) (GB Compatible) (Aftermarket) (Unl)" + description "Year After, The (World) (Pt) (Beta) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Year After, The (World) (Pt) (Beta) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc b70c1c7f sha1 ce25cdf6a6264586423e76e34dc42779d39a1cb1 ) ) game ( - name "Zen-Nihon Shounen Soccer Taikai - Mezase Nihon Ichi! (Japan)" - description "Zen-Nihon Shounen Soccer Taikai - Mezase Nihon Ichi! (Japan)" - rom ( name "Zen-Nihon Shounen Soccer Taikai - Mezase Nihon Ichi! (Japan).gbc" size 2097152 crc efad8b34 sha1 bffe5fdb803f0872d1c0de9d152eb626c5b36147 ) + name "YiYa - The Digital Pet Game (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "YiYa - The Digital Pet Game (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "YiYa - The Digital Pet Game (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc b2c84c00 sha1 8bf1843102bc5a8577a8d0b44a16e46ade14bd16 ) ) game ( - name "Zephyr's Pass (World) (v1.02) (Demo) (Aftermarket) (Unl)" - description "Zephyr's Pass (World) (v1.02) (Demo) (Aftermarket) (Unl)" - rom ( name "Zephyr's Pass (World) (v1.02) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc db0951d3 sha1 7b74c658f24894659cfda1fc3c7775fd9f7b6013 ) + name "YiYa - The Digital Pet Game DX (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "YiYa - The Digital Pet Game DX (World) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "YiYa - The Digital Pet Game DX (World) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc 21e80905 sha1 b372eb9d049c962392868d7abfcb7b7e4ab2d40f ) ) game ( - name "Zhen Sanguo Wushuang 2 - Shin Sangokumusou (Taiwan) (Unl)" - description "Zhen Sanguo Wushuang 2 - Shin Sangokumusou (Taiwan) (Unl)" - rom ( name "Zhen Sanguo Wushuang 2 - Shin Sangokumusou (Taiwan) (Unl).gbc" size 2097152 crc 95c322c9 sha1 e6ab58d212de83cb18e9eadac4cee5d0f6e4e31f ) + name "Yurivania - Uhaul of the Night (World) (v1.5) (GB Compatible) (Aftermarket) (Unl)" + description "Yurivania - Uhaul of the Night (World) (v1.5) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Yurivania - Uhaul of the Night (World) (v1.5) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc c5447011 sha1 8197ed0ac5591893b7d04ed3f02529f120daab7e ) ) game ( - name "Zhihuan Wang - Shoubu Qu (Taiwan) (Zh) (Unl)" - description "Zhihuan Wang - Shoubu Qu (Taiwan) (Zh) (Unl)" - rom ( name "Zhihuan Wang - Shoubu Qu (Taiwan) (Zh) (Unl).gbc" size 2097152 crc 8160b3f5 sha1 97d7e0d05205b02c6cb69e68978a3f0fd2e3fde0 ) + name "Yurivania 0 - Soul Night Prelude (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" + description "Yurivania 0 - Soul Night Prelude (World) (v1.3) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Yurivania 0 - Soul Night Prelude (World) (v1.3) (GB Compatible) (Aftermarket) (Unl).gbc" size 262144 crc 8cdf4b90 sha1 9df6bf7c2babc47cc9e461d16a7ab1a24d898003 ) ) game ( - name "Zhizhu Xia III - Dianying Ban (Taiwan) (Unl)" - description "Zhizhu Xia III - Dianying Ban (Taiwan) (Unl)" - rom ( name "Zhizhu Xia III - Dianying Ban (Taiwan) (Unl).gbc" size 2097152 crc d311efcc sha1 9eb0c468d5f898ef7b4d6ff74d7ff497b8c7818d ) + name "Yurivania II - Josette's Quest (World) (v1.3) (Aftermarket) (Unl)" + description "Yurivania II - Josette's Quest (World) (v1.3) (Aftermarket) (Unl)" + rom ( name "Yurivania II - Josette's Quest (World) (v1.3) (Aftermarket) (Unl).gbc" size 1048576 crc b80d7525 sha1 05c7256bf9f12f60f453a0627d813904c8713378 ) ) game ( - name "Zidane - Football Generation (Europe) (En,Fr,De,Es,It)" - description "Zidane - Football Generation (Europe) (En,Fr,De,Es,It)" - rom ( name "Zidane - Football Generation (Europe) (En,Fr,De,Es,It).gbc" size 1048576 crc e96dbfb5 sha1 06385470bb0b4ef6c743ab6a5e7f8d7a97f6100b ) + name "Yurivania II - Josette's Quest (World) (v1.2) (Aftermarket) (Unl)" + description "Yurivania II - Josette's Quest (World) (v1.2) (Aftermarket) (Unl)" + rom ( name "Yurivania II - Josette's Quest (World) (v1.2) (Aftermarket) (Unl).gbc" size 1048576 crc c3a76413 sha1 6b6dac77795148d7eba6f7c8fa1c65a6d1e404c3 ) ) game ( - name "Zidane - Football Generation (Europe) (En,Fr,De,Es,It) (Beta)" - description "Zidane - Football Generation (Europe) (En,Fr,De,Es,It) (Beta)" - rom ( name "Zidane - Football Generation (Europe) (En,Fr,De,Es,It) (Beta).gbc" size 1048576 crc c2fde3c4 sha1 cba5d2fc5dbbe184e9ed58afe8525044bd8ea040 ) + name "Yurivania III - Circle of the Polycule (World) (v1.4) (Aftermarket) (Unl)" + description "Yurivania III - Circle of the Polycule (World) (v1.4) (Aftermarket) (Unl)" + rom ( name "Yurivania III - Circle of the Polycule (World) (v1.4) (Aftermarket) (Unl).gbc" size 2097152 crc 439b087f sha1 91178b5ba17e891060badf0c7681e6a76052de97 ) ) game ( - name "Zoboomafoo - Playtime in Zobooland (USA)" - description "Zoboomafoo - Playtime in Zobooland (USA)" - rom ( name "Zoboomafoo - Playtime in Zobooland (USA).gbc" size 1048576 crc 38d91885 sha1 a85a113bc266325f807f110daaf30feeea4b2738 ) + name "Zagan Warrior (World) (Aftermarket) (Unl)" + description "Zagan Warrior (World) (Aftermarket) (Unl)" + rom ( name "Zagan Warrior (World) (Aftermarket) (Unl).gbc" size 262144 crc e770f71a sha1 99d9267946e7bf26942a8276863ba50ef0b8f90e ) ) game ( - name "Zodiac (World) (Aftermarket) (Unl)" - description "Zodiac (World) (Aftermarket) (Unl)" - rom ( name "Zodiac (World) (Aftermarket) (Unl).gbc" size 262144 crc c4d86c05 sha1 73bd9e6e3bede8de489680ba84129e8fd17abbc0 ) + name "Zap'em (World) (Aftermarket) (Unl)" + description "Zap'em (World) (Aftermarket) (Unl)" + rom ( name "Zap'em (World) (Aftermarket) (Unl).gbc" size 262144 crc 66f17c5e sha1 63d44c8c2492dc32bcf632feb2d994e9af25fc97 ) ) game ( - name "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (SGB Enhanced) (GB Compatible)" - description "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (SGB Enhanced) (GB Compatible)" - rom ( name "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc f36c874d sha1 4ddb1d66d909d453374bd195a4a7dbe328ed41be ) + name "Zephyr's Pass (World) (v1.02) (Demo) (Aftermarket) (Unl)" + description "Zephyr's Pass (World) (v1.02) (Demo) (Aftermarket) (Unl)" + rom ( name "Zephyr's Pass (World) (v1.02) (Demo) (Aftermarket) (Unl).gbc" size 2097152 crc db0951d3 sha1 7b74c658f24894659cfda1fc3c7775fd9f7b6013 ) ) game ( - name "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - description "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible)" - rom ( name "Zoids - Jashin Fukkatsu! Genobreaker Hen (Japan) (Rev 1) (SGB Enhanced) (GB Compatible).gbc" size 2097152 crc 96461918 sha1 bfe8cdb8a8da37d5c8d9db57e8a5eeedee24d4cc flags verified ) + name "Zippy The Pinecone (World) (GB Compatible) (Aftermarket) (Unl)" + description "Zippy The Pinecone (World) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Zippy The Pinecone (World) (GB Compatible) (Aftermarket) (Unl).gbc" size 1048576 crc d1854d92 sha1 ba5f1a020f39ecd29669fc38ca4b23dd4f3dc061 ) ) game ( - name "Zoids - Shirogane no Juukishin Liger Zero (Japan)" - description "Zoids - Shirogane no Juukishin Liger Zero (Japan)" - rom ( name "Zoids - Shirogane no Juukishin Liger Zero (Japan).gbc" size 2097152 crc 530705a1 sha1 a5623ab4e026aa546b345f2bd5638cfdfed68c04 ) + name "Zippy The Pinecone (World) (v2.7) (Demo) (GB Compatible) (Aftermarket) (Unl)" + description "Zippy The Pinecone (World) (v2.7) (Demo) (GB Compatible) (Aftermarket) (Unl)" + rom ( name "Zippy The Pinecone (World) (v2.7) (Demo) (GB Compatible) (Aftermarket) (Unl).gbc" size 524288 crc fc555c4d sha1 ad3e95a917c4572c150b4b7cc49d17f1b20a0408 ) ) game ( - name "Zok Zok Heroes (Japan)" - description "Zok Zok Heroes (Japan)" - rom ( name "Zok Zok Heroes (Japan).gbc" size 2097152 crc c09f9e1b sha1 91ab908fddebd926e7db8d61295a40955b2adc39 ) + name "Zodiac (World) (Aftermarket) (Unl)" + description "Zodiac (World) (Aftermarket) (Unl)" + rom ( name "Zodiac (World) (Aftermarket) (Unl).gbc" size 262144 crc c4d86c05 sha1 73bd9e6e3bede8de489680ba84129e8fd17abbc0 ) ) game ( @@ -48040,8 +50693,8 @@ game ( ) game ( - name "Zook Z (USA) (Unl)" - description "Zook Z (USA) (Unl)" - rom ( name "Zook Z (USA) (Unl).gbc" size 1048576 crc a7b09e70 sha1 243cc40cfc6bcbd3b6106870773a72edff079904 ) + name "Zork + Harris (World) (v0.0.1.0) (Proto) (Aftermarket) (Unl)" + description "Zork + Harris (World) (v0.0.1.0) (Proto) (Aftermarket) (Unl)" + rom ( name "Zork + Harris (World) (v0.0.1.0) (Proto) (Aftermarket) (Unl).gbc" size 262144 crc 38282614 sha1 2507cfd5414c45b8a2f9839552d6115730da6bf8 ) ) From 8ab2681bca4052b9c53fb8d255e42d28a9095821 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 10 Aug 2024 21:23:00 -0700 Subject: [PATCH 171/338] Core: Expose more ROM information from the API --- CHANGES | 1 + include/mgba/core/core.h | 3 +- include/mgba/core/interface.h | 8 +++++ include/mgba/internal/gb/gb.h | 3 +- include/mgba/internal/gba/gba.h | 3 +- src/core/library.c | 7 +++-- src/core/scripting.c | 12 ++++---- src/gb/core.c | 11 ++----- src/gb/gb.c | 37 +++++++++-------------- src/gba/core.c | 11 ++----- src/gba/gba.c | 33 ++++++++++---------- src/platform/qt/BattleChipView.cpp | 13 ++++---- src/platform/qt/CoreController.cpp | 6 ++-- src/platform/qt/GBAOverride.cpp | 6 ++-- src/platform/qt/ROMInfo.cpp | 14 ++++----- src/platform/qt/ROMInfo.ui | 48 +++++++++++++++++++++++++----- src/platform/qt/ReportView.cpp | 15 +++++----- src/platform/test/perf-main.c | 7 ++--- 18 files changed, 129 insertions(+), 109 deletions(-) diff --git a/CHANGES b/CHANGES index 9af2528d96a..c2617c316c0 100644 --- a/CHANGES +++ b/CHANGES @@ -49,6 +49,7 @@ Misc: - Qt: Handle multiple save game files for disparate games separately (fixes mgba.io/i/2887) - Qt: Remove maligned double-click-to-fullscreen shortcut (closes mgba.io/i/2632) - Qt: Pass logging context through to video proxy thread (fixes mgba.io/i/3095) + - Qt: Show maker code and game version in ROM info - Scripting: Add `callbacks:oneshot` for single-call callbacks - Switch: Add bilinear filtering option (closes mgba.io/i/3111) - Vita: Add imc0 and xmc0 mount point support diff --git a/include/mgba/core/core.h b/include/mgba/core/core.h index 97f256c823a..18295ed1345 100644 --- a/include/mgba/core/core.h +++ b/include/mgba/core/core.h @@ -119,8 +119,7 @@ struct mCore { int32_t (*frameCycles)(const struct mCore*); int32_t (*frequency)(const struct mCore*); - void (*getGameTitle)(const struct mCore*, char* title); - void (*getGameCode)(const struct mCore*, char* title); + void (*getGameInfo)(const struct mCore*, struct mGameInfo* info); void (*setPeripheral)(struct mCore*, int type, void*); void* (*getPeripheral)(struct mCore*, int type); diff --git a/include/mgba/core/interface.h b/include/mgba/core/interface.h index 3e6261e9c5b..2f4e299ddd1 100644 --- a/include/mgba/core/interface.h +++ b/include/mgba/core/interface.h @@ -22,6 +22,14 @@ enum mCoreFeature { mCORE_FEATURE_OPENGL = 1, }; +struct mGameInfo { + char title[17]; + char system[4]; + char code[5]; + char maker[3]; + uint8_t version; +}; + struct mCoreCallbacks { void* context; void (*videoFrameStarted)(void* context); diff --git a/include/mgba/internal/gb/gb.h b/include/mgba/internal/gb/gb.h index 08068ec58c9..64579d3c166 100644 --- a/include/mgba/internal/gb/gb.h +++ b/include/mgba/internal/gb/gb.h @@ -190,8 +190,7 @@ void GBSavedataUnmask(struct GB* gb); struct Patch; void GBApplyPatch(struct GB* gb, struct Patch* patch); -void GBGetGameTitle(const struct GB* gba, char* out); -void GBGetGameCode(const struct GB* gba, char* out); +void GBGetGameInfo(const struct GB* gba, struct mGameInfo* info); void GBTestKeypadIRQ(struct GB* gb); diff --git a/include/mgba/internal/gba/gba.h b/include/mgba/internal/gba/gba.h index cc340d76024..ea9d69961a5 100644 --- a/include/mgba/internal/gba/gba.h +++ b/include/mgba/internal/gba/gba.h @@ -182,8 +182,7 @@ void GBAUnloadMB(struct GBA* gba); bool GBALoadNull(struct GBA* gba); -void GBAGetGameCode(const struct GBA* gba, char* out); -void GBAGetGameTitle(const struct GBA* gba, char* out); +void GBAGetGameInfo(const struct GBA* gba, struct mGameInfo* info); void GBATestKeypadIRQ(struct GBA* gba); diff --git a/src/core/library.c b/src/core/library.c index 44148f7f50d..1c92a0cbc3a 100644 --- a/src/core/library.c +++ b/src/core/library.c @@ -6,6 +6,7 @@ #include #include +#include #include #ifdef USE_SQLITE3 @@ -291,8 +292,10 @@ bool _mLibraryAddEntry(struct mLibrary* library, const char* filename, const cha core->init(core); core->loadROM(core, vf); - core->getGameTitle(core, entry.internalTitle); - core->getGameCode(core, entry.internalCode); + struct mGameInfo info; + core->getGameInfo(core, &info); + snprintf(entry.internalCode, sizeof(entry.internalCode), "%s-%s", info.system, info.code); + strlcpy(entry.internalTitle, info.title, sizeof(entry.internalTitle)); core->checksum(core, &entry.crc32, mCHECKSUM_CRC32); entry.platform = core->platform(core); entry.title = NULL; diff --git a/src/core/scripting.c b/src/core/scripting.c index ea0af459dfc..064027d45be 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -332,15 +332,15 @@ mSCRIPT_DEFINE_STRUCT(mScriptMemoryDomain) mSCRIPT_DEFINE_END; static struct mScriptValue* _mScriptCoreGetGameTitle(const struct mCore* core) { - char title[32] = {0}; - core->getGameTitle(core, title); - return mScriptStringCreateFromASCII(title); + struct mGameInfo info; + core->getGameInfo(core, &info); + return mScriptStringCreateFromASCII(info.title); } static struct mScriptValue* _mScriptCoreGetGameCode(const struct mCore* core) { - char code[16] = {0}; - core->getGameCode(core, code); - return mScriptStringCreateFromASCII(code); + struct mGameInfo info; + core->getGameInfo(core, &info); + return mScriptStringCreateFromASCII(info.code); } static struct mScriptValue* _mScriptCoreChecksum(const struct mCore* core, int t) { diff --git a/src/gb/core.c b/src/gb/core.c index 4e8351fc6e9..ed8dda1e58e 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -781,12 +781,8 @@ static int32_t _GBCoreFrequency(const struct mCore* core) { return DMG_SM83_FREQUENCY; } -static void _GBCoreGetGameTitle(const struct mCore* core, char* title) { - GBGetGameTitle(core->board, title); -} - -static void _GBCoreGetGameCode(const struct mCore* core, char* title) { - GBGetGameCode(core->board, title); +static void _GBCoreGetGameInfo(const struct mCore* core, struct mGameInfo* info) { + GBGetGameInfo(core->board, info); } static void _GBCoreSetPeripheral(struct mCore* core, int type, void* periph) { @@ -1332,8 +1328,7 @@ struct mCore* GBCoreCreate(void) { core->frameCounter = _GBCoreFrameCounter; core->frameCycles = _GBCoreFrameCycles; core->frequency = _GBCoreFrequency; - core->getGameTitle = _GBCoreGetGameTitle; - core->getGameCode = _GBCoreGetGameCode; + core->getGameInfo = _GBCoreGetGameInfo; core->setPeripheral = _GBCoreSetPeripheral; core->getPeripheral = _GBCoreGetPeripheral; core->busRead8 = _GBCoreBusRead8; diff --git a/src/gb/gb.c b/src/gb/gb.c index c6198ed58e5..ea0a4d7df6b 100644 --- a/src/gb/gb.c +++ b/src/gb/gb.c @@ -16,6 +16,7 @@ #include #include #include +#include #include const uint32_t CGB_SM83_FREQUENCY = 0x800000; @@ -1116,38 +1117,28 @@ bool GBIsROM(struct VFile* vf) { return false; } -void GBGetGameTitle(const struct GB* gb, char* out) { +void GBGetGameInfo(const struct GB* gb, struct mGameInfo* info) { + memset(info, 0, sizeof(*info)); const struct GBCartridge* cart = NULL; if (gb->memory.rom) { cart = (const struct GBCartridge*) &gb->memory.rom[0x100]; } - if (!cart) { - return; - } - if (cart->oldLicensee != 0x33) { - memcpy(out, cart->titleLong, 16); - } else { - memcpy(out, cart->titleShort, 11); - } -} -void GBGetGameCode(const struct GB* gb, char* out) { - memset(out, 0, 8); - const struct GBCartridge* cart = NULL; - if (gb->memory.rom) { - cart = (const struct GBCartridge*) &gb->memory.rom[0x100]; - } - if (!cart) { - return; - } if (cart->cgb == 0xC0) { - memcpy(out, "CGB-????", 8); + strlcpy(info->system, "CGB", sizeof(info->system)); } else { - memcpy(out, "DMG-????", 8); + strlcpy(info->system, "DMG", sizeof(info->system)); } - if (cart->oldLicensee == 0x33) { - memcpy(&out[4], cart->maker, 4); + + if (cart->oldLicensee != 0x33) { + memcpy(info->title, cart->titleLong, 16); + snprintf(info->maker, sizeof(info->maker), "%02X", cart->oldLicensee); + } else { + memcpy(info->title, cart->titleShort, 11); + memcpy(info->code, cart->maker, 4); + memcpy(info->maker, &cart->licensee, 2); } + info->version = cart->version; } void GBFrameStarted(struct GB* gb) { diff --git a/src/gba/core.c b/src/gba/core.c index 1f39afea692..b39a5f40131 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -870,12 +870,8 @@ static int32_t _GBACoreFrequency(const struct mCore* core) { return GBA_ARM7TDMI_FREQUENCY; } -static void _GBACoreGetGameTitle(const struct mCore* core, char* title) { - GBAGetGameTitle(core->board, title); -} - -static void _GBACoreGetGameCode(const struct mCore* core, char* title) { - GBAGetGameCode(core->board, title); +static void _GBACoreGetGameInfo(const struct mCore* core, struct mGameInfo* info) { + GBAGetGameInfo(core->board, info); } static void _GBACoreSetPeripheral(struct mCore* core, int type, void* periph) { @@ -1550,8 +1546,7 @@ struct mCore* GBACoreCreate(void) { core->frameCounter = _GBACoreFrameCounter; core->frameCycles = _GBACoreFrameCycles; core->frequency = _GBACoreFrequency; - core->getGameTitle = _GBACoreGetGameTitle; - core->getGameCode = _GBACoreGetGameCode; + core->getGameInfo = _GBACoreGetGameInfo; core->setPeripheral = _GBACoreSetPeripheral; core->getPeripheral = _GBACoreGetPeripheral; core->busRead8 = _GBACoreBusRead8; diff --git a/src/gba/gba.c b/src/gba/gba.c index 2d10f5cc91d..f9c4dad5d6f 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -18,6 +18,7 @@ #include #include #include +#include #include #ifdef USE_ELF @@ -849,26 +850,24 @@ bool GBAIsBIOS(struct VFile* vf) { return true; } -void GBAGetGameCode(const struct GBA* gba, char* out) { - memset(out, 0, 8); - if (!gba->memory.rom) { - return; - } - - memcpy(out, "AGB-", 4); - memcpy(&out[4], &((struct GBACartridge*) gba->memory.rom)->id, 4); -} - -void GBAGetGameTitle(const struct GBA* gba, char* out) { +void GBAGetGameInfo(const struct GBA* gba, struct mGameInfo* info) { + memset(info, 0, sizeof(*info)); + strlcpy(info->system, "AGB", sizeof(info->system)); + struct GBACartridge* cart = NULL; if (gba->memory.rom) { - memcpy(out, &((struct GBACartridge*) gba->memory.rom)->title, 12); - return; + cart = (struct GBACartridge*) gba->memory.rom; + } else if (gba->isPristine && gba->memory.wram) { + cart = (struct GBACartridge*) gba->memory.wram; } - if (gba->isPristine && gba->memory.wram) { - memcpy(out, &((struct GBACartridge*) gba->memory.wram)->title, 12); - return; + + if (cart) { + memcpy(info->title, &cart->title, 12); + memcpy(info->code, &cart->id, 4); + memcpy(info->maker, &cart->maker, 2); + info->version = cart->version; + } else { + strlcpy(info->title, "(BIOS)", 12); } - strncpy(out, "(BIOS)", 12); } void GBAHitStub(struct ARMCore* cpu, uint32_t opcode) { diff --git a/src/platform/qt/BattleChipView.cpp b/src/platform/qt/BattleChipView.cpp index d72f78c41e1..f7d6eb4c7dd 100644 --- a/src/platform/qt/BattleChipView.cpp +++ b/src/platform/qt/BattleChipView.cpp @@ -30,12 +30,11 @@ BattleChipView::BattleChipView(std::shared_ptr controller, Windo m_ui.setupUi(this); m_ui.chipList->setModel(&m_model); - char title[9]; CoreController::Interrupter interrupter(m_controller); mCore* core = m_controller->thread()->core; - title[8] = '\0'; - core->getGameCode(core, title); - QString qtitle(title); + mGameInfo info; + core->getGameInfo(core, &info); + QString qtitle(info.title); #if (QT_VERSION >= QT_VERSION_CHECK(5, 6, 0)) int size = QFontMetrics(QFont()).height() / ((int) ceil(devicePixelRatioF()) * 12); @@ -101,11 +100,11 @@ BattleChipView::BattleChipView(std::shared_ptr controller, Windo m_controller->attachBattleChipGate(); setFlavor(4); - if (qtitle.startsWith("AGB-B4B") || qtitle.startsWith("AGB-B4W") || qtitle.startsWith("AGB-BR4") || qtitle.startsWith("AGB-BZ3")) { + if (qtitle.startsWith("B4B") || qtitle.startsWith("B4W") || qtitle.startsWith("BR4") || qtitle.startsWith("BZ3")) { m_ui.gateBattleChip->setChecked(true); - } else if (qtitle.startsWith("AGB-BRB") || qtitle.startsWith("AGB-BRK")) { + } else if (qtitle.startsWith("BRB") || qtitle.startsWith("BRK")) { m_ui.gateProgress->setChecked(true); - } else if (qtitle.startsWith("AGB-BR5") || qtitle.startsWith("AGB-BR6")) { + } else if (qtitle.startsWith("BR5") || qtitle.startsWith("BR6")) { m_ui.gateBeastLink->setChecked(true); } diff --git a/src/platform/qt/CoreController.cpp b/src/platform/qt/CoreController.cpp index 02cd4db4c4b..519ce45fb1d 100644 --- a/src/platform/qt/CoreController.cpp +++ b/src/platform/qt/CoreController.cpp @@ -1318,9 +1318,9 @@ void CoreController::updateROMInfo() { mCore* core = m_threadContext.core; core->checksum(core, &m_crc32, mCHECKSUM_CRC32); - char gameTitle[17] = { '\0' }; - core->getGameTitle(core, gameTitle); - m_internalTitle = QLatin1String(gameTitle); + mGameInfo info; + core->getGameInfo(core, &info); + m_internalTitle = QLatin1String(info.title); #ifdef USE_SQLITE3 if (db && m_crc32 && NoIntroDBLookupGameByCRC(db, m_crc32, &game)) { diff --git a/src/platform/qt/GBAOverride.cpp b/src/platform/qt/GBAOverride.cpp index 57fb2048e86..dbf62726840 100644 --- a/src/platform/qt/GBAOverride.cpp +++ b/src/platform/qt/GBAOverride.cpp @@ -14,9 +14,9 @@ void GBAOverride::identify(const struct mCore* core) { if (core->platform(core) != mPLATFORM_GBA) { return; } - char gameId[8]; - core->getGameCode(core, gameId); - memcpy(override.id, &gameId[4], 4); + mGameInfo info; + core->getGameInfo(core, &info); + memcpy(override.id, info.code, 4); } void GBAOverride::save(struct Configuration* config) const { diff --git a/src/platform/qt/ROMInfo.cpp b/src/platform/qt/ROMInfo.cpp index 473918f2674..9f25374398c 100644 --- a/src/platform/qt/ROMInfo.cpp +++ b/src/platform/qt/ROMInfo.cpp @@ -27,16 +27,16 @@ ROMInfo::ROMInfo(std::shared_ptr controller, QWidget* parent) CoreController::Interrupter interrupter(controller); mCore* core = controller->thread()->core; - char title[17] = {}; - core->getGameTitle(core, title); - m_ui.title->setText(QLatin1String(title)); - title[8] = '\0'; - core->getGameCode(core, title); - if (title[0]) { - m_ui.id->setText(QLatin1String(title)); + mGameInfo info; + core->getGameInfo(core, &info); + m_ui.title->setText(QLatin1String(info.title)); + if (info.code[0]) { + m_ui.id->setText(QLatin1String(info.code)); } else { m_ui.id->setText(tr("(unknown)")); } + m_ui.maker->setText(QLatin1String(info.maker)); + m_ui.version->setText(QString::number(info.version)); core->checksum(core, &crc32, mCHECKSUM_CRC32); diff --git a/src/platform/qt/ROMInfo.ui b/src/platform/qt/ROMInfo.ui index 727cff032a0..655d4810fc2 100644 --- a/src/platform/qt/ROMInfo.ui +++ b/src/platform/qt/ROMInfo.ui @@ -6,8 +6,8 @@ 0 0 - 236 - 146 + 178 + 198 @@ -75,13 +75,47 @@ + + + Maker Code: + + + + + + + {MAKER} + + + Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse + + + + + + + Revision: + + + + + + + {VERSION} + + + Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse + + + + File size: - + {SIZE} @@ -91,14 +125,14 @@ - + CRC32: - + {CRC} @@ -108,14 +142,14 @@ - + Save file: - + {SAVEFILE} diff --git a/src/platform/qt/ReportView.cpp b/src/platform/qt/ReportView.cpp index 04944ef5c4b..9843cae7660 100644 --- a/src/platform/qt/ReportView.cpp +++ b/src/platform/qt/ReportView.cpp @@ -497,17 +497,16 @@ void ReportView::addROMInfo(QStringList& report, CoreController* controller) { report << QString("Currently paused: %1").arg(yesNo[controller->isPaused()]); mCore* core = controller->thread()->core; - char title[17] = {}; - core->getGameTitle(core, title); - report << QString("Internal title: %1").arg(QLatin1String(title)); - - title[8] = '\0'; - core->getGameCode(core, title); - if (title[0]) { - report << QString("Game code: %1").arg(QLatin1String(title)); + struct mGameInfo info; + core->getGameInfo(core, &info); + report << QString("Internal title: %1").arg(QLatin1String(info.title)); + if (info.code[0]) { + report << QString("Game code: %1").arg(QLatin1String(info.code)); } else { report << QString("Invalid game code"); } + report << QString("Game maker: %1").arg(QLatin1String(info.maker)); + report << QString("Game version: %1").arg(info.version); uint32_t crc32 = 0; core->checksum(core, &crc32, mCHECKSUM_CRC32); diff --git a/src/platform/test/perf-main.c b/src/platform/test/perf-main.c index 38d50b30c19..26a3715eb5e 100644 --- a/src/platform/test/perf-main.c +++ b/src/platform/test/perf-main.c @@ -196,8 +196,6 @@ bool _mPerfRunCore(const char* fname, const struct mArguments* args, const struc } // TODO: Put back debugger - char gameCode[9] = { 0 }; - core->init(core); if (!perfOpts->noVideo) { core->setVideoBuffer(core, _outputBuffer, 256); @@ -226,7 +224,8 @@ bool _mPerfRunCore(const char* fname, const struct mArguments* args, const struc mCoreLoadStateNamed(core, _savestate, 0); } - core->getGameCode(core, gameCode); + struct mGameInfo info; + core->getGameInfo(core, &info); int frames = perfOpts->frames; if (!frames) { @@ -255,7 +254,7 @@ bool _mPerfRunCore(const char* fname, const struct mArguments* args, const struc } else { rendererName = "software"; } - snprintf(buffer, sizeof(buffer), "%s,%i,%" PRIu64 ",%s\n", gameCode, frames, duration, rendererName); + snprintf(buffer, sizeof(buffer), "%s-%s,%i,%" PRIu64 ",%s\n", info.system, info.code, frames, duration, rendererName); printf("%s", buffer); if (_socket != INVALID_SOCKET) { SocketSend(_socket, buffer, strlen(buffer)); From b12858e97498c2ee4719db5672c0e4843c98c421 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 11 Aug 2024 20:04:35 -0700 Subject: [PATCH 172/338] GBA: Fix getting game info for multiboot ROMs --- CHANGES | 1 + src/gba/gba.c | 8 ++++++-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/CHANGES b/CHANGES index c2617c316c0..0adab66735f 100644 --- a/CHANGES +++ b/CHANGES @@ -25,6 +25,7 @@ Other fixes: - GB: Fix uninitialized save data when loading undersized temporary saves - GB, GBA Core: Fix memory leak if reloading debug symbols - GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1 + - GBA: Fix getting game info for multiboot ROMs - GBA Audio: Fix crash if audio FIFOs and timers get out of sync - GBA Audio: Fix crash in audio subsampling if timing lockstep breaks - GBA Core: Fix loading symbols from ELF files if the file doesn't end with .elf diff --git a/src/gba/gba.c b/src/gba/gba.c index f9c4dad5d6f..ce7e3478e36 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -408,10 +408,14 @@ bool GBALoadMB(struct GBA* gba, struct VFile* vf) { gba->mbVf = vf; vf->seek(vf, 0, SEEK_SET); memset(gba->memory.wram, 0, GBA_SIZE_EWRAM); - vf->read(vf, gba->memory.wram, GBA_SIZE_EWRAM); + off_t read = vf->read(vf, gba->memory.wram, GBA_SIZE_EWRAM); + if (read < 0) { + return false; + } if (gba->cpu && gba->memory.activeRegion == GBA_REGION_IWRAM) { gba->cpu->memory.setActiveRegion(gba->cpu, gba->cpu->gprs[ARM_PC]); } + gba->romCrc32 = doCrc32(gba->memory.wram, read); return true; } @@ -856,7 +860,7 @@ void GBAGetGameInfo(const struct GBA* gba, struct mGameInfo* info) { struct GBACartridge* cart = NULL; if (gba->memory.rom) { cart = (struct GBACartridge*) gba->memory.rom; - } else if (gba->isPristine && gba->memory.wram) { + } else if (gba->mbVf && gba->memory.wram) { cart = (struct GBACartridge*) gba->memory.wram; } From 17cf2e6237f11c802f3d7baa051c44cd7c63ea2c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 11 Aug 2024 23:22:13 -0700 Subject: [PATCH 173/338] No-Intro: Index database on MD5 and SHA1 too --- src/feature/sqlite3/no-intro.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/feature/sqlite3/no-intro.c b/src/feature/sqlite3/no-intro.c index 649364de60a..f79f98a9da7 100644 --- a/src/feature/sqlite3/no-intro.c +++ b/src/feature/sqlite3/no-intro.c @@ -47,7 +47,9 @@ struct NoIntroDB* NoIntroDBLoad(const char* path) { "flags INTEGER DEFAULT 0," "gid INTEGER NOT NULL REFERENCES games(gid) ON DELETE CASCADE" ");\n" - "CREATE INDEX IF NOT EXISTS crc32 ON roms (crc32);"; + "CREATE INDEX IF NOT EXISTS crc32 ON roms (crc32);\n" + "CREATE INDEX IF NOT EXISTS md5 ON roms (md5);\n" + "CREATE INDEX IF NOT EXISTS sha1 ON roms (sha1);\n"; if (sqlite3_exec(db->db, createTables, NULL, NULL, NULL)) { goto error; } From dfab80127764acfb3b6e1895a5a2ca890d084fcf Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 12 Aug 2024 16:08:36 -0700 Subject: [PATCH 174/338] No-Intro: Prevent database from being downgraded --- src/feature/sqlite3/no-intro.c | 35 +++++++++++++++++++++++----------- 1 file changed, 24 insertions(+), 11 deletions(-) diff --git a/src/feature/sqlite3/no-intro.c b/src/feature/sqlite3/no-intro.c index f79f98a9da7..463a2fe5e23 100644 --- a/src/feature/sqlite3/no-intro.c +++ b/src/feature/sqlite3/no-intro.c @@ -72,6 +72,7 @@ bool NoIntroDBLoadClrMamePro(struct NoIntroDB* db, struct VFile* vf) { sqlite3_stmt* gamedbTable = NULL; sqlite3_stmt* gamedbDrop = NULL; + sqlite3_stmt* gamedbSelect = NULL; sqlite3_stmt* gameTable = NULL; sqlite3_stmt* romTable = NULL; char* fieldName = NULL; @@ -91,6 +92,11 @@ bool NoIntroDBLoadClrMamePro(struct NoIntroDB* db, struct VFile* vf) { return false; } + static const char selectGamedb[] = "SELECT * FROM gamedb WHERE name = ? AND version >= ?;"; + if (sqlite3_prepare_v2(db->db, selectGamedb, -1, &gamedbSelect, NULL)) { + return false; + } + static const char insertGame[] = "INSERT INTO games (dbid, name) VALUES (?, ?);"; if (sqlite3_prepare_v2(db->db, insertGame, -1, &gameTable, NULL)) { return false; @@ -161,18 +167,24 @@ bool NoIntroDBLoadClrMamePro(struct NoIntroDB* db, struct VFile* vf) { break; case ')': if (currentDb < 0 && dbType && dbVersion) { - sqlite3_clear_bindings(gamedbDrop); - sqlite3_reset(gamedbDrop); - sqlite3_bind_text(gamedbDrop, 1, dbType, -1, SQLITE_TRANSIENT); - sqlite3_bind_text(gamedbDrop, 2, dbVersion, -1, SQLITE_TRANSIENT); - sqlite3_step(gamedbDrop); + sqlite3_clear_bindings(gamedbSelect); + sqlite3_reset(gamedbSelect); + sqlite3_bind_text(gamedbSelect, 1, dbType, -1, SQLITE_TRANSIENT); + sqlite3_bind_text(gamedbSelect, 2, dbVersion, -1, SQLITE_TRANSIENT); + if (sqlite3_step(gamedbSelect) != SQLITE_ROW) { + sqlite3_clear_bindings(gamedbDrop); + sqlite3_reset(gamedbDrop); + sqlite3_bind_text(gamedbDrop, 1, dbType, -1, SQLITE_TRANSIENT); + sqlite3_bind_text(gamedbDrop, 2, dbVersion, -1, SQLITE_TRANSIENT); + sqlite3_step(gamedbDrop); - sqlite3_clear_bindings(gamedbTable); - sqlite3_reset(gamedbTable); - sqlite3_bind_text(gamedbTable, 1, dbType, -1, SQLITE_TRANSIENT); - sqlite3_bind_text(gamedbTable, 2, dbVersion, -1, SQLITE_TRANSIENT); - if (sqlite3_step(gamedbTable) == SQLITE_DONE) { - currentDb = sqlite3_last_insert_rowid(db->db); + sqlite3_clear_bindings(gamedbTable); + sqlite3_reset(gamedbTable); + sqlite3_bind_text(gamedbTable, 1, dbType, -1, SQLITE_TRANSIENT); + sqlite3_bind_text(gamedbTable, 2, dbVersion, -1, SQLITE_TRANSIENT); + if (sqlite3_step(gamedbTable) == SQLITE_DONE) { + currentDb = sqlite3_last_insert_rowid(db->db); + } } free((void*) dbType); free((void*) dbVersion); @@ -272,6 +284,7 @@ bool NoIntroDBLoadClrMamePro(struct NoIntroDB* db, struct VFile* vf) { sqlite3_finalize(gamedbTable); sqlite3_finalize(gamedbDrop); + sqlite3_finalize(gamedbSelect); sqlite3_finalize(gameTable); sqlite3_finalize(romTable); From cd22c140f07c273026b403f74f98a4716b973bd0 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 13 Aug 2024 00:16:42 -0700 Subject: [PATCH 175/338] GB: Fix potential null pointer deref --- src/gb/gb.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/gb/gb.c b/src/gb/gb.c index ea0a4d7df6b..282fc45c18e 100644 --- a/src/gb/gb.c +++ b/src/gb/gb.c @@ -1119,11 +1119,11 @@ bool GBIsROM(struct VFile* vf) { void GBGetGameInfo(const struct GB* gb, struct mGameInfo* info) { memset(info, 0, sizeof(*info)); - const struct GBCartridge* cart = NULL; - if (gb->memory.rom) { - cart = (const struct GBCartridge*) &gb->memory.rom[0x100]; + if (!gb->memory.rom) { + return; } + const struct GBCartridge* cart = (const struct GBCartridge*) &gb->memory.rom[0x100]; if (cart->cgb == 0xC0) { strlcpy(info->system, "CGB", sizeof(info->system)); } else { From e91da0f423f2ac0ac7641fdda622569b256c0e99 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 13 Aug 2024 18:38:07 -0700 Subject: [PATCH 176/338] Scripting: Expose currentCycle in debugger builds The global time is only maintained in debugger builds for performance reasons. While it can be reconstructed on GBA, this is not the case on GB, so limit it to debugger builds only. --- src/core/scripting.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/src/core/scripting.c b/src/core/scripting.c index 064027d45be..a00d5cbdca6 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -938,6 +938,10 @@ static bool _mScriptCoreAdapterClearBreakpoint(struct mScriptCoreAdapter* adapte } return true; } + +uint64_t _mScriptCoreAdapterCurrentCycle(struct mScriptCoreAdapter* adapter) { + return mTimingGlobalTime(adapter->core->timing); +} #endif static void _mScriptCoreAdapterDeinit(struct mScriptCoreAdapter* adapter) { @@ -1085,6 +1089,7 @@ mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, write16, _mScriptCoreAdap mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mScriptCoreAdapter, write32, _mScriptCoreAdapterWrite32, 2, U32, address, U32, value); #ifdef ENABLE_DEBUGGERS +mSCRIPT_DECLARE_STRUCT_METHOD(mScriptCoreAdapter, U64, currentCycle, _mScriptCoreAdapterCurrentCycle, 0); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptCoreAdapter, S64, setBreakpoint, _mScriptCoreAdapterSetBreakpoint, 3, WRAPPER, callback, U32, address, S32, segment); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptCoreAdapter, S64, setWatchpoint, _mScriptCoreAdapterSetWatchpoint, 4, WRAPPER, callback, U32, address, S32, type, S32, segment); mSCRIPT_DECLARE_STRUCT_METHOD_WITH_DEFAULTS(mScriptCoreAdapter, S64, setRangeWatchpoint, _mScriptCoreAdapterSetRangeWatchpoint, 5, WRAPPER, callback, U32, minAddress, U32, maxAddress, S32, type, S32, segment); @@ -1150,6 +1155,8 @@ mSCRIPT_DEFINE_STRUCT(mScriptCoreAdapter) mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, write16) mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, write32) #ifdef ENABLE_DEBUGGERS + mSCRIPT_DEFINE_DOCSTRING("Get the current execution cycle") + mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, currentCycle) mSCRIPT_DEFINE_DOCSTRING("Set a breakpoint at a given address") mSCRIPT_DEFINE_STRUCT_METHOD(mScriptCoreAdapter, setBreakpoint) mSCRIPT_DEFINE_DOCSTRING("Clear a breakpoint or watchpoint for a given id returned by a previous call") From eaee4228bad46a23f2f6805437d239d2b41e5373 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 16 Aug 2024 02:32:44 -0700 Subject: [PATCH 177/338] GBA Video: Improve emulation of window start/end conditions (fixes #1945) --- CHANGES | 1 + .../internal/gba/renderers/video-software.h | 2 + src/gba/renderers/video-software.c | 82 ++++++++++--------- 3 files changed, 48 insertions(+), 37 deletions(-) diff --git a/CHANGES b/CHANGES index 0adab66735f..3aef9e24604 100644 --- a/CHANGES +++ b/CHANGES @@ -19,6 +19,7 @@ Emulation fixes: - GBA Serialize: Fix some minor save state edge cases - GBA SIO: Fix MULTI mode SIOCNT bit 7 writes on secondary GBAs (fixes mgba.io/i/3110) - GBA Video: Disable BG target 1 blending when OBJ blending (fixes mgba.io/i/2722) + - GBA Video: Improve emulation of window start/end conditions (fixes mgba.io/i/1945) Other fixes: - Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963) - Debugger: Fix writing to specific segment in command-line debugger diff --git a/include/mgba/internal/gba/renderers/video-software.h b/include/mgba/internal/gba/renderers/video-software.h index 969ffed6413..d03c5237490 100644 --- a/include/mgba/internal/gba/renderers/video-software.h +++ b/include/mgba/internal/gba/renderers/video-software.h @@ -118,6 +118,7 @@ struct GBAVideoSoftwareRenderer { struct WindowControl control; int16_t offsetX; int16_t offsetY; + bool on; } winN[2]; struct WindowControl winout; @@ -142,6 +143,7 @@ struct GBAVideoSoftwareRenderer { struct ScanlineCache { uint16_t io[GBA_REG(SOUND1CNT_LO)]; int32_t scale[2][2]; + bool windowOn[2]; } cache[GBA_VIDEO_VERTICAL_PIXELS]; int nextY; diff --git a/src/gba/renderers/video-software.c b/src/gba/renderers/video-software.c index 6c78c08e023..7eba88ba354 100644 --- a/src/gba/renderers/video-software.c +++ b/src/gba/renderers/video-software.c @@ -35,14 +35,15 @@ static void GBAVideoSoftwareRendererWriteBGY_LO(struct GBAVideoSoftwareBackgroun static void GBAVideoSoftwareRendererWriteBGY_HI(struct GBAVideoSoftwareBackground* bg, uint16_t value); static void GBAVideoSoftwareRendererWriteBLDCNT(struct GBAVideoSoftwareRenderer* renderer, uint16_t value); -static void GBAVideoSoftwareRendererPreprocessBuffer(struct GBAVideoSoftwareRenderer* renderer, int y); +static void GBAVideoSoftwareRendererStepWindow(struct GBAVideoSoftwareRenderer* renderer, int y); +static void GBAVideoSoftwareRendererPreprocessBuffer(struct GBAVideoSoftwareRenderer* renderer); static void GBAVideoSoftwareRendererPostprocessBuffer(struct GBAVideoSoftwareRenderer* renderer); static int GBAVideoSoftwareRendererPreprocessSpriteLayer(struct GBAVideoSoftwareRenderer* renderer, int y); static void _updatePalettes(struct GBAVideoSoftwareRenderer* renderer); static void _updateFlags(struct GBAVideoSoftwareRenderer* renderer, struct GBAVideoSoftwareBackground* bg); -static void _breakWindow(struct GBAVideoSoftwareRenderer* softwareRenderer, struct WindowN* win, int y); +static void _breakWindow(struct GBAVideoSoftwareRenderer* softwareRenderer, struct WindowN* win); static void _breakWindowInner(struct GBAVideoSoftwareRenderer* softwareRenderer, struct WindowN* win); void GBAVideoSoftwareRendererCreate(struct GBAVideoSoftwareRenderer* renderer) { @@ -343,28 +344,10 @@ static uint16_t GBAVideoSoftwareRendererWriteVideoRegister(struct GBAVideoRender case GBA_REG_WIN0V: softwareRenderer->winN[0].v.end = value; softwareRenderer->winN[0].v.start = value >> 8; - if (softwareRenderer->winN[0].v.start > GBA_VIDEO_VERTICAL_PIXELS && softwareRenderer->winN[0].v.start > softwareRenderer->winN[0].v.end) { - softwareRenderer->winN[0].v.start = 0; - } - if (softwareRenderer->winN[0].v.end > GBA_VIDEO_VERTICAL_PIXELS) { - softwareRenderer->winN[0].v.end = GBA_VIDEO_VERTICAL_PIXELS; - if (softwareRenderer->winN[0].v.start > GBA_VIDEO_VERTICAL_PIXELS) { - softwareRenderer->winN[0].v.start = GBA_VIDEO_VERTICAL_PIXELS; - } - } break; case GBA_REG_WIN1V: softwareRenderer->winN[1].v.end = value; softwareRenderer->winN[1].v.start = value >> 8; - if (softwareRenderer->winN[1].v.start > GBA_VIDEO_VERTICAL_PIXELS && softwareRenderer->winN[1].v.start > softwareRenderer->winN[1].v.end) { - softwareRenderer->winN[1].v.start = 0; - } - if (softwareRenderer->winN[1].v.end > GBA_VIDEO_VERTICAL_PIXELS) { - softwareRenderer->winN[1].v.end = GBA_VIDEO_VERTICAL_PIXELS; - if (softwareRenderer->winN[1].v.start > GBA_VIDEO_VERTICAL_PIXELS) { - softwareRenderer->winN[1].v.start = GBA_VIDEO_VERTICAL_PIXELS; - } - } break; case GBA_REG_WININ: value &= 0x3F3F; @@ -432,17 +415,7 @@ static void GBAVideoSoftwareRendererWritePalette(struct GBAVideoRenderer* render memset(softwareRenderer->scanlineDirty, 0xFFFFFFFF, sizeof(softwareRenderer->scanlineDirty)); } -static void _breakWindow(struct GBAVideoSoftwareRenderer* softwareRenderer, struct WindowN* win, int y) { - if (win->v.end >= win->v.start) { - if (y >= win->v.end + win->offsetY) { - return; - } - if (y < win->v.start + win->offsetY) { - return; - } - } else if (y >= win->v.end + win->offsetY && y < win->v.start + win->offsetY) { - return; - } +static void _breakWindow(struct GBAVideoSoftwareRenderer* softwareRenderer, struct WindowN* win) { if (win->h.end > GBA_VIDEO_HORIZONTAL_PIXELS || win->h.end < win->h.start) { struct WindowN splits[2] = { *win, *win }; splits[0].h.start = 0; @@ -585,6 +558,14 @@ static void GBAVideoSoftwareRendererDrawScanline(struct GBAVideoRenderer* render softwareRenderer->cache[y].scale[1][0] = softwareRenderer->bg[3].sx; softwareRenderer->cache[y].scale[1][1] = softwareRenderer->bg[3].sy; + GBAVideoSoftwareRendererStepWindow(softwareRenderer, y); + if (softwareRenderer->cache[y].windowOn[0] != softwareRenderer->winN[0].on || + softwareRenderer->cache[y].windowOn[1] != softwareRenderer->winN[1].on) { + dirty = true; + } + softwareRenderer->cache[y].windowOn[0] = softwareRenderer->winN[0].on; + softwareRenderer->cache[y].windowOn[1] = softwareRenderer->winN[1].on; + if (!dirty) { if (GBARegisterDISPCNTGetMode(softwareRenderer->dispcnt) != 0) { if (softwareRenderer->bg[2].enabled == ENABLED_MAX) { @@ -610,7 +591,7 @@ static void GBAVideoSoftwareRendererDrawScanline(struct GBAVideoRenderer* render return; } - GBAVideoSoftwareRendererPreprocessBuffer(softwareRenderer, y); + GBAVideoSoftwareRendererPreprocessBuffer(softwareRenderer); softwareRenderer->spriteCyclesRemaining = GBARegisterDISPCNTIsHblankIntervalFree(softwareRenderer->dispcnt) ? OBJ_HBLANK_FREE_LENGTH : OBJ_LENGTH; int spriteLayers = GBAVideoSoftwareRendererPreprocessSpriteLayer(softwareRenderer, y); @@ -747,6 +728,20 @@ static void GBAVideoSoftwareRendererFinishFrame(struct GBAVideoRenderer* rendere if (softwareRenderer->bg[3].enabled > 0) { softwareRenderer->bg[3].enabled = ENABLED_MAX; } + + int i; + for (i = 0; i < 2; ++i) { + struct WindowN* win = &softwareRenderer->winN[i]; + if (win->v.end >= GBA_VIDEO_VERTICAL_PIXELS && win->v.end < VIDEO_VERTICAL_TOTAL_PIXELS) { + win->on = false; + } + + if (win->v.start >= GBA_VIDEO_VERTICAL_PIXELS && + win->v.start < VIDEO_VERTICAL_TOTAL_PIXELS && + win->v.start > win->v.end) { + win->on = true; + } + } } static void GBAVideoSoftwareRendererGetPixels(struct GBAVideoRenderer* renderer, size_t* stride, const void** pixels) { @@ -855,7 +850,20 @@ static void GBAVideoSoftwareRendererWriteBLDCNT(struct GBAVideoSoftwareRenderer* } } -void GBAVideoSoftwareRendererPreprocessBuffer(struct GBAVideoSoftwareRenderer* softwareRenderer, int y) { +void GBAVideoSoftwareRendererStepWindow(struct GBAVideoSoftwareRenderer* softwareRenderer, int y) { + int i; + for (i = 0; i < 2; ++i) { + struct WindowN* win = &softwareRenderer->winN[i]; + if (y == win->v.start + win->offsetY) { + win->on = true; + } + if (y == win->v.end + win->offsetY) { + win->on = false; + } + } +} + +void GBAVideoSoftwareRendererPreprocessBuffer(struct GBAVideoSoftwareRenderer* softwareRenderer) { int x; for (x = 0; x < GBA_VIDEO_HORIZONTAL_PIXELS; x += 4) { softwareRenderer->spriteLayer[x] = FLAG_UNWRITTEN; @@ -868,11 +876,11 @@ void GBAVideoSoftwareRendererPreprocessBuffer(struct GBAVideoSoftwareRenderer* s softwareRenderer->nWindows = 1; if (GBARegisterDISPCNTIsWin0Enable(softwareRenderer->dispcnt) || GBARegisterDISPCNTIsWin1Enable(softwareRenderer->dispcnt) || GBARegisterDISPCNTIsObjwinEnable(softwareRenderer->dispcnt)) { softwareRenderer->windows[0].control = softwareRenderer->winout; - if (GBARegisterDISPCNTIsWin1Enable(softwareRenderer->dispcnt) && !softwareRenderer->d.disableWIN[1]) { - _breakWindow(softwareRenderer, &softwareRenderer->winN[1], y); + if (GBARegisterDISPCNTIsWin1Enable(softwareRenderer->dispcnt) && !softwareRenderer->d.disableWIN[1] && softwareRenderer->winN[1].on) { + _breakWindow(softwareRenderer, &softwareRenderer->winN[1]); } - if (GBARegisterDISPCNTIsWin0Enable(softwareRenderer->dispcnt) && !softwareRenderer->d.disableWIN[0]) { - _breakWindow(softwareRenderer, &softwareRenderer->winN[0], y); + if (GBARegisterDISPCNTIsWin0Enable(softwareRenderer->dispcnt) && !softwareRenderer->d.disableWIN[0] && softwareRenderer->winN[0].on) { + _breakWindow(softwareRenderer, &softwareRenderer->winN[0]); } } else { softwareRenderer->windows[0].control.packed = 0xFF; From ecfdff23382c16d6772d6be89f69afafcb3491b2 Mon Sep 17 00:00:00 2001 From: anthonydo8196 Date: Mon, 19 Aug 2024 20:58:47 -0500 Subject: [PATCH 178/338] Add load most recent script menu option (#3266) --- .gitignore | Bin 323 -> 454 bytes src/platform/qt/scripting/ScriptingView.cpp | 15 ++++++++++++++- src/platform/qt/scripting/ScriptingView.h | 2 ++ src/platform/qt/scripting/ScriptingView.ui | 6 ++++++ 4 files changed, 22 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index fedbc461f4689076caf4b0cd451a299043c4fcdf..e9e3b3956726efab97169a7e106d812bb3e0b72f 100644 GIT binary patch literal 454 zcmZWl!EVDK4D~ru{sF1CN+tV-RoYIIs!cmr1l-0gfe4eVz3kg((qudAfS=#9{V;6Q zD+Wwt)rmZEU2XNqn6{F97s6jdf#GiJs;)Nbc_idur#z`vMEY8x|HzV2S%TbH%-}9qN3`3x9bmIoCcgX9{Q57mi`6f6DHMgp7HW zZR`gbItunCxK(bnE!K}+ZFG{^UM@UR;B36tGpno4aLC$WK|8aW-Huo@~+JTMIZY7SbdWk}K= Oq=O{a;>WXFnfw82-g}Jz literal 323 zcmYLF!EVDK488j+ka~+$vTsize)|l`v;%(jv;BCmGq0Gi zkT)la$k5rDv2@TqH0A50ak_heoq3)q1{0{Dmt06^`=L@B>^tb~!vB+hdQK(6JselectionModel(), &QItemSelectionModel::currentChanged, this, &ScriptingView::selectBuffer); connect(m_ui.load, &QAction::triggered, this, &ScriptingView::load); + connect(m_ui.loadMostRecent, &QAction::triggered, this, &ScriptingView::loadMostRecent); connect(m_ui.reset, &QAction::triggered, controller, &ScriptingController::reset); m_mruFiles = m_config->getMRU(ConfigController::MRU::Script); @@ -66,6 +67,10 @@ void ScriptingView::load() { } } +void ScriptingView::loadMostRecent() { + m_controller->loadFile(m_mruFiles.at(0)); +} + void ScriptingView::controllerReset() { selectBuffer(QModelIndex()); } @@ -105,7 +110,15 @@ void ScriptingView::updateMRU() { m_ui.mru->clear(); for (const auto& fname : m_mruFiles) { m_ui.mru->addAction(fname, [this, fname]() { - m_controller->loadFile(fname); + if (m_controller->loadFile(fname)) { + appendMRU(fname); + } }); } + checkEmptyMRU(); } + + +void ScriptingView::checkEmptyMRU() { + m_ui.loadMostRecent->setEnabled(!m_mruFiles.isEmpty()); +} \ No newline at end of file diff --git a/src/platform/qt/scripting/ScriptingView.h b/src/platform/qt/scripting/ScriptingView.h index 1f90a3f19bb..a62bd2314b3 100644 --- a/src/platform/qt/scripting/ScriptingView.h +++ b/src/platform/qt/scripting/ScriptingView.h @@ -22,6 +22,7 @@ Q_OBJECT private slots: void submitRepl(); void load(); + void loadMostRecent(); void controllerReset(); void selectBuffer(const QModelIndex& current, const QModelIndex& = QModelIndex()); @@ -31,6 +32,7 @@ private slots: void appendMRU(const QString&); void updateMRU(); + void checkEmptyMRU(); Ui::ScriptingView m_ui; diff --git a/src/platform/qt/scripting/ScriptingView.ui b/src/platform/qt/scripting/ScriptingView.ui index 8b97449b0d8..4d55a8707ff 100644 --- a/src/platform/qt/scripting/ScriptingView.ui +++ b/src/platform/qt/scripting/ScriptingView.ui @@ -98,6 +98,7 @@ + @@ -108,6 +109,11 @@ Load script... + + + + &Load most recent + From 84dd69ff86aaaccf85b33f83a26f18203a4a0b4f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 25 Aug 2024 02:32:04 -0700 Subject: [PATCH 179/338] Util: Add UIntList predefined vector --- include/mgba-util/vector.h | 1 + src/util/vector.c | 1 + 2 files changed, 2 insertions(+) diff --git a/include/mgba-util/vector.h b/include/mgba-util/vector.h index 8c0f11e458d..c837379e210 100644 --- a/include/mgba-util/vector.h +++ b/include/mgba-util/vector.h @@ -112,6 +112,7 @@ CXX_GUARD_START } \ DECLARE_VECTOR(IntList, int); +DECLARE_VECTOR(UIntList, unsigned); DECLARE_VECTOR(SInt8List, int8_t); DECLARE_VECTOR(SInt16List, int16_t); DECLARE_VECTOR(SInt32List, int32_t); diff --git a/src/util/vector.c b/src/util/vector.c index 28750a1b4a3..f84838a16c1 100644 --- a/src/util/vector.c +++ b/src/util/vector.c @@ -6,6 +6,7 @@ #include DEFINE_VECTOR(IntList, int); +DEFINE_VECTOR(UIntList, unsigned); DEFINE_VECTOR(SInt8List, int8_t); DEFINE_VECTOR(SInt16List, int16_t); DEFINE_VECTOR(SInt32List, int32_t); From c06a376b2e2f5f9023a6edec1ec20df3ab532c1d Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 31 Aug 2024 05:14:54 -0700 Subject: [PATCH 180/338] Core: Switch video log state load/store to use mCore*State functions --- src/feature/video-logger.c | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/src/feature/video-logger.c b/src/feature/video-logger.c index 978700864c5..adcbea2760a 100644 --- a/src/feature/video-logger.c +++ b/src/feature/video-logger.c @@ -511,9 +511,13 @@ struct mVideoLogContext* mVideoLogContextCreate(struct mCore* core) { #endif if (core) { - context->initialStateSize = core->stateSize(core); + struct VFile* vf = VFileMemChunk(NULL, core->stateSize(core)); + mCoreSaveStateNamed(core, vf, 0); + context->initialStateSize = vf->size(vf); context->initialState = anonymousMemoryMap(context->initialStateSize); - core->saveState(core, context->initialState); + vf->seek(vf, 0, SEEK_SET); + vf->write(vf, context->initialState, context->initialStateSize); + vf->close(vf); core->startVideoLog(core, context); } @@ -763,15 +767,15 @@ void mVideoLogContextDestroy(struct mCore* core, struct mVideoLogContext* contex void mVideoLogContextRewind(struct mVideoLogContext* context, struct mCore* core) { _readHeader(context); if (core) { - size_t size = core->stateSize(core); - if (size <= context->initialStateSize) { - core->loadState(core, context->initialState); + struct VFile* vf; + if (context->initialStateSize < core->stateSize(core)) { + vf = VFileMemChunk(NULL, core->stateSize(core)); + vf->write(vf, context->initialState, context->initialStateSize); } else { - void* extendedState = anonymousMemoryMap(size); - memcpy(extendedState, context->initialState, context->initialStateSize); - core->loadState(core, extendedState); - mappedMemoryFree(extendedState, size); + vf = VFileFromConstMemory(context->initialState, context->initialStateSize); } + mCoreLoadStateNamed(core, vf, 0); + vf->close(vf); } off_t pointer = context->backing->seek(context->backing, 0, SEEK_CUR); From 3a6657bd88ec04744896e4704a5c40baf1067b75 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 1 Sep 2024 00:55:29 -0700 Subject: [PATCH 181/338] Core: Add stubs for loading/saving subsystem extra state --- include/mgba/core/core.h | 2 ++ include/mgba/core/serialize.h | 2 ++ src/core/serialize.c | 3 +++ src/gb/core.c | 14 ++++++++++++++ src/gba/core.c | 14 ++++++++++++++ 5 files changed, 35 insertions(+) diff --git a/include/mgba/core/core.h b/include/mgba/core/core.h index 18295ed1345..04bca468922 100644 --- a/include/mgba/core/core.h +++ b/include/mgba/core/core.h @@ -109,6 +109,8 @@ struct mCore { size_t (*stateSize)(struct mCore*); bool (*loadState)(struct mCore*, const void* state); bool (*saveState)(struct mCore*, void* state); + bool (*loadExtraState)(struct mCore*, const struct mStateExtdata*); + bool (*saveExtraState)(struct mCore*, struct mStateExtdata*); void (*setKeys)(struct mCore*, uint32_t keys); void (*addKeys)(struct mCore*, uint32_t keys); diff --git a/include/mgba/core/serialize.h b/include/mgba/core/serialize.h index ee9de69a1bd..e7b11427114 100644 --- a/include/mgba/core/serialize.h +++ b/include/mgba/core/serialize.h @@ -17,6 +17,8 @@ enum mStateExtdataTag { EXTDATA_CHEATS = 3, EXTDATA_RTC = 4, EXTDATA_SCREENSHOT_DIMENSIONS = 5, + EXTDATA_SUBSYSTEM_START = 0x40, + EXTDATA_SUBSYSTEM_MAX = 0x7F, EXTDATA_META_TIME = 0x101, EXTDATA_META_CREATOR = 0x102, EXTDATA_MAX diff --git a/src/core/serialize.c b/src/core/serialize.c index b721cdafa9e..e42457470b4 100644 --- a/src/core/serialize.c +++ b/src/core/serialize.c @@ -371,6 +371,7 @@ bool mCoreSaveStateNamed(struct mCore* core, struct VFile* vf, int flags) { mStateExtdataInit(&extdata); size_t stateSize = core->stateSize(core); + core->saveExtraState(core, &extdata); if (flags & SAVESTATE_METADATA) { uint64_t* creationUsec = malloc(sizeof(*creationUsec)); if (creationUsec) { @@ -528,6 +529,8 @@ bool mCoreLoadStateNamed(struct mCore* core, struct VFile* vf, int flags) { bool success = core->loadState(core, state); mappedMemoryFree(state, core->stateSize(core)); + core->loadExtraState(core, &extdata); + unsigned width, height; core->currentVideoSize(core, &width, &height); diff --git a/src/gb/core.c b/src/gb/core.c index ed8dda1e58e..17a474ed18e 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -743,6 +743,18 @@ static bool _GBCoreSaveState(struct mCore* core, void* state) { return true; } +static bool _GBCoreLoadExtraState(struct mCore* core, const struct mStateExtdata* extdata) { + UNUSED(core); + UNUSED(extdata); + return true; +} + +static bool _GBCoreSaveExtraState(struct mCore* core, struct mStateExtdata* extdata) { + UNUSED(core); + UNUSED(extdata); + return true; +} + static void _GBCoreSetKeys(struct mCore* core, uint32_t keys) { struct GBCore* gbcore = (struct GBCore*) core; gbcore->keys = keys; @@ -1321,6 +1333,8 @@ struct mCore* GBCoreCreate(void) { core->stateSize = _GBCoreStateSize; core->loadState = _GBCoreLoadState; core->saveState = _GBCoreSaveState; + core->loadExtraState = _GBCoreLoadExtraState; + core->saveExtraState = _GBCoreSaveExtraState; core->setKeys = _GBCoreSetKeys; core->addKeys = _GBCoreAddKeys; core->clearKeys = _GBCoreClearKeys; diff --git a/src/gba/core.c b/src/gba/core.c index b39a5f40131..904d85c20af 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -832,6 +832,18 @@ static bool _GBACoreSaveState(struct mCore* core, void* state) { return true; } +static bool _GBACoreLoadExtraState(struct mCore* core, const struct mStateExtdata* extdata) { + UNUSED(core); + UNUSED(extdata); + return true; +} + +static bool _GBACoreSaveExtraState(struct mCore* core, struct mStateExtdata* extdata) { + UNUSED(core); + UNUSED(extdata); + return true; +} + static void _GBACoreSetKeys(struct mCore* core, uint32_t keys) { struct GBA* gba = core->board; gba->keysActive = keys; @@ -1539,6 +1551,8 @@ struct mCore* GBACoreCreate(void) { core->stateSize = _GBACoreStateSize; core->loadState = _GBACoreLoadState; core->saveState = _GBACoreSaveState; + core->loadExtraState = _GBACoreLoadExtraState; + core->saveExtraState = _GBACoreSaveExtraState; core->setKeys = _GBACoreSetKeys; core->addKeys = _GBACoreAddKeys; core->clearKeys = _GBACoreClearKeys; From 59b561b8c01d988d267c2ffc371733b899a81a78 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 1 Sep 2024 01:28:05 -0700 Subject: [PATCH 182/338] Core: mStateExtdataGet const correctness --- include/mgba/core/serialize.h | 2 +- src/core/serialize.c | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/include/mgba/core/serialize.h b/include/mgba/core/serialize.h index e7b11427114..177a7871aa2 100644 --- a/include/mgba/core/serialize.h +++ b/include/mgba/core/serialize.h @@ -44,7 +44,7 @@ struct mStateExtdata { void mStateExtdataInit(struct mStateExtdata*); void mStateExtdataDeinit(struct mStateExtdata*); void mStateExtdataPut(struct mStateExtdata*, enum mStateExtdataTag, struct mStateExtdataItem*); -bool mStateExtdataGet(struct mStateExtdata*, enum mStateExtdataTag, struct mStateExtdataItem*); +bool mStateExtdataGet(const struct mStateExtdata*, enum mStateExtdataTag, struct mStateExtdataItem*); struct VFile; bool mStateExtdataSerialize(struct mStateExtdata* extdata, struct VFile* vf); diff --git a/src/core/serialize.c b/src/core/serialize.c index e42457470b4..203ed809aca 100644 --- a/src/core/serialize.c +++ b/src/core/serialize.c @@ -57,7 +57,7 @@ void mStateExtdataPut(struct mStateExtdata* extdata, enum mStateExtdataTag tag, extdata->data[tag] = *item; } -bool mStateExtdataGet(struct mStateExtdata* extdata, enum mStateExtdataTag tag, struct mStateExtdataItem* item) { +bool mStateExtdataGet(const struct mStateExtdata* extdata, enum mStateExtdataTag tag, struct mStateExtdataItem* item) { if (tag == EXTDATA_NONE || tag >= EXTDATA_MAX) { return false; } From da553d191f005e7a921dc1067b973e3d516b7d81 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 1 Sep 2024 01:36:07 -0700 Subject: [PATCH 183/338] Core: Extdata should not have a size < 0 --- src/core/serialize.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/core/serialize.c b/src/core/serialize.c index 203ed809aca..4f7c07a4afe 100644 --- a/src/core/serialize.c +++ b/src/core/serialize.c @@ -131,6 +131,9 @@ bool mStateExtdataDeserialize(struct mStateExtdata* extdata, struct VFile* vf) { if (vf->seek(vf, header.offset, SEEK_SET) < 0) { return false; } + if (header.size <= 0) { + continue; + } struct mStateExtdataItem item = { .data = malloc(header.size), .size = header.size, From a5ea157c9a73aca2247f34c2e9ed461ec2861c2f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 1 Sep 2024 01:56:52 -0700 Subject: [PATCH 184/338] GBA Video: Add stubs for saving/loading extra data out of the video renderers --- include/mgba/feature/video-logger.h | 6 ++++ include/mgba/internal/gba/serialize.h | 5 +++ include/mgba/internal/gba/video.h | 4 +++ src/gba/core.c | 41 ++++++++++++++++++++--- src/gba/extra/proxy.c | 47 +++++++++++++++++++++++++++ src/gba/renderers/gl.c | 29 +++++++++++++++++ src/gba/renderers/video-software.c | 30 ++++++++++++++++- 7 files changed, 156 insertions(+), 6 deletions(-) diff --git a/include/mgba/feature/video-logger.h b/include/mgba/feature/video-logger.h index cf50dd58ede..373ea806999 100644 --- a/include/mgba/feature/video-logger.h +++ b/include/mgba/feature/video-logger.h @@ -35,6 +35,8 @@ enum mVideoLoggerEvent { LOGGER_EVENT_DEINIT, LOGGER_EVENT_RESET, LOGGER_EVENT_GET_PIXELS, + LOGGER_EVENT_LOAD_STATE, + LOGGER_EVENT_SAVE_STATE, }; enum mVideoLoggerInjectionPoint { @@ -85,6 +87,10 @@ struct mVideoLogger { const void* pixelBuffer; size_t pixelStride; + + void* stateBuffer; + size_t stateSize; + bool stateStatus; }; void mVideoLoggerRendererCreate(struct mVideoLogger* logger, bool readonly); diff --git a/include/mgba/internal/gba/serialize.h b/include/mgba/internal/gba/serialize.h index b31fd0f5a6c..9bd21821a38 100644 --- a/include/mgba/internal/gba/serialize.h +++ b/include/mgba/internal/gba/serialize.h @@ -285,6 +285,11 @@ DECL_BIT(GBASerializedMiscFlags, IrqPending, 2); DECL_BIT(GBASerializedMiscFlags, Blocked, 3); DECL_BITS(GBASerializedMiscFlags, KeyIRQKeys, 4, 11); +enum { + GBA_SUBSYSTEM_VIDEO_RENDERER = 0, + GBA_SUBSYSTEM_MAX, +}; + struct GBASerializedState { uint32_t versionMagic; uint32_t biosChecksum; diff --git a/include/mgba/internal/gba/video.h b/include/mgba/internal/gba/video.h index b29b3d60742..92477266003 100644 --- a/include/mgba/internal/gba/video.h +++ b/include/mgba/internal/gba/video.h @@ -182,6 +182,10 @@ struct GBAVideoRenderer { void (*reset)(struct GBAVideoRenderer* renderer); void (*deinit)(struct GBAVideoRenderer* renderer); + uint32_t (*rendererId)(const struct GBAVideoRenderer* renderer); + bool (*loadState)(struct GBAVideoRenderer* renderer, const void* state, size_t size); + void (*saveState)(struct GBAVideoRenderer* renderer, void** state, size_t* size); + uint16_t (*writeVideoRegister)(struct GBAVideoRenderer* renderer, uint32_t address, uint16_t value); void (*writeVRAM)(struct GBAVideoRenderer* renderer, uint32_t address); void (*writePalette)(struct GBAVideoRenderer* renderer, uint32_t address, uint16_t value); diff --git a/src/gba/core.c b/src/gba/core.c index 904d85c20af..e9cf2b81c68 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -7,6 +7,7 @@ #include #include +#include #include #include #include @@ -833,14 +834,44 @@ static bool _GBACoreSaveState(struct mCore* core, void* state) { } static bool _GBACoreLoadExtraState(struct mCore* core, const struct mStateExtdata* extdata) { - UNUSED(core); - UNUSED(extdata); - return true; + struct GBA* gba = core->board; + struct mStateExtdataItem item; + bool ok = true; + if (mStateExtdataGet(extdata, EXTDATA_SUBSYSTEM_START + GBA_SUBSYSTEM_VIDEO_RENDERER, &item)) { + if ((uint32_t) item.size > sizeof(uint32_t)) { + uint32_t type; + LOAD_32(type, 0, item.data); + if (type == gba->video.renderer->rendererId(gba->video.renderer)) { + ok = gba->video.renderer->loadState(gba->video.renderer, + (void*) ((uintptr_t) item.data + sizeof(uint32_t)), + item.size - sizeof(type)); + } + } else if (item.data) { + ok = false; + } + } + return ok; } static bool _GBACoreSaveExtraState(struct mCore* core, struct mStateExtdata* extdata) { - UNUSED(core); - UNUSED(extdata); + struct GBA* gba = core->board; + void* buffer = NULL; + size_t size = 0; + gba->video.renderer->saveState(gba->video.renderer, &buffer, &size); + if (size > 0 && buffer) { + struct mStateExtdataItem item; + item.size = size + sizeof(uint32_t); + item.data = malloc(item.size); + item.clean = free; + uint32_t type = gba->video.renderer->rendererId(gba->video.renderer); + STORE_32(type, 0, item.data); + memcpy((void*) ((uintptr_t) item.data + sizeof(uint32_t)), buffer, size); + mStateExtdataPut(extdata, EXTDATA_SUBSYSTEM_START + GBA_SUBSYSTEM_VIDEO_RENDERER, &item); + } + if (buffer) { + free(buffer); + } + return true; } diff --git a/src/gba/extra/proxy.c b/src/gba/extra/proxy.c index 7842bef1f01..0847e1f4a5b 100644 --- a/src/gba/extra/proxy.c +++ b/src/gba/extra/proxy.c @@ -13,6 +13,9 @@ static void GBAVideoProxyRendererInit(struct GBAVideoRenderer* renderer); static void GBAVideoProxyRendererReset(struct GBAVideoRenderer* renderer); static void GBAVideoProxyRendererDeinit(struct GBAVideoRenderer* renderer); +static uint32_t GBAVideoProxyRendererId(const struct GBAVideoRenderer* renderer); +static bool GBAVideoProxyRendererLoadState(struct GBAVideoRenderer* renderer, const void* state, size_t size); +static void GBAVideoProxyRendererSaveState(struct GBAVideoRenderer* renderer, void** state, size_t* size); static uint16_t GBAVideoProxyRendererWriteVideoRegister(struct GBAVideoRenderer* renderer, uint32_t address, uint16_t value); static void GBAVideoProxyRendererWriteVRAM(struct GBAVideoRenderer* renderer, uint32_t address); static void GBAVideoProxyRendererWritePalette(struct GBAVideoRenderer* renderer, uint32_t address, uint16_t value); @@ -27,9 +30,13 @@ static bool _parsePacket(struct mVideoLogger* logger, const struct mVideoLoggerD static uint16_t* _vramBlock(struct mVideoLogger* logger, uint32_t address); void GBAVideoProxyRendererCreate(struct GBAVideoProxyRenderer* renderer, struct GBAVideoRenderer* backend) { + memset(renderer, 0, sizeof(*renderer)); renderer->d.init = GBAVideoProxyRendererInit; renderer->d.reset = GBAVideoProxyRendererReset; renderer->d.deinit = GBAVideoProxyRendererDeinit; + renderer->d.rendererId = GBAVideoProxyRendererId; + renderer->d.loadState = GBAVideoProxyRendererLoadState; + renderer->d.saveState = GBAVideoProxyRendererSaveState; renderer->d.writeVideoRegister = GBAVideoProxyRendererWriteVideoRegister; renderer->d.writeVRAM = GBAVideoProxyRendererWriteVRAM; renderer->d.writeOAM = GBAVideoProxyRendererWriteOAM; @@ -172,6 +179,11 @@ void GBAVideoProxyRendererDeinit(struct GBAVideoRenderer* renderer) { mVideoLoggerRendererDeinit(proxyRenderer->logger); } +uint32_t GBAVideoProxyRendererId(const struct GBAVideoRenderer* renderer) { + struct GBAVideoProxyRenderer* proxyRenderer = (struct GBAVideoProxyRenderer*) renderer; + return proxyRenderer->backend->rendererId(proxyRenderer->backend); +} + static void _handleEvent(struct mVideoLogger* logger, enum mVideoLoggerEvent event) { struct GBAVideoProxyRenderer* proxyRenderer = logger->context; switch (event) { @@ -189,6 +201,12 @@ static void _handleEvent(struct mVideoLogger* logger, enum mVideoLoggerEvent eve case LOGGER_EVENT_GET_PIXELS: proxyRenderer->backend->getPixels(proxyRenderer->backend, &logger->pixelStride, &logger->pixelBuffer); break; + case LOGGER_EVENT_LOAD_STATE: + logger->stateStatus = proxyRenderer->backend->loadState(proxyRenderer->backend, logger->stateBuffer, logger->stateSize); + break; + case LOGGER_EVENT_SAVE_STATE: + proxyRenderer->backend->saveState(proxyRenderer->backend, &logger->stateBuffer, &logger->stateSize); + break; } } @@ -279,6 +297,35 @@ uint16_t GBAVideoProxyRendererWriteVideoRegister(struct GBAVideoRenderer* render return value; } +bool GBAVideoProxyRendererLoadState(struct GBAVideoRenderer* renderer, const void* state, size_t size) { + struct GBAVideoProxyRenderer* proxyRenderer = (struct GBAVideoProxyRenderer*) renderer; + if (proxyRenderer->logger->block && proxyRenderer->logger->wait) { + proxyRenderer->logger->wait(proxyRenderer->logger); + proxyRenderer->logger->stateBuffer = (void*) state; + proxyRenderer->logger->stateSize = size; + proxyRenderer->logger->postEvent(proxyRenderer->logger, LOGGER_EVENT_LOAD_STATE); + proxyRenderer->logger->stateBuffer = NULL; + proxyRenderer->logger->stateSize = 0; + return proxyRenderer->logger->stateStatus; + } else { + return proxyRenderer->backend->loadState(proxyRenderer->backend, state, size); + } +} + +void GBAVideoProxyRendererSaveState(struct GBAVideoRenderer* renderer, void** state, size_t* size) { + struct GBAVideoProxyRenderer* proxyRenderer = (struct GBAVideoProxyRenderer*) renderer; + if (proxyRenderer->logger->block && proxyRenderer->logger->wait) { + proxyRenderer->logger->wait(proxyRenderer->logger); + proxyRenderer->logger->postEvent(proxyRenderer->logger, LOGGER_EVENT_SAVE_STATE); + *state = proxyRenderer->logger->stateBuffer; + *size = proxyRenderer->logger->stateSize; + proxyRenderer->logger->stateBuffer = NULL; + proxyRenderer->logger->stateSize = 0; + } else { + proxyRenderer->backend->saveState(proxyRenderer->backend, state, size); + } +} + void GBAVideoProxyRendererWriteVRAM(struct GBAVideoRenderer* renderer, uint32_t address) { struct GBAVideoProxyRenderer* proxyRenderer = (struct GBAVideoProxyRenderer*) renderer; mVideoLoggerRendererWriteVRAM(proxyRenderer->logger, address); diff --git a/src/gba/renderers/gl.c b/src/gba/renderers/gl.c index afc9c54ace2..24fb092c7dd 100644 --- a/src/gba/renderers/gl.c +++ b/src/gba/renderers/gl.c @@ -13,9 +13,14 @@ #include #include +#define OPENGL_MAGIC 0x6E726C67 + static void GBAVideoGLRendererInit(struct GBAVideoRenderer* renderer); static void GBAVideoGLRendererDeinit(struct GBAVideoRenderer* renderer); static void GBAVideoGLRendererReset(struct GBAVideoRenderer* renderer); +static uint32_t GBAVideoGLRendererId(const struct GBAVideoRenderer* renderer); +static bool GBAVideoGLRendererLoadState(struct GBAVideoRenderer* renderer, const void* state, size_t size); +static void GBAVideoGLRendererSaveState(struct GBAVideoRenderer* renderer, void** state, size_t* size); static void GBAVideoGLRendererWriteVRAM(struct GBAVideoRenderer* renderer, uint32_t address); static void GBAVideoGLRendererWriteOAM(struct GBAVideoRenderer* renderer, uint32_t oam); static void GBAVideoGLRendererWritePalette(struct GBAVideoRenderer* renderer, uint32_t address, uint16_t value); @@ -656,9 +661,13 @@ static const GLint _vertices[] = { }; void GBAVideoGLRendererCreate(struct GBAVideoGLRenderer* renderer) { + memset(renderer, 0, sizeof(*renderer)); renderer->d.init = GBAVideoGLRendererInit; renderer->d.reset = GBAVideoGLRendererReset; renderer->d.deinit = GBAVideoGLRendererDeinit; + renderer->d.rendererId = GBAVideoGLRendererId; + renderer->d.loadState = GBAVideoGLRendererLoadState; + renderer->d.saveState = GBAVideoGLRendererSaveState; renderer->d.writeVideoRegister = GBAVideoGLRendererWriteVideoRegister; renderer->d.writeVRAM = GBAVideoGLRendererWriteVRAM; renderer->d.writeOAM = GBAVideoGLRendererWriteOAM; @@ -953,6 +962,26 @@ void GBAVideoGLRendererReset(struct GBAVideoRenderer* renderer) { } } +static uint32_t GBAVideoGLRendererId(const struct GBAVideoRenderer* renderer) { + UNUSED(renderer); + return OPENGL_MAGIC; +} + +static bool GBAVideoGLRendererLoadState(struct GBAVideoRenderer* renderer, const void* state, size_t size) { + UNUSED(renderer); + UNUSED(state); + UNUSED(size); + // TODO + return false; +} + +static void GBAVideoGLRendererSaveState(struct GBAVideoRenderer* renderer, void** state, size_t* size) { + UNUSED(renderer); + *state = NULL; + *size = 0; + // TODO +} + void GBAVideoGLRendererWriteVRAM(struct GBAVideoRenderer* renderer, uint32_t address) { struct GBAVideoGLRenderer* glRenderer = (struct GBAVideoGLRenderer*) renderer; if (renderer->cache) { diff --git a/src/gba/renderers/video-software.c b/src/gba/renderers/video-software.c index 7eba88ba354..41f092937fb 100644 --- a/src/gba/renderers/video-software.c +++ b/src/gba/renderers/video-software.c @@ -14,10 +14,14 @@ #define DIRTY_SCANLINE(R, Y) R->scanlineDirty[Y >> 5] |= (1U << (Y & 0x1F)) #define CLEAN_SCANLINE(R, Y) R->scanlineDirty[Y >> 5] &= ~(1U << (Y & 0x1F)) +#define SOFTWARE_MAGIC 0x6E727773 static void GBAVideoSoftwareRendererInit(struct GBAVideoRenderer* renderer); static void GBAVideoSoftwareRendererDeinit(struct GBAVideoRenderer* renderer); static void GBAVideoSoftwareRendererReset(struct GBAVideoRenderer* renderer); +static uint32_t GBAVideoSoftwareRendererId(const struct GBAVideoRenderer* renderer); +static bool GBAVideoSoftwareRendererLoadState(struct GBAVideoRenderer* renderer, const void* state, size_t size); +static void GBAVideoSoftwareRendererSaveState(struct GBAVideoRenderer* renderer, void** state, size_t* size); static void GBAVideoSoftwareRendererWriteVRAM(struct GBAVideoRenderer* renderer, uint32_t address); static void GBAVideoSoftwareRendererWriteOAM(struct GBAVideoRenderer* renderer, uint32_t oam); static void GBAVideoSoftwareRendererWritePalette(struct GBAVideoRenderer* renderer, uint32_t address, uint16_t value); @@ -47,9 +51,13 @@ static void _breakWindow(struct GBAVideoSoftwareRenderer* softwareRenderer, stru static void _breakWindowInner(struct GBAVideoSoftwareRenderer* softwareRenderer, struct WindowN* win); void GBAVideoSoftwareRendererCreate(struct GBAVideoSoftwareRenderer* renderer) { + memset(renderer, 0, sizeof(*renderer)); renderer->d.init = GBAVideoSoftwareRendererInit; renderer->d.reset = GBAVideoSoftwareRendererReset; renderer->d.deinit = GBAVideoSoftwareRendererDeinit; + renderer->d.rendererId = GBAVideoSoftwareRendererId; + renderer->d.loadState = GBAVideoSoftwareRendererLoadState; + renderer->d.saveState = GBAVideoSoftwareRendererSaveState; renderer->d.writeVideoRegister = GBAVideoSoftwareRendererWriteVideoRegister; renderer->d.writeVRAM = GBAVideoSoftwareRendererWriteVRAM; renderer->d.writeOAM = GBAVideoSoftwareRendererWriteOAM; @@ -79,7 +87,7 @@ void GBAVideoSoftwareRendererCreate(struct GBAVideoSoftwareRenderer* renderer) { renderer->d.highlightColor = M_COLOR_WHITE; renderer->d.highlightAmount = 0; - renderer->temporaryBuffer = 0; + renderer->temporaryBuffer = NULL; } static void GBAVideoSoftwareRendererInit(struct GBAVideoRenderer* renderer) { @@ -155,6 +163,26 @@ static void GBAVideoSoftwareRendererDeinit(struct GBAVideoRenderer* renderer) { UNUSED(softwareRenderer); } +static uint32_t GBAVideoSoftwareRendererId(const struct GBAVideoRenderer* renderer) { + UNUSED(renderer); + return SOFTWARE_MAGIC; +} + +static bool GBAVideoSoftwareRendererLoadState(struct GBAVideoRenderer* renderer, const void* state, size_t size) { + UNUSED(renderer); + UNUSED(state); + UNUSED(size); + // TODO + return false; +} + +static void GBAVideoSoftwareRendererSaveState(struct GBAVideoRenderer* renderer, void** state, size_t* size) { + UNUSED(renderer); + *state = NULL; + *size = 0; + // TODO +} + static uint16_t GBAVideoSoftwareRendererWriteVideoRegister(struct GBAVideoRenderer* renderer, uint32_t address, uint16_t value) { struct GBAVideoSoftwareRenderer* softwareRenderer = (struct GBAVideoSoftwareRenderer*) renderer; if (renderer->cache) { From 3a07834226d271ad15dd54476c0940e49e5b4ed2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 6 Sep 2024 21:13:56 -0700 Subject: [PATCH 185/338] Test: Allow extdata fuzzing --- src/platform/test/fuzz-main.c | 26 ++++++++++++++++---------- 1 file changed, 16 insertions(+), 10 deletions(-) diff --git a/src/platform/test/fuzz-main.c b/src/platform/test/fuzz-main.c index af3bcf0833e..143edaba128 100644 --- a/src/platform/test/fuzz-main.c +++ b/src/platform/test/fuzz-main.c @@ -109,7 +109,7 @@ int main(int argc, char** argv) { } if (fuzzOpts.ssOverlay) { overlayOffset = fuzzOpts.overlayOffset; - if (overlayOffset < core->stateSize(core)) { + if (overlayOffset <= core->stateSize(core)) { savestateOverlay = VFileOpen(fuzzOpts.ssOverlay, O_RDONLY); } free(fuzzOpts.ssOverlay); @@ -137,19 +137,25 @@ int main(int argc, char** argv) { if (savestate) { if (!savestateOverlay) { - mCoreLoadStateNamed(core, savestate, 0); + mCoreLoadStateNamed(core, savestate, SAVESTATE_ALL); } else { - size_t size = core->stateSize(core); - uint8_t* state = malloc(size); - savestate->read(savestate, state, size); - savestateOverlay->read(savestateOverlay, state + overlayOffset, size - overlayOffset); - core->loadState(core, state); - free(state); + size_t size = savestate->size(savestate); + void* mapped = savestate->map(savestate, size, MAP_READ); + struct VFile* newState = VFileMemChunk(mapped, size); + savestate->unmap(savestate, mapped, size); + newState->seek(newState, overlayOffset, SEEK_SET); + uint8_t buffer[2048]; + int read; + while ((read = savestateOverlay->read(savestateOverlay, buffer, sizeof(buffer))) > 0) { + newState->write(newState, buffer, read); + } savestateOverlay->close(savestateOverlay); - savestateOverlay = 0; + savestateOverlay = NULL; + mCoreLoadStateNamed(core, newState, SAVESTATE_ALL); + newState->close(newState); } savestate->close(savestate); - savestate = 0; + savestate = NULL; } _fuzzRunloop(core, fuzzOpts.frames); From ae6cc33a5e6d2c0339d2ef586a6d186f4bc860ca Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 6 Sep 2024 21:33:09 -0700 Subject: [PATCH 186/338] Core: Improve future-proofing of struct initialization --- src/core/interface.c | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/src/core/interface.c b/src/core/interface.c index e5b7f83783a..10d3433ab2d 100644 --- a/src/core/interface.c +++ b/src/core/interface.c @@ -101,9 +101,9 @@ static bool _rtcGenericDeserialize(struct mRTCSource* source, const struct mStat } void mRTCGenericSourceInit(struct mRTCGenericSource* rtc, struct mCore* core) { + memset(rtc, 0, sizeof(*rtc)); rtc->p = core; rtc->override = RTC_NO_OVERRIDE; - rtc->value = 0; rtc->d.sample = _rtcGenericSample; rtc->d.unixTime = _rtcGenericCallback; rtc->d.serialize = _rtcGenericSerialize; @@ -143,10 +143,8 @@ static void mRumbleIntegratorIntegrate(struct mRumble* rumble, uint32_t period) } void mRumbleIntegratorInit(struct mRumbleIntegrator* integrator) { + memset(integrator, 0, sizeof(*integrator)); integrator->d.reset = mRumbleIntegratorReset; integrator->d.setRumble = mRumbleIntegratorSetRumble; integrator->d.integrate = mRumbleIntegratorIntegrate; - - integrator->state = false; - integrator->timeOn = 0; } From b072cb40cb073a4bb6fdf38535d457c1a66865fc Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 6 Sep 2024 23:24:04 -0700 Subject: [PATCH 187/338] Core: Fix video proxy renderer creation and improve API --- include/mgba/internal/gb/renderers/proxy.h | 2 +- include/mgba/internal/gba/renderers/proxy.h | 2 +- src/gb/core.c | 16 +++++++-------- src/gb/extra/proxy.c | 16 ++++++++------- src/gba/core.c | 22 ++++++++++----------- src/gba/extra/proxy.c | 17 ++++++++-------- 6 files changed, 38 insertions(+), 37 deletions(-) diff --git a/include/mgba/internal/gb/renderers/proxy.h b/include/mgba/internal/gb/renderers/proxy.h index ca3b59f29ad..b7db8d00fc4 100644 --- a/include/mgba/internal/gb/renderers/proxy.h +++ b/include/mgba/internal/gb/renderers/proxy.h @@ -20,7 +20,7 @@ struct GBVideoProxyRenderer { enum GBModel model; }; -void GBVideoProxyRendererCreate(struct GBVideoProxyRenderer* renderer, struct GBVideoRenderer* backend); +void GBVideoProxyRendererCreate(struct GBVideoProxyRenderer* renderer, struct GBVideoRenderer* backend, struct mVideoLogger* logger); void GBVideoProxyRendererShim(struct GBVideo* video, struct GBVideoProxyRenderer* renderer); void GBVideoProxyRendererUnshim(struct GBVideo* video, struct GBVideoProxyRenderer* renderer); diff --git a/include/mgba/internal/gba/renderers/proxy.h b/include/mgba/internal/gba/renderers/proxy.h index c1044c77e31..6cb58d092e8 100644 --- a/include/mgba/internal/gba/renderers/proxy.h +++ b/include/mgba/internal/gba/renderers/proxy.h @@ -19,7 +19,7 @@ struct GBAVideoProxyRenderer { struct mVideoLogger* logger; }; -void GBAVideoProxyRendererCreate(struct GBAVideoProxyRenderer* renderer, struct GBAVideoRenderer* backend); +void GBAVideoProxyRendererCreate(struct GBAVideoProxyRenderer* renderer, struct GBAVideoRenderer* backend, struct mVideoLogger* logger); void GBAVideoProxyRendererShim(struct GBAVideo* video, struct GBAVideoProxyRenderer* renderer); void GBAVideoProxyRendererUnshim(struct GBAVideo* video, struct GBAVideoProxyRenderer* renderer); diff --git a/src/gb/core.c b/src/gb/core.c index 17a474ed18e..020bf85232b 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -1266,12 +1266,12 @@ static void _GBCoreStartVideoLog(struct mCore* core, struct mVideoLogContext* co gbcore->logContext = context; int channelId = mVideoLoggerAddChannel(context); - gbcore->proxyRenderer.logger = malloc(sizeof(struct mVideoLogger)); - mVideoLoggerRendererCreate(gbcore->proxyRenderer.logger, false); - mVideoLoggerAttachChannel(gbcore->proxyRenderer.logger, context, channelId); - gbcore->proxyRenderer.logger->block = false; + struct mVideoLogger* logger = malloc(sizeof(*logger)); + mVideoLoggerRendererCreate(logger, false); + mVideoLoggerAttachChannel(logger, context, channelId); + logger->block = false; - GBVideoProxyRendererCreate(&gbcore->proxyRenderer, &gbcore->renderer.d); + GBVideoProxyRendererCreate(&gbcore->proxyRenderer, &gbcore->renderer.d, logger); GBVideoProxyRendererShim(&gb->video, &gbcore->proxyRenderer); } @@ -1405,9 +1405,9 @@ static bool _GBVLPInit(struct mCore* core) { if (!_GBCoreInit(core)) { return false; } - gbcore->proxyRenderer.logger = malloc(sizeof(struct mVideoLogger)); - mVideoLoggerRendererCreate(gbcore->proxyRenderer.logger, true); - GBVideoProxyRendererCreate(&gbcore->proxyRenderer, NULL); + struct mVideoLogger* logger = malloc(sizeof(*logger)); + mVideoLoggerRendererCreate(logger, true); + GBVideoProxyRendererCreate(&gbcore->proxyRenderer, NULL, logger); memset(&gbcore->logCallbacks, 0, sizeof(gbcore->logCallbacks)); gbcore->logCallbacks.videoFrameStarted = _GBVLPStartFrameCallback; gbcore->logCallbacks.context = core; diff --git a/src/gb/extra/proxy.c b/src/gb/extra/proxy.c index 54d46eef3c9..ba36c0090cf 100644 --- a/src/gb/extra/proxy.c +++ b/src/gb/extra/proxy.c @@ -29,7 +29,8 @@ static void GBVideoProxyRendererPutPixels(struct GBVideoRenderer* renderer, size static bool _parsePacket(struct mVideoLogger* logger, const struct mVideoLoggerDirtyInfo* packet); static uint16_t* _vramBlock(struct mVideoLogger* logger, uint32_t address); -void GBVideoProxyRendererCreate(struct GBVideoProxyRenderer* renderer, struct GBVideoRenderer* backend) { +void GBVideoProxyRendererCreate(struct GBVideoProxyRenderer* renderer, struct GBVideoRenderer* backend, struct mVideoLogger* logger) { + memset(renderer, 0, sizeof(*renderer)); renderer->d.init = GBVideoProxyRendererInit; renderer->d.deinit = GBVideoProxyRendererDeinit; renderer->d.writeVideoRegister = GBVideoProxyRendererWriteVideoRegister; @@ -57,12 +58,13 @@ void GBVideoProxyRendererCreate(struct GBVideoProxyRenderer* renderer, struct GB renderer->d.highlightColor = M_COLOR_WHITE; renderer->d.highlightAmount = 0; - renderer->logger->context = renderer; - renderer->logger->parsePacket = _parsePacket; - renderer->logger->vramBlock = _vramBlock; - renderer->logger->paletteSize = 0; - renderer->logger->vramSize = GB_SIZE_VRAM; - renderer->logger->oamSize = GB_SIZE_OAM; + renderer->logger = logger; + logger->context = renderer; + logger->parsePacket = _parsePacket; + logger->vramBlock = _vramBlock; + logger->paletteSize = 0; + logger->vramSize = GB_SIZE_VRAM; + logger->oamSize = GB_SIZE_OAM; renderer->backend = backend; } diff --git a/src/gba/core.c b/src/gba/core.c index e9cf2b81c68..ea6adfdf3be 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -470,8 +470,7 @@ static void _GBACoreReloadConfigOption(struct mCore* core, const char* option, c #endif #ifndef MINIMAL_CORE if (renderer && core->videoLogger) { - gbacore->proxyRenderer.logger = core->videoLogger; - GBAVideoProxyRendererCreate(&gbacore->proxyRenderer, renderer); + GBAVideoProxyRendererCreate(&gbacore->proxyRenderer, renderer, core->videoLogger); renderer = &gbacore->proxyRenderer.d; } #endif @@ -712,8 +711,7 @@ static void _GBACoreReset(struct mCore* core) { #endif #ifndef MINIMAL_CORE if (renderer && core->videoLogger) { - gbacore->proxyRenderer.logger = core->videoLogger; - GBAVideoProxyRendererCreate(&gbacore->proxyRenderer, renderer); + GBAVideoProxyRendererCreate(&gbacore->proxyRenderer, renderer, core->videoLogger); renderer = &gbacore->proxyRenderer.d; } #endif @@ -1516,12 +1514,12 @@ static void _GBACoreStartVideoLog(struct mCore* core, struct mVideoLogContext* c state->cpu.gprs[ARM_PC] = GBA_BASE_EWRAM; int channelId = mVideoLoggerAddChannel(context); - gbacore->vlProxy.logger = malloc(sizeof(struct mVideoLogger)); - mVideoLoggerRendererCreate(gbacore->vlProxy.logger, false); - mVideoLoggerAttachChannel(gbacore->vlProxy.logger, context, channelId); - gbacore->vlProxy.logger->block = false; + struct mVideoLogger* logger = malloc(sizeof(*logger)); + mVideoLoggerRendererCreate(logger, false); + mVideoLoggerAttachChannel(logger, context, channelId); + logger->block = false; - GBAVideoProxyRendererCreate(&gbacore->vlProxy, gba->video.renderer); + GBAVideoProxyRendererCreate(&gbacore->vlProxy, gba->video.renderer, logger); GBAVideoProxyRendererShim(&gba->video, &gbacore->vlProxy); } @@ -1654,9 +1652,9 @@ static bool _GBAVLPInit(struct mCore* core) { if (!_GBACoreInit(core)) { return false; } - gbacore->vlProxy.logger = malloc(sizeof(struct mVideoLogger)); - mVideoLoggerRendererCreate(gbacore->vlProxy.logger, true); - GBAVideoProxyRendererCreate(&gbacore->vlProxy, NULL); + struct mVideoLogger* logger = malloc(sizeof(*logger)); + mVideoLoggerRendererCreate(logger, true); + GBAVideoProxyRendererCreate(&gbacore->vlProxy, NULL, logger); memset(&gbacore->logCallbacks, 0, sizeof(gbacore->logCallbacks)); gbacore->logCallbacks.videoFrameStarted = _GBAVLPStartFrameCallback; gbacore->logCallbacks.context = core; diff --git a/src/gba/extra/proxy.c b/src/gba/extra/proxy.c index 0847e1f4a5b..ee611247b31 100644 --- a/src/gba/extra/proxy.c +++ b/src/gba/extra/proxy.c @@ -29,7 +29,7 @@ static void _handleEvent(struct mVideoLogger* logger, enum mVideoLoggerEvent eve static bool _parsePacket(struct mVideoLogger* logger, const struct mVideoLoggerDirtyInfo* packet); static uint16_t* _vramBlock(struct mVideoLogger* logger, uint32_t address); -void GBAVideoProxyRendererCreate(struct GBAVideoProxyRenderer* renderer, struct GBAVideoRenderer* backend) { +void GBAVideoProxyRendererCreate(struct GBAVideoProxyRenderer* renderer, struct GBAVideoRenderer* backend, struct mVideoLogger* logger) { memset(renderer, 0, sizeof(*renderer)); renderer->d.init = GBAVideoProxyRendererInit; renderer->d.reset = GBAVideoProxyRendererReset; @@ -66,13 +66,14 @@ void GBAVideoProxyRendererCreate(struct GBAVideoProxyRenderer* renderer, struct renderer->d.highlightColor = M_COLOR_WHITE; renderer->d.highlightAmount = 0; - renderer->logger->context = renderer; - renderer->logger->parsePacket = _parsePacket; - renderer->logger->handleEvent = _handleEvent; - renderer->logger->vramBlock = _vramBlock; - renderer->logger->paletteSize = GBA_SIZE_PALETTE_RAM; - renderer->logger->vramSize = GBA_SIZE_VRAM; - renderer->logger->oamSize = GBA_SIZE_OAM; + renderer->logger = logger; + logger->context = renderer; + logger->parsePacket = _parsePacket; + logger->handleEvent = _handleEvent; + logger->vramBlock = _vramBlock; + logger->paletteSize = GBA_SIZE_PALETTE_RAM; + logger->vramSize = GBA_SIZE_VRAM; + logger->oamSize = GBA_SIZE_OAM; renderer->backend = backend; } From 1c85dba0df52d7329b3aaa78a84338866d833124 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 6 Sep 2024 23:22:06 -0700 Subject: [PATCH 188/338] Core: Fix creating mVL contexts dropping the savestate --- src/feature/video-logger.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/feature/video-logger.c b/src/feature/video-logger.c index adcbea2760a..4044a492839 100644 --- a/src/feature/video-logger.c +++ b/src/feature/video-logger.c @@ -516,7 +516,7 @@ struct mVideoLogContext* mVideoLogContextCreate(struct mCore* core) { context->initialStateSize = vf->size(vf); context->initialState = anonymousMemoryMap(context->initialStateSize); vf->seek(vf, 0, SEEK_SET); - vf->write(vf, context->initialState, context->initialStateSize); + vf->read(vf, context->initialState, context->initialStateSize); vf->close(vf); core->startVideoLog(core, context); } From a6914b2ddb865bb3e67250cd22cbdc307085284e Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 6 Sep 2024 22:43:42 -0700 Subject: [PATCH 189/338] Util: Rename color_t to avoid namespace conflicts --- include/mgba-util/image.h | 12 ++--- include/mgba/core/bitmap-cache.h | 8 +-- include/mgba/core/cache-set.h | 2 +- include/mgba/core/core.h | 2 +- include/mgba/core/interface.h | 2 +- include/mgba/core/map-cache.h | 4 +- include/mgba/core/tile-cache.h | 14 +++--- include/mgba/internal/gb/renderers/software.h | 4 +- include/mgba/internal/gb/video.h | 2 +- .../internal/gba/renderers/video-software.h | 10 ++-- include/mgba/internal/gba/video.h | 2 +- src/core/bitmap-cache.c | 14 +++--- src/core/cache-set.c | 2 +- src/core/map-cache.c | 50 +++++++++---------- src/core/test/scripting.c | 2 +- src/core/tile-cache.c | 30 +++++------ src/feature/ffmpeg/ffmpeg-decoder.c | 2 +- src/feature/ffmpeg/ffmpeg-encoder.c | 4 +- src/feature/gui/gui-runner.c | 2 +- src/feature/gui/gui-runner.h | 4 +- src/gb/core.c | 2 +- src/gb/gb.c | 2 +- src/gb/renderers/software.c | 8 +-- src/gba/core.c | 2 +- src/gba/gba.c | 2 +- src/gba/renderers/software-bg.c | 2 +- src/gba/renderers/software-mode0.c | 2 +- src/gba/renderers/software-obj.c | 4 +- src/gba/renderers/software-private.h | 4 +- src/gba/renderers/video-software.c | 8 +-- src/platform/3ds/main.c | 18 +++---- src/platform/libretro/libretro.c | 4 +- src/platform/psp2/psp2-context.h | 2 +- src/platform/python/mgba/image.py | 4 +- src/platform/python/mgba/tile.py | 4 +- src/platform/qt/AssetTile.cpp | 6 +-- src/platform/qt/AssetView.cpp | 2 +- src/platform/qt/CoreController.cpp | 20 ++++---- src/platform/qt/CoreController.h | 2 +- src/platform/qt/DisplayQt.cpp | 2 +- src/platform/qt/FrameView.cpp | 2 +- src/platform/qt/ObjView.cpp | 4 +- src/platform/qt/TilePainter.cpp | 2 +- src/platform/qt/TilePainter.h | 2 +- src/platform/qt/TileView.cpp | 10 ++-- src/platform/sdl/main.h | 2 +- src/platform/switch/main.c | 4 +- src/platform/test/cinema-main.c | 2 +- 48 files changed, 150 insertions(+), 150 deletions(-) diff --git a/include/mgba-util/image.h b/include/mgba-util/image.h index 681e0a3a664..dd135a0b439 100644 --- a/include/mgba-util/image.h +++ b/include/mgba-util/image.h @@ -11,10 +11,10 @@ CXX_GUARD_START #ifdef COLOR_16_BIT -typedef uint16_t color_t; +typedef uint16_t mColor; #define BYTES_PER_PIXEL 2 #else -typedef uint32_t color_t; +typedef uint32_t mColor; #define BYTES_PER_PIXEL 4 #endif @@ -210,18 +210,18 @@ static inline bool mColorFormatHasAlpha(enum mColorFormat format) { return false; } -static inline color_t mColorFrom555(uint16_t value) { +static inline mColor mColorFrom555(uint16_t value) { #ifdef COLOR_16_BIT #ifdef COLOR_5_6_5 - color_t color = 0; + mColor color = 0; color |= (value & 0x001F) << 11; color |= (value & 0x03E0) << 1; color |= (value & 0x7C00) >> 10; #else - color_t color = value; + mColor color = value; #endif #else - color_t color = M_RGB5_TO_BGR8(value); + mColor color = M_RGB5_TO_BGR8(value); color |= (color >> 5) & 0x070707; #endif return color; diff --git a/include/mgba/core/bitmap-cache.h b/include/mgba/core/bitmap-cache.h index d8bd416e9c4..1529fddc2bb 100644 --- a/include/mgba/core/bitmap-cache.h +++ b/include/mgba/core/bitmap-cache.h @@ -29,13 +29,13 @@ struct mBitmapCacheEntry { }; struct mBitmapCache { - color_t* cache; + mColor* cache; struct mBitmapCacheEntry* status; uint32_t globalPaletteVersion; uint8_t* vram; - color_t* palette; + mColor* palette; uint32_t bitsSize; uint32_t bitsStart[2]; @@ -53,11 +53,11 @@ void mBitmapCacheDeinit(struct mBitmapCache* cache); void mBitmapCacheConfigure(struct mBitmapCache* cache, mBitmapCacheConfiguration config); void mBitmapCacheConfigureSystem(struct mBitmapCache* cache, mBitmapCacheSystemInfo config); void mBitmapCacheWriteVRAM(struct mBitmapCache* cache, uint32_t address); -void mBitmapCacheWritePalette(struct mBitmapCache* cache, uint32_t entry, color_t color); +void mBitmapCacheWritePalette(struct mBitmapCache* cache, uint32_t entry, mColor color); void mBitmapCacheCleanRow(struct mBitmapCache* cache, struct mBitmapCacheEntry* entry, unsigned y); bool mBitmapCacheCheckRow(struct mBitmapCache* cache, const struct mBitmapCacheEntry* entry, unsigned y); -const color_t* mBitmapCacheGetRow(struct mBitmapCache* cache, unsigned y); +const mColor* mBitmapCacheGetRow(struct mBitmapCache* cache, unsigned y); CXX_GUARD_END diff --git a/include/mgba/core/cache-set.h b/include/mgba/core/cache-set.h index 5749c0e64b3..627a647c726 100644 --- a/include/mgba/core/cache-set.h +++ b/include/mgba/core/cache-set.h @@ -31,7 +31,7 @@ void mCacheSetDeinit(struct mCacheSet*); void mCacheSetAssignVRAM(struct mCacheSet*, void* vram); void mCacheSetWriteVRAM(struct mCacheSet*, uint32_t address); -void mCacheSetWritePalette(struct mCacheSet*, uint32_t entry, color_t color); +void mCacheSetWritePalette(struct mCacheSet*, uint32_t entry, mColor color); CXX_GUARD_END diff --git a/include/mgba/core/core.h b/include/mgba/core/core.h index 04bca468922..e8c5df7bc8a 100644 --- a/include/mgba/core/core.h +++ b/include/mgba/core/core.h @@ -73,7 +73,7 @@ struct mCore { unsigned (*videoScale)(const struct mCore*); size_t (*screenRegions)(const struct mCore*, const struct mCoreScreenRegion**); - void (*setVideoBuffer)(struct mCore*, color_t* buffer, size_t stride); + void (*setVideoBuffer)(struct mCore*, mColor* buffer, size_t stride); void (*setVideoGLTex)(struct mCore*, unsigned texid); void (*getPixels)(struct mCore*, const void** buffer, size_t* stride); diff --git a/include/mgba/core/interface.h b/include/mgba/core/interface.h index 2f4e299ddd1..5973877535b 100644 --- a/include/mgba/core/interface.h +++ b/include/mgba/core/interface.h @@ -47,7 +47,7 @@ DECLARE_VECTOR(mCoreCallbacksList, struct mCoreCallbacks); struct mAVStream { void (*videoDimensionsChanged)(struct mAVStream*, unsigned width, unsigned height); void (*audioRateChanged)(struct mAVStream*, unsigned rate); - void (*postVideoFrame)(struct mAVStream*, const color_t* buffer, size_t stride); + void (*postVideoFrame)(struct mAVStream*, const mColor* buffer, size_t stride); void (*postAudioFrame)(struct mAVStream*, int16_t left, int16_t right); void (*postAudioBuffer)(struct mAVStream*, struct mAudioBuffer*); }; diff --git a/include/mgba/core/map-cache.h b/include/mgba/core/map-cache.h index 349fc16637a..29f17866c23 100644 --- a/include/mgba/core/map-cache.h +++ b/include/mgba/core/map-cache.h @@ -44,7 +44,7 @@ struct mMapCacheEntry { struct mTileCache; struct mTileCacheEntry; struct mMapCache { - color_t* cache; + mColor* cache; struct mTileCache* tileCache; struct mMapCacheEntry* status; @@ -75,7 +75,7 @@ bool mMapCacheCheckTile(struct mMapCache* cache, const struct mMapCacheEntry* en void mMapCacheCleanTile(struct mMapCache* cache, struct mMapCacheEntry* entry, unsigned x, unsigned y); void mMapCacheCleanRow(struct mMapCache* cache, unsigned y); -const color_t* mMapCacheGetRow(struct mMapCache* cache, unsigned y); +const mColor* mMapCacheGetRow(struct mMapCache* cache, unsigned y); CXX_GUARD_END diff --git a/include/mgba/core/tile-cache.h b/include/mgba/core/tile-cache.h index f8600b3adfc..24458b011f8 100644 --- a/include/mgba/core/tile-cache.h +++ b/include/mgba/core/tile-cache.h @@ -29,7 +29,7 @@ struct mTileCacheEntry { }; struct mTileCache { - color_t* cache; + mColor* cache; struct mTileCacheEntry* status; uint32_t* globalPaletteVersion; @@ -39,8 +39,8 @@ struct mTileCache { unsigned bpp; uint16_t* vram; - color_t* palette; - color_t temporaryTile[64]; + mColor* palette; + mColor temporaryTile[64]; mTileCacheConfiguration config; mTileCacheSystemInfo sysConfig; @@ -51,11 +51,11 @@ void mTileCacheDeinit(struct mTileCache* cache); void mTileCacheConfigure(struct mTileCache* cache, mTileCacheConfiguration config); void mTileCacheConfigureSystem(struct mTileCache* cache, mTileCacheSystemInfo config, uint32_t tileBase, uint32_t paletteBase); void mTileCacheWriteVRAM(struct mTileCache* cache, uint32_t address); -void mTileCacheWritePalette(struct mTileCache* cache, uint32_t entry, color_t color); +void mTileCacheWritePalette(struct mTileCache* cache, uint32_t entry, mColor color); -const color_t* mTileCacheGetTile(struct mTileCache* cache, unsigned tileId, unsigned paletteId); -const color_t* mTileCacheGetTileIfDirty(struct mTileCache* cache, struct mTileCacheEntry* entry, unsigned tileId, unsigned paletteId); -const color_t* mTileCacheGetPalette(struct mTileCache* cache, unsigned paletteId); +const mColor* mTileCacheGetTile(struct mTileCache* cache, unsigned tileId, unsigned paletteId); +const mColor* mTileCacheGetTileIfDirty(struct mTileCache* cache, struct mTileCacheEntry* entry, unsigned tileId, unsigned paletteId); +const mColor* mTileCacheGetPalette(struct mTileCache* cache, unsigned paletteId); const uint16_t* mTileCacheGetVRAM(struct mTileCache* cache, unsigned tileId); CXX_GUARD_END diff --git a/include/mgba/internal/gb/renderers/software.h b/include/mgba/internal/gb/renderers/software.h index c61f2270d8b..4ca4c1c1f6e 100644 --- a/include/mgba/internal/gb/renderers/software.h +++ b/include/mgba/internal/gb/renderers/software.h @@ -22,13 +22,13 @@ struct GBVideoRendererSprite { struct GBVideoSoftwareRenderer { struct GBVideoRenderer d; - color_t* outputBuffer; + mColor* outputBuffer; int outputBufferStride; // TODO: Implement the pixel FIFO uint16_t row[GB_VIDEO_HORIZONTAL_PIXELS + 8]; - color_t palette[192]; + mColor palette[192]; uint8_t lookup[192]; uint32_t* temporaryBuffer; diff --git a/include/mgba/internal/gb/video.h b/include/mgba/internal/gb/video.h index c9b1797392d..fc0f650ca0c 100644 --- a/include/mgba/internal/gb/video.h +++ b/include/mgba/internal/gb/video.h @@ -109,7 +109,7 @@ struct GBVideoRenderer { bool highlightBG; bool highlightOBJ[GB_VIDEO_MAX_OBJ]; bool highlightWIN; - color_t highlightColor; + mColor highlightColor; uint8_t highlightAmount; }; diff --git a/include/mgba/internal/gba/renderers/video-software.h b/include/mgba/internal/gba/renderers/video-software.h index d03c5237490..d9a012fa889 100644 --- a/include/mgba/internal/gba/renderers/video-software.h +++ b/include/mgba/internal/gba/renderers/video-software.h @@ -82,7 +82,7 @@ struct Window { struct GBAVideoSoftwareRenderer { struct GBAVideoRenderer d; - color_t* outputBuffer; + mColor* outputBuffer; int outputBufferStride; uint32_t* temporaryBuffer; @@ -100,10 +100,10 @@ struct GBAVideoSoftwareRenderer { unsigned target2Bd; bool blendDirty; enum GBAVideoBlendEffect blendEffect; - color_t normalPalette[512]; - color_t variantPalette[512]; - color_t highlightPalette[512]; - color_t highlightVariantPalette[512]; + mColor normalPalette[512]; + mColor variantPalette[512]; + mColor highlightPalette[512]; + mColor highlightVariantPalette[512]; uint16_t blda; uint16_t bldb; diff --git a/include/mgba/internal/gba/video.h b/include/mgba/internal/gba/video.h index 92477266003..5fc68eb598d 100644 --- a/include/mgba/internal/gba/video.h +++ b/include/mgba/internal/gba/video.h @@ -208,7 +208,7 @@ struct GBAVideoRenderer { bool highlightBG[4]; bool highlightOBJ[128]; - color_t highlightColor; + mColor highlightColor; uint8_t highlightAmount; }; diff --git a/src/core/bitmap-cache.c b/src/core/bitmap-cache.c index 6cb14eaf0e6..f42da90c5ed 100644 --- a/src/core/bitmap-cache.c +++ b/src/core/bitmap-cache.c @@ -20,7 +20,7 @@ void mBitmapCacheInit(struct mBitmapCache* cache) { static void _freeCache(struct mBitmapCache* cache) { size_t size = mBitmapCacheSystemInfoGetHeight(cache->sysConfig) * mBitmapCacheSystemInfoGetBuffers(cache->sysConfig); if (cache->cache) { - mappedMemoryFree(cache->cache, mBitmapCacheSystemInfoGetWidth(cache->sysConfig) * size * sizeof(color_t)); + mappedMemoryFree(cache->cache, mBitmapCacheSystemInfoGetWidth(cache->sysConfig) * size * sizeof(mColor)); cache->cache = NULL; } if (cache->status) { @@ -39,10 +39,10 @@ static void _redoCacheSize(struct mBitmapCache* cache) { } size_t size = mBitmapCacheSystemInfoGetHeight(cache->sysConfig) * mBitmapCacheSystemInfoGetBuffers(cache->sysConfig); - cache->cache = anonymousMemoryMap(mBitmapCacheSystemInfoGetWidth(cache->sysConfig) * size * sizeof(color_t)); + cache->cache = anonymousMemoryMap(mBitmapCacheSystemInfoGetWidth(cache->sysConfig) * size * sizeof(mColor)); cache->status = anonymousMemoryMap(size * sizeof(*cache->status)); if (mBitmapCacheSystemInfoIsUsesPalette(cache->sysConfig)) { - cache->palette = calloc((1 << (1 << mBitmapCacheSystemInfoGetEntryBPP(cache->sysConfig))), sizeof(color_t)); + cache->palette = calloc((1 << (1 << mBitmapCacheSystemInfoGetEntryBPP(cache->sysConfig))), sizeof(mColor)); } else { cache->palette = NULL; } @@ -101,7 +101,7 @@ void mBitmapCacheWriteVRAM(struct mBitmapCache* cache, uint32_t address) { } } -void mBitmapCacheWritePalette(struct mBitmapCache* cache, uint32_t entry, color_t color) { +void mBitmapCacheWritePalette(struct mBitmapCache* cache, uint32_t entry, mColor color) { if (!mBitmapCacheSystemInfoIsUsesPalette(cache->sysConfig)) { return; } @@ -122,7 +122,7 @@ uint32_t _lookupEntry15(void* vram, uint32_t offset) { } void mBitmapCacheCleanRow(struct mBitmapCache* cache, struct mBitmapCacheEntry* entry, unsigned y) { - color_t* row = &cache->cache[(cache->buffer * mBitmapCacheSystemInfoGetHeight(cache->sysConfig) + y) * mBitmapCacheSystemInfoGetWidth(cache->sysConfig)]; + mColor* row = &cache->cache[(cache->buffer * mBitmapCacheSystemInfoGetHeight(cache->sysConfig) + y) * mBitmapCacheSystemInfoGetWidth(cache->sysConfig)]; size_t location = cache->buffer + mBitmapCacheSystemInfoGetBuffers(cache->sysConfig) * y; struct mBitmapCacheEntry* status = &cache->status[location]; struct mBitmapCacheEntry desiredStatus = { @@ -181,7 +181,7 @@ bool mBitmapCacheCheckRow(struct mBitmapCache* cache, const struct mBitmapCacheE return memcmp(&entry[location], &desiredStatus, sizeof(*entry)) == 0; } -const color_t* mBitmapCacheGetRow(struct mBitmapCache* cache, unsigned y) { - color_t* row = &cache->cache[(cache->buffer * mBitmapCacheSystemInfoGetHeight(cache->sysConfig) + y) * mBitmapCacheSystemInfoGetWidth(cache->sysConfig)]; +const mColor* mBitmapCacheGetRow(struct mBitmapCache* cache, unsigned y) { + mColor* row = &cache->cache[(cache->buffer * mBitmapCacheSystemInfoGetHeight(cache->sysConfig) + y) * mBitmapCacheSystemInfoGetWidth(cache->sysConfig)]; return row; } diff --git a/src/core/cache-set.c b/src/core/cache-set.c index 04d42a2338f..098844bd923 100644 --- a/src/core/cache-set.c +++ b/src/core/cache-set.c @@ -72,7 +72,7 @@ void mCacheSetWriteVRAM(struct mCacheSet* cache, uint32_t address) { } } -void mCacheSetWritePalette(struct mCacheSet* cache, uint32_t entry, color_t color) { +void mCacheSetWritePalette(struct mCacheSet* cache, uint32_t entry, mColor color) { size_t i; for (i = 0; i < mBitmapCacheSetSize(&cache->bitmaps); ++i) { mBitmapCacheWritePalette(mBitmapCacheSetGetPointer(&cache->bitmaps, i), entry, color); diff --git a/src/core/map-cache.c b/src/core/map-cache.c index d51800780f7..5668d82f332 100644 --- a/src/core/map-cache.c +++ b/src/core/map-cache.c @@ -18,7 +18,7 @@ void mMapCacheInit(struct mMapCache* cache) { static void _freeCache(struct mMapCache* cache) { size_t tiles = (1 << mMapCacheSystemInfoGetTilesWide(cache->sysConfig)) * (1 << mMapCacheSystemInfoGetTilesHigh(cache->sysConfig)); if (cache->cache) { - mappedMemoryFree(cache->cache, 8 * 8 * sizeof(color_t) * tiles); + mappedMemoryFree(cache->cache, 8 * 8 * sizeof(mColor) * tiles); cache->cache = NULL; } if (cache->status) { @@ -33,7 +33,7 @@ static void _redoCacheSize(struct mMapCache* cache) { } size_t tiles = mMapCacheTileCount(cache); - cache->cache = anonymousMemoryMap(8 * 8 * sizeof(color_t) * tiles); + cache->cache = anonymousMemoryMap(8 * 8 * sizeof(mColor) * tiles); cache->status = anonymousMemoryMap(tiles * sizeof(*cache->status)); } @@ -87,19 +87,19 @@ void mMapCacheWriteVRAM(struct mMapCache* cache, uint32_t address) { } } -static inline void _cleanTile(struct mMapCache* cache, const color_t* tile, color_t* mapOut, const struct mMapCacheEntry* status) { +static inline void _cleanTile(struct mMapCache* cache, const mColor* tile, mColor* mapOut, const struct mMapCacheEntry* status) { size_t stride = 8 << mMapCacheSystemInfoGetTilesWide(cache->sysConfig); int x, y; switch (mMapCacheEntryFlagsGetMirror(status->flags)) { case 0: - memcpy(mapOut, tile, sizeof(color_t) * 8); - memcpy(&mapOut[stride], &tile[0x08], sizeof(color_t) * 8); - memcpy(&mapOut[stride * 2], &tile[0x10], sizeof(color_t) * 8); - memcpy(&mapOut[stride * 3], &tile[0x18], sizeof(color_t) * 8); - memcpy(&mapOut[stride * 4], &tile[0x20], sizeof(color_t) * 8); - memcpy(&mapOut[stride * 5], &tile[0x28], sizeof(color_t) * 8); - memcpy(&mapOut[stride * 6], &tile[0x30], sizeof(color_t) * 8); - memcpy(&mapOut[stride * 7], &tile[0x38], sizeof(color_t) * 8); + memcpy(mapOut, tile, sizeof(mColor) * 8); + memcpy(&mapOut[stride], &tile[0x08], sizeof(mColor) * 8); + memcpy(&mapOut[stride * 2], &tile[0x10], sizeof(mColor) * 8); + memcpy(&mapOut[stride * 3], &tile[0x18], sizeof(mColor) * 8); + memcpy(&mapOut[stride * 4], &tile[0x20], sizeof(mColor) * 8); + memcpy(&mapOut[stride * 5], &tile[0x28], sizeof(mColor) * 8); + memcpy(&mapOut[stride * 6], &tile[0x30], sizeof(mColor) * 8); + memcpy(&mapOut[stride * 7], &tile[0x38], sizeof(mColor) * 8); break; case 1: for (y = 0; y < 8; ++y) { @@ -109,14 +109,14 @@ static inline void _cleanTile(struct mMapCache* cache, const color_t* tile, colo } break; case 2: - memcpy(&mapOut[stride * 7], tile, sizeof(color_t) * 8); - memcpy(&mapOut[stride * 6], &tile[0x08], sizeof(color_t) * 8); - memcpy(&mapOut[stride * 5], &tile[0x10], sizeof(color_t) * 8); - memcpy(&mapOut[stride * 4], &tile[0x18], sizeof(color_t) * 8); - memcpy(&mapOut[stride * 3], &tile[0x20], sizeof(color_t) * 8); - memcpy(&mapOut[stride * 2], &tile[0x28], sizeof(color_t) * 8); - memcpy(&mapOut[stride], &tile[0x30], sizeof(color_t) * 8); - memcpy(mapOut, &tile[0x38], sizeof(color_t) * 8); + memcpy(&mapOut[stride * 7], tile, sizeof(mColor) * 8); + memcpy(&mapOut[stride * 6], &tile[0x08], sizeof(mColor) * 8); + memcpy(&mapOut[stride * 5], &tile[0x10], sizeof(mColor) * 8); + memcpy(&mapOut[stride * 4], &tile[0x18], sizeof(mColor) * 8); + memcpy(&mapOut[stride * 3], &tile[0x20], sizeof(mColor) * 8); + memcpy(&mapOut[stride * 2], &tile[0x28], sizeof(mColor) * 8); + memcpy(&mapOut[stride], &tile[0x30], sizeof(mColor) * 8); + memcpy(mapOut, &tile[0x38], sizeof(mColor) * 8); break; case 3: for (y = 0; y < 8; ++y) { @@ -146,7 +146,7 @@ uint32_t mMapCacheTileId(struct mMapCache* cache, unsigned x, unsigned y) { void mMapCacheCleanTile(struct mMapCache* cache, struct mMapCacheEntry* entry, unsigned x, unsigned y) { size_t location = mMapCacheTileId(cache, x, y); struct mMapCacheEntry* status = &cache->status[location]; - const color_t* tile = NULL; + const mColor* tile = NULL; if (!mMapCacheEntryFlagsIsVramClean(status->flags)) { status->flags = mMapCacheEntryFlagsFillVramClean(status->flags); cache->mapParser(cache, status, &cache->vram[cache->mapStart + (location << mMapCacheSystemInfoGetMapAlign(cache->sysConfig))]); @@ -164,7 +164,7 @@ void mMapCacheCleanTile(struct mMapCache* cache, struct mMapCacheEntry* entry, u } size_t stride = 8 << mMapCacheSystemInfoGetTilesWide(cache->sysConfig); - color_t* mapOut = &cache->cache[(y * stride + x) * 8]; + mColor* mapOut = &cache->cache[(y * stride + x) * 8]; _cleanTile(cache, tile, mapOut, status); entry[location] = *status; } @@ -173,7 +173,7 @@ bool mMapCacheCheckTile(struct mMapCache* cache, const struct mMapCacheEntry* en size_t location = mMapCacheTileId(cache, x, y); struct mMapCacheEntry* status = &cache->status[location]; int paletteId = mMapCacheEntryFlagsGetPaletteId(status->flags); - const color_t* tile = NULL; + const mColor* tile = NULL; if (mMapCacheEntryFlagsIsVramClean(status->flags) && memcmp(status, &entry[location], sizeof(*entry)) == 0) { unsigned tileId = status->tileId + cache->tileStart; if (tileId >= mTileCacheSystemInfoGetMaxTiles(cache->tileCache->sysConfig)) { @@ -207,13 +207,13 @@ void mMapCacheCleanRow(struct mMapCache* cache, unsigned y) { if (tileId >= mTileCacheSystemInfoGetMaxTiles(cache->tileCache->sysConfig)) { tileId = 0; } - const color_t* tile = mTileCacheGetTile(cache->tileCache, tileId, mMapCacheEntryFlagsGetPaletteId(status->flags)); - color_t* mapOut = &cache->cache[(y * stride + x) * 8]; + const mColor* tile = mTileCacheGetTile(cache->tileCache, tileId, mMapCacheEntryFlagsGetPaletteId(status->flags)); + mColor* mapOut = &cache->cache[(y * stride + x) * 8]; _cleanTile(cache, tile, mapOut, status); } } -const color_t* mMapCacheGetRow(struct mMapCache* cache, unsigned y) { +const mColor* mMapCacheGetRow(struct mMapCache* cache, unsigned y) { size_t stride = 8 << mMapCacheSystemInfoGetTilesWide(cache->sysConfig); return &cache->cache[y * stride]; } diff --git a/src/core/test/scripting.c b/src/core/test/scripting.c index e66f2a722fd..63927effed1 100644 --- a/src/core/test/scripting.c +++ b/src/core/test/scripting.c @@ -312,7 +312,7 @@ M_TEST_DEFINE(logging) { M_TEST_DEFINE(screenshot) { SETUP_LUA; CREATE_CORE; - color_t* buffer = malloc(240 * 160 * sizeof(color_t)); + mColor* buffer = malloc(240 * 160 * sizeof(mColor)); core->setVideoBuffer(core, buffer, 240); core->reset(core); core->runFrame(core); diff --git a/src/core/tile-cache.c b/src/core/tile-cache.c index d9f68066cb4..26ea864160b 100644 --- a/src/core/tile-cache.c +++ b/src/core/tile-cache.c @@ -20,7 +20,7 @@ static void _freeCache(struct mTileCache* cache) { unsigned size = 1 << mTileCacheSystemInfoGetPaletteCount(cache->sysConfig); unsigned tiles = mTileCacheSystemInfoGetMaxTiles(cache->sysConfig); if (cache->cache) { - mappedMemoryFree(cache->cache, 8 * 8 * sizeof(color_t) * tiles * size); + mappedMemoryFree(cache->cache, 8 * 8 * sizeof(mColor) * tiles * size); cache->cache = NULL; } if (cache->status) { @@ -44,7 +44,7 @@ static void _redoCacheSize(struct mTileCache* cache) { size = 1 << size; cache->entriesPerTile = size; unsigned tiles = mTileCacheSystemInfoGetMaxTiles(cache->sysConfig); - cache->cache = anonymousMemoryMap(8 * 8 * sizeof(color_t) * tiles * size); + cache->cache = anonymousMemoryMap(8 * 8 * sizeof(mColor) * tiles * size); cache->status = anonymousMemoryMap(tiles * size * sizeof(*cache->status)); cache->globalPaletteVersion = calloc(size, sizeof(*cache->globalPaletteVersion)); cache->palette = calloc(size * bpp, sizeof(*cache->palette)); @@ -89,7 +89,7 @@ void mTileCacheWriteVRAM(struct mTileCache* cache, uint32_t address) { } } -void mTileCacheWritePalette(struct mTileCache* cache, uint32_t entry, color_t color) { +void mTileCacheWritePalette(struct mTileCache* cache, uint32_t entry, mColor color) { if (entry < cache->paletteBase) { return; } @@ -103,10 +103,10 @@ void mTileCacheWritePalette(struct mTileCache* cache, uint32_t entry, color_t co ++cache->globalPaletteVersion[entry]; } -static void _regenerateTile4(struct mTileCache* cache, color_t* tile, unsigned tileId, unsigned paletteId) { +static void _regenerateTile4(struct mTileCache* cache, mColor* tile, unsigned tileId, unsigned paletteId) { uint8_t* start = (uint8_t*) &cache->vram[tileId << 3]; paletteId <<= 2; - color_t* palette = &cache->palette[paletteId]; + mColor* palette = &cache->palette[paletteId]; int i; for (i = 0; i < 8; ++i) { uint8_t tileDataLower = start[0]; @@ -133,10 +133,10 @@ static void _regenerateTile4(struct mTileCache* cache, color_t* tile, unsigned t } } -static void _regenerateTile16(struct mTileCache* cache, color_t* tile, unsigned tileId, unsigned paletteId) { +static void _regenerateTile16(struct mTileCache* cache, mColor* tile, unsigned tileId, unsigned paletteId) { uint32_t* start = (uint32_t*) &cache->vram[tileId << 4]; paletteId <<= 4; - color_t* palette = &cache->palette[paletteId]; + mColor* palette = &cache->palette[paletteId]; int i; for (i = 0; i < 8; ++i) { uint32_t line = *start; @@ -162,10 +162,10 @@ static void _regenerateTile16(struct mTileCache* cache, color_t* tile, unsigned } } -static void _regenerateTile256(struct mTileCache* cache, color_t* tile, unsigned tileId, unsigned paletteId) { +static void _regenerateTile256(struct mTileCache* cache, mColor* tile, unsigned tileId, unsigned paletteId) { uint32_t* start = (uint32_t*) &cache->vram[tileId << 5]; paletteId <<= 8; - color_t* palette = &cache->palette[paletteId]; + mColor* palette = &cache->palette[paletteId]; int i; for (i = 0; i < 8; ++i) { uint32_t line = *start; @@ -194,7 +194,7 @@ static void _regenerateTile256(struct mTileCache* cache, color_t* tile, unsigned } } -static inline color_t* _tileLookup(struct mTileCache* cache, unsigned tileId, unsigned paletteId) { +static inline mColor* _tileLookup(struct mTileCache* cache, unsigned tileId, unsigned paletteId) { if (mTileCacheConfigurationIsShouldStore(cache->config)) { unsigned tiles = mTileCacheSystemInfoGetMaxTiles(cache->sysConfig); mASSERT(tileId < tiles); @@ -205,7 +205,7 @@ static inline color_t* _tileLookup(struct mTileCache* cache, unsigned tileId, un } } -const color_t* mTileCacheGetTile(struct mTileCache* cache, unsigned tileId, unsigned paletteId) { +const mColor* mTileCacheGetTile(struct mTileCache* cache, unsigned tileId, unsigned paletteId) { unsigned count = cache->entriesPerTile; unsigned bpp = cache->bpp; struct mTileCacheEntry* status = &cache->status[tileId * count + paletteId]; @@ -215,7 +215,7 @@ const color_t* mTileCacheGetTile(struct mTileCache* cache, unsigned tileId, unsi .vramClean = 1, .paletteId = paletteId }; - color_t* tile = _tileLookup(cache, tileId, paletteId); + mColor* tile = _tileLookup(cache, tileId, paletteId); if (!mTileCacheConfigurationIsShouldStore(cache->config) || memcmp(status, &desiredStatus, sizeof(*status))) { switch (bpp) { case 0: @@ -235,7 +235,7 @@ const color_t* mTileCacheGetTile(struct mTileCache* cache, unsigned tileId, unsi return tile; } -const color_t* mTileCacheGetTileIfDirty(struct mTileCache* cache, struct mTileCacheEntry* entry, unsigned tileId, unsigned paletteId) { +const mColor* mTileCacheGetTileIfDirty(struct mTileCache* cache, struct mTileCacheEntry* entry, unsigned tileId, unsigned paletteId) { unsigned count = cache->entriesPerTile; unsigned bpp = cache->bpp; struct mTileCacheEntry* status = &cache->status[tileId * count + paletteId]; @@ -245,7 +245,7 @@ const color_t* mTileCacheGetTileIfDirty(struct mTileCache* cache, struct mTileCa .vramClean = 1, .paletteId = paletteId }; - color_t* tile = NULL; + mColor* tile = NULL; if (memcmp(status, &desiredStatus, sizeof(*status))) { tile = _tileLookup(cache, tileId, paletteId); switch (bpp) { @@ -270,7 +270,7 @@ const color_t* mTileCacheGetTileIfDirty(struct mTileCache* cache, struct mTileCa return tile; } -const color_t* mTileCacheGetPalette(struct mTileCache* cache, unsigned paletteId) { +const mColor* mTileCacheGetPalette(struct mTileCache* cache, unsigned paletteId) { return &cache->palette[paletteId << (1 << cache->bpp)]; } diff --git a/src/feature/ffmpeg/ffmpeg-decoder.c b/src/feature/ffmpeg/ffmpeg-decoder.c index daa47fbf2c1..09539ca61c2 100644 --- a/src/feature/ffmpeg/ffmpeg-decoder.c +++ b/src/feature/ffmpeg/ffmpeg-decoder.c @@ -190,7 +190,7 @@ bool FFmpegDecoderRead(struct FFmpegDecoder* decoder) { } int stride = decoder->width * BYTES_PER_PIXEL; sws_scale(decoder->scaleContext, (const uint8_t* const*) decoder->videoFrame->data, decoder->videoFrame->linesize, 0, decoder->videoFrame->height, &decoder->pixels, &stride); - decoder->out->postVideoFrame(decoder->out, (const color_t*) decoder->pixels, decoder->width); + decoder->out->postVideoFrame(decoder->out, (const mColor*) decoder->pixels, decoder->width); } } } diff --git a/src/feature/ffmpeg/ffmpeg-encoder.c b/src/feature/ffmpeg/ffmpeg-encoder.c index 220ce4d8602..5ee54a5e87d 100644 --- a/src/feature/ffmpeg/ffmpeg-encoder.c +++ b/src/feature/ffmpeg/ffmpeg-encoder.c @@ -34,7 +34,7 @@ #endif #include -static void _ffmpegPostVideoFrame(struct mAVStream*, const color_t* pixels, size_t stride); +static void _ffmpegPostVideoFrame(struct mAVStream*, const mColor* pixels, size_t stride); static void _ffmpegPostAudioFrame(struct mAVStream*, int16_t left, int16_t right); static void _ffmpegSetVideoDimensions(struct mAVStream*, unsigned width, unsigned height); static void _ffmpegSetAudioRate(struct mAVStream*, unsigned rate); @@ -784,7 +784,7 @@ bool _ffmpegWriteAudioFrame(struct FFmpegEncoder* encoder, struct AVFrame* audio return gotData; } -void _ffmpegPostVideoFrame(struct mAVStream* stream, const color_t* pixels, size_t stride) { +void _ffmpegPostVideoFrame(struct mAVStream* stream, const mColor* pixels, size_t stride) { struct FFmpegEncoder* encoder = (struct FFmpegEncoder*) stream; if (!encoder->context || !encoder->videoCodec) { return; diff --git a/src/feature/gui/gui-runner.c b/src/feature/gui/gui-runner.c index b3ce21ad970..035522f0232 100644 --- a/src/feature/gui/gui-runner.c +++ b/src/feature/gui/gui-runner.c @@ -123,7 +123,7 @@ static void _drawState(struct GUIBackground* background, void* id) { struct mGUIBackground* gbaBackground = (struct mGUIBackground*) background; unsigned stateId = ((uint32_t) id) >> 16; if (gbaBackground->p->drawScreenshot) { - color_t* pixels = gbaBackground->image; + mColor* pixels = gbaBackground->image; if (pixels && gbaBackground->screenshotId == (stateId | SCREENSHOT_VALID)) { gbaBackground->p->drawScreenshot(gbaBackground->p, pixels, gbaBackground->w, gbaBackground->h, true); return; diff --git a/src/feature/gui/gui-runner.h b/src/feature/gui/gui-runner.h index 334ef57d966..e65ced52fa4 100644 --- a/src/feature/gui/gui-runner.h +++ b/src/feature/gui/gui-runner.h @@ -31,7 +31,7 @@ struct mGUIBackground { struct GUIBackground d; struct mGUIRunner* p; - color_t* image; + mColor* image; size_t imageSize; uint16_t w; uint16_t h; @@ -86,7 +86,7 @@ struct mGUIRunner { void (*gameUnloaded)(struct mGUIRunner*); void (*prepareForFrame)(struct mGUIRunner*); void (*drawFrame)(struct mGUIRunner*, bool faded); - void (*drawScreenshot)(struct mGUIRunner*, const color_t* pixels, unsigned width, unsigned height, bool faded); + void (*drawScreenshot)(struct mGUIRunner*, const mColor* pixels, unsigned width, unsigned height, bool faded); void (*paused)(struct mGUIRunner*); void (*unpaused)(struct mGUIRunner*); void (*incrementScreenMode)(struct mGUIRunner*); diff --git a/src/gb/core.c b/src/gb/core.c index 020bf85232b..2bfea28ef95 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -407,7 +407,7 @@ static size_t _GBCoreScreenRegions(const struct mCore* core, const struct mCoreS } } -static void _GBCoreSetVideoBuffer(struct mCore* core, color_t* buffer, size_t stride) { +static void _GBCoreSetVideoBuffer(struct mCore* core, mColor* buffer, size_t stride) { struct GBCore* gbcore = (struct GBCore*) core; gbcore->renderer.outputBuffer = buffer; gbcore->renderer.outputBufferStride = stride; diff --git a/src/gb/gb.c b/src/gb/gb.c index 282fc45c18e..67dea55b8a2 100644 --- a/src/gb/gb.c +++ b/src/gb/gb.c @@ -1173,7 +1173,7 @@ void GBFrameEnded(struct GB* gb) { // TODO: Move to common code if (gb->stream && gb->stream->postVideoFrame) { - const color_t* pixels; + const mColor* pixels; size_t stride; gb->video.renderer->getPixels(gb->video.renderer, &stride, (const void**) &pixels); gb->stream->postVideoFrame(gb->stream, pixels, stride); diff --git a/src/gb/renderers/software.c b/src/gb/renderers/software.c index d157920fac7..76a0c55daf5 100644 --- a/src/gb/renderers/software.c +++ b/src/gb/renderers/software.c @@ -44,7 +44,7 @@ static void _clearScreen(struct GBVideoSoftwareRenderer* renderer) { } int y; for (y = 0; y < GB_VIDEO_VERTICAL_PIXELS; ++y) { - color_t* row = &renderer->outputBuffer[renderer->outputBufferStride * y + sgbOffset]; + mColor* row = &renderer->outputBuffer[renderer->outputBufferStride * y + sgbOffset]; int x; for (x = 0; x < GB_VIDEO_HORIZONTAL_PIXELS; x += 4) { row[x + 0] = renderer->palette[0]; @@ -492,7 +492,7 @@ static void GBVideoSoftwareRendererWriteSGBPacket(struct GBVideoRenderer* render static void GBVideoSoftwareRendererWritePalette(struct GBVideoRenderer* renderer, int index, uint16_t value) { struct GBVideoSoftwareRenderer* softwareRenderer = (struct GBVideoSoftwareRenderer*) renderer; - color_t color = mColorFrom555(value); + mColor color = mColorFrom555(value); if (softwareRenderer->model & GB_MODEL_SGB) { if (index >= PAL_SGB_BORDER && !(index & 0xF)) { color = softwareRenderer->palette[0]; @@ -668,7 +668,7 @@ static void GBVideoSoftwareRendererDrawRange(struct GBVideoRenderer* renderer, i if (softwareRenderer->model & GB_MODEL_SGB && softwareRenderer->sgbBorders) { sgbOffset = softwareRenderer->outputBufferStride * 40 + 48; } - color_t* row = &softwareRenderer->outputBuffer[softwareRenderer->outputBufferStride * y + sgbOffset]; + mColor* row = &softwareRenderer->outputBuffer[softwareRenderer->outputBufferStride * y + sgbOffset]; int x = startX; int p = 0; switch (softwareRenderer->d.sgbRenderMode) { @@ -1161,7 +1161,7 @@ static void GBVideoSoftwareRendererPutPixels(struct GBVideoRenderer* renderer, s struct GBVideoSoftwareRenderer* softwareRenderer = (struct GBVideoSoftwareRenderer*) renderer; // TODO: Share with GBAVideoSoftwareRendererGetPixels - const color_t* colorPixels = pixels; + const mColor* colorPixels = pixels; unsigned i; for (i = 0; i < GB_VIDEO_VERTICAL_PIXELS; ++i) { memmove(&softwareRenderer->outputBuffer[softwareRenderer->outputBufferStride * i], &colorPixels[stride * i], GB_VIDEO_HORIZONTAL_PIXELS * BYTES_PER_PIXEL); diff --git a/src/gba/core.c b/src/gba/core.c index ea6adfdf3be..a6939406e25 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -525,7 +525,7 @@ static size_t _GBACoreScreenRegions(const struct mCore* core, const struct mCore return 1; } -static void _GBACoreSetVideoBuffer(struct mCore* core, color_t* buffer, size_t stride) { +static void _GBACoreSetVideoBuffer(struct mCore* core, mColor* buffer, size_t stride) { struct GBACore* gbacore = (struct GBACore*) core; gbacore->renderer.outputBuffer = buffer; gbacore->renderer.outputBufferStride = stride; diff --git a/src/gba/gba.c b/src/gba/gba.c index ce7e3478e36..aab2cd3ec2f 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -980,7 +980,7 @@ void GBAFrameEnded(struct GBA* gba) { } if (gba->stream && gba->stream->postVideoFrame) { - const color_t* pixels; + const mColor* pixels; size_t stride; gba->video.renderer->getPixels(gba->video.renderer, &stride, (const void**) &pixels); gba->stream->postVideoFrame(gba->stream, pixels, stride); diff --git a/src/gba/renderers/software-bg.c b/src/gba/renderers/software-bg.c index 7d50b508869..6fa199b0ded 100644 --- a/src/gba/renderers/software-bg.c +++ b/src/gba/renderers/software-bg.c @@ -173,7 +173,7 @@ void GBAVideoSoftwareRendererDrawBackgroundMode4(struct GBAVideoSoftwareRenderer if (!objwinSlowPath) { _compositeBlendNoObjwin(renderer, pixel, palette[color] | flags, current); } else if (background->objwinForceEnable || (!(current & FLAG_OBJWIN)) == background->objwinOnly) { - color_t* currentPalette = (current & FLAG_OBJWIN) ? objwinPalette : palette; + mColor* currentPalette = (current & FLAG_OBJWIN) ? objwinPalette : palette; unsigned mergedFlags = flags; if (current & FLAG_OBJWIN) { mergedFlags = objwinFlags; diff --git a/src/gba/renderers/software-mode0.c b/src/gba/renderers/software-mode0.c index aa1d63924b4..4aada17b05a 100644 --- a/src/gba/renderers/software-mode0.c +++ b/src/gba/renderers/software-mode0.c @@ -512,7 +512,7 @@ void GBAVideoSoftwareRendererDrawBackgroundMode0(struct GBAVideoSoftwareRenderer uint32_t screenBase; uint32_t charBase; - color_t* palette = renderer->normalPalette; + mColor* palette = renderer->normalPalette; if (renderer->d.highlightAmount && background->highlight) { palette = renderer->highlightPalette; } diff --git a/src/gba/renderers/software-obj.c b/src/gba/renderers/software-obj.c index 3b44d86a558..4152685c646 100644 --- a/src/gba/renderers/software-obj.c +++ b/src/gba/renderers/software-obj.c @@ -182,11 +182,11 @@ int GBAVideoSoftwareRendererPreprocessSprite(struct GBAVideoSoftwareRenderer* re } } - color_t* palette = &renderer->normalPalette[0x100]; + mColor* palette = &renderer->normalPalette[0x100]; if (renderer->d.highlightAmount && renderer->d.highlightOBJ[index]) { palette = &renderer->highlightPalette[0x100]; } - color_t* objwinPalette = palette; + mColor* objwinPalette = palette; if (variant) { palette = &renderer->variantPalette[0x100]; diff --git a/src/gba/renderers/software-private.h b/src/gba/renderers/software-private.h index 8a195534b01..4f7e9f8d611 100644 --- a/src/gba/renderers/software-private.h +++ b/src/gba/renderers/software-private.h @@ -155,7 +155,7 @@ static inline void _compositeNoBlendNoObjwin(struct GBAVideoSoftwareRenderer* re // TODO: Remove UNUSEDs after implementing OBJWIN for modes 3 - 5 #define PREPARE_OBJWIN \ int objwinSlowPath = GBARegisterDISPCNTIsObjwinEnable(renderer->dispcnt); \ - color_t* objwinPalette = renderer->normalPalette; \ + mColor* objwinPalette = renderer->normalPalette; \ if (renderer->d.highlightAmount && background->highlight) { \ objwinPalette = renderer->highlightPalette; \ } \ @@ -194,7 +194,7 @@ static inline void _compositeNoBlendNoObjwin(struct GBAVideoSoftwareRenderer* re uint32_t flags = background->flags; \ uint32_t objwinFlags = background->objwinFlags; \ bool variant = background->variant; \ - color_t* palette = renderer->normalPalette; \ + mColor* palette = renderer->normalPalette; \ if (renderer->d.highlightAmount && background->highlight) { \ palette = renderer->highlightPalette; \ } \ diff --git a/src/gba/renderers/video-software.c b/src/gba/renderers/video-software.c index 41f092937fb..83550bcfa3d 100644 --- a/src/gba/renderers/video-software.c +++ b/src/gba/renderers/video-software.c @@ -97,7 +97,7 @@ static void GBAVideoSoftwareRendererInit(struct GBAVideoRenderer* renderer) { int y; for (y = 0; y < GBA_VIDEO_VERTICAL_PIXELS; ++y) { - color_t* row = &softwareRenderer->outputBuffer[softwareRenderer->outputBufferStride * y]; + mColor* row = &softwareRenderer->outputBuffer[softwareRenderer->outputBufferStride * y]; int x; for (x = 0; x < GBA_VIDEO_HORIZONTAL_PIXELS; ++x) { row[x] = M_COLOR_WHITE; @@ -422,7 +422,7 @@ static void GBAVideoSoftwareRendererWriteOAM(struct GBAVideoRenderer* renderer, static void GBAVideoSoftwareRendererWritePalette(struct GBAVideoRenderer* renderer, uint32_t address, uint16_t value) { struct GBAVideoSoftwareRenderer* softwareRenderer = (struct GBAVideoSoftwareRenderer*) renderer; - color_t color = mColorFrom555(value); + mColor color = mColorFrom555(value); softwareRenderer->normalPalette[address >> 1] = color; if (softwareRenderer->blendEffect == BLEND_BRIGHTEN) { softwareRenderer->variantPalette[address >> 1] = _brighten(color, softwareRenderer->bldy); @@ -610,7 +610,7 @@ static void GBAVideoSoftwareRendererDrawScanline(struct GBAVideoRenderer* render CLEAN_SCANLINE(softwareRenderer, y); - color_t* row = &softwareRenderer->outputBuffer[softwareRenderer->outputBufferStride * y]; + mColor* row = &softwareRenderer->outputBuffer[softwareRenderer->outputBufferStride * y]; if (GBARegisterDISPCNTIsForcedBlank(softwareRenderer->dispcnt)) { int x; for (x = 0; x < GBA_VIDEO_HORIZONTAL_PIXELS; ++x) { @@ -781,7 +781,7 @@ static void GBAVideoSoftwareRendererGetPixels(struct GBAVideoRenderer* renderer, static void GBAVideoSoftwareRendererPutPixels(struct GBAVideoRenderer* renderer, size_t stride, const void* pixels) { struct GBAVideoSoftwareRenderer* softwareRenderer = (struct GBAVideoSoftwareRenderer*) renderer; - const color_t* colorPixels = pixels; + const mColor* colorPixels = pixels; unsigned i; for (i = 0; i < GBA_VIDEO_VERTICAL_PIXELS; ++i) { memmove(&softwareRenderer->outputBuffer[softwareRenderer->outputBufferStride * i], &colorPixels[stride * i], GBA_VIDEO_HORIZONTAL_PIXELS * BYTES_PER_PIXEL); diff --git a/src/platform/3ds/main.c b/src/platform/3ds/main.c index de6575effb0..2d7f80d152a 100644 --- a/src/platform/3ds/main.c +++ b/src/platform/3ds/main.c @@ -85,8 +85,8 @@ static enum { } hasSound; // TODO: Move into context -static color_t* outputBuffer = NULL; -static color_t* screenshotBuffer = NULL; +static mColor* outputBuffer = NULL; +static mColor* screenshotBuffer = NULL; static struct mAVStream stream; static int16_t* audioLeft = 0; static size_t audioPos = 0; @@ -293,7 +293,7 @@ static void _setup(struct mGUIRunner* runner) { _map3DSKey(&runner->core->inputMap, KEY_L, GBA_KEY_L); _map3DSKey(&runner->core->inputMap, KEY_R, GBA_KEY_R); - memset(outputBuffer, 0, 256 * 224 * sizeof(color_t)); + memset(outputBuffer, 0, 256 * 224 * sizeof(mColor)); runner->core->setVideoBuffer(runner->core, outputBuffer, 256); unsigned mode; @@ -615,19 +615,19 @@ static void _drawFrame(struct mGUIRunner* runner, bool faded) { _drawTex(runner->core, faded, interframeBlending); } -static void _drawScreenshot(struct mGUIRunner* runner, const color_t* pixels, unsigned width, unsigned height, bool faded) { +static void _drawScreenshot(struct mGUIRunner* runner, const mColor* pixels, unsigned width, unsigned height, bool faded) { C3D_Tex* tex = &outputTexture[activeOutputTexture]; if (!screenshotBuffer) { - screenshotBuffer = linearMemAlign(256 * 224 * sizeof(color_t), 0x80); + screenshotBuffer = linearMemAlign(256 * 224 * sizeof(mColor), 0x80); } unsigned y; for (y = 0; y < height; ++y) { - memcpy(&screenshotBuffer[y * 256], &pixels[y * width], width * sizeof(color_t)); - memset(&screenshotBuffer[y * 256 + width], 0, (256 - width) * sizeof(color_t)); + memcpy(&screenshotBuffer[y * 256], &pixels[y * width], width * sizeof(mColor)); + memset(&screenshotBuffer[y * 256 + width], 0, (256 - width) * sizeof(mColor)); } - GSPGPU_FlushDataCache(screenshotBuffer, 256 * height * sizeof(color_t)); + GSPGPU_FlushDataCache(screenshotBuffer, 256 * height * sizeof(mColor)); C3D_SyncDisplayTransfer( (u32*) screenshotBuffer, GX_BUFFER_DIM(256, height), tex->data, GX_BUFFER_DIM(256, 256), @@ -917,7 +917,7 @@ int main(int argc, char* argv[]) { _cleanup(); return 1; } - outputBuffer = linearMemAlign(256 * 224 * sizeof(color_t), 0x80); + outputBuffer = linearMemAlign(256 * 224 * sizeof(mColor), 0x80); struct mGUIRunner runner = { .params = { diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index 88743b63edc..232c4e6ebb3 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -37,7 +37,7 @@ #define VIDEO_WIDTH_MAX 256 #define VIDEO_HEIGHT_MAX 224 -#define VIDEO_BUFF_SIZE (VIDEO_WIDTH_MAX * VIDEO_HEIGHT_MAX * sizeof(color_t)) +#define VIDEO_BUFF_SIZE (VIDEO_WIDTH_MAX * VIDEO_HEIGHT_MAX * sizeof(mColor)) static retro_environment_t environCallback; static retro_video_refresh_t videoCallback; @@ -66,7 +66,7 @@ static int32_t _readTiltY(struct mRotationSource* source); static int32_t _readGyroZ(struct mRotationSource* source); static struct mCore* core; -static color_t* outputBuffer = NULL; +static mColor* outputBuffer = NULL; static int16_t *audioSampleBuffer = NULL; static size_t audioSampleBufferSize; static float audioSamplesPerFrameAvg; diff --git a/src/platform/psp2/psp2-context.h b/src/platform/psp2/psp2-context.h index 2c9a47e096e..316dbd4346a 100644 --- a/src/platform/psp2/psp2-context.h +++ b/src/platform/psp2/psp2-context.h @@ -22,7 +22,7 @@ void mPSP2Paused(struct mGUIRunner* runner); void mPSP2Unpaused(struct mGUIRunner* runner); void mPSP2Swap(struct mGUIRunner* runner); void mPSP2Draw(struct mGUIRunner* runner, bool faded); -void mPSP2DrawScreenshot(struct mGUIRunner* runner, const color_t* pixels, unsigned width, unsigned height, bool faded); +void mPSP2DrawScreenshot(struct mGUIRunner* runner, const mColor* pixels, unsigned width, unsigned height, bool faded); void mPSP2IncrementScreenMode(struct mGUIRunner* runner); void mPSP2SetFrameLimiter(struct mGUIRunner* runner, bool limit); uint16_t mPSP2PollInput(struct mGUIRunner* runner); diff --git a/src/platform/python/mgba/image.py b/src/platform/python/mgba/image.py index 3b667952453..a678010217d 100644 --- a/src/platform/python/mgba/image.py +++ b/src/platform/python/mgba/image.py @@ -23,7 +23,7 @@ def __init__(self, width, height, stride=0, alpha=False): def constitute(self): if self.stride <= 0: self.stride = self.width - self.buffer = ffi.new("color_t[{}]".format(self.stride * self.height)) + self.buffer = ffi.new("mColor[{}]".format(self.stride * self.height)) def save_png(self, fileobj): png_file = png.PNG(fileobj, mode=png.MODE_RGBA if self.alpha else png.MODE_RGB) @@ -65,7 +65,7 @@ def u32_to_u16(color): return abgr -if ffi.sizeof("color_t") == 2: +if ffi.sizeof("mColor") == 2: def color_to_u16(color): return color diff --git a/src/platform/python/mgba/tile.py b/src/platform/python/mgba/tile.py index 48812930c6d..5a9e5d71344 100644 --- a/src/platform/python/mgba/tile.py +++ b/src/platform/python/mgba/tile.py @@ -18,7 +18,7 @@ def to_image(self): def composite(self, i, x, y): for iy in range(8): - ffi.memmove(ffi.addressof(i.buffer, x + (iy + y) * i.stride), ffi.addressof(self.buffer, iy * 8), 8 * ffi.sizeof("color_t")) + ffi.memmove(ffi.addressof(i.buffer, x + (iy + y) * i.stride), ffi.addressof(self.buffer, iy * 8), 8 * ffi.sizeof("mColor")) class CacheSet: @@ -55,7 +55,7 @@ def image(self): if not y & 7: lib.mMapCacheCleanRow(self.cache, y >> 3) row = lib.mMapCacheGetRow(self.cache, y) - ffi.memmove(ffi.addressof(i.buffer, i.stride * y), row, self.width * 8 * ffi.sizeof("color_t")) + ffi.memmove(ffi.addressof(i.buffer, i.stride * y), row, self.width * 8 * ffi.sizeof("mColor")) return i diff --git a/src/platform/qt/AssetTile.cpp b/src/platform/qt/AssetTile.cpp index 78db4ccd9a0..2661c9fdecc 100644 --- a/src/platform/qt/AssetTile.cpp +++ b/src/platform/qt/AssetTile.cpp @@ -86,7 +86,7 @@ void AssetTile::selectIndex(int index) { return; } m_index = index; - const color_t* data; + const mColor* data; mTileCache* tileCache = m_tileCaches[index >= m_boundary]; unsigned bpp = 8 << tileCache->bpp; @@ -130,10 +130,10 @@ void AssetTile::setFlip(bool h, bool v) { } void AssetTile::selectColor(int index) { - const color_t* data; + const mColor* data; mTileCache* tileCache = m_tileCaches[m_index >= m_boundary]; data = mTileCacheGetTile(tileCache, m_index >= m_boundary ? m_index - m_boundary : m_index, m_paletteId); - color_t color = data[index]; + mColor color = data[index]; m_ui.color->setColor(0, color); m_ui.color->update(); diff --git a/src/platform/qt/AssetView.cpp b/src/platform/qt/AssetView.cpp index c648982c6b6..17b7451009c 100644 --- a/src/platform/qt/AssetView.cpp +++ b/src/platform/qt/AssetView.cpp @@ -135,7 +135,7 @@ QImage AssetView::compositeMap(int map, QVector* mapStatus) { QImage AssetView::compositeObj(const ObjInfo& objInfo) { mTileCache* tileCache = mTileCacheSetGetPointer(&m_cacheSet->tiles, objInfo.paletteSet); unsigned maxTiles = mTileCacheSystemInfoGetMaxTiles(tileCache->sysConfig); - const color_t* rawPalette = mTileCacheGetPalette(tileCache, objInfo.paletteId); + const mColor* rawPalette = mTileCacheGetPalette(tileCache, objInfo.paletteId); unsigned colors = 1 << objInfo.bits; QVector palette; diff --git a/src/platform/qt/CoreController.cpp b/src/platform/qt/CoreController.cpp index 519ce45fb1d..08b96bd81a7 100644 --- a/src/platform/qt/CoreController.cpp +++ b/src/platform/qt/CoreController.cpp @@ -97,7 +97,7 @@ CoreController::CoreController(mCore* core, QObject* parent) controller->m_frameCounter = -1; if (!controller->m_hwaccel) { - context->core->setVideoBuffer(context->core, reinterpret_cast(controller->m_activeBuffer.data()), controller->screenDimensions().width()); + context->core->setVideoBuffer(context->core, reinterpret_cast(controller->m_activeBuffer.data()), controller->screenDimensions().width()); } QString message(tr("Reset r%1-%2 %3").arg(gitRevision).arg(QLatin1String(gitCommitShort)).arg(controller->m_crc32, 8, 16, QLatin1Char('0'))); @@ -236,12 +236,12 @@ void CoreController::setPath(const QString& path, const QString& base) { m_baseDirectory = base; } -const color_t* CoreController::drawContext() { +const mColor* CoreController::drawContext() { if (m_hwaccel) { return nullptr; } QMutexLocker locker(&m_bufferMutex); - return reinterpret_cast(m_completeBuffer.constData()); + return reinterpret_cast(m_completeBuffer.constData()); } QImage CoreController::getPixels() { @@ -307,14 +307,14 @@ void CoreController::loadConfig(ConfigController* config) { m_preload = config->getOption("preload").toInt(); QSize sizeBefore = screenDimensions(); - m_activeBuffer.resize(256 * 224 * sizeof(color_t)); - m_threadContext.core->setVideoBuffer(m_threadContext.core, reinterpret_cast(m_activeBuffer.data()), sizeBefore.width()); + m_activeBuffer.resize(256 * 224 * sizeof(mColor)); + m_threadContext.core->setVideoBuffer(m_threadContext.core, reinterpret_cast(m_activeBuffer.data()), sizeBefore.width()); mCoreLoadForeignConfig(m_threadContext.core, config->config()); QSize sizeAfter = screenDimensions(); - m_activeBuffer.resize(sizeAfter.width() * sizeAfter.height() * sizeof(color_t)); - m_threadContext.core->setVideoBuffer(m_threadContext.core, reinterpret_cast(m_activeBuffer.data()), sizeAfter.width()); + m_activeBuffer.resize(sizeAfter.width() * sizeAfter.height() * sizeof(mColor)); + m_threadContext.core->setVideoBuffer(m_threadContext.core, reinterpret_cast(m_activeBuffer.data()), sizeAfter.width()); if (hasStarted()) { updateFastForward(); @@ -461,11 +461,11 @@ void CoreController::setLogger(LogController* logger) { void CoreController::start() { QSize size(screenDimensions()); - m_activeBuffer.resize(size.width() * size.height() * sizeof(color_t)); + m_activeBuffer.resize(size.width() * size.height() * sizeof(mColor)); m_activeBuffer.fill(0xFF); m_completeBuffer = m_activeBuffer; - m_threadContext.core->setVideoBuffer(m_threadContext.core, reinterpret_cast(m_activeBuffer.data()), size.width()); + m_threadContext.core->setVideoBuffer(m_threadContext.core, reinterpret_cast(m_activeBuffer.data()), size.width()); if (!m_patched) { mCoreAutoloadPatch(m_threadContext.core); @@ -1194,7 +1194,7 @@ void CoreController::setFramebufferHandle(int fb) { if (hasStarted()) { m_threadContext.core->reloadConfigOption(m_threadContext.core, "hwaccelVideo", NULL); if (!m_hwaccel) { - m_threadContext.core->setVideoBuffer(m_threadContext.core, reinterpret_cast(m_activeBuffer.data()), screenDimensions().width()); + m_threadContext.core->setVideoBuffer(m_threadContext.core, reinterpret_cast(m_activeBuffer.data()), screenDimensions().width()); } } } diff --git a/src/platform/qt/CoreController.h b/src/platform/qt/CoreController.h index 684d864d051..57eb9ffe077 100644 --- a/src/platform/qt/CoreController.h +++ b/src/platform/qt/CoreController.h @@ -87,7 +87,7 @@ Q_OBJECT QString baseDirectory() const { return m_baseDirectory; } QString savePath() const { return m_savePath; } - const color_t* drawContext(); + const mColor* drawContext(); QImage getPixels(); bool isPaused(); diff --git a/src/platform/qt/DisplayQt.cpp b/src/platform/qt/DisplayQt.cpp index 3723a844524..b71147c43a1 100644 --- a/src/platform/qt/DisplayQt.cpp +++ b/src/platform/qt/DisplayQt.cpp @@ -78,7 +78,7 @@ void DisplayQt::filter(bool filter) { void DisplayQt::framePosted() { update(); - const color_t* buffer = m_context->drawContext(); + const mColor* buffer = m_context->drawContext(); if (const_cast(m_layers[VIDEO_LAYER_IMAGE]).bits() == reinterpret_cast(buffer)) { return; } diff --git a/src/platform/qt/FrameView.cpp b/src/platform/qt/FrameView.cpp index ada077d742f..245ebf4bb06 100644 --- a/src/platform/qt/FrameView.cpp +++ b/src/platform/qt/FrameView.cpp @@ -574,7 +574,7 @@ void FrameView::newVl() { unsigned width, height; m_vl->baseVideoSize(m_vl, &width, &height); m_framebuffer = QImage(width, height, QImage::Format_RGBX8888); - m_vl->setVideoBuffer(m_vl, reinterpret_cast(m_framebuffer.bits()), width); + m_vl->setVideoBuffer(m_vl, reinterpret_cast(m_framebuffer.bits()), width); m_vl->reset(m_vl); } diff --git a/src/platform/qt/ObjView.cpp b/src/platform/qt/ObjView.cpp index f4482aba628..a29c621fbfd 100644 --- a/src/platform/qt/ObjView.cpp +++ b/src/platform/qt/ObjView.cpp @@ -138,7 +138,7 @@ void ObjView::updateTilesGBA(bool force) { for (unsigned y = 0; y < newInfo.height; ++y) { for (unsigned x = 0; x < newInfo.width; ++x, ++i, ++tile, ++tileBase) { if (tile < maxTiles) { - const color_t* data = mTileCacheGetTileIfDirty(tileCache, &m_tileStatus[16 * tileBase], tile, newInfo.paletteId); + const mColor* data = mTileCacheGetTileIfDirty(tileCache, &m_tileStatus[16 * tileBase], tile, newInfo.paletteId); if (data) { m_ui.tiles->setTile(i, data); } else if (force) { @@ -233,7 +233,7 @@ void ObjView::updateTilesGB(bool force) { m_ui.tile->setPalette(newInfo.paletteId); for (unsigned y = 0; y < newInfo.height; ++y, ++i) { unsigned t = tile + i; - const color_t* data = mTileCacheGetTileIfDirty(tileCache, &m_tileStatus[8 * t], t, newInfo.paletteId); + const mColor* data = mTileCacheGetTileIfDirty(tileCache, &m_tileStatus[8 * t], t, newInfo.paletteId); if (data) { m_ui.tiles->setTile(i, data); } else if (force) { diff --git a/src/platform/qt/TilePainter.cpp b/src/platform/qt/TilePainter.cpp index fcb62d42080..b8c8075e677 100644 --- a/src/platform/qt/TilePainter.cpp +++ b/src/platform/qt/TilePainter.cpp @@ -62,7 +62,7 @@ void TilePainter::clearTile(int index) { update(r); } -void TilePainter::setTile(int index, const color_t* data) { +void TilePainter::setTile(int index, const mColor* data) { QPainter painter(&m_backing); int w = width() / m_size; int x = index % w; diff --git a/src/platform/qt/TilePainter.h b/src/platform/qt/TilePainter.h index 5ef4b05555f..f1f4a86e0eb 100644 --- a/src/platform/qt/TilePainter.h +++ b/src/platform/qt/TilePainter.h @@ -23,7 +23,7 @@ Q_OBJECT public slots: void clearTile(int index); - void setTile(int index, const color_t*); + void setTile(int index, const mColor*); void setTileCount(int tiles); void setTileMagnification(int mag); diff --git a/src/platform/qt/TileView.cpp b/src/platform/qt/TileView.cpp index 7d8d1a71e7f..dbfc1553155 100644 --- a/src/platform/qt/TileView.cpp +++ b/src/platform/qt/TileView.cpp @@ -142,7 +142,7 @@ void TileView::updateTilesGBA(bool force) { objOffset = 0; cache = mTileCacheSetGetPointer(&m_cacheSet->tiles, 1); for (int i = 0; i < 1024; ++i) { - const color_t* data = mTileCacheGetTileIfDirty(cache, &m_tileStatus[16 * i], i, 0); + const mColor* data = mTileCacheGetTileIfDirty(cache, &m_tileStatus[16 * i], i, 0); if (data) { m_ui.tiles->setTile(i, data); } else if (force) { @@ -153,7 +153,7 @@ void TileView::updateTilesGBA(bool force) { if (!m_ui.tilesBg->isChecked()) { cache = mTileCacheSetGetPointer(&m_cacheSet->tiles, 3); for (int i = 1024; i < 1536; ++i) { - const color_t* data = mTileCacheGetTileIfDirty(cache, &m_tileStatus[16 * i], i - 1024, 0); + const mColor* data = mTileCacheGetTileIfDirty(cache, &m_tileStatus[16 * i], i - 1024, 0); if (data) { m_ui.tiles->setTile(i - objOffset, data); } else if (force) { @@ -175,7 +175,7 @@ void TileView::updateTilesGBA(bool force) { objOffset = 0; cache = mTileCacheSetGetPointer(&m_cacheSet->tiles, 0); for (int i = 0; i < 2048; ++i) { - const color_t* data = mTileCacheGetTileIfDirty(cache, &m_tileStatus[16 * i], i, m_paletteId); + const mColor* data = mTileCacheGetTileIfDirty(cache, &m_tileStatus[16 * i], i, m_paletteId); if (data) { m_ui.tiles->setTile(i, data); } else if (force) { @@ -186,7 +186,7 @@ void TileView::updateTilesGBA(bool force) { if (!m_ui.tilesBg->isChecked()) { cache = mTileCacheSetGetPointer(&m_cacheSet->tiles, 2); for (int i = 2048; i < 3072; ++i) { - const color_t* data = mTileCacheGetTileIfDirty(cache, &m_tileStatus[16 * i], i - 2048, m_paletteId); + const mColor* data = mTileCacheGetTileIfDirty(cache, &m_tileStatus[16 * i], i - 2048, m_paletteId); if (data) { m_ui.tiles->setTile(i - objOffset, data); } else if (force) { @@ -205,7 +205,7 @@ void TileView::updateTilesGB(bool force) { m_ui.tiles->setTileCount(count); mTileCache* cache = mTileCacheSetGetPointer(&m_cacheSet->tiles, 0); for (int i = 0; i < count; ++i) { - const color_t* data = mTileCacheGetTileIfDirty(cache, &m_tileStatus[8 * i], i, m_paletteId); + const mColor* data = mTileCacheGetTileIfDirty(cache, &m_tileStatus[8 * i], i, m_paletteId); if (data) { m_ui.tiles->setTile(i, data); } else if (force) { diff --git a/src/platform/sdl/main.h b/src/platform/sdl/main.h index 43701b3c26d..8c2f517d711 100644 --- a/src/platform/sdl/main.h +++ b/src/platform/sdl/main.h @@ -30,7 +30,7 @@ CXX_GUARD_START struct mCore; struct mSDLRenderer { struct mCore* core; - color_t* outputBuffer; + mColor* outputBuffer; struct mSDLAudio audio; struct mSDLEvents events; diff --git a/src/platform/switch/main.c b/src/platform/switch/main.c index c829ab9b088..1f61cc27915 100644 --- a/src/platform/switch/main.c +++ b/src/platform/switch/main.c @@ -79,7 +79,7 @@ static GLuint oldTex; static GLuint screenshotTex; static struct GUIFont* font; -static color_t* frameBuffer; +static mColor* frameBuffer; static struct mAVStream stream; static struct mSwitchRumble { struct mRumbleIntegrator d; @@ -517,7 +517,7 @@ static void _drawFrame(struct mGUIRunner* runner, bool faded) { hidSendVibrationValues(vibrationDeviceHandles, values, 4); } -static void _drawScreenshot(struct mGUIRunner* runner, const color_t* pixels, unsigned width, unsigned height, bool faded) { +static void _drawScreenshot(struct mGUIRunner* runner, const mColor* pixels, unsigned width, unsigned height, bool faded) { glActiveTexture(GL_TEXTURE0); glBindTexture(GL_TEXTURE_2D, screenshotTex); glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, width, height, 0, GL_RGBA, GL_UNSIGNED_BYTE, pixels); diff --git a/src/platform/test/cinema-main.c b/src/platform/test/cinema-main.c index a990b5599c9..cc1bad8622c 100644 --- a/src/platform/test/cinema-main.c +++ b/src/platform/test/cinema-main.c @@ -684,7 +684,7 @@ static void _cinemaDimensionsChanged(struct mAVStream* stream, unsigned width, u } } -static void _cinemaVideoFrame(struct mAVStream* stream, const color_t* pixels, size_t stride) { +static void _cinemaVideoFrame(struct mAVStream* stream, const mColor* pixels, size_t stride) { struct CInemaStream* cistream = (struct CInemaStream*) stream; cistream->image->stride = stride; size_t bufferSize = cistream->image->stride * cistream->image->height * BYTES_PER_PIXEL; From bb8a6e05f9fb440efdf2121f08448814d6a7ed1f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 15 Sep 2024 03:18:16 -0700 Subject: [PATCH 190/338] GBA Memory: Add support for palette RAM, VRAM, and OAM to GBAPatch8 --- src/gba/memory.c | 34 +++++++++++++++++++++++++++++++--- 1 file changed, 31 insertions(+), 3 deletions(-) diff --git a/src/gba/memory.c b/src/gba/memory.c index 1ddd2eb993b..09d3e7a7425 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -1350,10 +1350,22 @@ void GBAPatch16(struct ARMCore* cpu, uint32_t address, int16_t value, int16_t* o } } +#define MUNGE8 \ + if (address & 1) { \ + oldValue = alignedValue >> 8; \ + alignedValue &= 0xFF; \ + alignedValue |= value << 8; \ + } else { \ + oldValue = alignedValue; \ + alignedValue &= 0xFF00; \ + alignedValue |= (uint8_t) value; \ + } + void GBAPatch8(struct ARMCore* cpu, uint32_t address, int8_t value, int8_t* old) { struct GBA* gba = (struct GBA*) cpu->master; struct GBAMemory* memory = &gba->memory; int8_t oldValue = -1; + int16_t alignedValue; switch (address >> BASE_OFFSET) { case GBA_REGION_EWRAM: @@ -1368,13 +1380,29 @@ void GBAPatch8(struct ARMCore* cpu, uint32_t address, int8_t value, int8_t* old) mLOG(GBA_MEM, STUB, "Unimplemented memory Patch8: 0x%08X", address); break; case GBA_REGION_PALETTE_RAM: - mLOG(GBA_MEM, STUB, "Unimplemented memory Patch8: 0x%08X", address); + LOAD_16(alignedValue, address & (GBA_SIZE_PALETTE_RAM - 2), gba->video.palette); + MUNGE8; + STORE_16(alignedValue, address & (GBA_SIZE_PALETTE_RAM - 2), gba->video.palette); + gba->video.renderer->writePalette(gba->video.renderer, address & (GBA_SIZE_PALETTE_RAM - 2), alignedValue); break; case GBA_REGION_VRAM: - mLOG(GBA_MEM, STUB, "Unimplemented memory Patch8: 0x%08X", address); + if ((address & 0x0001FFFF) < GBA_SIZE_VRAM) { + LOAD_16(alignedValue, address & 0x0001FFFE, gba->video.vram); + MUNGE8; + STORE_16(alignedValue, address & 0x0001FFFE, gba->video.vram); + gba->video.renderer->writeVRAM(gba->video.renderer, address & 0x0001FFFE); + } else { + LOAD_16(alignedValue, address & 0x00017FFE, gba->video.vram); + MUNGE8; + STORE_16(alignedValue, address & 0x00017FFE, gba->video.vram); + gba->video.renderer->writeVRAM(gba->video.renderer, address & 0x00017FFE); + } break; case GBA_REGION_OAM: - mLOG(GBA_MEM, STUB, "Unimplemented memory Patch8: 0x%08X", address); + LOAD_16(alignedValue, address & (GBA_SIZE_OAM - 2), gba->video.oam.raw); + MUNGE8; + STORE_16(alignedValue, address & (GBA_SIZE_OAM - 2), gba->video.oam.raw); + gba->video.renderer->writeOAM(gba->video.renderer, (address & (GBA_SIZE_OAM - 2)) >> 1); break; case GBA_REGION_ROM0: case GBA_REGION_ROM0_EX: From 3ad4e62b0248e1930c2d338810a272e7cc47d7d6 Mon Sep 17 00:00:00 2001 From: Hexaae Date: Wed, 17 Apr 2024 07:12:31 +0000 Subject: [PATCH 191/338] Qt: Update translation (Italian) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/it/ --- src/platform/qt/ts/mgba-it.ts | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/src/platform/qt/ts/mgba-it.ts b/src/platform/qt/ts/mgba-it.ts index 12a018db737..6c2d16d4f29 100644 --- a/src/platform/qt/ts/mgba-it.ts +++ b/src/platform/qt/ts/mgba-it.ts @@ -6,22 +6,22 @@ Game Boy Advance ROMs (%1) - ROM per Game Boy Advance (%1) + ROM per Game Boy Advance (%1) Game Boy ROMs (%1) - ROM per Game Boy (%1) + ROM per Game Boy (%1) All ROMs (%1) - Tutte le ROM (%1) + Tutte le ROM (%1) %1 Video Logs (*.mvl) - %1 log Video (*.mvl) + %1 log Video (*.mvl) @@ -561,7 +561,7 @@ Dimensione del download: %3 Background - Sfondo + Sfondo @@ -591,7 +591,7 @@ Dimensione del download: %3 Browse - Sfoglia + Sfoglia @@ -4759,12 +4759,12 @@ Dimensione del download: %3 Select image - Seleziona immagine + Seleziona immagine Image file (*.png *.jpg *.jpeg) - File immagine (*.png *.jpg *.jpeg) + File immagine (*.png *.jpg *.jpeg) @@ -4784,7 +4784,7 @@ Dimensione del download: %3 Less than an hour ago - Meno di un ora fa + Meno di un'ora fa @@ -4815,7 +4815,7 @@ Dimensione del download: %3 Gameplay - Gameplay + In gioco @@ -5555,7 +5555,7 @@ Dimensione del download: %3 by %1 - per %1 + di %1 @@ -6771,17 +6771,17 @@ Dimensione del download: %3 Super (L) - Super (L) + Super (L) Super (R) - Super (R) + Super (R) Menu - Menu + Menu From e4973a98d8dfd103d189d5363c7db24fc4da233b Mon Sep 17 00:00:00 2001 From: Milihraim Date: Tue, 7 May 2024 13:53:56 +0000 Subject: [PATCH 192/338] Qt: Update translation (Russian) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/ru/ --- src/platform/qt/ts/mgba-ru.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/platform/qt/ts/mgba-ru.ts b/src/platform/qt/ts/mgba-ru.ts index 17147a4678a..574a66861c6 100644 --- a/src/platform/qt/ts/mgba-ru.ts +++ b/src/platform/qt/ts/mgba-ru.ts @@ -5141,7 +5141,7 @@ Download size: %3 Rewind speed: - + СкороÑÑ‚ÑŒ перемотки: @@ -5231,7 +5231,7 @@ Download size: %3 Language - + Язык @@ -5322,7 +5322,7 @@ Download size: %3 Fast forward speed: - СкороÑÑ‚ÑŒ перемотки: + СкороÑÑ‚ÑŒ перемотки (уÑкр.): From a60448d7bcde4d720c8e98b84b27c4fb8c502de9 Mon Sep 17 00:00:00 2001 From: Evrins Hu Date: Sat, 11 May 2024 01:20:53 +0000 Subject: [PATCH 193/338] Qt: Update translation (Chinese (Simplified)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/zh_Hans/ --- src/platform/qt/ts/mgba-zh_CN.ts | 104 +++++++++++++++---------------- 1 file changed, 52 insertions(+), 52 deletions(-) diff --git a/src/platform/qt/ts/mgba-zh_CN.ts b/src/platform/qt/ts/mgba-zh_CN.ts index 6992a62809e..4e570c19626 100644 --- a/src/platform/qt/ts/mgba-zh_CN.ts +++ b/src/platform/qt/ts/mgba-zh_CN.ts @@ -6,22 +6,22 @@ Game Boy Advance ROMs (%1) - Game Boy Advance ROM (%1) + Game Boy Advance ROMs (%1) Game Boy ROMs (%1) - Game Boy ROM (%1) + Game Boy ROMs (%1) All ROMs (%1) - 所有 ROM (%1) + 所有 ROMs (%1) %1 Video Logs (*.mvl) - %1 视频日志 (*.mvl) + %1 视频日志 (*.mvl) @@ -530,12 +530,12 @@ Download size: %3 3DS - + 3DS Vita - + Vita @@ -561,7 +561,7 @@ Download size: %3 Background - 背景 + 背景 @@ -591,7 +591,7 @@ Download size: %3 Browse - æµè§ˆ + æµè§ˆ @@ -631,12 +631,12 @@ Download size: %3 3DS - + 3DS Vita - + Vita @@ -716,7 +716,7 @@ Download size: %3 Image files (*.png *.jpg *.bmp) - + 图åƒæ–‡ä»¶ (*.png *.jpg *.bmp) @@ -975,37 +975,37 @@ Download size: %3 Game Boy (DMG) - + Game Boy (DMG) Game Boy Pocket (MGB) - + Game Boy Pocket (MGB) Super Game Boy (SGB) - + Super Game Boy (SGB) Super Game Boy 2 (SGB) - + Super Game Boy 2 (SGB) Game Boy Color (CGB) - + Game Boy Color (CGB) Game Boy Advance (AGB) - + Game Boy Advance (AGB) Super Game Boy Color (SGB + CGB) - + Super Game Boy Color (SGB + CGB) @@ -1015,27 +1015,27 @@ Download size: %3 MBC1 - + MBC1 MBC2 - + MBC2 MBC3 - + MBC3 MBC3 + RTC - + MBC3 + 实时时钟 MBC5 - + MBC5 @@ -1045,7 +1045,7 @@ Download size: %3 MBC6 - + MBC6 @@ -1055,17 +1055,17 @@ Download size: %3 MMM01 - + MMM01 HuC-1 - + HuC-1 HuC-3 - + HuC-3 @@ -1080,17 +1080,17 @@ Download size: %3 Wisdom Tree - + Wisdom Tree NT (old 1) - + NT (æ—§ 1) NT (old 2) - + NT (æ—§ 2) @@ -1105,32 +1105,32 @@ Download size: %3 BBD - + BBD Hitek - + Hitek GGB-81 - + GGB-81 Li Cheng - + Li Cheng Sachen (MMC1) - + Sachen (MMC1) Sachen (MMC2) - + Sachen (MMC2) @@ -3752,17 +3752,17 @@ Download size: %3 Trying to detach a multiplayer player that's not attached - + å°è¯•æ–­å¼€ä¸Žæœªè¿žæŽ¥çš„多人玩家的连接 Trying to get player ID for a multiplayer player that's not attached - + å°è¯•èŽ·å–未连接的多人玩家的 ID Trying to get save ID for a multiplayer player that's not attached - + å°è¯•èŽ·å–未连接的多人玩家的存档 ID @@ -4310,7 +4310,7 @@ Download size: %3 Save file: - + ä¿å­˜æ–‡ä»¶: @@ -4759,12 +4759,12 @@ Download size: %3 Select image - 选择图片 + 选择图片 Image file (*.png *.jpg *.jpeg) - 图åƒæ–‡ä»¶ï¼ˆ*.png *.jpg *.jpeg) + 图åƒæ–‡ä»¶ï¼ˆ*.png *.jpg *.jpeg) @@ -5247,7 +5247,7 @@ Download size: %3 Custom border: - + 自定义边框: @@ -5283,7 +5283,7 @@ Download size: %3 Rewind speed: - + 倒带速度: @@ -5879,7 +5879,7 @@ Download size: %3 WavPack - + WavPack @@ -6099,7 +6099,7 @@ Download size: %3 %1 - %2 (%3 fps) - %4 - + %1 - %2 (%3 fps) - %4 @@ -6401,12 +6401,12 @@ Download size: %3 Increase fast forward speed - + 加快快进速度 Decrease fast forward speed - + é™ä½Žå¿«è¿›é€Ÿåº¦ @@ -6744,7 +6744,7 @@ Download size: %3 %1 kiB - + %1 åƒå­—节 @@ -6769,17 +6769,17 @@ Download size: %3 Super (L) - Super(L) + Super (L) Super (R) - Super(R) + Super (R) Menu - èœå• + èœå• From 9d9cb7450f083ec6beb8af5344f3ca71471f1b00 Mon Sep 17 00:00:00 2001 From: Imre Kristoffer Eilertsen Date: Sun, 9 Jun 2024 07:14:59 +0000 Subject: [PATCH 194/338] =?UTF-8?q?Qt:=20Update=20translation=20(Norwegian?= =?UTF-8?q?=20Bokm=C3=A5l)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/nb_NO/ --- src/platform/qt/ts/mgba-nb_NO.ts | 243 ++++++++++++++++--------------- 1 file changed, 122 insertions(+), 121 deletions(-) diff --git a/src/platform/qt/ts/mgba-nb_NO.ts b/src/platform/qt/ts/mgba-nb_NO.ts index 4a97f0c6073..6c06c2fe6ae 100644 --- a/src/platform/qt/ts/mgba-nb_NO.ts +++ b/src/platform/qt/ts/mgba-nb_NO.ts @@ -6,12 +6,12 @@ Game Boy Advance ROMs (%1) - + Game Boy Advance ROM-filer (%1) Game Boy ROMs (%1) - + Game Boy ROM-filer (%1) @@ -21,7 +21,7 @@ %1 Video Logs (*.mvl) - + %1-videologger (*.mvl) @@ -34,7 +34,7 @@ <a href="http://mgba.io/">Website</a> • <a href="https://forums.mgba.io/">Forums / Support</a> • <a href="https://patreon.com/mgba">Donate</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">Source</a> - <a href="http://mgba.io/">Nettside</a> • <a href="https://forums.mgba.io/">Forum / støtte</a> • <a href="https://patreon.com/mgba">Doner</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">Kildekode</a> + <a href="https://mgba.io/">Nettside</a> • <a href="https://forums.mgba.io/">Forum / støtte</a> • <a href="https://patreon.com/mgba">Doner</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">Kildekode</a> @@ -70,7 +70,8 @@ Game Boy Advance er et registrert varemerke tilhørende Nintendo Co., Ltd. An update to %1 is available. - + En oppdatering til %1 er tilgjengelig. + @@ -101,12 +102,12 @@ Nedlastningsstørrelse: %3 Downloading failed. Please update manually. - + Nedlastingen mislyktes. Vennligst oppdater manuelt. Downloading done. Press OK to restart %1 and install the update. - + Nedlastingen er fullført. Trykk OK for Ã¥ starte %1 pÃ¥ nytt og installere oppdateringen. @@ -137,7 +138,7 @@ Nedlastningsstørrelse: %3 Open in archive... - Ã…pne i arkiv … + Ã…pne i arkiv … @@ -244,7 +245,7 @@ Nedlastningsstørrelse: %3 Load - Last inn + Last inn @@ -313,7 +314,7 @@ Nedlastningsstørrelse: %3 (untitled) - + (uten tittel) @@ -346,7 +347,7 @@ Nedlastningsstørrelse: %3 Code type - + Kodetype @@ -373,7 +374,7 @@ Nedlastningsstørrelse: %3 Select cheats file - Velg juksekodefil + Velg juksekodefil @@ -397,7 +398,7 @@ Nedlastningsstørrelse: %3 Reset the game? - + Vil du starte spillet pÃ¥ nytt? @@ -532,7 +533,7 @@ Nedlastningsstørrelse: %3 Vita - + Vita @@ -545,7 +546,7 @@ Nedlastningsstørrelse: %3 Banner - + Plakat @@ -588,7 +589,7 @@ Nedlastningsstørrelse: %3 Browse - + Bla @@ -761,7 +762,7 @@ Nedlastningsstørrelse: %3 Portable Network Graphics (*.png) - + Portable Network Graphics (*.png) @@ -781,7 +782,7 @@ Nedlastningsstørrelse: %3 Objwin - + Objwin @@ -817,12 +818,12 @@ Nedlastningsstørrelse: %3 Clear Button - + Tøm knapper Clear Analog - + Tøm analoge @@ -832,7 +833,7 @@ Nedlastningsstørrelse: %3 Set all - + Sett alle @@ -860,7 +861,7 @@ Nedlastningsstørrelse: %3 Standard GDB - + Standard GDB @@ -1082,27 +1083,27 @@ Nedlastningsstørrelse: %3 NT (old 1) - + NT (gammel 1) NT (old 2) - + NT (gammel 2) NT (new) - + NT (ny) Pokémon Jade/Diamond - + Pokémon Jade/Diamond BBD - + BBD @@ -1122,12 +1123,12 @@ Nedlastningsstørrelse: %3 Sachen (MMC1) - + Sachen (MMC1) Sachen (MMC2) - + Sachen (MMC2) @@ -1212,22 +1213,22 @@ Nedlastningsstørrelse: %3 Enable background 0 - + Skru pÃ¥ bakgrunn 0 Enable background 1 - + Skru pÃ¥ bakgrunn 1 Enable background 2 - + Skru pÃ¥ bakgrunn 2 Enable background 3 - + Skru pÃ¥ bakgrunn 3 @@ -1237,12 +1238,12 @@ Nedlastningsstørrelse: %3 Enable Window 0 - + Skru pÃ¥ vindu 1 Enable Window 1 - + Skru pÃ¥ vindu 1 @@ -1311,7 +1312,7 @@ Nedlastningsstørrelse: %3 Enable mosaic - + Skru pÃ¥ flislegging @@ -1609,7 +1610,7 @@ Nedlastningsstørrelse: %3 Blend mode - + Blendmodus @@ -1876,49 +1877,49 @@ Nedlastningsstørrelse: %3 Enable channel 1 right - + Skru pÃ¥ kanal 1 høyre Enable channel 2 right - + Skru pÃ¥ kanal 2 høyre Enable channel 3 right - + Skru pÃ¥ kanal 3 høyre Enable channel 4 right - + Skru pÃ¥ kanal 4 høyre Enable channel 1 left - + Skru pÃ¥ kanal 1 venstre Enable channel 2 left - + Skru pÃ¥ kanal 2 venstre Enable channel 3 left - + Skru pÃ¥ kanal 3 venstre Enable channel 4 left - + Skru pÃ¥ kanal 4 venstre @@ -2211,7 +2212,7 @@ Nedlastningsstørrelse: %3 Joypad - + Kontroller @@ -2271,13 +2272,13 @@ Nedlastningsstørrelse: %3 0x9800 – 0x9BFF - + 0x9800 – 0x9BFF 0x9C00 – 0x9FFF - + 0x9C00 – 0x9FFF @@ -2287,12 +2288,12 @@ Nedlastningsstørrelse: %3 0x8800 – 0x87FF - + 0x8800 – 0x87FF 0x8000 – 0x8FFF - + 0x8000 – 0x8FFF @@ -2317,12 +2318,12 @@ Nedlastningsstørrelse: %3 0: HBlank - + 0: HBlank 1: VBlank - + 1: VBlank @@ -2517,7 +2518,7 @@ Nedlastningsstørrelse: %3 WRAM bank - + WRAM-bank @@ -2569,7 +2570,7 @@ Nedlastningsstørrelse: %3 Fixed - + Fastsatt @@ -2654,7 +2655,7 @@ Nedlastningsstørrelse: %3 IRQ - + IRQ @@ -2804,22 +2805,22 @@ Nedlastningsstørrelse: %3 SC - + SC SD - + SD SI - + SI SO - + SO @@ -2855,37 +2856,37 @@ Nedlastningsstørrelse: %3 SIO - + SIO DMA 0 - + DMA 0 DMA 1 - + DMA 1 DMA 2 - + DMA 2 DMA 3 - + DMA 3 Keypad - + Talltastatur @@ -3056,7 +3057,7 @@ Nedlastningsstørrelse: %3 No Save - + Ingen lagrefil @@ -3236,7 +3237,7 @@ Nedlastningsstørrelse: %3 Enabled Levels - + PÃ¥skrudde nivÃ¥er @@ -3266,7 +3267,7 @@ Nedlastningsstørrelse: %3 Fatal - Kritisk + Kritisk @@ -3286,7 +3287,7 @@ Nedlastningsstørrelse: %3 Max Lines - + Maks antall linjer @@ -3342,7 +3343,7 @@ Nedlastningsstørrelse: %3 Xform - + Xform @@ -3422,7 +3423,7 @@ Nedlastningsstørrelse: %3 Failed to open output file: %1 - Klarte ikke Ã¥ Ã¥pne utdatafil: %1 + Klarte ikke Ã¥ Ã¥pne utdatafil: %1 @@ -3445,7 +3446,7 @@ Nedlastningsstørrelse: %3 Load - Last inn + Last inn @@ -3465,7 +3466,7 @@ Nedlastningsstørrelse: %3 Failed to open output file: %1 - Klarte ikke Ã¥ Ã¥pne utdatafil: %1 + Klarte ikke Ã¥ Ã¥pne utdatafil: %1 @@ -3708,7 +3709,7 @@ Nedlastningsstørrelse: %3 Load TBL - + Last inn TBL @@ -3733,7 +3734,7 @@ Nedlastningsstørrelse: %3 Load - Last inn + Last inn @@ -3937,7 +3938,7 @@ Nedlastningsstørrelse: %3 Portable Network Graphics (*.png) - + Portable Network Graphics (*.png) @@ -4250,7 +4251,7 @@ Nedlastningsstørrelse: %3 Portable Network Graphics (*.png) - + Portable Network Graphics (*.png) @@ -4335,7 +4336,7 @@ Nedlastningsstørrelse: %3 Generate report - + Generer rapport @@ -4363,7 +4364,7 @@ Nedlastningsstørrelse: %3 Save games and save states (%1) - + Lagrefiler og lagringstilstander @@ -4373,7 +4374,7 @@ Nedlastningsstørrelse: %3 Save games (%1) - + Lagrefiler (%1) @@ -4428,13 +4429,13 @@ Nedlastningsstørrelse: %3 Input file - + Inndatafil Browse - + Bla @@ -4484,7 +4485,7 @@ Nedlastningsstørrelse: %3 %1 SRAM - + %1 SRAM @@ -4613,7 +4614,7 @@ Nedlastningsstørrelse: %3 Fixed time - + Fastsatt tid @@ -4623,7 +4624,7 @@ Nedlastningsstørrelse: %3 Start time at - + Start tiden pÃ¥ @@ -4633,7 +4634,7 @@ Nedlastningsstørrelse: %3 Offset time - + Tidsavvik @@ -4664,13 +4665,13 @@ Nedlastningsstørrelse: %3 Set Y - + Sett Y Set X - + Sett X @@ -4710,7 +4711,7 @@ Nedlastningsstørrelse: %3 OpenGL (force version 1.x) - + OpenGL (tving versjon 1.x) @@ -4908,7 +4909,7 @@ Nedlastningsstørrelse: %3 Sample rate: - + Datapunktfrekvens: @@ -4957,7 +4958,7 @@ Nedlastningsstørrelse: %3 Audio in multiplayer: - + Lyd i flerspiller: @@ -4967,7 +4968,7 @@ Nedlastningsstørrelse: %3 Player 1 window only - + Kun spiller 1 sitt vindu @@ -5277,12 +5278,12 @@ Nedlastningsstørrelse: %3 Rewind history: - + Tilbakestillingshistorikk: Rewind speed: - + Tilbakespolingsfart: @@ -5420,7 +5421,7 @@ Nedlastningsstørrelse: %3 GB BIOS file: - + GB BIOS-fil: @@ -5434,12 +5435,12 @@ Nedlastningsstørrelse: %3 Browse - + Bla Use BIOS file if found - + Bruk BIOS-filen hvis den blir funnet @@ -5464,7 +5465,7 @@ Nedlastningsstørrelse: %3 Save games - + Lagrefiler @@ -5483,7 +5484,7 @@ Nedlastningsstørrelse: %3 Screenshots - + Skjermklipp @@ -5493,7 +5494,7 @@ Nedlastningsstørrelse: %3 Cheats - Juks + Juks @@ -5572,7 +5573,7 @@ Nedlastningsstørrelse: %3 Active Shader: - + Aktiv skyggelegger: @@ -5652,7 +5653,7 @@ Nedlastningsstørrelse: %3 Portable Network Graphics (*.png) - + Portable Network Graphics (*.png) @@ -5662,7 +5663,7 @@ Nedlastningsstørrelse: %3 Tiles - + Fliser @@ -5687,7 +5688,7 @@ Nedlastningsstørrelse: %3 Magnification - Forstørrelse + Forstørrelse @@ -5722,7 +5723,7 @@ Nedlastningsstørrelse: %3 Copy Selected - + Kopier valgte @@ -5745,7 +5746,7 @@ Nedlastningsstørrelse: %3 Select output file - Velg utdatafil + Velg utdatafil @@ -5872,7 +5873,7 @@ Nedlastningsstørrelse: %3 FFV1 - + FFV1 @@ -6024,7 +6025,7 @@ Nedlastningsstørrelse: %3 Crash - Krasj + Krasj @@ -6121,7 +6122,7 @@ Nedlastningsstørrelse: %3 Save games (%1) - + Lagrefiler (%1) @@ -6197,7 +6198,7 @@ Nedlastningsstørrelse: %3 ROM &info... - + ROM-&info ... @@ -6232,12 +6233,12 @@ Nedlastningsstørrelse: %3 Quick load - + Hurtiginnlasting Quick save - + Hurtiglagring @@ -6278,12 +6279,12 @@ Nedlastningsstørrelse: %3 GameShark saves (*.gsv *.sps *.xps) - + GameShark-lagrefiler (*.gsv *.sps *.xps) Reset needed - + Tilbakestilling kreves @@ -6293,7 +6294,7 @@ Nedlastningsstørrelse: %3 Save games - + Lagrefiler @@ -6318,7 +6319,7 @@ Nedlastningsstørrelse: %3 New multiplayer window - + Nytt flerspillervindu @@ -6413,7 +6414,7 @@ Nedlastningsstørrelse: %3 Re&wind - + Spol ti&lbake @@ -6463,7 +6464,7 @@ Nedlastningsstørrelse: %3 Audio/&Video - + Lyd/&Video @@ -6568,7 +6569,7 @@ Nedlastningsstørrelse: %3 Game &overrides... - + Spilloverstyringer ... @@ -6638,12 +6639,12 @@ Nedlastningsstørrelse: %3 View memory... - + Vis minne ... Search memory... - + Søk i minne ... From 3853b699f427c928ea7c170b9e739042c7864d97 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 16 Sep 2024 02:48:17 -0700 Subject: [PATCH 195/338] Qt: Fix how some languages are shown in settings --- src/platform/qt/ts/{mgba-es.ts => mgba-es_419.ts} | 0 src/platform/qt/ts/{mgba-pt.ts => mgba-pt_PT.ts} | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) rename src/platform/qt/ts/{mgba-es.ts => mgba-es_419.ts} (100%) rename src/platform/qt/ts/{mgba-pt.ts => mgba-pt_PT.ts} (99%) diff --git a/src/platform/qt/ts/mgba-es.ts b/src/platform/qt/ts/mgba-es_419.ts similarity index 100% rename from src/platform/qt/ts/mgba-es.ts rename to src/platform/qt/ts/mgba-es_419.ts diff --git a/src/platform/qt/ts/mgba-pt.ts b/src/platform/qt/ts/mgba-pt_PT.ts similarity index 99% rename from src/platform/qt/ts/mgba-pt.ts rename to src/platform/qt/ts/mgba-pt_PT.ts index cddb1dd8cf0..f3aa6bdc197 100644 --- a/src/platform/qt/ts/mgba-pt.ts +++ b/src/platform/qt/ts/mgba-pt_PT.ts @@ -1,6 +1,6 @@ - + QGBA From b37bd308f2b9947450cea783c952ff9a64bc95b8 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 16 Sep 2024 02:57:54 -0700 Subject: [PATCH 196/338] Qt: Update translations --- src/platform/qt/ts/mgba-de.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-en.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-es_419.ts | 870 ++++++++++++++-------------- src/platform/qt/ts/mgba-fr.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-hu.ts | 870 ++++++++++++++-------------- src/platform/qt/ts/mgba-it.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-ja.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-ko.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-ms.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-nb_NO.ts | 870 ++++++++++++++-------------- src/platform/qt/ts/mgba-pl.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-pt_BR.ts | 870 ++++++++++++++-------------- src/platform/qt/ts/mgba-pt_PT.ts | 870 ++++++++++++++-------------- src/platform/qt/ts/mgba-ru.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-sv.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-template.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-tr.ts | 868 +++++++++++++-------------- src/platform/qt/ts/mgba-zh_CN.ts | 868 +++++++++++++-------------- 18 files changed, 7850 insertions(+), 7784 deletions(-) diff --git a/src/platform/qt/ts/mgba-de.ts b/src/platform/qt/ts/mgba-de.ts index ce7f38c30a4..4e65105da42 100644 --- a/src/platform/qt/ts/mgba-de.ts +++ b/src/platform/qt/ts/mgba-de.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) Game Boy Advance-ROMs (%1) - + Game Boy ROMs (%1) Game Boy-ROMs (%1) - + All ROMs (%1) Alle ROMs (%1) - + %1 Video Logs (*.mvl) %1 Video-Logs (*.mvl) @@ -191,17 +191,17 @@ Download-Größe: %3 QGBA::AudioDevice - + Can't set format of context-less audio device Format des kontextlosen Audio-Gerätes konnte nicht gesetzt werden - + Audio device is missing its core Dem Audio-Gerät fehlt sein Core - + Writing data to read-only audio device Schreibe Daten an ein schreibgeschütztes Audio-Gerät @@ -209,7 +209,7 @@ Download-Größe: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input Ohne Eingabe kann ein Audio-Prozessor nicht gestartet werden @@ -285,28 +285,28 @@ Download-Größe: %3 Erweiterte Optionen anzeigen - + BattleChip data missing BattleChip-Daten fehlen - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? BattleChip-Daten fehlen. BattleChip Gates wird weiterhin funktionieren, einige Grafiken werden jedoch fehlen. Möchtest Du die Daten jetzt herunterladen? - - + + Select deck file Deck-Datei auswählen - + Incompatible deck Inkompatibles Deck - + The selected deck is not compatible with this Chip Gate Das gewählte Deck ist nicht mit diesem Chip Gate kompatibel @@ -367,19 +367,19 @@ Download-Größe: %3 Codes hier eingeben... - - + + Autodetect (recommended) Automatisch erkennen (empfohlen) - - + + Select cheats file Cheat-Datei auswählen - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. Einige Cheats konnten nicht hinzugefügt werden. Bitte stelle sicher, dass sie korrekt formatiert sind und/oder probiere es mit anderen Cheat-Typen. @@ -398,37 +398,37 @@ Download-Größe: %3 Zurückspulen ist derzeit nicht aktiviert - + Reset the game? Spiel zurücksetzen? - + Most games will require a reset to load the new save. Do you want to reset now? Die meisten Spiele müssen zurückgesetzt werden, um einen neuen Spielstand zu laden. Möchtest Du das Spiel jetzt zurücksetzen? - + Failed to open save file: %1 Fehler beim Öffnen der Speicherdatei: %1 - + Failed to open game file: %1 Fehler beim Öffnen der Spieldatei: %1 - + Can't yank pack in unexpected platform! Das GamePak kann nur auf unterstützten Plattformen herausgezogen werden! - + Failed to open snapshot file for reading: %1 Konnte Snapshot-Datei %1 nicht zum Lesen öffnen - + Failed to open snapshot file for writing: %1 Konnte Snapshot-Datei %1 nicht zum Schreiben öffnen @@ -477,6 +477,14 @@ Download-Größe: %3 CLI-Verlauf kann nicht gespeichert werden + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Download-Größe: %3 Zurücksetzen - + Export frame Bild exportieren - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) - + None Keine - + Background Hintergrund - + Window Fenster - + Objwin Objwin - + Sprite Sprite - + Backdrop Hintergrund - + Frame Frame - + %1 %2 %1 %2 @@ -818,22 +826,22 @@ Download-Größe: %3 QGBA::GBAKeyEditor - + Clear Button Button löschen - + Clear Analog Analog löschen - + Refresh Aktualisieren - + Set all Alle belegen @@ -3006,8 +3014,8 @@ Download-Größe: %3 QGBA::KeyEditor - - + + --- --- @@ -3378,23 +3386,87 @@ Download-Größe: %3 Vertikal - - - + + + N/A Nicht verfügbar - + Export map Map exportieren - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + Durchsuchen + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + Start + + + + Stop + Stopp + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Download-Größe: %3 Aktualisieren - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 byte%2 @@ -3750,17 +3822,17 @@ Download-Größe: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached Versuch Multiplayer-Spieler zu trennen der nicht verbunden ist - + Trying to get player ID for a multiplayer player that's not attached Versuch Spieler-ID festzustellen von einem Multiplayer-Spieler der nicht verbunden ist - + Trying to get save ID for a multiplayer player that's not attached Versuch Speicherstand-ID festzustellen von einem Multiplayer-Spieler der nicht verbunden ist @@ -4157,35 +4229,35 @@ Download-Größe: %3 OBJ exportieren - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette Palette exportieren - + Windows PAL (*.pal);;Adobe Color Table (*.act) Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 Fehler beim Öffnen der Ausgabe-Palettendatei: %1 @@ -4259,7 +4331,7 @@ Download-Größe: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Download-Größe: %3 + Maker Code: + + + + + Revision: + + + + File size: Dateigröße: - + CRC32: CRC32: - + Save file: Speicherstand: @@ -4364,62 +4446,62 @@ Download-Größe: %3 QGBA::SaveConverter - + Save games and save states (%1) Spielstände und Savestates (%1) - + Select save game or save state Spielstand oder Savestate auswählen - + Save games (%1) Spielstände (%1) - + Select save game Spielstand auswählen - + Conversion failed Konvertierung fehlgeschlagen - + Failed to convert the save game. This is probably a bug. Fehler beim Konvertieren des Spielstands. Es handelt sich möglicherweise um einen Programmfehler. - + No file selected Keine Datei ausgewählt - + Could not open file Datei konnte nicht geöffnet werden - + No valid formats found Keine gültigen Formate gefunden - + Please select a valid input file Bitte wähle eine gültige Eingabedatei - + No valid conversions found Keine gültigen Konvertierungen gefunden - + Cannot convert save games between platforms Der Spielstand konnte nicht zwischen verschiedenen Plattformen konvertiert werden @@ -4445,97 +4527,97 @@ Download-Größe: %3 Ausgabedatei - + %1 %2 save game Spielstand %1 %2 - + little endian little-endian - + big endian big-endian - + SRAM SRAM - + %1 flash %1 Flash - + %1 EEPROM %1 EEPROM - + + RTC + RTC - + %1 SRAM + RTC %1 SRAM + RTC - + %1 SRAM %1 SRAM - + packed MBC2 MBC2, komprimiert - + unpacked MBC2 MBC2, entpackt - + MBC6 flash MBC6 Flash-Speicher - + MBC6 combined SRAM + flash MBC6 SRAM + Flash-Speicher - + MBC6 SRAM MBC6 SRAM - + TAMA5 TAMA5 - + %1 (%2) %1 (%2) - + %1 save state with embedded %2 save game Savestate %1 mit eingebettetem Spielstand %2 - + %1 SharkPort %2 save game SharkPort %1 Spielstand %2 - + %1 GameShark Advance SP %2 save game %1 GameShark Advance SP %2 Spielstand @@ -4571,32 +4653,37 @@ Download-Größe: %3 Kürzlich geöffnetes Skript laden - + Load script... Skript laden... - + + &Load most recent + + + + &Reset Zu&rücksetzen - + 0 0 - + Select script to load Skript auswählen, welches geladen werden soll - + Lua scripts (*.lua) Lua-Skripte (*.lua) - + All files (*.*) Alle Dateien (*.*) @@ -4689,105 +4776,105 @@ Download-Größe: %3 QGBA::SettingsView - - + + Qt Multimedia Qt Multimedia - + SDL SDL - + Software (Qt) Software (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL (erzwinge Version 1.x) - + None Keiner - + None (Still Image) Keiner (Standbild) - + Keyboard Tastatur - + Controllers Gamepads - + Shortcuts Tastenkürzel - - + + Shaders Shader - + Select BIOS BIOS auswählen - + Select directory Verzeichnis auswählen - + Select image Bild auswählen - + Image file (*.png *.jpg *.jpeg) Bilddatei (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Nie - + Just now Gerade eben - + Less than an hour ago Vor weniger als einer Stunde - + %n hour(s) ago Vor %n Stunde @@ -4795,7 +4882,7 @@ Download-Größe: %3 - + %n day(s) ago Vor %n Tag @@ -5122,37 +5209,37 @@ Download-Größe: %3 Zurückspulgeschwindigkeit: - + Default color palette only Nur Standard-Farbpalette - + SGB color palette if available SGB-Farbpalette, sofern verfügbar - + GBC color palette if available GBC-Farbpalette, sofern verfügbar - + SGB (preferred) or GBC color palette if available SGB (bevorzugt) oder GBC-Farbpalette, sofern verfügbar - + Game Boy Camera Game Boy Camera - + Driver: Treiber: - + Source: Quelle: @@ -5223,42 +5310,42 @@ Download-Größe: %3 Zusätzliche Savestate-Daten laden: - + Models Modelle - + GB only: Nur GB: - + SGB compatible: SGB-kompatibel: - + GBC only: Nur GBC: - + GBC compatible: GBC-kompatibel: - + SGB and GBC compatible: SGB- und GBC-kompatibel: - + Game Boy palette Game Boy-Palette - + Preset: Voreinstellungen: @@ -5303,57 +5390,52 @@ Download-Größe: %3 Software - + OpenGL enhancements OpenGL-Verbesserungen - + High-resolution scale: Hochauflösende Skalierung: - - XQ GBA audio (experimental) - XQ GBA-Audio (experimentell) - - - + Cheats Cheats - + Log to file In Datei protokollieren - + Log to console Auf die Konsole protokollieren - + Select Log File Protokoll-Datei auswählen - + Default BG colors: Standard-Hintergrundfarben: - + Default sprite colors 1: Standard-Sprite-Farben 1: - + Default sprite colors 2: Standard-Sprite-Farben 2: - + Super Game Boy borders Super Game Boy-Rahmen @@ -5384,25 +5466,25 @@ Download-Größe: %3 - - - - - - - - - + + + + + + + + + Browse Durchsuchen - + Use BIOS file if found BIOS-Datei verwenden, wenn vorhanden - + Skip BIOS intro BIOS-Intro überspringen @@ -5480,56 +5562,56 @@ Download-Größe: %3 Autofeuer-Intervall: - + (240×160) (240×160) - + GB BIOS file: Datei mit GB-BIOS: - + GBA BIOS file: Datei mit GBA-BIOS: - + GBC BIOS file: Datei mit GBC-BIOS: - + SGB BIOS file: Datei mit SGB-BIOS: - + Save games Spielstände - - - - - + + + + + Same directory as the ROM Verzeichnis der ROM-Datei - + Save states Savestates - + Screenshots Bildschirmfotos - + Patches Korrekturen @@ -5777,7 +5859,6 @@ Download-Größe: %3 - WebM WebM @@ -5786,19 +5867,8 @@ Download-Größe: %3 Format Format - - - MKV - MKV - - - - AVI - AVI - - MP4 MP4 @@ -5842,72 +5912,6 @@ Download-Größe: %3 &Native &Nativ - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - Leer - - - - FLAC - FLAC - - - - WavPack - WavPack - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - Unkomprimiert - Bitrate (kbps) @@ -5918,16 +5922,6 @@ Download-Größe: %3 ABR ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5957,85 +5951,85 @@ Download-Größe: %3 QGBA::Window - + Archives (%1) Archive (%1) - - + + Select ROM ROM auswählen - - + + Select save Speicherdatei wählen - + Select patch Patch wählen - + Patches (*.ips *.ups *.bps) Korrekturen (*.ips *.ups *.bps) - + Select e-Reader card images Bilder der Lesegerät-Karte auswählen - + Image file (*.png *.jpg *.jpeg) Bilddatei (*.png *.jpg *.jpeg) - + Conversion finished Konvertierung abgeschlossen - + %1 of %2 e-Reader cards converted successfully. %1 von %2 Lesegerät-Karten erfolgreich konvertiert. - + Select image Bild auswählen - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Bild-Datei (*.png *.gif *.jpg *.jpeg);;Alle Dateien (*) - + GameShark saves (*.sps *.xps) GameShark-Speicherdaten (*.sps *.xps) - + Select video log Video-Log auswählen - + Video logs (*.mvl) Video-Logs (*.mvl) - + Crash Absturz - + The game has crashed with the following error: %1 @@ -6044,694 +6038,704 @@ Download-Größe: %3 %1 - + Unimplemented BIOS call Nicht implementierter BIOS-Aufruf - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Dieses Spiel verwendet einen BIOS-Aufruf, der nicht implementiert ist. Bitte verwenden Sie für die beste Spielerfahrung das offizielle BIOS. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Es konnte kein geeignetes Ausgabegerät erstellt werden, stattdessen wird Software-Rendering als Rückfalloption genutzt. Spiele laufen möglicherweise langsamer, besonders innerhalb großer Fenster. - + Really make portable? Portablen Modus wirklich aktivieren? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Diese Einstellung wird den Emulator so konfigurieren, dass er seine Konfiguration aus dem gleichen Verzeichnis wie die Programmdatei lädt. Möchten Sie fortfahren? - + Restart needed Neustart benötigt - + Some changes will not take effect until the emulator is restarted. Einige Änderungen werden erst übernommen, wenn der Emulator neu gestartet wurde. - + - Player %1 of %2 - Spieler %1 von %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 Bilder/Sekunde) - %4 - + &File &Datei - + Load &ROM... &ROM laden... - + Load ROM in archive... ROM aus Archiv laden... - + Save games Spielstände - + Automatically determine Automatisch erkennen - + Use player %0 save game Verwende Spielstand von Spieler %0 - + Load &patch... &Patch laden... - + Boot BIOS BIOS booten - + Replace ROM... ROM ersetzen... - + Convert e-Reader card image to raw... Lesegerät-Kartenbild in Rohdaten umwandeln â€¦ - + ROM &info... ROM-&Informationen... - + Recent Zuletzt verwendet - + Make portable Portablen Modus aktivieren - + &Load state Savestate (aktueller Zustand) &laden - + Load state file... Savestate-Datei laden... - + &Save state Savestate (aktueller Zustand) &speichern - + Save state file... Savestate-Datei speichern... - + Quick load Schnell laden - + Quick save Schnell speichern - + Load recent Lade zuletzt gespeicherten Savestate - + Save recent Speichere aktuellen Zustand - + Undo load state Laden des Savestate rückgängig machen - + Undo save state Speichern des Savestate rückgängig machen - - + + State &%1 Savestate &%1 - + Load camera image... Lade Kamerabild... - + Convert save game... Spielstand konvertieren... - + Reset needed Zurücksetzen erforderlich - + Some changes will not take effect until the game is reset. Einige Änderungen werden erst dann wirksam, wenn das Spiel zurückgesetzt wird. - + New multiplayer window Neues Multiplayer-Fenster - + Connect to Dolphin... Mit Dolphin verbinden... - + Report bug... Fehler melden... - + E&xit &Beenden - + &Emulation &Emulation - + &Reset Zu&rücksetzen - + Sh&utdown Schli&eßen - + Yank game pak Spielmodul herausziehen - + &Pause &Pause - + &Next frame &Nächstes Bild - + Fast forward (held) Schneller Vorlauf (gehalten) - + &Fast forward Schneller &Vorlauf - + Fast forward speed Vorlauf-Geschwindigkeit - + Unbounded Unbegrenzt - + %0x %0x - + Increase fast forward speed Vorspulgeschwindigkeit erhöhen - + Decrease fast forward speed Vorspulgeschwindigkeit senken - + Rewind (held) Zurückspulen (gehalten) - + Re&wind Zur&ückspulen - + Step backwards Schrittweiser Rücklauf - + Solar sensor Sonnen-Sensor - + Increase solar level Sonnen-Level erhöhen - + Decrease solar level Sonnen-Level verringern - + Brightest solar level Hellster Sonnen-Level - + Darkest solar level Dunkelster Sonnen-Level - + Brightness %1 Helligkeit %1 - + BattleChip Gate... BattleChip Gate... - + Audio/&Video Audio/&Video - + Frame size Bildgröße - + Toggle fullscreen Vollbildmodus umschalten - + + &Lock frame size + + + + Lock aspect ratio Seitenverhältnis korrigieren - + Force integer scaling Pixelgenaue Skalierung (Integer scaling) - + Interframe blending Interframe-Ãœberblendung - + Frame&skip Frame&skip - + Mute Stummschalten - + FPS target Bildwiederholrate - + Take &screenshot &Screenshot erstellen - + F12 F12 - + Scripting... Scripting... - + Create forwarder... Forwarder erzeugen... - + Game state views Spiel-Zustände ansehen - + + Log memory &accesses... + + + + Clear Leeren - + Game Boy Printer... Game Boy Printer... - + Video layers Video-Ebenen - + Audio channels Audio-Kanäle - + Adjust layer placement... Lage der Bildebenen anpassen... - + &Tools &Werkzeuge - + View &logs... &Logs ansehen... - + Game &overrides... Spiel-&Ãœberschreibungen... - + &Cheats... &Cheats... - + Open debugger console... Debugger-Konsole öffnen... - + Start &GDB server... &GDB-Server starten... - + Settings... Einstellungen... - + Select folder Ordner auswählen - + Save games (%1) Spielstände (%1) - + Select save game Spielstand auswählen - + mGBA save state files (%1) mGBA-Savestates (%1) - - + + Select save state Savestate auswählen - + Select e-Reader dotcode e-Reader-Code auswählen - + e-Reader card (*.raw *.bin *.bmp) e-Reader-Karte (*.raw *.bin *.bmp) - + GameShark saves (*.gsv *.sps *.xps) GameShark-Spielstände (*.gsv *.sps *.xps) - + Couldn't Start Konnte nicht gestartet werden - + Could not start game. Spiel konnte nicht gestartet werden. - + Add folder to library... Ordner zur Bibliothek hinzufügen... - + Load alternate save game... Alternativen Spielstand laden... - + Load temporary save game... Temporären Spielstand laden... - + Scan e-Reader dotcodes... e-Reader-Code einlesen... - + Import GameShark Save... GameShare-Speicherstand importieren... - + Export GameShark Save... GameShark-Speicherstand exportieren... - + About... Ãœber... - + %1× %1x - + Bilinear filtering Bilineare Filterung - + Native (59.7275) Nativ (59.7275) - + Record A/V... Audio/Video aufzeichnen... - + Record GIF/WebP/APNG... GIF/WebP/APNG aufzeichnen... - + Game Pak sensors... Spielmodul-Sensoren... - + View &palette... &Palette betrachten... - + View &sprites... &Sprites betrachten... - + View &tiles... &Tiles betrachten... - + View &map... &Map betrachten... - + &Frame inspector... &Bildbetrachter... - + View memory... Speicher betrachten... - + Search memory... Speicher durchsuchen... - + View &I/O registers... &I/O-Register betrachten... - + Record debug video log... Video-Protokoll aufzeichnen... - + Stop debug video log Aufzeichnen des Video-Protokolls beenden - + Exit fullscreen Vollbildmodus beenden - + GameShark Button (held) GameShark-Taste (gehalten) - + Autofire Autofeuer - + Autofire A Autofeuer A - + Autofire B Autofeuer B - + Autofire L Autofeuer L - + Autofire R Autofeuer R - + Autofire Start Autofeuer Start - + Autofire Select Autofeuer Select - + Autofire Up Autofeuer nach oben - + Autofire Right Autofeuer rechts - + Autofire Down Autofeuer nach unten - + Autofire Left Autofeuer links @@ -6769,17 +6773,17 @@ Download-Größe: %3 ? - + Super (L) Super (L) - + Super (R) Super (R) - + Menu Menü @@ -6787,22 +6791,22 @@ Download-Größe: %3 QShortcut - + Shift Shift - + Control Strg - + Alt Alt - + Meta AltGr diff --git a/src/platform/qt/ts/mgba-en.ts b/src/platform/qt/ts/mgba-en.ts index 4b67efd508e..cdb0f81b4c7 100644 --- a/src/platform/qt/ts/mgba-en.ts +++ b/src/platform/qt/ts/mgba-en.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) - + Game Boy ROMs (%1) - + All ROMs (%1) - + %1 Video Logs (*.mvl) @@ -185,17 +185,17 @@ Download size: %3 QGBA::AudioDevice - + Can't set format of context-less audio device - + Audio device is missing its core - + Writing data to read-only audio device @@ -203,7 +203,7 @@ Download size: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input @@ -279,28 +279,28 @@ Download size: %3 - + BattleChip data missing - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? - - + + Select deck file - + Incompatible deck - + The selected deck is not compatible with this Chip Gate @@ -361,19 +361,19 @@ Download size: %3 - - + + Autodetect (recommended) - - + + Select cheats file - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. @@ -392,37 +392,37 @@ Download size: %3 - + Reset the game? - + Most games will require a reset to load the new save. Do you want to reset now? - + Failed to open save file: %1 - + Failed to open game file: %1 - + Can't yank pack in unexpected platform! - + Failed to open snapshot file for reading: %1 - + Failed to open snapshot file for writing: %1 @@ -471,6 +471,14 @@ Download size: %3 + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -751,52 +759,52 @@ Download size: %3 - + Export frame - + Portable Network Graphics (*.png) - + None - + Background - + Window - + Objwin - + Sprite - + Backdrop - + Frame - + %1 %2 @@ -812,22 +820,22 @@ Download size: %3 QGBA::GBAKeyEditor - + Clear Button - + Clear Analog - + Refresh - + Set all @@ -3000,8 +3008,8 @@ Download size: %3 QGBA::KeyEditor - - + + --- @@ -3372,23 +3380,87 @@ Download size: %3 - - - + + + N/A - + Export map - + Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3635,22 +3707,22 @@ Download size: %3 - + (%0/%1×) - + (â…Ÿ%0×) - + (%0×) - + %1 byte%2 @@ -3744,17 +3816,17 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4151,35 +4223,35 @@ Download size: %3 - + #%0 - + 0x%0 + + - - 0x%0 (%1) - + Export palette - + Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 @@ -4253,7 +4325,7 @@ Download size: %3 QGBA::ROMInfo - + @@ -4293,16 +4365,26 @@ Download size: %3 - File size: + Maker Code: - CRC32: + Revision: + File size: + + + + + CRC32: + + + + Save file: @@ -4358,62 +4440,62 @@ Download size: %3 QGBA::SaveConverter - + Save games and save states (%1) - + Select save game or save state - + Save games (%1) - + Select save game - + Conversion failed - + Failed to convert the save game. This is probably a bug. - + No file selected - + Could not open file - + No valid formats found - + Please select a valid input file - + No valid conversions found - + Cannot convert save games between platforms @@ -4439,97 +4521,97 @@ Download size: %3 - + %1 %2 save game - + little endian - + big endian - + SRAM - + %1 flash - + %1 EEPROM - + + RTC - + %1 SRAM + RTC - + %1 SRAM - + packed MBC2 - + unpacked MBC2 - + MBC6 flash - + MBC6 combined SRAM + flash - + MBC6 SRAM - + TAMA5 - + %1 (%2) - + %1 save state with embedded %2 save game - + %1 SharkPort %2 save game - + %1 GameShark Advance SP %2 save game @@ -4565,32 +4647,37 @@ Download size: %3 - + Load script... - + + &Load most recent + + + + &Reset - + 0 - + Select script to load - + Lua scripts (*.lua) - + All files (*.*) @@ -4683,105 +4770,105 @@ Download size: %3 QGBA::SettingsView - - + + Qt Multimedia - + SDL - + Software (Qt) - + OpenGL - + OpenGL (force version 1.x) - + None - + None (Still Image) - + Keyboard - + Controllers - + Shortcuts - - + + Shaders - + Select BIOS - + Select directory - + Select image - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago @@ -4789,7 +4876,7 @@ Download size: %3 - + %n day(s) ago @@ -5116,37 +5203,37 @@ Download size: %3 - + Default color palette only - + SGB color palette if available - + GBC color palette if available - + SGB (preferred) or GBC color palette if available - + Game Boy Camera - + Driver: - + Source: @@ -5323,42 +5410,42 @@ Download size: %3 - + Models - + GB only: - + SGB compatible: - + GBC only: - + GBC compatible: - + SGB and GBC compatible: - + Game Boy palette - + Preset: @@ -5395,135 +5482,130 @@ Download size: %3 - + OpenGL enhancements - + High-resolution scale: - + (240×160) - - XQ GBA audio (experimental) - - - - + GB BIOS file: - - - - - - - - - + + + + + + + + + Browse - + Use BIOS file if found - + Skip BIOS intro - + GBA BIOS file: - + GBC BIOS file: - + SGB BIOS file: - + Save games - - - - - + + + + + Same directory as the ROM - + Save states - + Screenshots - + Patches - + Cheats - + Log to file - + Log to console - + Select Log File - + Default BG colors: - + Default sprite colors 1: - + Default sprite colors 2: - + Super Game Boy borders @@ -5781,13 +5863,11 @@ Download size: %3 - WebM - MP4 @@ -5826,82 +5906,6 @@ Download size: %3 Format - - - MKV - - - - - AVI - - - - - HEVC - - - - - HEVC (NVENC) - - - - - VP8 - - - - - VP9 - - - - - FFV1 - - - - - - None - - - - - FLAC - - - - - WavPack - - - - - Opus - - - - - Vorbis - - - - - MP3 - - - - - AAC - - - - - Uncompressed - - Bitrate (kbps) @@ -5912,16 +5916,6 @@ Download size: %3 ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5951,779 +5945,789 @@ Download size: %3 QGBA::Window - + Archives (%1) - - + + Select ROM - + Select folder - - + + Select save - + Select patch - + Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) - + Select image - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) - + Select video log - + Video logs (*.mvl) - + Crash - + The game has crashed with the following error: %1 - + Couldn't Start - + Could not start game. - + Unimplemented BIOS call - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + Really make portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + Restart needed - + Some changes will not take effect until the emulator is restarted. - + - Player %1 of %2 - + %1 - %2 - + %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File - + Load &ROM... - + Load ROM in archive... - + Add folder to library... - + Save games (%1) - + Select save game - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Load &patch... - + Boot BIOS - + Replace ROM... - + Scan e-Reader dotcodes... - + Convert e-Reader card image to raw... - + ROM &info... - + Recent - + Make portable - + &Load state - + Load state file... - + &Save state - + Save state file... - + Quick load - + Quick save - + Load recent - + Save recent - + Undo load state - + Undo save state - - + + State &%1 - + Load camera image... - + Convert save game... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games - + Import GameShark Save... - + Export GameShark Save... - + Automatically determine - + Use player %0 save game - + New multiplayer window - + Connect to Dolphin... - + Report bug... - + About... - + E&xit - + &Emulation - + &Reset - + Sh&utdown - + Yank game pak - + &Pause - + &Next frame - + Fast forward (held) - + &Fast forward - + Fast forward speed - + Unbounded - + %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) - + Re&wind - + Step backwards - + Solar sensor - + Increase solar level - + Decrease solar level - + Brightest solar level - + Darkest solar level - + Brightness %1 - + Game Boy Printer... - + BattleChip Gate... - + Audio/&Video - + Frame size - + %1× - + Toggle fullscreen - + + &Lock frame size + + + + Lock aspect ratio - + Force integer scaling - + Interframe blending - + Bilinear filtering - + Frame&skip - + Mute - + FPS target - + Native (59.7275) - + Take &screenshot - + F12 - + Record A/V... - + Record GIF/WebP/APNG... - + Video layers - + Audio channels - + Adjust layer placement... - + &Tools - + View &logs... - + Game &overrides... - + Game Pak sensors... - + &Cheats... - + Create forwarder... - + Settings... - + Open debugger console... - + Start &GDB server... - + Scripting... - + Game state views - + View &palette... - + View &sprites... - + View &tiles... - + View &map... - + &Frame inspector... - + View memory... - + Search memory... - + View &I/O registers... - + + Log memory &accesses... + + + + Record debug video log... - + Stop debug video log - + Exit fullscreen - + GameShark Button (held) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear @@ -6761,17 +6765,17 @@ Download size: %3 - + Super (L) - + Super (R) - + Menu @@ -6779,22 +6783,22 @@ Download size: %3 QShortcut - + Shift - + Control - + Alt - + Meta diff --git a/src/platform/qt/ts/mgba-es_419.ts b/src/platform/qt/ts/mgba-es_419.ts index 7dfe054c7e1..cc40f84f70d 100644 --- a/src/platform/qt/ts/mgba-es_419.ts +++ b/src/platform/qt/ts/mgba-es_419.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) ROMs para Game Boy Advance (%1) - + Game Boy ROMs (%1) ROMs para Game Boy Advance (%1) - + All ROMs (%1) Todas las ROMs (%1) - + %1 Video Logs (*.mvl) %1 Registros de vídeo (*.mvl) @@ -191,17 +191,17 @@ Tamaño de descarga: %3 QGBA::AudioDevice - + Can't set format of context-less audio device No se puede establecer el formato de un dispositivo de audio sin contexto - + Audio device is missing its core No se encuentra el sistema del dispositivo de audio - + Writing data to read-only audio device Escribiendo datos a dispositivo de audio de sólo lectura @@ -209,7 +209,7 @@ Tamaño de descarga: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input No se puede iniciar el procesador de audio sin entrada @@ -285,28 +285,28 @@ Tamaño de descarga: %3 Mostrar configuración avanzada - + BattleChip data missing Faltan los datos del BattleChip - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? Faltan los datos de BattleChip. Los BattleChip Gates seguirán funcionando pero faltarán algunos gráficos. ¿Quieres descargar los datos ahora? - - + + Select deck file Seleccionar fichero de baraja - + Incompatible deck Baraja no compatible - + The selected deck is not compatible with this Chip Gate La baraja seleccionada no es compatible con este Chip Gate @@ -367,19 +367,19 @@ Tamaño de descarga: %3 Ingresa los códigos aquí... - - + + Autodetect (recommended) Autodetectar (recomendado) - - + + Select cheats file Seleccionar archivo de trucos - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. Algunos trucos no se pudieron añadir. Asegúrate de que están en el formato correcto y/o prueba otro tipo de trucos. @@ -398,37 +398,37 @@ Tamaño de descarga: %3 Rebobinado desactivado actualmente - + Reset the game? ¿Reiniciar el juego? - + Most games will require a reset to load the new save. Do you want to reset now? La mayoría de juegos requieren reiniciar para cargar la nueva partida guardada. ¿Quieres reiniciar ahora? - + Failed to open save file: %1 Error al abrir el archivo de guardado: %1 - + Failed to open game file: %1 Error al abrir el archivo del juego: %1 - + Can't yank pack in unexpected platform! ¡No se puede quitar el cartucho en esta plataforma! - + Failed to open snapshot file for reading: %1 Error al leer del archivo de captura: %1 - + Failed to open snapshot file for writing: %1 Error al escribir al archivo de captura: %1 @@ -477,6 +477,14 @@ Tamaño de descarga: %3 No se ha podido abrir el historial de la línea de comandos para escritura + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Tamaño de descarga: %3 Reiniciar - + Export frame Exportar cuadro - + Portable Network Graphics (*.png) Gráficos de red portátiles (*.png) - + None Ninguno - + Background Fondo - + Window Ventana - + Objwin Objwin - + Sprite Sprite - + Backdrop Telón de fondo (backdrop) - + Frame Cuadro - + %1 %2 %1× {1 %2?} @@ -818,22 +826,22 @@ Tamaño de descarga: %3 QGBA::GBAKeyEditor - + Clear Button Reestablecer botones - + Clear Analog Reestablecer sticks analógicos - + Refresh Actualizar - + Set all Configurar todo @@ -3006,8 +3014,8 @@ Tamaño de descarga: %3 QGBA::KeyEditor - - + + --- --- @@ -3378,23 +3386,87 @@ Tamaño de descarga: %3 Vertical - - - + + + N/A n/d - + Export map Exportar mapa - + Portable Network Graphics (*.png) Gráficos de red portátiles (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + Detener + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Tamaño de descarga: %3 Actualizar - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 byte%2 @@ -3750,17 +3822,17 @@ Tamaño de descarga: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached Intentando desvincular a un multijugador que no está conectado - + Trying to get player ID for a multiplayer player that's not attached Intentando obtener el ID de un multijugador que no está conectado - + Trying to get save ID for a multiplayer player that's not attached Intentando obtener ID de guardado para un jugador multijugador que no está conectado @@ -4157,35 +4229,35 @@ Tamaño de descarga: %3 Exportar OBJ - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette Exportar paleta - + Windows PAL (*.pal);;Adobe Color Table (*.act) Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 Error al abrir el archivo de paleta de salida: %1 @@ -4259,7 +4331,7 @@ Tamaño de descarga: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Tamaño de descarga: %3 + Maker Code: + + + + + Revision: + + + + File size: Tamaño del archivo: - + CRC32: CRC32: - + Save file: Guardar: @@ -4364,62 +4446,62 @@ Tamaño de descarga: %3 QGBA::SaveConverter - + Save games and save states (%1) Juegos y estados guardados (%1) - + Select save game or save state Seleccionar juego o estado guardado - + Save games (%1) Datos de guardado (%1) - + Select save game Seleccionar juego guardado - + Conversion failed Conversión fallada - + Failed to convert the save game. This is probably a bug. No se pudo convertir el estado guardado. Esto probablemente es un error. - + No file selected Archivo no seleccionado - + Could not open file Error al abrir el archivo - + No valid formats found No se encontraron formatos válidos - + Please select a valid input file Seleccione un archivo de entrada válido - + No valid conversions found No se encontraron conversiones validas - + Cannot convert save games between platforms No se pueden convertir los estados guardados entre plataformas distintas @@ -4445,97 +4527,97 @@ Tamaño de descarga: %3 Archivo de salida - + %1 %2 save game %1 %2 juego guardado - + little endian little-endian - + big endian big-endian - + SRAM SRAM - + %1 flash %1 flash - + %1 EEPROM %1 EEPROM - + + RTC + RTC - + %1 SRAM + RTC %1 SRAM + RTC - + %1 SRAM %1 SRAM - + packed MBC2 MBC2 empacado - + unpacked MBC2 MBC2 desempacado - + MBC6 flash flash MBC6 - + MBC6 combined SRAM + flash SRAM + flash combinados MBC6 - + MBC6 SRAM SRAM MBC6 - + TAMA5 TAMA5 - + %1 (%2) %1 (%2) - + %1 save state with embedded %2 save game %1 estado guardado con juego guardado %2 integrado - + %1 SharkPort %2 save game %1 SharkPort %2 partida guardada - + %1 GameShark Advance SP %2 save game %1 GameShark Advance SP %2 partida guardada @@ -4571,32 +4653,37 @@ Tamaño de descarga: %3 Cargar script reciente - + Load script... Cargar script... - + + &Load most recent + + + + &Reset &Reiniciar - + 0 0 - + Select script to load Elegir script - + Lua scripts (*.lua) Scripts de Lua (*.lua) - + All files (*.*) Todos los archivos (*.*) @@ -4689,119 +4776,117 @@ Tamaño de descarga: %3 QGBA::SettingsView - - + + Qt Multimedia Qt Multimedia - + SDL SDL - + Software (Qt) Software (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL (forzar versión 1.x) - + None Ninguno - + None (Still Image) Nada (imagen estática) - + Keyboard Teclado - + Controllers Mandos - + Shortcuts Atajos de teclado - - + + Shaders Shaders - + Select BIOS Seleccionar BIOS - + Select directory Elegir carpeta - + Select image Seleccionar imagen - + Image file (*.png *.jpg *.jpeg) Archivo de imagen (*.png *.jpg *.jpeg) - + (%1×%2) - + Never Nunca - + Just now Ahora mismo - + Less than an hour ago Hace menos de una hora - + %n hour(s) ago Hace %n hora Hace %n horas - Hace %n horas - + %n day(s) ago Hace %n día Hace %n días - Hace %n días @@ -5139,37 +5224,37 @@ Tamaño de descarga: %3 Velocidad de rebobinado: - + Default color palette only Sólo paleta de colores predeterminada - + SGB color palette if available Paleta de color SGB si está disponible - + GBC color palette if available Paleta de color GBC si está disponible - + SGB (preferred) or GBC color palette if available Paleta de colores SGB (preferida) o GBC si está disponible - + Game Boy Camera Cámara Game Boy - + Driver: Controlador: - + Source: Fuente: @@ -5215,7 +5300,7 @@ Tamaño de descarga: %3 Activar modo de compatibilidad VBA en ROM hacks - + Preset: Ajustes: @@ -5230,22 +5315,22 @@ Tamaño de descarga: %3 Avance rápido (mantenido): - + (240×160) (240×160) - + Log to file Guardar en archivo - + Log to console Escribir en consola - + Select Log File Seleccionar @@ -5383,61 +5468,56 @@ Tamaño de descarga: %3 Software - + OpenGL enhancements Mejoras para OpenGL - + High-resolution scale: Escala de alta resolución: - - XQ GBA audio (experimental) - Mejorar audio GBA (experimental) - - - + GB BIOS file: Archivo BIOS GB: - - - - - - - - - + + + + + + + + + Browse Examinar - + Use BIOS file if found Usar archivo BIOS si está disponible - + Skip BIOS intro Saltar animación de entrada de la BIOS - + GBA BIOS file: Archivo BIOS GBA: - + GBC BIOS file: Archivo BIOS GBC: - + SGB BIOS file: Archivo BIOS SGB: @@ -5447,91 +5527,91 @@ Tamaño de descarga: %3 Guardar estado automáticamente - + Save games Datos de guardado - - - - - + + + + + Same directory as the ROM En el mismo directorio que la ROM - + Save states Estados de guardado - + Screenshots Capturas de pantalla - + Patches Parches - + Cheats Trucos - + Models Modelos - + GB only: Sólo GB: - + SGB compatible: Compatible con SGB: - + GBC only: Sólo GBC: - + GBC compatible: Compatible con GBC: - + SGB and GBC compatible: Compatible con SGB y GBC: - + Game Boy palette Paleta de Game Boy - + Default BG colors: Colores de fondo por defecto: - + Super Game Boy borders Bordes de Super Game Boy - + Default sprite colors 1: Colores de sprite 1 por defecto: - + Default sprite colors 2: Colores de sprite 2 por defecto: @@ -5779,7 +5859,6 @@ Tamaño de descarga: %3 - WebM WebM @@ -5788,19 +5867,8 @@ Tamaño de descarga: %3 Format Formato - - - MKV - MKV - - - - AVI - AVI - - MP4 MP4 @@ -5844,72 +5912,6 @@ Tamaño de descarga: %3 &Native &Nativo - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - Ninguno - - - - FLAC - FLAC - - - - WavPack - WavPack - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - Sin comprimir - Bitrate (kbps) @@ -5920,16 +5922,6 @@ Tamaño de descarga: %3 ABR ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5959,80 +5951,80 @@ Tamaño de descarga: %3 QGBA::Window - + Archives (%1) Contenedores (%1) - - + + Select ROM Seleccionar ROM - + Select folder Seleccionar carpeta - - + + Select save Seleccionar guardado - + Select patch Seleccionar parche - + Patches (*.ips *.ups *.bps) Parches (*.ips *.ups *.bps) - + Select e-Reader dotcode Seleccionar dotcode del e-Reader - + e-Reader card (*.raw *.bin *.bmp) Tarjeta e-Reader (*.raw *.bin *.bmp) - + Select image Seleccionar imagen - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Archivo de imagen (*.png *.gif *.jpg *.jpeg);;Todos los archivos (*) - + GameShark saves (*.sps *.xps) Guardados de GameShark (*.sps *.xps) - + Select video log Seleccionar registro de vídeo - + Video logs (*.mvl) Registros de vídeo (*.mvl) - + Crash Cierre inesperado - + The game has crashed with the following error: %1 @@ -6041,699 +6033,709 @@ Tamaño de descarga: %3 %1 - + Unimplemented BIOS call Llamada a BIOS no implementada - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Este juego utiliza una llamada al BIOS que no se ha implementado. Utiliza el BIOS oficial para obtener la mejor experiencia. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. No se pudo crear un dispositivo de pantalla apropiado, recurriendo a software. Los juegos pueden funcionar lentamente, especialmente con ventanas grandes. - + Really make portable? ¿Hacer "portable"? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Esto hará que el emulador cargue su configuración desde el mismo directorio que el ejecutable. ¿Quieres continuar? - + Restart needed Reinicio necesario - + Some changes will not take effect until the emulator is restarted. Algunos cambios no surtirán efecto hasta que se reinicie el emulador. - + - Player %1 of %2 - Jugador %1 de %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &Archivo - + Load &ROM... Cargar &ROM... - + Load ROM in archive... Cargar ROM desde archivo comprimido... - + Add folder to library... Agregar carpeta a la biblioteca... - + Save games Datos de guardado - + Automatically determine Determinar automáticamente - + Use player %0 save game Usar la partida guardada del jugador %0 - + Load &patch... Cargar &parche... - + Boot BIOS Arrancar BIOS - + Replace ROM... Reemplazar ROM... - + ROM &info... &Información de la ROM... - + Recent Reciente - + Make portable Crear instalación portable - + &Load state Ca&rgar estado - + Report bug... Reportar error... - + About... Acerca de... - + Game Pak sensors... Sensores del cartucho... - + Clear Limpiar - + Load state file... Cargar archivo de estado... - + Save games (%1) Juegos guardados (%1) - + Select save game Elegir juego guardado - + mGBA save state files (%1) Archivos estados guardados mGBA (%1) - - + + Select save state Elegir estado guardado - + Select e-Reader card images Elegir imágenes de tarjeta e-Reader - + Image file (*.png *.jpg *.jpeg) Archivo de imagen (*.png *.jpg *.jpeg) - + Conversion finished Conversión terminada - + %1 of %2 e-Reader cards converted successfully. %1 de %2 tarjetas e-Reader convertidas con éxito. - + Load alternate save game... Cargar partida guardada alternativa... - + Load temporary save game... Cargar partida guardada temporal... - + Convert e-Reader card image to raw... Convertir imagen de tarjeta e-Reader a archivo en bruto... - + &Save state Guardar e&stado - + Save state file... Guardar archivo de estado... - + Quick load Cargado rápido - + Quick save Guardado rápido - + Load recent Cargar reciente - + Save recent Guardar reciente - + Undo load state Deshacer cargar estado - + Undo save state Deshacer guardar estado - - + + State &%1 Estado &%1 - + Load camera image... Cargar imagen para cámara... - + Convert save game... Convertir juego guardado... - + GameShark saves (*.gsv *.sps *.xps) Partidas guardadas de GameShark (*.gsv *.sps *.xps) - + Reset needed Reinicio necesario - + Some changes will not take effect until the game is reset. Algunos cambios no tendrán efecto hasta que se reinicie el juego. - + New multiplayer window Nueva ventana multijugador - + Connect to Dolphin... Conectar a Dolphin... - + E&xit Salir (&X) - + &Emulation &Emulación - + &Reset &Reiniciar - + Sh&utdown Apagar (&U) - + Yank game pak Sacar cartucho - + &Pause &Pausar - + &Next frame Cuadro siguie&nte - + Fast forward (held) Avance rápido (mantener) - + &Fast forward &Avance rápido - + Fast forward speed Velocidad de avance rápido - + Unbounded Sin límite - + %0x %0x - + Increase fast forward speed Aumentar la velocidad de avance rápido - + Decrease fast forward speed Disminuir velocidad de avance rápido - + Rewind (held) Rebobinar (mantener) - + Re&wind Re&bobinar - + Step backwards Paso hacia atrás - + Solar sensor Sensor solar - + Increase solar level Subir nivel - + Decrease solar level Bajar nivel - + Brightest solar level Más claro - + Darkest solar level Más oscuro - + Brightness %1 Brillo %1 - + Audio/&Video Audio/&vídeo - + Frame size Tamaño del cuadro - + Toggle fullscreen Pantalla completa - + + &Lock frame size + + + + Lock aspect ratio Bloquear proporción de aspecto - + Force integer scaling Forzar escala a enteros - + Bilinear filtering Filtro bilineal - + Frame&skip &Salto de cuadros - + Mute Silenciar - + FPS target Objetivo de FPS - + Native (59.7275) Nativo (59,7275) - + Take &screenshot Tomar pan&tallazo - + F12 F12 - + Game Boy Printer... Game Boy Printer... - + BattleChip Gate... BattleChip Gate... - + %1× %1× - + Interframe blending Mezcla entre cuadros - + Record A/V... Grabar A/V... - + Video layers Capas de vídeo - + Audio channels Canales de audio - + Adjust layer placement... Ajustar ubicación de capas... - + &Tools Herramien&tas - + View &logs... Ver re&gistros... - + Game &overrides... Ajustes específic&os por juego... - + Couldn't Start No se pudo iniciar - + Could not start game. No se pudo iniciar el juego. - + Scan e-Reader dotcodes... Escanear dotcodes del e-Reader... - + Import GameShark Save... Importar desde GameShark... - + Export GameShark Save... Exportar a GameShark... - + Record GIF/WebP/APNG... Grabar GIF/WebP/APNG... - + &Cheats... Tru&cos... - + Settings... Ajustes... - + Open debugger console... Abrir consola de depuración... - + Start &GDB server... Iniciar servidor &GDB... - + Scripting... Scripts... - + Create forwarder... Crear autocargador... - + Game state views Estado del juego - + View &palette... Ver &paleta... - + View &sprites... Ver &sprites... - + View &tiles... Ver m&osaicos... - + View &map... Ver &mapa... - + &Frame inspector... Inspec&tor de cuadros... - + View memory... Ver memoria... - + Search memory... Buscar memoria... - + View &I/O registers... Ver registros &I/O... - + + Log memory &accesses... + + + + Record debug video log... Grabar registro de depuración de vídeo... - + Stop debug video log Detener registro de depuración de vídeo - + Exit fullscreen Salir de pantalla completa - + GameShark Button (held) Botón GameShark (mantener) - + Autofire Disparo automático - + Autofire A Disparo automático A - + Autofire B Disparo automático B - + Autofire L Disparo automático L - + Autofire R Disparo automático R - + Autofire Start Disparo automático Start - + Autofire Select Disparo automático Select - + Autofire Up Disparo automático arriba - + Autofire Right Disparo automático derecha - + Autofire Down Disparo automático abajo - + Autofire Left Disparo automático izquierda @@ -6771,17 +6773,17 @@ Tamaño de descarga: %3 ? - + Super (L) Súper (L) - + Super (R) Súper (R) - + Menu Menú @@ -6789,22 +6791,22 @@ Tamaño de descarga: %3 QShortcut - + Shift Mayús - + Control Ctrl - + Alt Alt - + Meta Meta diff --git a/src/platform/qt/ts/mgba-fr.ts b/src/platform/qt/ts/mgba-fr.ts index 7efbfef1c8e..27eb207a978 100644 --- a/src/platform/qt/ts/mgba-fr.ts +++ b/src/platform/qt/ts/mgba-fr.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) ROMs de Game Boy Advance (%1) - + Game Boy ROMs (%1) ROMs de Game Boy (%1) - + All ROMs (%1) Toutes les ROM (%1) - + %1 Video Logs (*.mvl) %1 Journaux vidéo (*.mvl) @@ -191,17 +191,17 @@ Taille du téléchargement : %3 QGBA::AudioDevice - + Can't set format of context-less audio device - + Audio device is missing its core - + Writing data to read-only audio device @@ -209,7 +209,7 @@ Taille du téléchargement : %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input @@ -285,28 +285,28 @@ Taille du téléchargement : %3 Paramètres avancés - + BattleChip data missing - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? - - + + Select deck file - + Incompatible deck - + The selected deck is not compatible with this Chip Gate @@ -368,19 +368,19 @@ Taille du téléchargement : %3 Entrez les codes ici… - - + + Autodetect (recommended) Détecter automatiquement (recommandé) - - + + Select cheats file Choisir un fichier de cheats - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. @@ -399,37 +399,37 @@ Taille du téléchargement : %3 Le rembobinage n'est pas actuellement activé - + Reset the game? Réinitialiser le jeu ? - + Most games will require a reset to load the new save. Do you want to reset now? La plupart des jeux nécessitent une réinitialisation pour charger la nouvelle sauvegarde. Voulez-vous réinitialiser maintenant ? - + Failed to open save file: %1 Échec de l'ouverture du fichier de sauvegarde : %1 - + Failed to open game file: %1 Échec de l'ouverture du fichier de jeu : %1 - + Can't yank pack in unexpected platform! - + Failed to open snapshot file for reading: %1 Échec de l'ouverture de l'instantané pour lire : %1 - + Failed to open snapshot file for writing: %1 Échec de l'ouverture de l'instantané pour écrire : %1 @@ -478,6 +478,14 @@ Taille du téléchargement : %3 + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -758,52 +766,52 @@ Taille du téléchargement : %3 Réinitialiser - + Export frame Exporter l'image - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) - + None Aucun - + Background Arrière plan - + Window Fenêtre - + Objwin Objwin - + Sprite Sprite - + Backdrop Toile de fond - + Frame Cadre - + %1 %2 %1 %2 @@ -819,22 +827,22 @@ Taille du téléchargement : %3 QGBA::GBAKeyEditor - + Clear Button Bouton d'effacement - + Clear Analog Effacer l'analogique - + Refresh Rafraîchir - + Set all Tout définir @@ -3017,8 +3025,8 @@ Taille du téléchargement : %3 QGBA::KeyEditor - - + + --- --- @@ -3396,23 +3404,87 @@ Taille du téléchargement : %3 Vertical - - - + + + N/A s.o. - + Export map Exporter la map - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + Parcourir + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + Arrêter + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3659,22 +3731,22 @@ Taille du téléchargement : %3 Rafraîchir - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 octet%2 @@ -3768,17 +3840,17 @@ Taille du téléchargement : %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4175,35 +4247,35 @@ Taille du téléchargement : %3 Exporter l'OBJ - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette Exporter la palette - + Windows PAL (*.pal);;Adobe Color Table (*.act) Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 Impossible d'ouvrir le fichier de la palette de sortie : %1 @@ -4277,7 +4349,7 @@ Taille du téléchargement : %3 QGBA::ROMInfo - + @@ -4317,16 +4389,26 @@ Taille du téléchargement : %3 + Maker Code: + + + + + Revision: + + + + File size: Taille du fichier : - + CRC32: CRC32 : - + Save file: @@ -4382,62 +4464,62 @@ Taille du téléchargement : %3 QGBA::SaveConverter - + Save games and save states (%1) - + Select save game or save state - + Save games (%1) - + Select save game - + Conversion failed - + Failed to convert the save game. This is probably a bug. - + No file selected - + Could not open file - + No valid formats found - + Please select a valid input file - + No valid conversions found - + Cannot convert save games between platforms @@ -4463,97 +4545,97 @@ Taille du téléchargement : %3 - + %1 %2 save game - + little endian - + big endian - + SRAM SRAM - + %1 flash - + %1 EEPROM - + + RTC - + %1 SRAM + RTC - + %1 SRAM - + packed MBC2 - + unpacked MBC2 - + MBC6 flash - + MBC6 combined SRAM + flash - + MBC6 SRAM - + TAMA5 - + %1 (%2) - + %1 save state with embedded %2 save game - + %1 SharkPort %2 save game - + %1 GameShark Advance SP %2 save game @@ -4589,32 +4671,37 @@ Taille du téléchargement : %3 - + Load script... - + + &Load most recent + + + + &Reset &Réinitialiser - + 0 0 - + Select script to load - + Lua scripts (*.lua) - + All files (*.*) @@ -4708,105 +4795,105 @@ Taille du téléchargement : %3 QGBA::SettingsView - - + + Qt Multimedia Qt Multimédia - + SDL SDL - + Software (Qt) Software (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL (version forcée 1.x) - + None Aucun - + None (Still Image) Aucun (Image fixe) - + Keyboard Clavier - + Controllers Contrôleurs - + Shortcuts Raccourcis - - + + Shaders Shaders - + Select BIOS Choisir le BIOS - + Select directory - + Select image Choisir une image - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago @@ -4814,7 +4901,7 @@ Taille du téléchargement : %3 - + %n day(s) ago @@ -5182,77 +5269,77 @@ Taille du téléchargement : %3 - + Models - + GB only: - + SGB compatible: - + GBC only: - + GBC compatible: - + SGB and GBC compatible: - + Game Boy palette - + Preset: - + Default color palette only - + SGB color palette if available - + GBC color palette if available - + SGB (preferred) or GBC color palette if available - + Game Boy Camera - + Driver: - + Source: @@ -5262,17 +5349,17 @@ Taille du téléchargement : %3 - + Log to file Journalisation vers le fichier - + Log to console Journalisation vers la console - + Select Log File Sélectionner le fichier de journalisation @@ -5435,120 +5522,115 @@ Taille du téléchargement : %3 Logiciel(s) - + OpenGL enhancements Améliorations OpenGL - + High-resolution scale: Échelle haute résolution : - + (240×160) (240×160) - - XQ GBA audio (experimental) - XQ GBA audio (expérimental) - - - + GB BIOS file: GB BIOS : - - - - - - - - - + + + + + + + + + Browse Parcourir - + Use BIOS file if found Utiliser le fichier BIOS si trouvé - + Skip BIOS intro Passer l'intro du BIOS - + GBA BIOS file: GBA BIOS : - + GBC BIOS file: GBC BIOS : - + SGB BIOS file: SGB BIOS : - + Save games Sauvegarder les jeux - - - - - + + + + + Same directory as the ROM Même répertoire que la ROM - + Save states Sauvegarder les états - + Screenshots Captures d'écran - + Patches Correctifs - + Cheats Cheats - + Default BG colors: Couleurs par défaut de l'arrière plan : - + Super Game Boy borders Bordures Super Game Boy - + Default sprite colors 1: Couleurs par défaut de la sprite nº 1 : - + Default sprite colors 2: Couleurs par défaut de la sprite n°2 : @@ -5796,7 +5878,6 @@ Taille du téléchargement : %3 - WebM WebM @@ -5805,19 +5886,8 @@ Taille du téléchargement : %3 Format Format - - - MKV - MKV - - - - AVI - AVI - - MP4 MP4 @@ -5861,72 +5931,6 @@ Taille du téléchargement : %3 &Native &Natif - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - Aucun - - - - FLAC - FLAC - - - - WavPack - - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - Non compressé - Bitrate (kbps) @@ -5937,16 +5941,6 @@ Taille du téléchargement : %3 ABR ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5976,100 +5970,100 @@ Taille du téléchargement : %3 QGBA::Window - + Archives (%1) Archives (%1) - - + + Select ROM Choisir une ROM - + Select folder Choisir un dossier - - + + Select save Choisir une sauvegarde - + Select patch Sélectionner un correctif - + Patches (*.ips *.ups *.bps) Correctifs/Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode Sélectionnez le numéro de point du e-Reader - + e-Reader card (*.raw *.bin *.bmp) e-Reader carte (*.raw *.bin *.bmp) - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Select image Choisir une image - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Image (*.png *.gif *.jpg *.jpeg);;Tous les fichiers (*) - + GameShark saves (*.sps *.xps) Sauvegardes GameShark (*.sps *.xps) - + Select video log Sélectionner un journal vidéo - + Video logs (*.mvl) Journaux vidéo (*.mvl) - + Crash Plantage - + The game has crashed with the following error: %1 @@ -6078,679 +6072,689 @@ Taille du téléchargement : %3 %1 - + Unimplemented BIOS call Requête au BIOS non supporté - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Ce jeu utilise un appel BIOS qui n'est pas implémenté. Veuillez utiliser le BIOS officiel pour une meilleure expérience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Échec de la création d'un périphérique d'affichage approprié, retour à l'affichage du logiciel. Les jeux peuvent fonctionner lentement, en particulier avec des fenêtres plus grandes. - + Really make portable? Vraiment rendre portable ? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Cela amènera l'émulateur à charger sa configuration depuis le même répertoire que l'exécutable. Souhaitez vous continuer ? - + Restart needed Un redémarrage est nécessaire - + Some changes will not take effect until the emulator is restarted. Certains changements ne prendront effet qu'après le redémarrage de l'émulateur. - + - Player %1 of %2 - Joueur %1 of %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &Fichier - + Load &ROM... Charger une &ROM… - + Load ROM in archive... Charger la ROM d'une archive… - + Add folder to library... Ajouter un dossier à la bibliothèque… - + Load &patch... Charger un c&orrectif… - + Boot BIOS Démarrer le BIOS - + Replace ROM... Remplacer la ROM… - + Increase fast forward speed - + Decrease fast forward speed - + + &Lock frame size + + + + Create forwarder... - + Game state views - + + Log memory &accesses... + + + + Convert e-Reader card image to raw... - + ROM &info... &Infos sur la ROM… - + Recent Récent - + Make portable Rendre portable - + &Load state &Charger un état - + &Save state &Sauvegarder un état - + Quick load Chargement rapide - + Quick save Sauvegarde rapide - + Load recent Charger un fichier récent - + Save recent Sauvegarder un fichier récent - + Undo load state Annuler le chargement de l'état - + Undo save state Annuler la sauvegarde de l'état - - + + State &%1 État &%1 - + Load camera image... Charger une image de la caméra… - + Convert save game... - + New multiplayer window Nouvelle fenêtre multijoueur - + Connect to Dolphin... - + Report bug... Signalement de l'erreur… - + E&xit &Quitter - + &Emulation &Émulation - + &Reset &Réinitialiser - + Sh&utdown Extin&ction - + Yank game pak Yank game pak - + &Pause &Pause - + &Next frame &Image suivante - + Fast forward (held) Avance rapide (maintenir) - + &Fast forward A&vance rapide - + Fast forward speed Vitesse de l'avance rapide - + Unbounded Sans limites - + %0x %0x - + Rewind (held) Rembobiner (maintenir) - + Re&wind Rem&bobiner - + Step backwards Retour en arrière - + Solar sensor Capteur solaire - + Increase solar level Augmenter le niveau solaire - + Decrease solar level Diminuer le niveau solaire - + Brightest solar level Tester le niveau solaire - + Darkest solar level Assombrir le niveau solaire - + Brightness %1 Luminosité %1 - + Audio/&Video Audio/&Vidéo - + Frame size Taille de l'image - + Toggle fullscreen Basculer en plein écran - + Lock aspect ratio Bloquer les proportions - + Force integer scaling Forcer la mise à l'échelle par des nombres entiers - + Bilinear filtering Filtrage bilinèaire - + Frame&skip &Saut d'image - + Mute Muet - + FPS target FPS ciblé - + Take &screenshot Prendre une ca&pture d'écran - + F12 F12 - + Game Boy Printer... Imprimante GameBoy… - + Video layers Couches vidéo - + Audio channels Canaux audio - + Adjust layer placement... Ajuster la disposition… - + &Tools Ou&tils - + View &logs... Voir les &journaux… - + Game &overrides... - + Couldn't Start N'a pas pu démarrer - + Save games (%1) - + Select save game - + mGBA save state files (%1) - - + + Select save state - + GameShark saves (*.gsv *.sps *.xps) - + Could not start game. Impossible de démarrer le jeu. - + Load alternate save game... - + Load temporary save game... - + Scan e-Reader dotcodes... Scanner les dotcodes e-Reader... - + Load state file... Charger le fichier d'état... - + Save state file... Enregistrer le fichier d'état... - + Import GameShark Save... Importer la sauvegarde de GameShark... - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games Sauvegarder les jeux - + Export GameShark Save... Exporter la sauvegarde de GameShark... - + Automatically determine - + Use player %0 save game - + About... À propos de… - + BattleChip Gate... - + %1× %1× - + Interframe blending Mélange d'images - + Native (59.7275) Natif (59.7275) - + Record A/V... Enregistrer A/V... - + Record GIF/WebP/APNG... Enregistrer GIF/WebP/APNG... - + Game Pak sensors... Capteurs de la Game Pak... - + &Cheats... &Cheats… - + Settings... Paramètres… - + Open debugger console... Ouvrir la console de débug… - + Start &GDB server... Démarrer le serveur &GDB… - + Scripting... - + View &palette... Voir la &palette… - + View &sprites... Voir les &sprites… - + View &tiles... Voir les &tiles… - + View &map... Voir la &map… - + &Frame inspector... Inspecteur de &frame... - + View memory... Voir la mémoire… - + Search memory... Recherche dans la mémoire… - + View &I/O registers... Voir les registres d'&E/S... - + Record debug video log... Enregistrer le journal vidéo de débogage... - + Stop debug video log Arrêter le journal vidéo de débogage - + Exit fullscreen Quitter le plein écran - + GameShark Button (held) Bouton GameShark (maintenir) - + Autofire Tir automatique - + Autofire A Tir automatique A - + Autofire B Tir automatique B - + Autofire L Tir automatique L - + Autofire R Tir automatique R - + Autofire Start Tir automatique Start - + Autofire Select Tir automatique Select - + Autofire Up Tir automatique Up - + Autofire Right Tir automatique Right - + Autofire Down Tir automatique Down - + Autofire Left Tir automatique Gauche - + Clear Vider @@ -6788,17 +6792,17 @@ Taille du téléchargement : %3 ? - + Super (L) Super (L) - + Super (R) Super (R) - + Menu Menu @@ -6806,22 +6810,22 @@ Taille du téléchargement : %3 QShortcut - + Shift Shift - + Control Control - + Alt Alt - + Meta Méta/Super diff --git a/src/platform/qt/ts/mgba-hu.ts b/src/platform/qt/ts/mgba-hu.ts index 6db9b2da969..a51655410d9 100644 --- a/src/platform/qt/ts/mgba-hu.ts +++ b/src/platform/qt/ts/mgba-hu.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) Game Boy Advance ROMok (%1) - + Game Boy ROMs (%1) Game Boy ROMok (%1) - + All ROMs (%1) Összes ROM (%1) - + %1 Video Logs (*.mvl) %1 Videonaplók (*.mvl) @@ -192,17 +192,17 @@ LetöltendÅ‘ adat: %3 QGBA::AudioDevice - + Can't set format of context-less audio device - + Audio device is missing its core - + Writing data to read-only audio device @@ -210,7 +210,7 @@ LetöltendÅ‘ adat: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input @@ -286,28 +286,28 @@ LetöltendÅ‘ adat: %3 - + BattleChip data missing - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? - - + + Select deck file - + Incompatible deck - + The selected deck is not compatible with this Chip Gate @@ -368,19 +368,19 @@ LetöltendÅ‘ adat: %3 Ãrd ide a kódokat... - - + + Autodetect (recommended) Automatikus felisnerés (javasolt) - - + + Select cheats file Csalásfájl kiválasztása - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. Néhány csalást nem sikerült betölteni. EllenÅ‘rizze, hogy helyesen formázottak-e és/vagy próbáljon ki más csalástípust! @@ -399,37 +399,37 @@ LetöltendÅ‘ adat: %3 Visszatekerés jelenleg nem engedélyezett - + Reset the game? - + Most games will require a reset to load the new save. Do you want to reset now? - + Failed to open save file: %1 Nem sikerült a mentésfájl megnyitása: %1 - + Failed to open game file: %1 Nem sikerült a játékfájl megnyitása: %1 - + Can't yank pack in unexpected platform! A játékkazettát nem lehet kirántani ismeretlen platformon! - + Failed to open snapshot file for reading: %1 A pillanatkép fájljának olvasásra való megnyitása sikertelen: %1 - + Failed to open snapshot file for writing: %1 A pillanatkép fájljának írásra való megnyitása sikertelen: %1 @@ -478,6 +478,14 @@ LetöltendÅ‘ adat: %3 + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -758,52 +766,52 @@ LetöltendÅ‘ adat: %3 Visszaállítás - + Export frame Képkocka exportálása - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) - + None Nincs - + Background Háttér - + Window Ablak - + Objwin Objektumablak - + Sprite Sprite - + Backdrop Háttérréteg - + Frame Képkocka - + %1 %2 %1 %2 @@ -819,22 +827,22 @@ LetöltendÅ‘ adat: %3 QGBA::GBAKeyEditor - + Clear Button Gombhozzárendelés törlése - + Clear Analog Analóg hozzárendelések törlése - + Refresh Frissítés - + Set all Mind beállítása @@ -2957,7 +2965,7 @@ LetöltendÅ‘ adat: %3 Unknown - + Nem ismert @@ -3007,8 +3015,8 @@ LetöltendÅ‘ adat: %3 QGBA::KeyEditor - - + + --- @@ -3379,23 +3387,87 @@ LetöltendÅ‘ adat: %3 - - - + + + N/A - + Export map - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3642,22 +3714,22 @@ LetöltendÅ‘ adat: %3 Frissítés - + (%0/%1×) - + (â…Ÿ%0×) - + (%0×) - + %1 byte%2 @@ -3751,17 +3823,17 @@ LetöltendÅ‘ adat: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4158,35 +4230,35 @@ LetöltendÅ‘ adat: %3 Objektumpaletta exportálása - + #%0 - + 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette - + Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 @@ -4260,7 +4332,7 @@ LetöltendÅ‘ adat: %3 QGBA::ROMInfo - + @@ -4300,16 +4372,26 @@ LetöltendÅ‘ adat: %3 - File size: + Maker Code: - CRC32: + Revision: + File size: + + + + + CRC32: + + + + Save file: @@ -4365,62 +4447,62 @@ LetöltendÅ‘ adat: %3 QGBA::SaveConverter - + Save games and save states (%1) - + Select save game or save state - + Save games (%1) - + Select save game - + Conversion failed - + Failed to convert the save game. This is probably a bug. - + No file selected - + Could not open file - + No valid formats found - + Please select a valid input file - + No valid conversions found - + Cannot convert save games between platforms @@ -4446,97 +4528,97 @@ LetöltendÅ‘ adat: %3 - + %1 %2 save game - + little endian - + big endian - + SRAM SRAM - + %1 flash - + %1 EEPROM - + + RTC - + %1 SRAM + RTC - + %1 SRAM - + packed MBC2 - + unpacked MBC2 - + MBC6 flash - + MBC6 combined SRAM + flash - + MBC6 SRAM - + TAMA5 - + %1 (%2) - + %1 save state with embedded %2 save game - + %1 SharkPort %2 save game - + %1 GameShark Advance SP %2 save game @@ -4572,32 +4654,37 @@ LetöltendÅ‘ adat: %3 - + Load script... - + + &Load most recent + + + + &Reset - + 0 0 - + Select script to load - + Lua scripts (*.lua) - + All files (*.*) @@ -4690,112 +4777,112 @@ LetöltendÅ‘ adat: %3 QGBA::SettingsView - - + + Qt Multimedia - + SDL - + Software (Qt) - + OpenGL - + OpenGL (force version 1.x) - + None Nincs - + None (Still Image) - + Keyboard - + Controllers - + Shortcuts - - + + Shaders - + Select BIOS - + Select directory - + Select image - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago - + %n day(s) ago @@ -5060,37 +5147,37 @@ LetöltendÅ‘ adat: %3 - + Default color palette only - + SGB color palette if available - + GBC color palette if available - + SGB (preferred) or GBC color palette if available - + Game Boy Camera - + Driver: - + Source: @@ -5328,42 +5415,42 @@ LetöltendÅ‘ adat: %3 - + Models - + GB only: - + SGB compatible: - + GBC only: - + GBC compatible: - + SGB and GBC compatible: - + Game Boy palette - + Preset: @@ -5400,135 +5487,130 @@ LetöltendÅ‘ adat: %3 - + OpenGL enhancements - + High-resolution scale: - + (240×160) - - XQ GBA audio (experimental) - - - - + GB BIOS file: - - - - - - - - - + + + + + + + + + Browse - + Use BIOS file if found - + Skip BIOS intro - + GBA BIOS file: - + GBC BIOS file: - + SGB BIOS file: - + Save games - - - - - + + + + + Same directory as the ROM - + Save states - + Screenshots - + Patches - + Cheats Csalások - + Log to file - + Log to console - + Select Log File - + Default BG colors: - + Default sprite colors 1: - + Default sprite colors 2: - + Super Game Boy borders @@ -5786,13 +5868,11 @@ LetöltendÅ‘ adat: %3 - WebM - MP4 @@ -5831,82 +5911,6 @@ LetöltendÅ‘ adat: %3 Format - - - MKV - - - - - AVI - - - - - HEVC - - - - - HEVC (NVENC) - - - - - VP8 - - - - - VP9 - - - - - FFV1 - - - - - - None - Nincs - - - - FLAC - - - - - WavPack - - - - - Opus - - - - - Vorbis - - - - - MP3 - - - - - AAC - - - - - Uncompressed - - Bitrate (kbps) @@ -5917,16 +5921,6 @@ LetöltendÅ‘ adat: %3 ABR - - - H.264 - - - - - H.264 (NVENC) - - VBR @@ -5956,779 +5950,789 @@ LetöltendÅ‘ adat: %3 QGBA::Window - + Archives (%1) - - + + Select ROM - + Select folder - - + + Select save - + Select patch - + Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) - + Select image - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) - + Select video log - + Video logs (*.mvl) - + Crash - + The game has crashed with the following error: %1 - + Couldn't Start - + Could not start game. - + Unimplemented BIOS call - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + Really make portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + Restart needed - + Some changes will not take effect until the emulator is restarted. - + - Player %1 of %2 - + %1 - %2 - + %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File - + Load &ROM... - + Load ROM in archive... - + Add folder to library... - + Save games (%1) - + Select save game - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Load &patch... - + Boot BIOS - + Replace ROM... - + Scan e-Reader dotcodes... - + Convert e-Reader card image to raw... - + ROM &info... - + Recent - + Make portable - + &Load state - + Load state file... - + &Save state - + Save state file... - + Quick load - + Quick save - + Load recent - + Save recent - + Undo load state - + Undo save state - - + + State &%1 - + Load camera image... - + Convert save game... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games - + Import GameShark Save... - + Export GameShark Save... - + Automatically determine - + Use player %0 save game - + New multiplayer window - + Connect to Dolphin... - + Report bug... - + About... - + E&xit - + &Emulation - + &Reset - + Sh&utdown - + Yank game pak - + &Pause - + &Next frame - + Fast forward (held) - + &Fast forward - + Fast forward speed - + Unbounded - + %0x %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) - + Re&wind - + Step backwards - + Solar sensor - + Increase solar level - + Decrease solar level - + Brightest solar level - + Darkest solar level - + Brightness %1 - + Game Boy Printer... - + BattleChip Gate... - + Audio/&Video - + Frame size - + %1× %1× - + Toggle fullscreen - + + &Lock frame size + + + + Lock aspect ratio - + Force integer scaling - + Interframe blending - + Bilinear filtering - + Frame&skip - + Mute - + FPS target - + Native (59.7275) - + Take &screenshot - + F12 - + Record A/V... - + Record GIF/WebP/APNG... - + Video layers - + Audio channels - + Adjust layer placement... - + &Tools - + View &logs... - + Game &overrides... - + Game Pak sensors... - + &Cheats... - + Create forwarder... - + Settings... - + Open debugger console... - + Start &GDB server... - + Scripting... - + Game state views - + View &palette... - + View &sprites... - + View &tiles... - + View &map... - + &Frame inspector... - + View memory... - + Search memory... - + View &I/O registers... - + + Log memory &accesses... + + + + Record debug video log... - + Stop debug video log - + Exit fullscreen - + GameShark Button (held) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear Napló törlése @@ -6766,17 +6770,17 @@ LetöltendÅ‘ adat: %3 - + Super (L) - + Super (R) - + Menu @@ -6784,22 +6788,22 @@ LetöltendÅ‘ adat: %3 QShortcut - + Shift - + Control - + Alt - + Meta diff --git a/src/platform/qt/ts/mgba-it.ts b/src/platform/qt/ts/mgba-it.ts index 6c2d16d4f29..7338f41f626 100644 --- a/src/platform/qt/ts/mgba-it.ts +++ b/src/platform/qt/ts/mgba-it.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) ROM per Game Boy Advance (%1) - + Game Boy ROMs (%1) ROM per Game Boy (%1) - + All ROMs (%1) Tutte le ROM (%1) - + %1 Video Logs (*.mvl) %1 log Video (*.mvl) @@ -191,17 +191,17 @@ Dimensione del download: %3 QGBA::AudioDevice - + Can't set format of context-less audio device Non è stato possibile impostare il formato per il dispositivo audio - + Audio device is missing its core Il dispositivo audio è mancante di un core - + Writing data to read-only audio device Scrittura dati sul dispositivo in modalità sola lettura @@ -209,7 +209,7 @@ Dimensione del download: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input Impossibile avviare un processore audio senza input @@ -285,28 +285,28 @@ Dimensione del download: %3 Mostra avanzate - + BattleChip data missing Dati Battlechip mancanti - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? Dati Battlechip mancanti. I Battlechip Gates continueranno a funzionare ma alcuni elementi grafici mancheranno. Sei sicuro di voler scaricare questi dati adesso? - - + + Select deck file Selezione file mazzo - + Incompatible deck Mazzo non compatibile - + The selected deck is not compatible with this Chip Gate Il mazzo selezionato non è compatibile con questo Chip Gate @@ -367,19 +367,19 @@ Dimensione del download: %3 Inserisci i codici qui.. - - + + Autodetect (recommended) Rilevamento automatico (consigliato) - - + + Select cheats file Seleziona il file cheats - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. Non è stato possibile aggiungere alcuni trucchi. Assicurati che siano formattati correttamente e / o prova altri tipi di trucchi. @@ -398,37 +398,37 @@ Dimensione del download: %3 La funzione 'riavvolgi' non è attualmente abilitata - + Reset the game? Riavviare il gioco? - + Most games will require a reset to load the new save. Do you want to reset now? La maggior parte dei giochi richiede un riavvio per caricare il nuovo salvataggio. Vuoi riavviare ora? - + Failed to open save file: %1 Impossibile aprire il file di salvataggio: %1 - + Failed to open game file: %1 Impossibile aprire il file di gioco: %1 - + Can't yank pack in unexpected platform! Non riesco a strappare il pacchetto in una piattaforma inaspettata! - + Failed to open snapshot file for reading: %1 Impossibile aprire il file snapshot per la lettura: %1 - + Failed to open snapshot file for writing: %1 Impossibile aprire il file snapshot per la scrittura: %1 @@ -477,6 +477,14 @@ Dimensione del download: %3 Impossibile aprire lo storico della riga di comando in scrittura + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Dimensione del download: %3 Reset - + Export frame Esporta Frame - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) - + None Nessuno - + Background Sfondo - + Window Finestra - + Objwin Objwin - + Sprite Sprite - + Backdrop Sfondo - + Frame Inquadratura - + %1 %2 %1x {1 %2?} @@ -818,22 +826,22 @@ Dimensione del download: %3 QGBA::GBAKeyEditor - + Clear Button Svuota i pulsanti - + Clear Analog Svuota Analogici - + Refresh Aggiorna - + Set all Imposta tutti @@ -3006,8 +3014,8 @@ Dimensione del download: %3 QGBA::KeyEditor - - + + --- --- @@ -3378,23 +3386,87 @@ Dimensione del download: %3 Verticale - - - + + + N/A N/D - + Export map Esporta Mappa - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + Sfoglia + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + Ferma + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Dimensione del download: %3 Aggiorna - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 byte%2 @@ -3750,17 +3822,17 @@ Dimensione del download: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached Tentativo di scollegare un giocatore in multi che non è collegato - + Trying to get player ID for a multiplayer player that's not attached Cerco di ottenere l'ID giocatore per un giocatore in multi non collegato - + Trying to get save ID for a multiplayer player that's not attached Cerco di ottenere l'ID di salvataggio per un giocatore in multi non collegato @@ -4157,35 +4229,35 @@ Dimensione del download: %3 Esporta OBJ - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette Esporta palette - + Windows PAL (*.pal);;Adobe Color Table (*.act) WIndows PAL (*.pal);;Tabella dei colori Adobe (*.act) - + Failed to open output palette file: %1 Errore nell'aprire il file palette di output: %1 @@ -4259,7 +4331,7 @@ Dimensione del download: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Dimensione del download: %3 + Maker Code: + + + + + Revision: + + + + File size: Dimensioni del file: - + CRC32: CRC32: - + Save file: Salva file: @@ -4364,62 +4446,62 @@ Dimensione del download: %3 QGBA::SaveConverter - + Save games and save states (%1) Salvataggi e stati di salvataggio dei giochi (%1) - + Select save game or save state Seleziona salvataggio o stato di salvataggio - + Save games (%1) Salvataggi (%1) - + Select save game Seleziona salvataggio - + Conversion failed Conversione fallita - + Failed to convert the save game. This is probably a bug. Impossibile convertire il salvataggio. Molto probabilmente è dovuto ad un bug. - + No file selected Nessun file selezionato - + Could not open file Non è stato possibile aprire il file - + No valid formats found Nessun formato valido trovato - + Please select a valid input file Si prega di selezionare un file di input valido - + No valid conversions found Nessune conversioni valide trovate - + Cannot convert save games between platforms Impossibile convertire salvataggi tra piattaforme @@ -4445,97 +4527,97 @@ Dimensione del download: %3 File output - + %1 %2 save game %1 %2 salvataggio - + little endian little endian - + big endian big endian - + SRAM SRAM - + %1 flash %1 flash - + %1 EEPROM %1 EEPROM - + + RTC + RTC - + %1 SRAM + RTC %1 SRAM + OTR - + %1 SRAM %1 SRAM - + packed MBC2 MBC2 compresso - + unpacked MBC2 MBC2 non compresso - + MBC6 flash MBC6 flash - + MBC6 combined SRAM + flash MBC6 combinato con la SRAM + flash - + MBC6 SRAM SRAM MBC6 - + TAMA5 TAMA5 - + %1 (%2) %1 (%2) - + %1 save state with embedded %2 save game %1 stato di salvataggio incorporato con il salvataggio %2 - + %1 SharkPort %2 save game %1 SharkPort %2 salvataggio gioco - + %1 GameShark Advance SP %2 save game %1 GameShark Advance SP %2 salvataggio gioco @@ -4571,32 +4653,37 @@ Dimensione del download: %3 Carica script recente - + Load script... Carica script... - + + &Load most recent + + + + &Reset &Ripristina - + 0 0 - + Select script to load Selezionare lo script da caricare - + Lua scripts (*.lua) Script Lua (*.lua) - + All files (*.*) Tutti i file (*.*) @@ -4689,105 +4776,105 @@ Dimensione del download: %3 QGBA::SettingsView - - + + Qt Multimedia Qt Multimedia - + SDL SDL - + Software (Qt) Software (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL (forza la versione 1.x) - + None Nessuno - + None (Still Image) nessuno (immagine fissa) - + Keyboard Tastiera - + Controllers Controller - + Shortcuts Scorciatoie - - + + Shaders Shader - + Select BIOS Seleziona BIOS - + Select directory Seleziona directory - + Select image Seleziona immagine - + Image file (*.png *.jpg *.jpeg) File immagine (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Mai - + Just now Proprio adesso - + Less than an hour ago Meno di un'ora fa - + %n hour(s) ago %n ora fa @@ -4795,7 +4882,7 @@ Dimensione del download: %3 - + %n day(s) ago %n giorno fa @@ -5127,72 +5214,72 @@ Dimensione del download: %3 Velocità riavvolgimento: - + Models Modelli - + GB only: Solo GB: - + SGB compatible: Compatibile SGB: - + GBC only: Solo GBC: - + GBC compatible: Compatibile BGC: - + SGB and GBC compatible: Compatibile SGB e GBC: - + Game Boy palette Tavolozza Game Boy - + Default color palette only Solo tavolozza colori predefinita - + SGB color palette if available Tavolozza colori SGB se disponibile - + GBC color palette if available Tavolozza colori GBC se disponibile - + SGB (preferred) or GBC color palette if available Tavolozza colori SGB (preferita) o GBC se disponibile - + Game Boy Camera Videocamera Game Boy - + Driver: Driver: - + Source: Sorgente: @@ -5238,7 +5325,7 @@ Dimensione del download: %3 Abilita compatibilità con i bug di VBA nelle hack delle ROM - + Preset: Profilo: @@ -5278,62 +5365,57 @@ Dimensione del download: %3 Software - + OpenGL enhancements Miglioramenti OpenGL - + High-resolution scale: Rapporto alta risoluzione: - + (240×160) (240×160) - - XQ GBA audio (experimental) - audio XQ GBA (sperimentale) - - - + Cheats Trucchi - + Log to file Registro log in file - + Log to console Registro log in console - + Select Log File Seleziona file log - + Default BG colors: Colori predefiniti sfondo: - + Super Game Boy borders Bordi Super Game Boy - + Default sprite colors 1: Colori predefiniti sprite 1: - + Default sprite colors 2: Colori predefiniti sprite 2: @@ -5359,25 +5441,25 @@ Dimensione del download: %3 - - - - - - - - - + + + + + + + + + Browse Sfoglia - + Use BIOS file if found Usa il file del BIOS se è presente - + Skip BIOS intro Salta intro del BIOS @@ -5485,51 +5567,51 @@ Dimensione del download: %3 Intervallo Autofire: - + GB BIOS file: File BIOS del GB: - + GBA BIOS file: File BIOS del GBA: - + GBC BIOS file: File BIOS del GBC: - + SGB BIOS file: File BIOS del SGB: - + Save games Salva le partite - - - - - + + + + + Same directory as the ROM Stessa cartella della ROM - + Save states Salvataggio Stati - + Screenshots Schermate - + Patches Patch @@ -5777,7 +5859,6 @@ Dimensione del download: %3 - WebM WebM @@ -5786,32 +5867,11 @@ Dimensione del download: %3 Format Formato - - - MKV - MKV - - - - AVI - AVI - - MP4 MP4 - - - HEVC - HEVC - - - - VP8 - VP8 - High &Quality @@ -5852,72 +5912,6 @@ Dimensione del download: %3 &Native &Nativa - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - Nessuno - - - - FLAC - FLAC - - - - WavPack - WavPack - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - Senza compressione - Bitrate (kbps) @@ -5957,95 +5951,95 @@ Dimensione del download: %3 QGBA::Window - + Archives (%1) Archivi (%1) - - + + Select ROM Seleziona ROM - - + + Select save Seleziona salvataggio - + Select patch Seleziona patch - + Patches (*.ips *.ups *.bps) Patch (*.ips *.ups *.bps) - + Select e-Reader dotcode Selezione e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) Scheda e-Reader (*.raw *.bin *.bmp) - + Select e-Reader card images Seleziona immagini carte e-Reader - + Image file (*.png *.jpg *.jpeg) File immagine (*.png *.jpg *.jpeg) - + Conversion finished Conversione terminata - + %1 of %2 e-Reader cards converted successfully. %1 di %2 carte e-Reader convertite con successo. - + Select image Seleziona immagine - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) File immagine (*.png *.gif *.jpg *.jpeg);;Tutti i file (*) - + GameShark saves (*.sps *.xps) Salvataggi GameShark (*.sps *.xps) - + Select video log Seleziona log video - + Video logs (*.mvl) Log video (*.mvl) - + Crash Errore fatale - + The game has crashed with the following error: %1 @@ -6054,684 +6048,694 @@ Dimensione del download: %3 %1 - + Unimplemented BIOS call BIOS non implementato - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Questo gioco utilizza una chiamata BIOS non implementata. Utilizza il BIOS ufficiale per una migliore esperienza. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Impossibile creare un dispositivo di visualizzazione appropriato, tornando alla visualizzazione software. I giochi possono funzionare lentamente, specialmente con finestre più grandi. - + Really make portable? Vuoi davvero rendere portatile l'applicazione? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? In questo modo l'emulatore carica la propria configurazione dalla stessa cartella dell'eseguibile. Vuoi continuare? - + Restart needed È necessario riavviare - + Some changes will not take effect until the emulator is restarted. Alcune modifiche non avranno effetto finché l'emulatore non verrà riavviato. - + - Player %1 of %2 - Giocatore %1 di %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File File - + Load &ROM... Carica ROM... - + Load ROM in archive... Carica la ROM in archivio... - + Load &patch... Carica patch... - + Boot BIOS Avvia BIOS - + Replace ROM... Sostituisci la ROM... - + Scan e-Reader dotcodes... Scansiona e-Reader dotcode... - + Convert e-Reader card image to raw... Converti immagini carte e-Reader in raw... - + ROM &info... Informazioni ROM... - + Recent Recenti - + Make portable Rendi portatile - + &Load state Carica stato - + &Save state Salva stato - + Quick load Caricamento rapido - + Quick save Salvataggio rapido - + Load recent Carica recente - + Save recent Salva recente - + Undo load state Annulla il caricamento dello stato - + Undo save state Annulla salvataggio stato - - + + State &%1 Stato %1 - + Load camera image... Carica immagine fotocamera... - + Convert save game... Converti salvataggi... - + GameShark saves (*.gsv *.sps *.xps) Salvataggi GameShark (*.gsv *.sps *.xps) - + Reset needed Reset necessario - + Some changes will not take effect until the game is reset. Alcune modifiche non si applicheranno finché il gioco non viene resettato. - + New multiplayer window Nuova finestra multigiocatore - + Connect to Dolphin... Connessione a Dolphin... - + Report bug... Segnala bug... - + E&xit Esci (&X) - + &Emulation Emulazione - + &Reset Reset - + Sh&utdown Spegni (&U) - + Yank game pak Stacca game pak - + &Pause Pausa - + &Next frame Salta il prossimo frame (&N) - + Fast forward (held) Avanzamento rapido (tieni premuto) - + &Fast forward Avanzamento rapido (&F) - + Fast forward speed Velocità di avanzamento rapido - + Unbounded Illimitata - + %0x %0x - + Increase fast forward speed Aumenta la velocità di avvolgimento veloce - + Decrease fast forward speed Diminuisci la velocità di avvolgimento veloce - + Rewind (held) Riavvolgimento (tieni premuto) - + Re&wind Riavvolgimento (&W) - + Step backwards Torna indietro - + Solar sensor Sensore solare - + Increase solar level Incrementa il livello solare - + Decrease solar level Riduci il livello solare - + Brightest solar level Livello solare massimo - + Darkest solar level Livello solare minimo - + Brightness %1 Luminosità %1 - + Audio/&Video Audio/Video - + Frame size Dimensione frame - + Toggle fullscreen Abilita schermo Intero - + + &Lock frame size + + + + Lock aspect ratio Blocca rapporti aspetto - + Frame&skip Salto frame - + Mute Muto - + FPS target FPS finali - + Take &screenshot Acquisisci schermata - + F12 F12 - + Record GIF/WebP/APNG... Registra GIF / WebP / APNG ... - + Video layers Layers video - + Audio channels Canali audio - + &Tools Strumenti - + View &logs... Visualizza registri (&log)... - + Game &overrides... Valore specifico per il gioco... - + &Cheats... Trucchi... - + Create forwarder... Crea Icona di avvio... - + Open debugger console... Apri console debugger... - + Start &GDB server... Avvia server GDB... - + Settings... Impostazioni... - + Select folder Seleziona cartella - + Couldn't Start Non è stato possibile avviare - + Could not start game. Non è stato possibile avviare il gioco. - + Add folder to library... Aggiungi cartella alla libreria... - + Load state file... Carica stato di salvataggio... - + Save state file... Salva stato di salvataggio... - + Import GameShark Save... Importa Salvataggio GameShark... - + Export GameShark Save... Esporta Salvataggio GameShark... - + About... Informazioni… - + Force integer scaling Forza ridimensionamento a interi - + Bilinear filtering Filtro bilineare - + Game Boy Printer... Stampante Game Boy... - + Save games (%1) Salvataggi (%1) - + Select save game Seleziona salvataggio - + mGBA save state files (%1) file di stati di salvataggio mGBA (%1) - - + + Select save state Seleziona stato di salvataggio - + Save games Salvataggi - + Load alternate save game... Carica stato di salvataggio alternativo... - + Load temporary save game... Carica salvataggio temporaneo... - + Automatically determine Determina automaticamente - + Use player %0 save game Usa il salvataggio del giocatore %0 - + BattleChip Gate... BattleChip Gate... - + %1× %1x - + Interframe blending Miscelazione dei frame - + Native (59.7275) Nativo (59.7) - + Record A/V... Registra A/V... - + Adjust layer placement... Regola posizionamento layer... - + Game Pak sensors... Sensori Game Pak... - + Scripting... Scripting... - + Game state views Viste degli stati del gioco - + View &palette... Mostra palette... - + View &sprites... Mostra sprites... - + View &tiles... Mostra tiles... - + View &map... Mostra mappa... - + &Frame inspector... &Frame inspector... - + View memory... Mostra memoria... - + Search memory... Ricerca memoria... - + View &I/O registers... Mostra registri I/O... - + + Log memory &accesses... + + + + Record debug video log... Registra video log di debug... - + Stop debug video log Ferma video log di debug - + Exit fullscreen Esci da Schermo Intero - + GameShark Button (held) Pulsante GameShark (tieni premuto) - + Autofire Pulsanti Autofire - + Autofire A Autofire A - + Autofire B Autofire B - + Autofire L Autofire L - + Autofire R Autofire R - + Autofire Start Autofire Start - + Autofire Select Autofire Select - + Autofire Up Autofire Su - + Autofire Right AAutofire Destra - + Autofire Down Autofire Giù - + Autofire Left Autofire Sinistra - + Clear Pulisci @@ -6769,17 +6773,17 @@ Dimensione del download: %3 ? - + Super (L) Super (L) - + Super (R) Super (R) - + Menu Menu @@ -6787,22 +6791,22 @@ Dimensione del download: %3 QShortcut - + Shift Shift - + Control Control - + Alt Alt - + Meta Meta diff --git a/src/platform/qt/ts/mgba-ja.ts b/src/platform/qt/ts/mgba-ja.ts index 29e56717f09..dfb056123ed 100644 --- a/src/platform/qt/ts/mgba-ja.ts +++ b/src/platform/qt/ts/mgba-ja.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) ゲームボーイアドãƒãƒ³ã‚¹ãƒ•ã‚¡ã‚¤ãƒ« (%1) - + Game Boy ROMs (%1) ゲームボーイファイル (%1) - + All ROMs (%1) ã™ã¹ã¦ã®ROM (%1) - + %1 Video Logs (*.mvl) %1ビデオログ (*.mvl) @@ -191,17 +191,17 @@ Download size: %3 QGBA::AudioDevice - + Can't set format of context-less audio device - + Audio device is missing its core オーディオ デãƒã‚¤ã‚¹ã«ã‚³ã‚¢ãŒã‚ã‚Šã¾ã›ã‚“ - + Writing data to read-only audio device @@ -209,7 +209,7 @@ Download size: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input @@ -285,28 +285,28 @@ Download size: %3 詳細表示 - + BattleChip data missing ãƒãƒˆãƒ«ãƒãƒƒãƒ—ã®ãƒ‡ãƒ¼ã‚¿ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“ - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? ãƒãƒˆãƒ«ãƒãƒƒãƒ—ã®ç”»åƒãƒ‡ãƒ¼ã‚¿ãŒè¦‹ã¤ã‹ã‚Šã¾ã›ã‚“。ã“ã®ã¾ã¾ã§ã‚‚ãƒãƒƒãƒ—ゲートã¯å‹•ä½œã—ã¾ã™ãŒã€ãƒãƒƒãƒ—ã®ç”»åƒãŒè¡¨ç¤ºã•ã‚Œãªã„ã¾ã¾ä½¿ã†äº‹ã«ãªã‚Šã¾ã™ã€‚今ã™ãダウンロードã—ã¾ã™ã‹ï¼Ÿ - - + + Select deck file デッキファイルをé¸æŠž - + Incompatible deck 互æ›æ€§ã®ãªã„デッキ - + The selected deck is not compatible with this Chip Gate é¸æŠžã—ãŸãƒ‡ãƒƒã‚­ã¯ã“ã®ãƒãƒƒãƒ—ゲートã§ã¯ä½¿ç”¨ã§ãã¾ã›ã‚“ @@ -367,19 +367,19 @@ Download size: %3 ã“ã“ã«ã‚³ãƒ¼ãƒ‰ã‚’入力ã—ã¦ãã ã•ã„... - - + + Autodetect (recommended) 自動検出 (推奨) - - + + Select cheats file ãƒãƒ¼ãƒˆãƒ•ã‚¡ã‚¤ãƒ«ã‚’é¸æŠž - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. 一部ã®ã‚³ãƒ¼ãƒ‰ãŒè¿½åŠ ã§ãã¾ã›ã‚“ã§ã—ãŸã€‚フォーマットãŒæ­£å¸¸ã‹ã©ã†ã‹ã‚’確èªã—ã¦ãã ã•ã„。もã—ãã¯ã€é•ã†å½¢å¼ã«å¤‰æ›ã—ã¦è©¦ã—ã¦ã¿ã¦ãã ã•ã„。 @@ -398,37 +398,37 @@ Download size: %3 - + Reset the game? - + Most games will require a reset to load the new save. Do you want to reset now? - + Failed to open save file: %1 セーブファイルを開ã‘ã¾ã›ã‚“ã§ã—ãŸ: %1 - + Failed to open game file: %1 ゲームファイルを開ã‘ã¾ã›ã‚“ã§ã—ãŸ: %1 - + Can't yank pack in unexpected platform! 予期ã—ãªã„プラットフォームã§ãƒ‘ックをヤンクã™ã‚‹ã“ã¨ã¯ã§ãã¾ã›ã‚“ï¼ - + Failed to open snapshot file for reading: %1 読ã¿å–り用ã®ã‚¹ãƒŠãƒƒãƒ—ショットファイルを開ã‘ã¾ã›ã‚“ã§ã—ãŸ: %1 - + Failed to open snapshot file for writing: %1 書ãè¾¼ã¿ç”¨ã®ã‚¹ãƒŠãƒƒãƒ—ショットファイルを開ã‘ã¾ã›ã‚“ã§ã—ãŸ: %1 @@ -477,6 +477,14 @@ Download size: %3 + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Download size: %3 リセット - + Export frame フレームを書ã出㙠- + Portable Network Graphics (*.png) Portable Network Graphics (*.png) - + None ãªã— - + Background ãƒãƒƒã‚¯ã‚°ãƒ©ã‚¦ãƒ³ãƒ‰ - + Window ウインドウ - + Objwin Objwin - + Sprite スプライト - + Backdrop 背景 - + Frame フレーム - + %1 %2 %1 %2 @@ -818,22 +826,22 @@ Download size: %3 QGBA::GBAKeyEditor - + Clear Button ボタンクリア - + Clear Analog アナログクリア - + Refresh æ›´æ–° - + Set all ã™ã¹ã¦è¨­å®š @@ -3006,8 +3014,8 @@ Download size: %3 QGBA::KeyEditor - - + + --- --- @@ -3378,23 +3386,87 @@ Download size: %3 縦 - - - + + + N/A N/A - + Export map マップを書ã出㙠- + Portable Network Graphics (*.png) Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + å‚ç…§ + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + åœæ­¢ + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Download size: %3 æ›´æ–° - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 byte%2 @@ -3750,17 +3822,17 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4157,35 +4229,35 @@ Download size: %3 OBJを書ã出㙠- + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette パレットを書ã出㙠- + Windows PAL (*.pal);;Adobe Color Table (*.act) Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 出力パレットファイルを開ã‘ã¾ã›ã‚“ã§ã—ãŸ: %1 @@ -4259,7 +4331,7 @@ Download size: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Download size: %3 + Maker Code: + + + + + Revision: + + + + File size: ファイルサイズ: - + CRC32: CRC32: - + Save file: @@ -4364,62 +4446,62 @@ Download size: %3 QGBA::SaveConverter - + Save games and save states (%1) セーブデータ ã¾ãŸã¯ ステートセーブ (%1) - + Select save game or save state セーブゲームã¾ãŸã¯ã‚¹ãƒ†ãƒ¼ãƒˆã‚»ãƒ¼ãƒ–ã‚’é¸æŠž - + Save games (%1) セーブデータ (%1) - + Select save game セーブデータをé¸æŠž - + Conversion failed 変æ›ã«å¤±æ•—ã—ã¾ã—㟠- + Failed to convert the save game. This is probably a bug. セーブデータã®å¤‰æ›ã«å¤±æ•—ã—ã¾ã—ãŸã€‚ãƒã‚°ã«ã‚ˆã‚‹ã‚‚ã®ã§ã‚ã‚‹å¯èƒ½æ€§ãŒã‚ã‚Šã¾ã™ã€‚ - + No file selected ファイルãŒé¸æŠžã•ã‚Œã¦ã„ã¾ã›ã‚“ - + Could not open file - + No valid formats found - + Please select a valid input file 有効ãªå…¥åŠ›ãƒ•ã‚¡ã‚¤ãƒ«ã‚’é¸æŠžã—ã¦ãã ã•ã„ - + No valid conversions found 利用å¯èƒ½ãªå¤‰æ›å…ˆãŒã‚ã‚Šã¾ã›ã‚“ - + Cannot convert save games between platforms @@ -4445,97 +4527,97 @@ Download size: %3 出力 - + %1 %2 save game - + little endian リトルエンディアン - + big endian ビッグエンディアン - + SRAM SRAM - + %1 flash - + %1 EEPROM - + + RTC - + %1 SRAM + RTC - + %1 SRAM - + packed MBC2 - + unpacked MBC2 - + MBC6 flash - + MBC6 combined SRAM + flash - + MBC6 SRAM - + TAMA5 - + %1 (%2) - + %1 save state with embedded %2 save game %2 å½¢å¼ã®ã‚»ãƒ¼ãƒ–データãŒåŸ‹ã‚è¾¼ã¾ã‚ŒãŸ %1 ã®ã‚¹ãƒ†ãƒ¼ãƒˆã‚»ãƒ¼ãƒ– - + %1 SharkPort %2 save game - + %1 GameShark Advance SP %2 save game @@ -4571,32 +4653,37 @@ Download size: %3 - + Load script... - + + &Load most recent + + + + &Reset リセット (&R) - + 0 0 - + Select script to load - + Lua scripts (*.lua) - + All files (*.*) @@ -4689,112 +4776,112 @@ Download size: %3 QGBA::SettingsView - - + + Qt Multimedia Qt Multimedia - + SDL SDL - + Software (Qt) ソフト(Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL(ãƒãƒ¼ã‚¸ãƒ§ãƒ³1.xを強制) - + None ãªã— - + None (Still Image) ãªã—(é™æ­¢ç”») - + Keyboard キーボード - + Controllers コントローラー - + Shortcuts ショートカット - - + + Shaders シェーダー - + Select BIOS BIOSã‚’é¸æŠž - + Select directory フォルダをé¸æŠž - + Select image ç”»åƒã‚’é–‹ã - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never 一度もã—ã¦ã„ãªã„ - + Just now ãŸã£ãŸä»Š - + Less than an hour ago 1時間以内 - + %n hour(s) ago %n æ™‚é–“å‰ - + %n day(s) ago %n æ—¥å‰ @@ -5135,37 +5222,37 @@ Download size: %3 - + Default color palette only - + SGB color palette if available - + GBC color palette if available - + SGB (preferred) or GBC color palette if available - + Game Boy Camera - + Driver: - + Source: @@ -5216,42 +5303,42 @@ Download size: %3 ステートロード時ã«èª­ã¿è¾¼ã‚€: - + Models - + GB only: - + SGB compatible: - + GBC only: - + GBC compatible: - + SGB and GBC compatible: - + Game Boy palette - + Preset: @@ -5261,22 +5348,22 @@ Download size: %3 ゲームボーイプレーヤーã®æ©Ÿèƒ½ã‚’デフォルトã§æœ‰åŠ¹åŒ– - + (240×160) (240×160) - + Log to file ファイルã«å‡ºåŠ›ã™ã‚‹ - + Log to console コンソールã«å‡ºåŠ›ã™ã‚‹ - + Select Log File ログファイルをé¸æŠž @@ -5419,115 +5506,110 @@ Download size: %3 ソフト - + OpenGL enhancements OpenGL機能強化 - + High-resolution scale: 高解åƒåº¦ã‚¹ã‚±ãƒ¼ãƒ«: - - XQ GBA audio (experimental) - XQ GBA オーディオ機能(実験的) - - - + GB BIOS file: ゲームボーイ: - - - - - - - - - + + + + + + + + + Browse å‚ç…§ - + Use BIOS file if found 存在ã™ã‚‹å ´åˆã«BIOSファイルを使用 - + Skip BIOS intro BIOSイントロをスキップ - + GBA BIOS file: ゲームボーイアドãƒãƒ³ã‚¹: - + GBC BIOS file: ゲームボーイカラー: - + SGB BIOS file: スーパーゲームボーイ: - + Save games セーブデータ - - - - - + + + + + Same directory as the ROM ROMファイルã¨åŒã˜ãƒ‡ã‚£ãƒ¬ã‚¯ãƒˆãƒª - + Save states セーブステート - + Screenshots スクリーンショット - + Patches パッム- + Cheats ãƒãƒ¼ãƒˆ - + Default BG colors: デフォルト背景色: - + Super Game Boy borders スーパーゲームボーイã®ãƒœãƒ¼ãƒ€ãƒ¼ - + Default sprite colors 1: デフォルトスプライト1: - + Default sprite colors 2: デフォルトスプライト2: @@ -5775,7 +5857,6 @@ Download size: %3 - WebM WebM @@ -5784,19 +5865,8 @@ Download size: %3 Format フォーマット - - - MKV - MKV - - - - AVI - AVI - - MP4 MP4 @@ -5840,72 +5910,6 @@ Download size: %3 &Native ãƒã‚¤ãƒ†ã‚£ãƒ– (&N) - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC(NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - ãªã— - - - - FLAC - FLAC - - - - WavPack - - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - 圧縮ãªã— - Bitrate (kbps) @@ -5916,16 +5920,6 @@ Download size: %3 ABR ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5955,80 +5949,80 @@ Download size: %3 QGBA::Window - + Archives (%1) アーカイブファイル (%1) - - + + Select ROM ROMã‚’é–‹ã - + Select folder フォルダを開ã - - + + Select save セーブを開ã - + Select patch パッãƒã‚’é–‹ã - + Patches (*.ips *.ups *.bps) パッãƒãƒ•ã‚¡ã‚¤ãƒ« (*.ips *.ups *.bps) - + Select e-Reader dotcode カードeã‚’é–‹ã - + e-Reader card (*.raw *.bin *.bmp) カードe (*.raw *.bin *.bmp) - + Select image ç”»åƒã‚’é–‹ã - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) ç”»åƒãƒ•ã‚¡ã‚¤ãƒ« (*.png *.gif *.jpg *.jpeg);;ã™ã¹ã¦ã®ãƒ•ã‚¡ã‚¤ãƒ« (*) - + GameShark saves (*.sps *.xps) GameSharkセーブファイル (*.sps *.xps) - + Select video log ビデオログを開ã - + Video logs (*.mvl) ビデオログ (*.mvl) - + Crash クラッシュ - + The game has crashed with the following error: %1 @@ -6037,699 +6031,709 @@ Download size: %3 %1 - + Couldn't Start 起動失敗 - + Could not start game. ゲームを起動ã§ãã¾ã›ã‚“ã§ã—ãŸã€‚ - + Unimplemented BIOS call 未実装ã®BIOS呼ã³å‡ºã— - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. ã“ã®ã‚²ãƒ¼ãƒ ã¯å®Ÿè£…ã•ã‚Œã¦ã„ãªã„BIOS呼ã³å‡ºã—を使用ã—ã¾ã™ã€‚最高ã®ã‚¨ã‚¯ã‚¹ãƒšãƒªã‚¨ãƒ³ã‚¹ã‚’å¾—ã‚‹ã«ã¯å…¬å¼ã®BIOSを使用ã—ã¦ãã ã•ã„。 - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. é©åˆ‡ãªãƒ‡ã‚£ã‚¹ãƒ—レイデãƒã‚¤ã‚¹ã®ä½œæˆã«å¤±æ•—ã—ã€ã‚½ãƒ•ãƒˆãƒ‡ã‚£ã‚¹ãƒ—レイã«ãƒ•ã‚©ãƒ¼ãƒ«ãƒãƒƒã‚¯ã—ã¾ã—ãŸã€‚特ã«å¤§ããªã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã§ã¯ã€ã‚²ãƒ¼ãƒ ã®å®Ÿè¡ŒãŒé…ã„å ´åˆãŒã‚ã‚Šã¾ã™ã€‚ - + Really make portable? 本当ã«ãƒãƒ¼ã‚¿ãƒ–ル化ã—ã¾ã™ã‹ï¼Ÿ - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? ãƒãƒ¼ã‚¿ãƒ–ル化ã™ã‚‹ã¨ã€ä»¥é™ã¯å®Ÿè¡Œãƒ•ã‚¡ã‚¤ãƒ«ã¨åŒã˜ãƒ‡ã‚£ãƒ¬ã‚¯ãƒˆãƒªã«è¨­å®šãƒ•ã‚¡ã‚¤ãƒ«ãŒç½®ã‹ã‚Œã‚‹ã‚ˆã†ã«ãªã‚Šã¾ã™ã€‚続行ã—ã¾ã™ã‹ï¼Ÿ - + Restart needed å†èµ·å‹•ãŒå¿…è¦ - + Some changes will not take effect until the emulator is restarted. 一部ã®å¤‰æ›´ã¯ã€ã‚¨ãƒŸãƒ¥ãƒ¬ãƒ¼ã‚¿ã‚’å†èµ·å‹•ã™ã‚‹ã¾ã§æœ‰åŠ¹ã«ãªã‚Šã¾ã›ã‚“。 - + - Player %1 of %2 - プレーヤー %1 of %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &ファイル (&F) - + Load &ROM... ROMをロード... - + Load ROM in archive... アーカイブã«ROMをロード... - + Add folder to library... ライブラリーã«ãƒ•ã‚©ãƒ«ãƒ€ã‚’追加... - + Load &patch... パッãƒã‚’ロード... (&P) - + Boot BIOS BIOSã‚’èµ·å‹• - + Replace ROM... ROMを交æ›... - + Scan e-Reader dotcodes... カードeをスキャン... - + ROM &info... ROM情報... (&I) - + Recent 最近開ã„ãŸROM - + Make portable ãƒãƒ¼ã‚¿ãƒ–ル化 - + &Load state ステートをロード (&L) - + Report bug... ãƒã‚°å ±å‘Š - + About... ãƒãƒ¼ã‚¸ãƒ§ãƒ³æƒ…å ±... - + Record GIF/WebP/APNG... GIF/WebP/APNGを記録 - + Game Pak sensors... カートリッジセンサー... - + Clear 消去 - + Load state file... ステートファイルをロード... - + Save games (%1) セーブデータ (%1) - + Select save game セーブデータをé¸æŠž - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Convert e-Reader card image to raw... - + &Save state ステートをセーブ (&S) - + Save state file... ステートファイルをセーブ... - + Quick load クイックロード - + Quick save クイックセーブ - + Load recent 最後ã«ä½¿ã£ãŸã‚¯ã‚¤ãƒƒã‚¯ã‚¹ãƒ­ãƒƒãƒˆã‹ã‚‰ãƒ­ãƒ¼ãƒ‰ - + Save recent 最後ã«ä½¿ã£ãŸã‚¯ã‚¤ãƒƒã‚¯ã‚¹ãƒ­ãƒƒãƒˆã«ã‚»ãƒ¼ãƒ– - + Undo load state クイックロードを元ã«æˆ»ã™ - + Undo save state クイックセーブを元ã«æˆ»ã™ - - + + State &%1 クイックスロット &%1 - + Load camera image... カメラ画åƒã‚’ロード... - + Convert save game... セーブデータを変æ›... - + GameShark saves (*.gsv *.sps *.xps) - + Import GameShark Save... GameSharkスナップショットを読ã¿è¾¼ã‚€ - + Export GameShark Save... GameSharkスナップショットを書ã出㙠- + New multiplayer window æ–°ã—ã„ウィンドウ(マルãƒãƒ—レイ) - + Connect to Dolphin... Dolphinã«æŽ¥ç¶š... - + E&xit 終了 (&X) - + &Emulation エミュレーション (&E) - + &Reset リセット (&R) - + Sh&utdown é–‰ã˜ã‚‹ (&U) - + Yank game pak カートリッジを抜ã - + &Pause 一時åœæ­¢ (&P) - + &Next frame 次ã®ãƒ•ãƒ¬ãƒ¼ãƒ  (&N) - + Fast forward (held) æ—©é€ã‚Š(押ã—) - + &Fast forward æ—©é€ã‚Š (&F) - + Fast forward speed æ—©é€ã‚Šé€Ÿåº¦ - + Unbounded 制é™ãªã— - + %0x %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) 巻戻ã—(押ã—) - + Re&wind 巻戻㗠(&R) - + Step backwards 1フレーム巻ã戻㙠- + Solar sensor 太陽センサー - + Increase solar level 明るã•ã‚’上ã’ã‚‹ - + Decrease solar level 明るã•ã‚’下ã’ã‚‹ - + Brightest solar level 明るã•æœ€é«˜ - + Darkest solar level 明るã•æœ€ä½Ž - + Brightness %1 明る㕠%1 - + Audio/&Video オーディオ/ビデオ (&V) - + Frame size ç”»é¢ã‚µã‚¤ã‚º - + Toggle fullscreen 全画é¢è¡¨ç¤º - + + &Lock frame size + + + + Lock aspect ratio 縦横比を固定 - + Force integer scaling 整数スケーリングを強制 - + Bilinear filtering ãƒã‚¤ãƒªãƒ‹ã‚¢ãƒ•ã‚£ãƒ«ã‚¿ãƒªãƒ³ã‚° - + Frame&skip フレームスキップ (&S) - + Mute ミュート - + FPS target FPS - + Native (59.7275) ãƒã‚¤ãƒ†ã‚£ãƒ–(59.7275) - + Take &screenshot スクリーンショット (&S) - + F12 F12 - + Game Boy Printer... ãƒã‚±ãƒƒãƒˆãƒ—リンタ... - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games セーブデータ - + Automatically determine - + Use player %0 save game - + BattleChip Gate... ãƒãƒˆãƒ«ãƒãƒƒãƒ—ゲート... - + %1× %1× - + Interframe blending ãƒ•ãƒ¬ãƒ¼ãƒ é–“æ··åˆ - + Record A/V... ビデオ録画... - + Video layers ビデオレイヤー - + Audio channels オーディオãƒãƒ£ãƒ³ãƒãƒ« - + Adjust layer placement... レイヤーã®é…置を調整... - + &Tools ツール (&T) - + View &logs... ログビューアー... (&L) - + Game &overrides... ゲーム別設定... (&O) - + &Cheats... ãƒãƒ¼ãƒˆ... (&C) - + Settings... 設定... - + Open debugger console... デãƒãƒƒã‚¬ã‚³ãƒ³ã‚½ãƒ¼ãƒ«ã‚’é–‹ã... - + Start &GDB server... GDBサーãƒã‚’èµ·å‹•... (&G) - + Scripting... - + Create forwarder... - + Game state views - + View &palette... パレットビューアー... (&P) - + View &sprites... スプライトビューアー... (&S) - + View &tiles... タイルビューアー... (&T) - + View &map... マップビューアー... (&M) - + &Frame inspector... フレームインスペクタ... (&F) - + View memory... メモリビューアー... - + Search memory... メモリ検索... - + View &I/O registers... IOビューアー... (&I) - + + Log memory &accesses... + + + + Record debug video log... デãƒãƒƒã‚°ãƒ“デオログ... - + Stop debug video log デãƒãƒƒã‚°ãƒ“デオログをåœæ­¢ - + Exit fullscreen 全画é¢è¡¨ç¤ºã‚’終了 - + GameShark Button (held) GameSharkボタン(押ã—) - + Autofire 連打 - + Autofire A 連打 A - + Autofire B 連打 B - + Autofire L 連打 L - + Autofire R 連打 R - + Autofire Start 連打 Start - + Autofire Select 連打 Select - + Autofire Up 連打 上 - + Autofire Right 連打 å³ - + Autofire Down 連打 下 - + Autofire Left 連打 å·¦ @@ -6767,17 +6771,17 @@ Download size: %3 ? - + Super (L) Super (L) - + Super (R) Super (R) - + Menu メニュー @@ -6785,22 +6789,22 @@ Download size: %3 QShortcut - + Shift Shift - + Control Control - + Alt Alt - + Meta Meta diff --git a/src/platform/qt/ts/mgba-ko.ts b/src/platform/qt/ts/mgba-ko.ts index 05a8dc60410..5eb6849150f 100644 --- a/src/platform/qt/ts/mgba-ko.ts +++ b/src/platform/qt/ts/mgba-ko.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) ê²Œìž„ë³´ì´ ì–´ë“œë°´ìŠ¤ 롬 (%1) - + Game Boy ROMs (%1) ê²Œìž„ë³´ì´ ë¡¬ (%1) - + All ROMs (%1) 모든 롬 (%1) - + %1 Video Logs (*.mvl) %1 비디오 로그 (*.mvl) @@ -191,17 +191,17 @@ Download size: %3 QGBA::AudioDevice - + Can't set format of context-less audio device 컨í…스트 없는 오디오 ìž¥ì¹˜ì˜ í˜•ì‹ì„ 설정할 수 ì—†ìŒ - + Audio device is missing its core 오디오 ìž¥ì¹˜ì— ì½”ì–´ê°€ ì—†ìŒ - + Writing data to read-only audio device ì½ê¸° ì „ìš© 오디오 ìž¥ì¹˜ì— ë°ì´í„° 쓰기 @@ -209,7 +209,7 @@ Download size: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input ìž…ë ¥ ì—†ì´ ì˜¤ë””ì˜¤ 프로세서를 시작할 수 ì—†ìŒ @@ -285,28 +285,28 @@ Download size: %3 고급 보기 - + BattleChip data missing 배틀칩 ë°ì´í„° ëˆ„ë½ - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? 배트칩 ë°ì´í„°ê°€ 없습니다. 배틀칩 게ì´íŠ¸ëŠ” ê³„ì† ìž‘ë™í•˜ì§€ë§Œ ì¼ë¶€ ê·¸ëž˜í”½ì´ ëˆ„ë½ë©ë‹ˆë‹¤. 지금 ë°ì´í„°ë¥¼ 다운로드하겠습니까? - - + + Select deck file ë± íŒŒì¼ ì„ íƒ - + Incompatible deck 호환ë˜ì§€ 않는 ë± - + The selected deck is not compatible with this Chip Gate ì„ íƒí•œ ë±ì€ ì´ ì¹© 게ì´íŠ¸ì™€ 호환ë˜ì§€ ì•ŠìŒ @@ -367,19 +367,19 @@ Download size: %3 ì—¬ê¸°ì— ì½”ë“œë¥¼ 입력하세요... - - + + Autodetect (recommended) ìžë™ ê°ì§€ (권장) - - + + Select cheats file 치트 íŒŒì¼ ì„ íƒ - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. ì¼ë¶€ 치트를 추가할 수 없습니다. 형ì‹ì´ 올바른지 확ì¸í•˜ê³  다른 치트 ìœ í˜•ì„ ì‹œë„하세요. @@ -398,37 +398,37 @@ Download size: %3 현재 활성화ë˜ì§€ ì•Šì€ ë˜ê°ê¸° - + Reset the game? ê²Œìž„ì„ ìž¬ì„¤ì •í•˜ê² ìŠµë‹ˆê¹Œ? - + Most games will require a reset to load the new save. Do you want to reset now? ëŒ€ë¶€ë¶„ì˜ ê²Œìž„ì€ ìƒˆë¡œìš´ ì €ìž¥ì„ ë¡œë“œí•˜ë ¤ë©´ ìž¬ì„¤ì •ì´ í•„ìš”í•©ë‹ˆë‹¤. 지금 재설정하겠습니까? - + Failed to open save file: %1 저장 파ì¼ì„ 열지 못했습니다: %1 - + Failed to open game file: %1 게임 파ì¼ì„ 열지 못했습니다: %1 - + Can't yank pack in unexpected platform! 예기치 ì•Šì€ í”Œëž«í¼ì—ì„œ íŒ©ì„ ìž¡ì•„ë‹¹ê¸¸ 수 없습니다! - + Failed to open snapshot file for reading: %1 ì½ê¸° ìš© 스냅샷 파ì¼ì„ 열지 못했습니다: %1 - + Failed to open snapshot file for writing: %1 쓰기 ìš© 스냅샷 파ì¼ì„ 열지 못했습니다: %1 @@ -477,6 +477,14 @@ Download size: %3 쓰기 위해 CLI 기ë¡ì„ ì—´ 수 ì—†ìŒ + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Download size: %3 재설정 - + Export frame 프레임 내보내기 - + Portable Network Graphics (*.png) 휴대용 ë„¤íŠ¸ì›Œí¬ ê·¸ëž˜í”½ (*.png) - + None ì—†ìŒ - + Background ë°°ê²½ - + Window ì°½ - + Objwin Objwin - + Sprite 스프ë¼ì´íŠ¸ - + Backdrop ë°°ê²½ - + Frame 프레임 - + %1 %2 %1 %2 @@ -818,22 +826,22 @@ Download size: %3 QGBA::GBAKeyEditor - + Clear Button 버튼 정리 - + Clear Analog 아날로그 정리 - + Refresh 새로 고침 - + Set all ëª¨ë‘ ì„¤ì • @@ -3006,8 +3014,8 @@ Download size: %3 QGBA::KeyEditor - - + + --- --- @@ -3378,23 +3386,87 @@ Download size: %3 ìˆ˜ì§ - - - + + + N/A 해당 ì—†ìŒ - + Export map 맵 내보내기 - + Portable Network Graphics (*.png) 휴대용 ë„¤íŠ¸ì›Œí¬ ê·¸ëž˜í”½ (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + 시작 + + + + Stop + 정지 + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Download size: %3 새로 고침 - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 ë°”ì´íŠ¸%2 @@ -3750,17 +3822,17 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached ì—°ê²°ë˜ì§€ ì•Šì€ ë©€í‹°í”Œë ˆì´ì–´ 플레ì´ì–´ë¥¼ 분리하려고 함 - + Trying to get player ID for a multiplayer player that's not attached ì—°ê²°ë˜ì§€ ì•Šì€ ë©€í‹°í”Œë ˆì´ì–´ 플레ì´ì–´ì˜ 플레ì´ì–´ ID를 가져오려고 함 - + Trying to get save ID for a multiplayer player that's not attached ì—°ê²°ë˜ì§€ ì•Šì€ ë©€í‹°í”Œë ˆì´ì–´ 플레ì´ì–´ì˜ 저장 ID를 얻으려고 함 @@ -4157,35 +4229,35 @@ Download size: %3 보트 타기 내보내기 - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette 팔레트 내보내기 - + Windows PAL (*.pal);;Adobe Color Table (*.act) ì°½ PAL (*.pal);;ì–´ë„비 컬러 í…Œì´ë¸” (*.act) - + Failed to open output palette file: %1 출력 팔레트 파ì¼ì„ 열지 못했습니다: %1 @@ -4259,7 +4331,7 @@ Download size: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Download size: %3 + Maker Code: + + + + + Revision: + + + + File size: íŒŒì¼ í¬ê¸°: - + CRC32: CRC32: - + Save file: 저장 파ì¼: @@ -4364,62 +4446,62 @@ Download size: %3 QGBA::SaveConverter - + Save games and save states (%1) 게임 저장 ë° ìƒíƒœ 저장 (%1) - + Select save game or save state 게임 저장 ë˜ëŠ” ìƒíƒœ 저장 ì„ íƒ - + Save games (%1) 게임 (%1) 저장 - + Select save game 저장 게임 ì„ íƒ - + Conversion failed 변환 실패 - + Failed to convert the save game. This is probably a bug. 저장 ê²Œìž„ì„ ë³€í™˜í•˜ì§€ 못했습니다. ì´ê²ƒì€ ì•„ë§ˆë„ ë²„ê·¸ì¼ ê²ƒìž…ë‹ˆë‹¤. - + No file selected íŒŒì¼ ì„ íƒë˜ì§€ ì•Šì•˜ìŒ - + Could not open file íŒŒì¼ ì—´ 수 ì—†ìŒ - + No valid formats found 유효한 í˜•ì‹ ì—†ìŒ - + Please select a valid input file 유효한 ìž…ë ¥ íŒŒì¼ ì„ íƒ - + No valid conversions found 유효한 전환 ì—†ìŒ - + Cannot convert save games between platforms í”Œëž«í¼ ê°„ì— ì €ìž¥ 게임 변환할 수 ì—†ìŒ @@ -4445,97 +4527,97 @@ Download size: %3 출력 íŒŒì¼ - + %1 %2 save game %1 %2 저장 게임 - + little endian 리틀 엔디안 - + big endian ë¹… 엔디안 - + SRAM SRAM - + %1 flash %1 플래시 - + %1 EEPROM %1 EEPROM - + + RTC + RTC - + %1 SRAM + RTC %1 SRAM + RTC - + %1 SRAM %1 SRAM - + packed MBC2 íŒ©í‚¹ëœ MBC2 - + unpacked MBC2 ì–¸íŒ©í‚¹ëœ MBC2 - + MBC6 flash MBC6 플래시 - + MBC6 combined SRAM + flash MBC6 ê²°í•© SRAM + 플래시 - + MBC6 SRAM MBC6 SRAM - + TAMA5 TAMA5 - + %1 (%2) %1 (%2) - + %1 save state with embedded %2 save game í¬í•¨ëœ %2 저장 ê²Œìž„ì´ ìžˆëŠ” %1 저장 ìƒíƒœ - + %1 SharkPort %2 save game %1 샤í¬í¬íŠ¸ %2 게임 저장 - + %1 GameShark Advance SP %2 save game %1 ê²Œìž„ìƒ¤í¬ ì–´ë“œë°´ìŠ¤ SP %2 게임 저장 @@ -4571,32 +4653,37 @@ Download size: %3 최근 스í¬ë¦½íŠ¸ 로드 - + Load script... 스í¬ë¦½íŠ¸ 로드... - + + &Load most recent + + + + &Reset 재설정 (&R) - + 0 0 - + Select script to load 로드할 스í¬ë¦½íŠ¸ ì„ íƒ - + Lua scripts (*.lua) 루아 스í¬ë¦½íŠ¸ (*.lua) - + All files (*.*) 모든 íŒŒì¼ (*.*) @@ -4689,112 +4776,112 @@ Download size: %3 QGBA::SettingsView - - + + Qt Multimedia Qt 멀티미디어 - + SDL SDL - + Software (Qt) 소프트웨어 (Qt) - + OpenGL 오픈GL - + OpenGL (force version 1.x) 오픈GL (버전 1.x ê°•ì œ) - + None ì—†ìŒ - + None (Still Image) ì—†ìŒ (정지 ì´ë¯¸ì§€) - + Keyboard 키보드 - + Controllers 컨트롤러 - + Shortcuts 단축키 - - + + Shaders ì‰ì´ë” - + Select BIOS ë°”ì´ì˜¤ìŠ¤ ì„ íƒ - + Select directory 디렉토리 ì„ íƒ - + Select image ì´ë¯¸ì§€ ì„ íƒ - + Image file (*.png *.jpg *.jpeg) ì´ë¯¸ì§€ íŒŒì¼ (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never 절대 - + Just now 방금 - + Less than an hour ago 1시간 미만 ì „ - + %n hour(s) ago %n 시간 ì „ - + %n day(s) ago %n ì¼ ì „ @@ -5115,37 +5202,37 @@ Download size: %3 ë˜ê°ê¸° ì†ë„: - + Default color palette only 기본 ìƒ‰ìƒ íŒ”ë ˆíŠ¸ë§Œ - + SGB color palette if available 가능한 경우 SGB ìƒ‰ìƒ íŒ”ë ˆíŠ¸ - + GBC color palette if available 가능한 경우 GBC ìƒ‰ìƒ íŒ”ë ˆíŠ¸ - + SGB (preferred) or GBC color palette if available 사용 가능한 경우 SGB (선호) ë˜ëŠ” GBC ìƒ‰ìƒ íŒ”ë ˆíŠ¸ - + Game Boy Camera 게임 ë³´ì´ ì¹´ë©”ë¼ - + Driver: ë“œë¼ì´ë²„: - + Source: 소스: @@ -5216,42 +5303,42 @@ Download size: %3 ìƒíƒœ 추가 ë°ì´í„° 로드: - + Models ëª¨ë¸ - + GB only: GB ì „ìš©: - + SGB compatible: SGB 호환: - + GBC only: GBC ì „ìš©: - + GBC compatible: GBC 호환: - + SGB and GBC compatible: SGB 와 GBC 호환: - + Game Boy palette 게임 ë³´ì´ íŒ”ë ˆíŠ¸ - + Preset: 사전 설정: @@ -5276,62 +5363,57 @@ Download size: %3 소프트웨어 - + OpenGL enhancements OpenGL 개선 사항 - + High-resolution scale: ê³ í•´ìƒë„ 스케ì¼: - + (240×160) (240×160) - - XQ GBA audio (experimental) - XQ GBA 오디오 (시험용) - - - + Cheats 치트 - + Default BG colors: 기본 ë°°ê²½ 색ìƒ: - + Super Game Boy borders ìŠˆí¼ ê²Œìž„ ë³´ì´ í…Œë‘리 - + Default sprite colors 1: 기본 스프ë¼ì´íŠ¸ ìƒ‰ìƒ 1: - + Log to file 파ì¼ì— ê¸°ë¡ - + Log to console ì½˜ì†”ì— ê¸°ë¡ - + Select Log File 로그 íŒŒì¼ ì„ íƒ - + Default sprite colors 2: 기본 스프ë¼ì´íŠ¸ ìƒ‰ìƒ 2: @@ -5357,25 +5439,25 @@ Download size: %3 - - - - - - - - - + + + + + + + + + Browse 브ë¼ìš°ì € - + Use BIOS file if found 발견ë˜ë©´ ë°”ì´ì˜¤ìŠ¤ íŒŒì¼ ì‚¬ìš© - + Skip BIOS intro ë°”ì´ì˜¤ìŠ¤ 소개 건너 뛰기 @@ -5483,51 +5565,51 @@ Download size: %3 Intervallo Autofire: - + GB BIOS file: GB ë°”ì´ì˜¤ìŠ¤ 파ì¼: - + GBA BIOS file: GBA ë°”ì´ì˜¤ìŠ¤ 파ì¼: - + GBC BIOS file: GBC ë°”ì´ì˜¤ìŠ¤ 파ì¼: - + SGB BIOS file: SGB ë°”ì´ì˜¤ìŠ¤ 파ì¼: - + Save games 게임 저장 - - - - - + + + + + Same directory as the ROM 롬과 ê°™ì€ ë””ë ‰í† ë¦¬ - + Save states 저장 íŒŒì¼ ìƒíƒœ - + Screenshots 스í¬ë¦°ìƒ· - + Patches 패치 @@ -5775,7 +5857,6 @@ Download size: %3 - WebM WebM @@ -5784,32 +5865,11 @@ Download size: %3 Format í˜•ì‹ - - - MKV - MKV - - - - AVI - AVI - - MP4 MP4 - - - HEVC - HEVC - - - - VP8 - VP8 - High &Quality @@ -5850,72 +5910,6 @@ Download size: %3 &Native 실기 (&N) - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - ì—†ìŒ - - - - FLAC - FLAC - - - - WavPack - Wav팩 - - - - Opus - 오푸스 - - - - Vorbis - 보비스 - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - 미압축 - Bitrate (kbps) @@ -5955,95 +5949,95 @@ Download size: %3 QGBA::Window - + Archives (%1) ì•„ì¹´ì´ë¸Œ (%1) - - + + Select ROM 롬 ì„ íƒ - - + + Select save 저장 íŒŒì¼ ì„ íƒ - + Select patch 패치 ì„ íƒ - + Patches (*.ips *.ups *.bps) 패치 (*.ips *.ups *.bps) - + Select e-Reader dotcode e-ë¦¬ë” ë„트코드 ì„ íƒ - + e-Reader card (*.raw *.bin *.bmp) e-ë¦¬ë” ì¹´ë“œ (*.raw *.bin *.bmp) - + Select e-Reader card images e-ë¦¬ë” ì¹´ë“œ ì´ë¯¸ì§€ ì„ íƒ - + Image file (*.png *.jpg *.jpeg) ì´ë¯¸ì§€ íŒŒì¼ (*.png *.jpg *.jpeg) - + Conversion finished 변환 완료 - + %1 of %2 e-Reader cards converted successfully. %2 e-ë¦¬ë” ì¹´ë“œ 중 %1ì´(ê°€) 성공ì ìœ¼ë¡œ 변환ë˜ì—ˆìŠµë‹ˆë‹¤. - + Select image ì´ë¯¸ì§€ ì„ íƒ - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) ì´ë¯¸ì§€ íŒŒì¼ (*.png *.gif *.jpg *.jpeg);;모든 íŒŒì¼ (*) - + GameShark saves (*.sps *.xps) ê²Œìž„ìƒ¤í¬ ì €ìž¥ íŒŒì¼ (*.sps *.xps) - + Select video log 비디오 로그 ì„ íƒ - + Video logs (*.mvl) 비디오 로그 (*.mvl) - + Crash 치명ì ì¸ 오류 - + The game has crashed with the following error: %1 @@ -6052,684 +6046,694 @@ Download size: %3 %1 - + Unimplemented BIOS call 구현ë˜ì§€ ì•Šì€ ë°”ì´ì˜¤ìŠ¤ 호출 - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. ì´ ê²Œìž„ì€ êµ¬í˜„ë˜ì§€ ì•Šì€ ë°”ì´ì˜¤ìŠ¤ í˜¸ì¶œì„ ì‚¬ìš©í•©ë‹ˆë‹¤. 최ìƒì˜ ì„±ëŠ¥ì„ ì–»ìœ¼ë ¤ë©´ ê³µì‹ ë°”ì´ì˜¤ìŠ¤ë¥¼ 사용하십시오. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. ì ì ˆí•œ ë””ìŠ¤í”Œë ˆì´ ìž¥ì¹˜ë¥¼ ìƒì„±í•˜ì§€ 못했습니다. 소프트웨어 디스플레ì´ë¡œ ëŒì•„갑니다. 특히 í° ì°½ì—서는 ê²Œìž„ì´ ëŠë¦¬ê²Œ ì‹¤í–‰ë  ìˆ˜ 있습니다. - + Really make portable? ì •ë§ë¡œ íœ´ëŒ€ìš©ì„ ë§Œë“­ë‹ˆê¹Œ? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? ì´ë ‡ê²Œí•˜ë©´ ì—뮬레ì´í„°ê°€ 실행 파ì¼ê³¼ ë™ì¼í•œ 디렉토리ì—ì„œ êµ¬ì„±ì„ ë¡œë“œí•˜ê²Œë©ë‹ˆë‹¤. ê³„ì† í•˜ì‹œê² ìŠµë‹ˆê¹Œ? - + Restart needed 재시작 í•„ìš” - + Some changes will not take effect until the emulator is restarted. ì¼ë¶€ 변경 ì‚¬í•­ì€ ì—뮬레ì´í„°ê°€ 다시 ì‹œìž‘ë  ë•Œê¹Œì§€ ì ìš©ë˜ì§€ 않습니다. - + Reset needed 재설정 í•„ìš” - + Some changes will not take effect until the game is reset. ì¼ë¶€ 변경 ì‚¬í•­ì€ ê²Œìž„ì´ ìž¬ì„¤ì •ë  ë•Œê¹Œì§€ ì ìš©ë˜ì§€ 않습니다. - + - Player %1 of %2 - 플레ì´ì–´ %1 ì˜ %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &íŒŒì¼ - + Load &ROM... 로드 &롬... - + Load ROM in archive... ë¡¬ì„ ì•„ì¹´ì´ë¸Œì— 로드... - + Save games 게임 저장 - + Automatically determine ìžë™ìœ¼ë¡œ ê²°ì • - + Use player %0 save game 플레ì´ì–´ %0 저장 게임 사용 - + Load &patch... 로드 &패치... - + Boot BIOS BIOS 부팅 - + Replace ROM... 롬 êµì²´... - + Scan e-Reader dotcodes... e-ë¦¬ë” ë„트코드 스캔... - + Game state views 게임 ìƒíƒœ 보기 - + Convert e-Reader card image to raw... e-ë¦¬ë” ì¹´ë“œ ì´ë¯¸ì§€ë¥¼ ì›ì‹œ ë°ì´í„°ë¡œ 변환... - + ROM &info... 롬 &ì •ë³´... - + Recent 최근 실행 - + Make portable 휴대용 만들기 - + &Load state &로드 íŒŒì¼ ìƒíƒœ - + &Save state &저장 íŒŒì¼ ìƒíƒœ - + Quick load 빠른 로드 - + Quick save 빠른 저장 - + Load recent 최근 실행 로드 - + Save recent 최근 실행 저장 - + Undo load state 로드 íŒŒì¼ ìƒíƒœ ë³µì› - + Undo save state 저장 íŒŒì¼ ìƒíƒœ ë³µì› - - + + State &%1 ìƒíƒœ &%1 - + Load camera image... ì¹´ë©”ë¼ ì´ë¯¸ì§€ 로드... - + Convert save game... 저장 게임 변환... - + GameShark saves (*.gsv *.sps *.xps) ê²Œìž„ìƒ¤í¬ ì €ìž¥ (*.gsv *.sps *.xps) - + New multiplayer window 새로운 멀티 플레ì´ì–´ ì°½ - + Connect to Dolphin... ëŒí•€ì— ì—°ê²°... - + E&xit 종&료 - + &Emulation &ì—뮬레ì´ì…˜ - + &Reset &재설정 - + Sh&utdown 종&료 - + Yank game pak 양키 게임 팩 - + &Pause &정지 - + &Next frame &ë‹¤ìŒ í”„ë ˆìž„ - + Fast forward (held) 빨리 ê°ê¸° (누름) - + &Fast forward &빨리 ê°ê¸° - + Fast forward speed 빨리 ê°ê¸° ì†ë„ - + Unbounded 무제한 - + %0x %0x - + Increase fast forward speed 빨리 ê°ê¸° ì†ë„ í–¥ìƒ - + Decrease fast forward speed 빨리 ê°ê¸° ì†ë„ 줄ì´ê¸° - + Rewind (held) ë˜ê¹€ê¸° (누름) - + Re&wind 리&와ì¸ë“œ - + Step backwards ëŒì•„가기 - + Brightest solar level 가장 ë°ì€ 태양 수준 - + Darkest solar level 가장 ì–´ë‘ìš´ 태양 수준 - + Brightness %1 ë°ê¸° %1 - + Audio/&Video 오디오/&비디오 - + Frame size 프레임 í¬ê¸° - + Toggle fullscreen 전체화면 전환 - + + &Lock frame size + + + + Lock aspect ratio 화면비 잠금 - + Frame&skip 프레임&건너뛰기 - + Mute ë¬´ìŒ - + FPS target FPS ëŒ€ìƒ - + Take &screenshot 스í¬ë¦°ìƒ· &ì°ê¸° - + F12 F12 - + Video layers 비디오 ë ˆì´ì–´ - + Audio channels 오디오 ì±„ë„ - + &Tools &ë„구 - + View &logs... 로그 &보기... - + Game &overrides... 게임 &오버ë¼ì´ë“œ... - + &Cheats... &치트.. - + Create forwarder... ì „ë‹¬ìž ìƒì„±... - + Open debugger console... 디버거 콘솔 열기... - + Start &GDB server... GDB 서버 &시작... - + Settings... 설정... - + Select folder í´ë” ì„ íƒ - + Couldn't Start 시작할 수 ì—†ìŒ - + Could not start game. ê²Œìž„ì„ ì‹œìž‘í•  수 없습니다. - + Add folder to library... ë¼ì´ë¸ŒëŸ¬ë¦¬ì— í´ë” 추가... - + Load state file... ìƒíƒœ íŒŒì¼ ë¡œë“œ... - + Save state file... ìƒíƒœ íŒŒì¼ ì €ìž¥... - + Import GameShark Save... ê²Œìž„ìƒ¤í¬ ì €ìž¥ 가져오기... - + Export GameShark Save... ê²Œìž„ìƒ¤í¬ ì €ìž¥ 내보내기... - + Report bug... 버그를 제보하기... - + About... ì •ë³´... - + Solar sensor 태양광 센서 - + Increase solar level 태양광 레벨 ì¦ê°€ - + Decrease solar level 태양광 레벨 ê°ì†Œ - + Force integer scaling 정수 스케ì¼ë§ ê°•ì œ 수행 - + Bilinear filtering ì´ì¤‘선형 í•„í„°ë§ - + Game Boy Printer... 게임 ë³´ì´ í”„ë¦°í„°... - + Save games (%1) 게임 (%1) 저장 - + Select save game 저장 게임 ì„ íƒ - + mGBA save state files (%1) mGBA 저장 ìƒíƒœ íŒŒì¼ (%1) - - + + Select save state 저장 ìƒíƒœ ì„ íƒ - + Load alternate save game... 대체 저장 게임 로드... - + Load temporary save game... ìž„ì‹œ 저장 게임 로드... - + BattleChip Gate... 배틀칩 게ì´íŠ¸... - + %1× %1× - + Interframe blending 프레임간 ì¡°í•© - + Native (59.7275) 실기 (59.7275) - + Record A/V... A/V 녹화... - + Record GIF/WebP/APNG... GIF/WebP/APNG 녹화... - + Adjust layer placement... ë ˆì´ì–´ 배치 ì¡°ì •... - + Game Pak sensors... 게임 팩 센서... - + Scripting... 스í¬ë¦½íŒ…... - + View &palette... 팔레트 &보기... - + View &sprites... 스프ë¼ì´íŠ¸ &보기... - + View &tiles... íƒ€ì¼ &보기... - + View &map... ì§€ë„ &보기... - + &Frame inspector... 프레임 검사기 (&F)... - + View memory... 메모리 보기... - + Search memory... 메모리 검색... - + View &I/O registers... I/O 레지스터 &보기... - + + Log memory &accesses... + + + + Record debug video log... 디버그 비디오 로그 녹화... - + Stop debug video log 디버그 비디오 로그 중지 - + Exit fullscreen 전체화면 종료 - + GameShark Button (held) ê²Œìž„ìƒ¤í¬ ë²„íŠ¼ (누름) - + Autofire 연사 - + Autofire A 연사 A - + Autofire B 연사 B - + Autofire L 연사 L - + Autofire R 연사 R - + Autofire Start 연사 시작 - + Autofire Select 연사 ì„ íƒ - + Clear 지움 - + Autofire Up 연사 위쪽 - + Autofire Right 연사 오른쪽 - + Autofire Down 연사 아래쪽 - + Autofire Left 연사 왼쪽 @@ -6767,17 +6771,17 @@ Download size: %3 ? - + Super (L) ìŠˆí¼ (L) - + Super (R) ìŠˆí¼ (R) - + Menu 메뉴 @@ -6785,22 +6789,22 @@ Download size: %3 QShortcut - + Shift 시프트 키 - + Control 콘트롤 키 - + Alt 알트 키 - + Meta 메타 diff --git a/src/platform/qt/ts/mgba-ms.ts b/src/platform/qt/ts/mgba-ms.ts index cb327e334c7..e606a3a9670 100644 --- a/src/platform/qt/ts/mgba-ms.ts +++ b/src/platform/qt/ts/mgba-ms.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) ROM Game Boy Advance (%1) - + Game Boy ROMs (%1) ROM Game Boy (%1) - + All ROMs (%1) Semua ROM (%1) - + %1 Video Logs (*.mvl) %1 Log Video (*.mvl) @@ -185,17 +185,17 @@ Download size: %3 QGBA::AudioDevice - + Can't set format of context-less audio device - + Audio device is missing its core - + Writing data to read-only audio device @@ -203,7 +203,7 @@ Download size: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input @@ -279,28 +279,28 @@ Download size: %3 Lanjutan - + BattleChip data missing - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? - - + + Select deck file - + Incompatible deck - + The selected deck is not compatible with this Chip Gate @@ -361,19 +361,19 @@ Download size: %3 Masuk kod di sini... - - + + Autodetect (recommended) - - + + Select cheats file Pilih fail tipu - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. @@ -392,37 +392,37 @@ Download size: %3 - + Reset the game? - + Most games will require a reset to load the new save. Do you want to reset now? - + Failed to open save file: %1 Gagal membuka fail tersimpan: %1 - + Failed to open game file: %1 Gagal membuka fail permainan: %1 - + Can't yank pack in unexpected platform! - + Failed to open snapshot file for reading: %1 Gagal membuka fail snapshot untuk baca: %1 - + Failed to open snapshot file for writing: %1 Gagal membuka fail snapshot untuk menulis: %1 @@ -471,6 +471,14 @@ Download size: %3 + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -751,52 +759,52 @@ Download size: %3 Tetap semula - + Export frame Eksport bingkai - + Portable Network Graphics (*.png) Grafik Rangkaian Mudah Alih (*.png) - + None Tiada - + Background Latar belakang - + Window Tetingkap - + Objwin Objwin - + Sprite - + Backdrop - + Frame Bingkai - + %1 %2 %1 %2 @@ -812,22 +820,22 @@ Download size: %3 QGBA::GBAKeyEditor - + Clear Button - + Clear Analog - + Refresh Segar Semula - + Set all @@ -3000,8 +3008,8 @@ Download size: %3 QGBA::KeyEditor - - + + --- --- @@ -3372,23 +3380,87 @@ Download size: %3 - - - + + + N/A - + Export map Eksport peta - + Portable Network Graphics (*.png) Grafik Rangkaian Mudah Alih (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + Pilih fail + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + Mula + + + + Stop + Henti + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3635,22 +3707,22 @@ Download size: %3 Segar Semula - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 bait%2 @@ -3744,17 +3816,17 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4151,35 +4223,35 @@ Download size: %3 Eksport OBJ - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette Eksport palet - + Windows PAL (*.pal);;Adobe Color Table (*.act) Windows PAL (*.pal);;Jadual Warna Adobe(*.act) - + Failed to open output palette file: %1 Gagal membuka fail palet output: %1 @@ -4253,7 +4325,7 @@ Download size: %3 QGBA::ROMInfo - + @@ -4293,16 +4365,26 @@ Download size: %3 + Maker Code: + + + + + Revision: + + + + File size: Saiz fail: - + CRC32: CRC32: - + Save file: @@ -4358,62 +4440,62 @@ Download size: %3 QGBA::SaveConverter - + Save games and save states (%1) Simpanan permainan dan keadaan tersimpan (%1) - + Select save game or save state Pilih simpanan permainan atau keadaan tersimpan - + Save games (%1) Simpanan permainan (%1) - + Select save game Pilih simpanan permainan - + Conversion failed Penukaran gagal - + Failed to convert the save game. This is probably a bug. Gagal menukar simpanan permainan. Mungkin ini suatu pepijat. - + No file selected Tiada pilihan - + Could not open file Tidak dapat membuka fail - + No valid formats found Tiada format yang sah ditemui - + Please select a valid input file Sila pilih fail input yang sah - + No valid conversions found Tiada penukaran yang sah ditemui - + Cannot convert save games between platforms Tidak boleh menukar simpanan permainan antara platform @@ -4439,97 +4521,97 @@ Download size: %3 Fail output - + %1 %2 save game Simpanan permainan %1 %2 - + little endian little-endian - + big endian big-endian - + SRAM SRAM - + %1 flash %1 kilat - + %1 EEPROM %1 EEPROM - + + RTC - + %1 SRAM + RTC %1 SRAM + RTC - + %1 SRAM %1 SRAM - + packed MBC2 - + unpacked MBC2 - + MBC6 flash Kilat MBC6 - + MBC6 combined SRAM + flash MBC6 bergabung SRAM + kilat - + MBC6 SRAM SRAM MBC6 - + TAMA5 TAMA5 - + %1 (%2) %1 (%2) - + %1 save state with embedded %2 save game Keadaan tersimpan %1 dgn simpanan permainan terbenam %2 - + %1 SharkPort %2 save game - + %1 GameShark Advance SP %2 save game @@ -4565,32 +4647,37 @@ Download size: %3 - + Load script... - + + &Load most recent + + + + &Reset - + 0 4K {0?} - + Select script to load - + Lua scripts (*.lua) - + All files (*.*) @@ -4683,112 +4770,112 @@ Download size: %3 QGBA::SettingsView - - + + Qt Multimedia Multimedia Qt - + SDL SDL - + Software (Qt) Perisian (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL (paksa versi 1.x) - + None Tiada - + None (Still Image) Tiada (Gambar Tenang) - + Keyboard Papan Kekunci - + Controllers Pengawal - + Shortcuts Pintas - - + + Shaders - + Select BIOS Pilih BIOS - + Select directory Pilih direktori - + Select image Pilih gambar - + Image file (*.png *.jpg *.jpeg) Fail gambar (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago - + %n day(s) ago @@ -5114,37 +5201,37 @@ Download size: %3 - + Default color palette only Palet warna piawai sahaja - + SGB color palette if available Palet warna SGB jika ada - + GBC color palette if available Palet warna GBC jika ada - + SGB (preferred) or GBC color palette if available SGB (pilihan utama) atau palet warna GBC jika ada - + Game Boy Camera Game Boy Camera - + Driver: Pemacu: - + Source: Sumber: @@ -5321,42 +5408,42 @@ Download size: %3 Data ekstra keadaan muat: - + Models Model - + GB only: GB sahaja: - + SGB compatible: SGB serasi: - + GBC only: GBC sahaja: - + GBC compatible: GBC serasi: - + SGB and GBC compatible: SGB dan GBC serasi: - + Game Boy palette Palet Game Boy - + Preset: Praset: @@ -5393,135 +5480,130 @@ Download size: %3 Perisian - + OpenGL enhancements - + High-resolution scale: - + (240×160) (240×160) - - XQ GBA audio (experimental) - - - - + GB BIOS file: Fail BIOS GB: - - - - - - - - - + + + + + + + + + Browse Pilih fail - + Use BIOS file if found Guna fail BIOS jika ada - + Skip BIOS intro Langkau pendahuluan BIOS - + GBA BIOS file: Fail BIOS GBA: - + GBC BIOS file: Fail BIOS GBC: - + SGB BIOS file: Fail BIOS SGB: - + Save games Simpanan permainan - - - - - + + + + + Same directory as the ROM Direktori sama dengan ROM - + Save states Keadaan tersimpan - + Screenshots Cekupan skrin - + Patches - + Cheats Tipuan - + Log to file Log dalam fail - + Log to console Log dalam konsol - + Select Log File Pilih fail log - + Default BG colors: Warna LB piawai: - + Default sprite colors 1: - + Default sprite colors 2: - + Super Game Boy borders @@ -5779,13 +5861,11 @@ Download size: %3 - WebM WebM - MP4 MP4 @@ -5824,82 +5904,6 @@ Download size: %3 Format Format - - - MKV - MKV - - - - AVI - AVI - - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - Tiada - - - - FLAC - FLAC - - - - WavPack - - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - - Bitrate (kbps) @@ -5910,16 +5914,6 @@ Download size: %3 ABR ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5949,80 +5943,80 @@ Download size: %3 QGBA::Window - + Archives (%1) Arkib (%1) - - + + Select ROM Pilih ROM - + Select folder Pilih folder - - + + Select save - + Select patch - + Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) - + Select image Pilih gambar - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Fail gambar (*.png *.gif *.jpg *.jpeg);;Semua fail (*) - + GameShark saves (*.sps *.xps) Simpanan GameShark (*.sps *.xps) - + Select video log Pilih log video - + Video logs (*.mvl) Log video (*.mvl) - + Crash Nahas - + The game has crashed with the following error: %1 @@ -6031,699 +6025,709 @@ Download size: %3 %1 - + Couldn't Start Tidak dapat memula - + Could not start game. Permainan tidak dapat bermula. - + Unimplemented BIOS call Panggilan BIOS yg belum dilaksanakan - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Permainan ini menggunakan panggilan BIOS yang belum dilaksanakan. Sila pakai BIOS rasmi untuk pengalaman yang lebih baik. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Gagal mencipta peranti paparan yang sesuai, berbalik ke paparan perisian. Permainan mungkin menjadi lembap, terutamanya dengan tetingkap besar. - + Really make portable? Betulkah mahu buat jadi mudah alih? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Ini akan menetapkan pelagak untuk muat konfigurasi dari direktori yang sama dengan fail bolehlakunya. Teruskan? - + Restart needed Mula semula diperlukan - + Some changes will not take effect until the emulator is restarted. Beberapa perubahan tidak akan dilaksanakan sehingga pelagak dimula semula. - + - Player %1 of %2 - Pemain %1 dari %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &File - + Load &ROM... Muat %ROM... - + Load ROM in archive... Muat ROM daripada arkib... - + Add folder to library... Tambah folder ke perpustakaan... - + Save games (%1) Simpanan permainan (%1) - + Select save game Pilih simpanan permainan - + mGBA save state files (%1) mGBA fail keadaan tersimpan (%1) - - + + Select save state Pilih keadaan tersimpan - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) Fail gambar (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... Muat simpanan permainan alternatif... - + Load temporary save game... Muat simpanan permainan sementara... - + Load &patch... - + Boot BIOS But BIOS - + Replace ROM... Ganti ROM... - + Scan e-Reader dotcodes... - + Convert e-Reader card image to raw... - + ROM &info... &Perihal ROM... - + Recent Terkini - + Make portable Buat jadi mudah alih - + &Load state &Muat keadaan - + Load state file... Muat fail keadaan... - + &Save state &Simpan keadaan - + Save state file... Simpan fail keadaan... - + Quick load - + Quick save - + Load recent Muat terkini - + Save recent Simpan terkini - + Undo load state Buat asal keadaan termuat - + Undo save state Buat asal keadaan tersimpan - - + + State &%1 Keadaan &%1 - + Load camera image... Muat gambar kamera... - + Convert save game... Tukar simpanan permainan... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games Simpanan permainan - + Import GameShark Save... Import Simpanan GameShark... - + Export GameShark Save... Eksport Simpanan GameShark... - + Automatically determine - + Use player %0 save game - + New multiplayer window Tetingkap multipemain baru - + Connect to Dolphin... Sambung ke Dolphin... - + Report bug... Laporkan pepijat... - + About... Perihal... - + E&xit &Keluar - + &Emulation Pe&lagak - + &Reset - + Sh&utdown &Matikan - + Yank game pak Alih keluar Game Pak - + &Pause &Jeda - + &Next frame Bingkai se&terusnya - + Fast forward (held) Mundar laju (pegang) - + &Fast forward Mundar &laju - + Fast forward speed Kelajuan mundar laju - + Unbounded Tidak terbatas - + %0x %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) Putar balik (pegang) - + Re&wind Ma&ndir - + Step backwards Langkah belakang - + Solar sensor Pengesan suria - + Increase solar level Meningkatkan aras suria - + Decrease solar level Mengurangkan aras suria - + Brightest solar level Aras suria paling terang - + Darkest solar level Aras suria paling gelap - + Brightness %1 Kecerahan %1 - + Game Boy Printer... Pencetak Game Boy... - + BattleChip Gate... BattleChip Gate... - + Audio/&Video Audio/&Video - + Frame size Saiz bingkai - + %1× %1× - + Toggle fullscreen Togol skrinpenuh - + + &Lock frame size + + + + Lock aspect ratio Kekalkan nisbah aspek - + Force integer scaling Paksa skala integer - + Interframe blending Persebatian antarabingkai - + Bilinear filtering Penapisan bilinear - + Frame&skip Langkauan &bingkai - + Mute Senyap - + FPS target Sasaran FPS - + Native (59.7275) Asal (59.7275) - + Take &screenshot Ambil &cekupan skrin - + F12 F12 - + Record A/V... Rakam A/V... - + Record GIF/WebP/APNG... Rakam GIF/WebP/APNG... - + Video layers Lapisan video - + Audio channels Saluran audio - + Adjust layer placement... Melaras peletakan lapisan... - + &Tools &Alat - + View &logs... Lihat &log... - + Game &overrides... - + Game Pak sensors... Pengesan Game Pak... - + &Cheats... &Tipu... - + Create forwarder... - + Settings... Tetapan... - + Open debugger console... Buka konsol penyahpepijat... - + Start &GDB server... Mula pelayan &GDB... - + Scripting... - + Game state views - + View &palette... Pelihat &palet... - + View &sprites... - + View &tiles... Pelihat &jubin... - + View &map... Pelihat pe&ta... - + &Frame inspector... Periksa &bingkai... - + View memory... Lihat ingatan... - + Search memory... Cari ingatan... - + View &I/O registers... Lihat daftar &I/O... - + + Log memory &accesses... + + + + Record debug video log... Rakam log video nyahpepijat... - + Stop debug video log Henti log video nyahpepijat - + Exit fullscreen Keluar skrinpenuh - + GameShark Button (held) Butang GameShark (pegang) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear Kosongkan @@ -6761,17 +6765,17 @@ Download size: %3 ? - + Super (L) Super (L) - + Super (R) Super (R) - + Menu Menu @@ -6779,22 +6783,22 @@ Download size: %3 QShortcut - + Shift Shift - + Control Ctrl - + Alt Alt - + Meta Meta diff --git a/src/platform/qt/ts/mgba-nb_NO.ts b/src/platform/qt/ts/mgba-nb_NO.ts index 6c06c2fe6ae..789faa1f0c2 100644 --- a/src/platform/qt/ts/mgba-nb_NO.ts +++ b/src/platform/qt/ts/mgba-nb_NO.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) Game Boy Advance ROM-filer (%1) - + Game Boy ROMs (%1) Game Boy ROM-filer (%1) - + All ROMs (%1) Alle ROM-filer (%1) - + %1 Video Logs (*.mvl) %1-videologger (*.mvl) @@ -189,17 +189,17 @@ Nedlastningsstørrelse: %3 QGBA::AudioDevice - + Can't set format of context-less audio device - + Audio device is missing its core - + Writing data to read-only audio device Skriver data til skrivebeskyttet lydenhet @@ -207,7 +207,7 @@ Nedlastningsstørrelse: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input @@ -283,28 +283,28 @@ Nedlastningsstørrelse: %3 Vis avanserte innstillinger - + BattleChip data missing - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? - - + + Select deck file - + Incompatible deck - + The selected deck is not compatible with this Chip Gate @@ -365,19 +365,19 @@ Nedlastningsstørrelse: %3 Skriv inn koder her … - - + + Autodetect (recommended) Auto-oppdag (anbefales) - - + + Select cheats file Velg juksekodefil - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. @@ -396,37 +396,37 @@ Nedlastningsstørrelse: %3 - + Reset the game? Vil du starte spillet pÃ¥ nytt? - + Most games will require a reset to load the new save. Do you want to reset now? - + Failed to open save file: %1 - + Failed to open game file: %1 Klarte ikke Ã¥ Ã¥pne spillfil: %1 - + Can't yank pack in unexpected platform! - + Failed to open snapshot file for reading: %1 - + Failed to open snapshot file for writing: %1 @@ -475,6 +475,14 @@ Nedlastningsstørrelse: %3 + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -755,52 +763,52 @@ Nedlastningsstørrelse: %3 Tilbakestill - + Export frame - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) - + None Ingen - + Background Bakgrunn - + Window Vindu - + Objwin Objwin - + Sprite - + Backdrop Bakgrunn - + Frame Ramme - + %1 %2 %1 %2 @@ -816,22 +824,22 @@ Nedlastningsstørrelse: %3 QGBA::GBAKeyEditor - + Clear Button Tøm knapper - + Clear Analog Tøm analoge - + Refresh Gjenoppfrisk - + Set all Sett alle @@ -3004,8 +3012,8 @@ Nedlastningsstørrelse: %3 QGBA::KeyEditor - - + + --- --- @@ -3376,23 +3384,87 @@ Nedlastningsstørrelse: %3 Vertikal - - - + + + N/A I/T - + Export map - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + Bla + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + Stopp + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3456,7 +3528,7 @@ Nedlastningsstørrelse: %3 Load TBL - + Last inn TBL @@ -3639,22 +3711,22 @@ Nedlastningsstørrelse: %3 Gjenoppfrisk - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 @@ -3748,17 +3820,17 @@ Nedlastningsstørrelse: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4155,35 +4227,35 @@ Nedlastningsstørrelse: %3 Eksporter OBJ - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette Eksporter palett - + Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 @@ -4257,7 +4329,7 @@ Nedlastningsstørrelse: %3 QGBA::ROMInfo - + @@ -4297,16 +4369,26 @@ Nedlastningsstørrelse: %3 + Maker Code: + + + + + Revision: + + + + File size: Filstørrelse: - + CRC32: CRC32: - + Save file: @@ -4362,62 +4444,62 @@ Nedlastningsstørrelse: %3 QGBA::SaveConverter - + Save games and save states (%1) Lagrefiler og lagringstilstander - + Select save game or save state - + Save games (%1) Lagrefiler (%1) - + Select save game Velg lagrefil - + Conversion failed Konvertering mislyktes - + Failed to convert the save game. This is probably a bug. - + No file selected Ingen fil valgt - + Could not open file Kunne ikke Ã¥pne fil - + No valid formats found - + Please select a valid input file Velg en gyldig inndatafil - + No valid conversions found - + Cannot convert save games between platforms @@ -4443,97 +4525,97 @@ Nedlastningsstørrelse: %3 Utdatafil - + %1 %2 save game - + little endian - + big endian - + SRAM SRAM - + %1 flash - + %1 EEPROM %1 EEPROM - + + RTC - + %1 SRAM + RTC - + %1 SRAM %1 SRAM - + packed MBC2 - + unpacked MBC2 - + MBC6 flash - + MBC6 combined SRAM + flash - + MBC6 SRAM MBC6-SRAM - + TAMA5 TAMA5 - + %1 (%2) %1 (%2) - + %1 save state with embedded %2 save game - + %1 SharkPort %2 save game - + %1 GameShark Advance SP %2 save game @@ -4569,32 +4651,37 @@ Nedlastningsstørrelse: %3 - + Load script... Last inn skript... - + + &Load most recent + + + + &Reset &Omstart - + 0 0 - + Select script to load - + Lua scripts (*.lua) - + All files (*.*) Alle filer (*.*) @@ -4687,105 +4774,105 @@ Nedlastningsstørrelse: %3 QGBA::SettingsView - - + + Qt Multimedia - + SDL SDL - + Software (Qt) Programvare (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL (tving versjon 1.x) - + None Ingen - + None (Still Image) Ingen (stillbilde) - + Keyboard Tastatur - + Controllers Kontrollere - + Shortcuts Snarveier - - + + Shaders Skyggeleggere - + Select BIOS Velg BIOS - + Select directory Velg mappe - + Select image Velg bilde - + Image file (*.png *.jpg *.jpeg) Bildefil (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Aldri - + Just now Akkurat nÃ¥ - + Less than an hour ago Mindre enn én time siden - + %n hour(s) ago @@ -4793,7 +4880,7 @@ Nedlastningsstørrelse: %3 - + %n day(s) ago @@ -5120,37 +5207,37 @@ Nedlastningsstørrelse: %3 Sjekk nÃ¥ - + Default color palette only - + SGB color palette if available SGB-fargepalett hvis tilgjengelig - + GBC color palette if available GBC-fargepalett hvis tilgjengelig - + SGB (preferred) or GBC color palette if available SGB (foretrukket) eller GBC-fargepalett hvis tilgjengelig - + Game Boy Camera Game Boy Camera - + Driver: Driver: - + Source: Kilde: @@ -5327,42 +5414,42 @@ Nedlastningsstørrelse: %3 - + Models Modeller - + GB only: Kun GB: - + SGB compatible: SGB-kompatibel: - + GBC only: Kun GBC: - + GBC compatible: GBC-kompatibel: - + SGB and GBC compatible: SGB- og GBC-kompatible: - + Game Boy palette Game Boy-fargepalett - + Preset: ForhÃ¥ndsinnstilling: @@ -5399,135 +5486,130 @@ Nedlastningsstørrelse: %3 Programvare - + OpenGL enhancements - + High-resolution scale: - + (240×160) (240×160) - - XQ GBA audio (experimental) - - - - + GB BIOS file: GB BIOS-fil: - - - - - - - - - + + + + + + + + + Browse Bla - + Use BIOS file if found Bruk BIOS-filen hvis den blir funnet - + Skip BIOS intro Hopp over BIOS-introen - + GBA BIOS file: GBA-BIOS-fil: - + GBC BIOS file: GBC-BIOS-fil: - + SGB BIOS file: SGB-BIOS-fil: - + Save games Lagrefiler - - - - - + + + + + Same directory as the ROM - + Save states - + Screenshots Skjermklipp - + Patches Patcher - + Cheats Juks - + Log to file Loggfør til en fil - + Log to console - + Select Log File - + Default BG colors: - + Default sprite colors 1: - + Default sprite colors 2: - + Super Game Boy borders Super Game Boy-kanter @@ -5785,13 +5867,11 @@ Nedlastningsstørrelse: %3 - WebM WebM - MP4 MP4 @@ -5830,92 +5910,6 @@ Nedlastningsstørrelse: %3 Format Format - - - MKV - MKV - - - - AVI - AVI - - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - Ingen - - - - FLAC - FLAC - - - - WavPack - - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - Ukomprimert - Bitrate (kbps) @@ -5955,779 +5949,789 @@ Nedlastningsstørrelse: %3 QGBA::Window - + Archives (%1) Arkiv (%1) - - + + Select ROM Velg ROM - + Select folder Velg mappe - - + + Select save Velg lagrefil - + Select patch Velg feilfiks - + Patches (*.ips *.ups *.bps) Feilfikser (*.ips *.ups *.bps) - + Select e-Reader dotcode Velg e-Reader-punktkode - + e-Reader card (*.raw *.bin *.bmp) e-Reader-kort (*.raw *.bin *.bmp) - + Select image Velg bilde - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Bildefil (*.png *.gif *.jpg *.jpeg);;All filer (*) - + GameShark saves (*.sps *.xps) - + Select video log - + Video logs (*.mvl) Videologgføringer (*.mvl) - + Crash Krasj - + The game has crashed with the following error: %1 - + Couldn't Start Klarte ikke Ã¥ starte opp - + Could not start game. Klarte ikke Ã¥ starte opp spillet. - + Unimplemented BIOS call - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + Really make portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + Restart needed Gjennomfør omstart - + Some changes will not take effect until the emulator is restarted. - + - Player %1 of %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File &Fil - + Load &ROM... Last inn &ROM... - + Load ROM in archive... - + Add folder to library... - + Save games (%1) Lagrefiler (%1) - + Select save game Velg lagrefil - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images Velg e-Reader-kortavbildninger - + Image file (*.png *.jpg *.jpeg) Bildefil (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Load &patch... - + Boot BIOS Oppstarts-BIOS - + Replace ROM... Bytt ROM.... - + Scan e-Reader dotcodes... Skann e-Reader-punktkoder... - + Convert e-Reader card image to raw... - + ROM &info... ROM-&info ... - + Recent Nylig - + Make portable - + &Load state &Last inn tilstand - + Load state file... - + &Save state &Lagre en tilstand - + Save state file... - + Quick load Hurtiginnlasting - + Quick save Hurtiglagring - + Load recent - + Save recent - + Undo load state - + Undo save state - - + + State &%1 - + Load camera image... - + Convert save game... - + GameShark saves (*.gsv *.sps *.xps) GameShark-lagrefiler (*.gsv *.sps *.xps) - + Reset needed Tilbakestilling kreves - + Some changes will not take effect until the game is reset. - + Save games Lagrefiler - + Import GameShark Save... - + Export GameShark Save... - + Automatically determine - + Use player %0 save game - + New multiplayer window Nytt flerspillervindu - + Connect to Dolphin... Koble til Dolphin... - + Report bug... Rapporter inn feil... - + About... Om … - + E&xit A&vslutt - + &Emulation &Emulering - + &Reset &Omstart - + Sh&utdown Skr&u av - + Yank game pak Dra ut spillkassetten - + &Pause &Pause - + &Next frame - + Fast forward (held) - + &Fast forward - + Fast forward speed - + Unbounded - + %0x %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) Spol tilbake (holdt) - + Re&wind Spol ti&lbake - + Step backwards - + Solar sensor Solsensor - + Increase solar level Øke solnivÃ¥et - + Decrease solar level Reduser solnivÃ¥et - + Brightest solar level Lyseste solnivÃ¥ - + Darkest solar level Mørkeste solnivÃ¥ - + Brightness %1 Lysstyrke %1 - + Game Boy Printer... Game Boy Printer... - + BattleChip Gate... - + Audio/&Video Lyd/&Video - + Frame size Rammestørrelse - + %1× %1× - + Toggle fullscreen Skru pÃ¥/av fullskjerm - + + &Lock frame size + + + + Lock aspect ratio LÃ¥s visningsforhold - + Force integer scaling - + Interframe blending - + Bilinear filtering Bilineær filtrering - + Frame&skip - + Mute Demp lyd - + FPS target - + Native (59.7275) Systemstandard (59.7275) - + Take &screenshot Ta &skjermbilde - + F12 F12 - + Record A/V... - + Record GIF/WebP/APNG... - + Video layers - + Audio channels Lydkanaler - + Adjust layer placement... - + &Tools Verk&tøy - + View &logs... - + Game &overrides... Spilloverstyringer ... - + Game Pak sensors... Game Pak-sensorer ... - + &Cheats... - + Create forwarder... - + Settings... Innstillinger… - + Open debugger console... - + Start &GDB server... - + Scripting... - + Game state views - + View &palette... Vis &palett ... - + View &sprites... - + View &tiles... - + View &map... Vis &kart … - + &Frame inspector... - + View memory... Vis minne ... - + Search memory... Søk i minne ... - + View &I/O registers... - + + Log memory &accesses... + + + + Record debug video log... - + Stop debug video log - + Exit fullscreen GÃ¥ ut av fullskjerm - + GameShark Button (held) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear Tøm @@ -6765,17 +6769,17 @@ Nedlastningsstørrelse: %3 ? - + Super (L) Super (L) - + Super (R) Super (R) - + Menu Meny @@ -6783,22 +6787,22 @@ Nedlastningsstørrelse: %3 QShortcut - + Shift Shift - + Control Kontroll - + Alt Alt - + Meta Meta diff --git a/src/platform/qt/ts/mgba-pl.ts b/src/platform/qt/ts/mgba-pl.ts index 650563e2e03..12ce3446223 100644 --- a/src/platform/qt/ts/mgba-pl.ts +++ b/src/platform/qt/ts/mgba-pl.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) ROMy Game Boy Advance (%1) - + Game Boy ROMs (%1) ROMy Game Boy (%1) - + All ROMs (%1) Wszystkie ROMy (%1) - + %1 Video Logs (*.mvl) Dzienniki wideo %1 (*.mvl) @@ -191,17 +191,17 @@ Rozmiar pobierania: %3 QGBA::AudioDevice - + Can't set format of context-less audio device Nie można ustawić formatu bezkontekstowego urzÄ…dzenia audio - + Audio device is missing its core UrzÄ…dzenie audio nie ma rdzenia - + Writing data to read-only audio device Zapisywanie danych na urzÄ…dzeniu audio tylko do odczytu @@ -209,7 +209,7 @@ Rozmiar pobierania: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input Nie można uruchomić procesora dźwiÄ™ku bez wejÅ›cia @@ -285,28 +285,28 @@ Rozmiar pobierania: %3 Pokaż zaawansowane opcje - + BattleChip data missing Brak danych BattleChip - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? Brak danych BattleChip. BattleChip Gates nadal bÄ™dzie dziaÅ‚ać, ale bÄ™dzie brakować niektórych elementów graficznych. Czy chcesz teraz pobrać dane? - - + + Select deck file Wybierz plik deck - + Incompatible deck Niezgodny deck - + The selected deck is not compatible with this Chip Gate Wybrany deck nie jest kompatybilny z tym Chip Gate @@ -367,19 +367,19 @@ Rozmiar pobierania: %3 Wpisz kody tutaj... - - + + Autodetect (recommended) Automatyczne wykrywanie (zalecane) - - + + Select cheats file Wybierz plik z kodami - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. Nie udaÅ‚o siÄ™ dodać niektórych kodów. Upewnij siÄ™, że sÄ… poprawnie sformatowane i/lub wypróbuj inne typy kodów. @@ -398,37 +398,37 @@ Rozmiar pobierania: %3 Przewijanie nie jest obecnie wÅ‚Ä…czone - + Reset the game? Zresetować grÄ™? - + Most games will require a reset to load the new save. Do you want to reset now? WiÄ™kszość gier wymaga zresetowania, aby wczytać nowy zapis. Czy chcesz teraz zresetować? - + Failed to open save file: %1 Nie udaÅ‚o siÄ™ otworzyć pliku zapisu: %1 - + Failed to open game file: %1 Nie udaÅ‚o siÄ™ otworzyć pliku gry: %1 - + Can't yank pack in unexpected platform! Nie można wyciÄ…gnąć pack na nieoczekiwanej platformie! - + Failed to open snapshot file for reading: %1 Nie udaÅ‚o siÄ™ otworzyć pliku snapshot do odczytu: %1 - + Failed to open snapshot file for writing: %1 Nie udaÅ‚o siÄ™ otworzyć pliku snapshot do zapisu: %1 @@ -477,6 +477,14 @@ Rozmiar pobierania: %3 Nie można otworzyć historii CLI do zapisu + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Rozmiar pobierania: %3 Resetuj - + Export frame Eksportuj klatkÄ™ - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) - + None Nic - + Background TÅ‚o - + Window Okno - + Objwin Obiwin - + Sprite Sprite - + Backdrop ZasÅ‚ona - + Frame Klatka - + %1 %2 %1 %2 @@ -818,22 +826,22 @@ Rozmiar pobierania: %3 QGBA::GBAKeyEditor - + Clear Button Wyczyść Przycisk - + Clear Analog Wyczyść Analog - + Refresh OdÅ›wież - + Set all Ustaw wszystko @@ -3006,8 +3014,8 @@ Rozmiar pobierania: %3 QGBA::KeyEditor - - + + --- --- @@ -3378,23 +3386,87 @@ Rozmiar pobierania: %3 Pionowy - - - + + + N/A N/D - + Export map Eksportuj mapÄ™ - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + PrzeglÄ…daj + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + Start + + + + Stop + Stop + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Rozmiar pobierania: %3 OdÅ›wież - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 bajt%2 @@ -3750,17 +3822,17 @@ Rozmiar pobierania: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached Próba odÅ‚Ä…czenia gracza multiplayer, który nie jest doÅ‚Ä…czony - + Trying to get player ID for a multiplayer player that's not attached Próba uzyskania ID gracza w trybie wieloosobowym, który nie jest poÅ‚Ä…czony - + Trying to get save ID for a multiplayer player that's not attached Próba uzyskania identyfikatora zapisu dla gracza multiplayer, który nie jest poÅ‚Ä…czony @@ -4157,35 +4229,35 @@ Rozmiar pobierania: %3 Eksportuj OBI - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette Eksportuj paletÄ™ - + Windows PAL (*.pal);;Adobe Color Table (*.act) Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 Nie udaÅ‚o siÄ™ otworzyć pliku palety wyjÅ›ciowej: %1 @@ -4259,7 +4331,7 @@ Rozmiar pobierania: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Rozmiar pobierania: %3 + Maker Code: + + + + + Revision: + + + + File size: Rozmiar pliku: - + CRC32: CRC32: - + Save file: Zapisz plik: @@ -4364,62 +4446,62 @@ Rozmiar pobierania: %3 QGBA::SaveConverter - + Save games and save states (%1) Zapisane gry i stany zapisu (%1) - + Select save game or save state Wybierz zapis gry lub stan zapisu - + Save games (%1) Zapisane gry (%1) - + Select save game Wybierz zapis gry - + Conversion failed Konwersja nie powiodÅ‚a siÄ™ - + Failed to convert the save game. This is probably a bug. Nie udaÅ‚o siÄ™ przekonwertować zapisanej gry. To prawdopodobnie bÅ‚Ä…d. - + No file selected Nie wybrano pliku - + Could not open file Nie można otworzyć pliku - + No valid formats found Nie znaleziono prawidÅ‚owych formatów - + Please select a valid input file Wybierz prawidÅ‚owy plik wejÅ›ciowy - + No valid conversions found Nie znaleziono prawidÅ‚owych konwersji - + Cannot convert save games between platforms Nie można konwertować zapisanych gier miÄ™dzy platformami @@ -4445,97 +4527,97 @@ Rozmiar pobierania: %3 Plik wyjÅ›ciowy - + %1 %2 save game %1 %2 zapis gry - + little endian little endian - + big endian big endian - + SRAM SRAM - + %1 flash %1 flash - + %1 EEPROM %1 EEPROM - + + RTC + RTC - + %1 SRAM + RTC %1 SRAM + RTC - + %1 SRAM %1 SRAM - + packed MBC2 MBC2 skompresowane - + unpacked MBC2 MBC2 nieskompresowany - + MBC6 flash MBC6 Flash - + MBC6 combined SRAM + flash MBC6 Å‚Ä…czny SRAM + flash - + MBC6 SRAM MBC6 SRAM - + TAMA5 TAMA5 - + %1 (%2) %1 (%2) - + %1 save state with embedded %2 save game %1 stan gry z osadzonym %2 zapisem gry - + %1 SharkPort %2 save game %1 SharkPort %2 zapis gry - + %1 GameShark Advance SP %2 save game %1 GameShark Advance SP %2 zapis gry @@ -4571,32 +4653,37 @@ Rozmiar pobierania: %3 ZaÅ‚aduj ostatni skrypt - + Load script... ZaÅ‚aduj skrypt... - + + &Load most recent + + + + &Reset &Resetuj - + 0 0 - + Select script to load Wybierz skrypt do zaÅ‚adowania - + Lua scripts (*.lua) Skrypty Lua (*.lua) - + All files (*.*) Wszystkie pliki (*.*) @@ -4689,105 +4776,105 @@ Rozmiar pobierania: %3 QGBA::SettingsView - - + + Qt Multimedia Qt Multimedia - + SDL SDL - + Software (Qt) Software (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL (wymuÅ› wersjÄ™ 1.x) - + None Nic - + None (Still Image) Brak (Obraz Nieruchomy) - + Keyboard Klawiatura - + Controllers Kontrolery - + Shortcuts Skróty - - + + Shaders Shadery - + Select BIOS Wybierz BIOS - + Select directory Wybierz katalog - + Select image Wybierz obraz - + Image file (*.png *.jpg *.jpeg) Plik graficzny (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Nigdy - + Just now WÅ‚aÅ›nie teraz - + Less than an hour ago Mniej niż godzinÄ™ temu - + %n hour(s) ago %n godzinÄ™ temu @@ -4796,7 +4883,7 @@ Rozmiar pobierania: %3 - + %n day(s) ago %n dzieÅ„ temu @@ -5124,37 +5211,37 @@ Rozmiar pobierania: %3 Sprawdź teraz - + Default color palette only Tylko domyÅ›lna paleta kolorów - + SGB color palette if available Paleta kolorów SGB, jeÅ›li jest dostÄ™pna - + GBC color palette if available Paleta kolorów GBC, jeÅ›li jest dostÄ™pna - + SGB (preferred) or GBC color palette if available Paleta kolorów SGB (preferowana) lub GBC, jeÅ›li jest dostÄ™pna - + Game Boy Camera Game Boy Camera - + Driver: Sterownik: - + Source: ŹródÅ‚o: @@ -5331,42 +5418,42 @@ Rozmiar pobierania: %3 Dodatkowe dane Å‚adowania stanu gry: - + Models Modele - + GB only: Tylko GB: - + SGB compatible: Kompatybilny z SGB: - + GBC only: Tylko GBC: - + GBC compatible: Kompatybilny z GBC: - + SGB and GBC compatible: Kompatybilny z SGB i GBC: - + Game Boy palette Paleta Game Boy - + Preset: Ustawienie wstÄ™pne: @@ -5403,135 +5490,130 @@ Rozmiar pobierania: %3 Software - + OpenGL enhancements Ulepszenia OpenGL - + High-resolution scale: Skala o wysokiej rozdzielczoÅ›ci: - + (240×160) (240×160) - - XQ GBA audio (experimental) - DźwiÄ™k wysokiej jakoÅ›ci GBA (eksperymentalny) - - - + GB BIOS file: Plik BIOS GB: - - - - - - - - - + + + + + + + + + Browse PrzeglÄ…daj - + Use BIOS file if found Użyj pliku BIOS, jeÅ›li zostanie znaleziony - + Skip BIOS intro PomiÅ„ wprowadzenie BIOS - + GBA BIOS file: Plik BIOS GBA: - + GBC BIOS file: Plik BIOS GBC: - + SGB BIOS file: Plik BIOS SGB: - + Save games Zapisane gry - - - - - + + + + + Same directory as the ROM Ten sam katalog co ROM - + Save states Stany gry - + Screenshots Zrzuty ekranu - + Patches Åatki - + Cheats Kody (cheaty) - + Log to file Loguj do pliku - + Log to console Loguj do konsoli - + Select Log File Wybierz plik dziennika - + Default BG colors: DomyÅ›lne kolory tÅ‚a: - + Default sprite colors 1: DomyÅ›lne kolory sprite'ów 1: - + Default sprite colors 2: DomyÅ›lne kolory sprite'ów 2: - + Super Game Boy borders Ramki Super Game Boy @@ -5789,13 +5871,11 @@ Rozmiar pobierania: %3 - WebM WebM - MP4 MP4 @@ -5834,82 +5914,6 @@ Rozmiar pobierania: %3 Format Format - - - MKV - MKV - - - - AVI - AVI - - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - Nic - - - - FLAC - FLAC - - - - WavPack - WavPack - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - Nieskompresowany - Bitrate (kbps) @@ -5920,16 +5924,6 @@ Rozmiar pobierania: %3 ABR ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5959,80 +5953,80 @@ Rozmiar pobierania: %3 QGBA::Window - + Archives (%1) Archiwa (%1) - - + + Select ROM Wybierz ROM - + Select folder Wybierz katalog - - + + Select save Wybierz zapis - + Select patch Wybierz Å‚atkÄ™ - + Patches (*.ips *.ups *.bps) Åatki (*.ips *.ups *.bps) - + Select e-Reader dotcode Wybierz kod kropki e-Reader - + e-Reader card (*.raw *.bin *.bmp) Karta e-Reader (*.raw *.bin *.bmp) - + Select image Wybierz obraz - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Plik obrazu (*.png *.gif *.jpg *.jpeg);;Wszystkie pliki (*) - + GameShark saves (*.sps *.xps) Zapisy GameShark (*.sps *.xps) - + Select video log Wybierz dziennik wideo - + Video logs (*.mvl) Dzienniki wideo (*.mvl) - + Crash Crash - + The game has crashed with the following error: %1 @@ -6041,699 +6035,709 @@ Rozmiar pobierania: %3 %1 - + Couldn't Start Nie udaÅ‚o siÄ™ uruchomić - + Could not start game. Nie udaÅ‚o siÄ™ rozpocząć gry. - + Unimplemented BIOS call Niewdrożone wywoÅ‚anie BIOS - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Ta gra używa wywoÅ‚ania BIOS, które nie jest zaimplementowane. Aby uzyskać najlepsze wrażenia, użyj oficjalnego BIOS. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Nie udaÅ‚o siÄ™ utworzyć odpowiedniego urzÄ…dzenia wyÅ›wietlajÄ…cego, powracam do wyÅ›wietlania programowego. Gry mogÄ… dziaÅ‚ać wolno, zwÅ‚aszcza w przypadku wiÄ™kszych okien. - + Really make portable? NaprawdÄ™ stworzyć wersjÄ™ portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? To sprawi, że emulator zaÅ‚aduje swojÄ… konfiguracjÄ™ z tego samego katalogu, co plik wykonywalny. Czy chcesz kontynuować? - + Restart needed Wymagane ponowne uruchomienie - + Some changes will not take effect until the emulator is restarted. Niektóre zmiany nie zacznÄ… obowiÄ…zywać, dopóki emulator nie zostanie ponownie uruchomiony. - + - Player %1 of %2 - Gracz %1 z %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 FPS) - %4 - + &File &Plik - + Load &ROM... ZaÅ‚aduj &ROM... - + Load ROM in archive... ZaÅ‚aduj ROM w archiwum... - + Add folder to library... Dodaj folder do biblioteki... - + Save games (%1) Zapisane gry (%1) - + Select save game Wybierz zapis gry - + mGBA save state files (%1) Pliki stanu gry mGBA (%1) - - + + Select save state Wybierz stan - + Select e-Reader card images Wybierz obrazy kart e-Reader - + Image file (*.png *.jpg *.jpeg) Plik graficzny (*.png *.jpg *.jpeg) - + Conversion finished Konwersja zakoÅ„czona - + %1 of %2 e-Reader cards converted successfully. %1 z %2 kart czytnika e-Reader zostaÅ‚o pomyÅ›lnie przekonwertowanych. - + Load alternate save game... ZaÅ‚aduj alternatywny zapis gry... - + Load temporary save game... ZaÅ‚aduj tymczasowy zapis gry... - + Load &patch... Wczytaj &poprawkÄ™... - + Boot BIOS BIOS startowy - + Replace ROM... WymieÅ„ ROM... - + Scan e-Reader dotcodes... Skanuj kody kropkowe czytnika e-Reader... - + Convert e-Reader card image to raw... Konwertuj obraz karty czytnika e-Reader na surowy... - + ROM &info... &Informacje o pamiÄ™ci ROM... - + Recent Ostatnie - + Make portable Stwórz wersjÄ™ portable - + &Load state &ZaÅ‚aduj stan - + Load state file... ZaÅ‚aduj plik stanu… - + &Save state &Zapisz stan - + Save state file... Zapisz plik stanu... - + Quick load Szybkie zaÅ‚adowanie - + Quick save Szybki zapis - + Load recent ZaÅ‚aduj ostatnie - + Save recent Zapisz ostatnie - + Undo load state Cofnij zaÅ‚adowanie stanu - + Undo save state Cofnij zapisanie stanu - - + + State &%1 Stan &%1 - + Load camera image... ZaÅ‚aduj obraz do kamery... - + Convert save game... Konwertuj zapisanÄ… grÄ™... - + GameShark saves (*.gsv *.sps *.xps) Zapisy GameShark (*.gsv *.sps *.xps) - + Reset needed Wymagane zresetowanie - + Some changes will not take effect until the game is reset. Niektóre zmiany nie zacznÄ… obowiÄ…zywać, dopóki gra nie zostanie zresetowana. - + Save games Zapisy gry - + Import GameShark Save... Importuj Zapis GameShark... - + Export GameShark Save... Eksportuj Zapis GameShark... - + Automatically determine Wykryj automatycznie - + Use player %0 save game Użyj zapis gry gracza %0 - + New multiplayer window Nowe okno dla wielu graczy - + Connect to Dolphin... PoÅ‚Ä…cz z Dolphinem... - + Report bug... ZgÅ‚oÅ› bÅ‚Ä…d... - + About... O Aplikacji... - + E&xit Z&akoÅ„cz - + &Emulation &Emulacja - + &Reset &Resetuj - + Sh&utdown Za&mknij - + Yank game pak WyciÄ…gnij Game Pak - + &Pause &Pauza - + &Next frame &NastÄ™pna klatka - + Fast forward (held) Przewijanie (przytrzymaj) - + &Fast forward &Przewijanie do przodu - + Fast forward speed PrÄ™dkość przewijania do przodu - + Unbounded Bez ograniczeÅ„ - + %0x %0x - + Increase fast forward speed ZwiÄ™kszenie prÄ™dkoÅ›ci przewijania do przodu - + Decrease fast forward speed Zmiejszenie prÄ™dkoÅ›ci przewijania do przodu - + Rewind (held) Przewijanie (przytrzymaj) - + Re&wind Pr&zewijanie - + Step backwards Krok w tyÅ‚ - + Solar sensor Czujnik sÅ‚oneczny - + Increase solar level ZwiÄ™ksz poziom energii sÅ‚onecznej - + Decrease solar level Zmniejsz poziom energii sÅ‚onecznej - + Brightest solar level NajjaÅ›niejszy poziom energii sÅ‚onecznej - + Darkest solar level Najciemniejszy poziom energii sÅ‚onecznej - + Brightness %1 Jasność %1 - + Game Boy Printer... Game Boy Printer... - + BattleChip Gate... BattleChip Gate... - + Audio/&Video DźwiÄ™k/&Wideo - + Frame size Rozmiar klatki - + %1× %1× - + Toggle fullscreen PrzeÅ‚Ä…cz tryb peÅ‚noekranowy - + + &Lock frame size + + + + Lock aspect ratio Zablokuj proporcje - + Force integer scaling WymuÅ› skalowanie caÅ‚kowite - + Interframe blending Blendowanie miÄ™dzyklatkowe - + Bilinear filtering Filtrowanie dwuliniowe - + Frame&skip Klatko&wanie - + Mute Wycisz - + FPS target Cel KL./S - + Native (59.7275) Natywny (59.7275) - + Take &screenshot Wykonaj &zrzut ekranu - + F12 F12 - + Record A/V... Nagraj A/W... - + Record GIF/WebP/APNG... Nagraj GIF/WebP/APNG... - + Video layers Warstwy wideo - + Audio channels KanaÅ‚y audio - + Adjust layer placement... Dostosuj poÅ‚ożenie warstw... - + &Tools &NarzÄ™dzia - + View &logs... WyÅ›wietl &logi... - + Game &overrides... Nadpisania &ustawieÅ„ gry... - + Game Pak sensors... Czujniki Game Pak... - + &Cheats... &Kody... - + Create forwarder... Utwórz forwarder... - + Settings... Ustawienia... - + Open debugger console... Otwórz konsolÄ™ debugera... - + Start &GDB server... Uruchom serwer &GDB... - + Scripting... Skrypty... - + Game state views Widoki stanu gry - + View &palette... WyÅ›wietl &paletÄ™... - + View &sprites... WyÅ›wietl &sprite'y... - + View &tiles... WyÅ›wietl &kafelki... - + View &map... WyÅ›wietl &mapÄ™... - + &Frame inspector... Inspektor &klatek... - + View memory... WyÅ›wietl pamięć... - + Search memory... Przeszukaj pamięć... - + View &I/O registers... WyÅ›wietl rejestry &we/wy... - + + Log memory &accesses... + + + + Record debug video log... Nagraj dziennik wideo debugowania... - + Stop debug video log Zatrzymaj dziennik wideo debugowania - + Exit fullscreen WyÅ‚Ä…czyć tryb peÅ‚noekranowy - + GameShark Button (held) Przycisk GameShark (przytrzymany) - + Autofire Turbo - + Autofire A Turbo A - + Autofire B Turbo B - + Autofire L Turbo L - + Autofire R Turbo R - + Autofire Start Turbo Start - + Autofire Select Turbo Select - + Autofire Up Turbo Góra - + Autofire Right Turbo Prawo - + Autofire Down Turbo Dół - + Autofire Left Turbo Lewo - + Clear Wyczyść @@ -6771,17 +6775,17 @@ Rozmiar pobierania: %3 ? - + Super (L) Super (L) - + Super (R) Super (R) - + Menu Menu @@ -6789,22 +6793,22 @@ Rozmiar pobierania: %3 QShortcut - + Shift Shift - + Control Control - + Alt Alt - + Meta Meta diff --git a/src/platform/qt/ts/mgba-pt_BR.ts b/src/platform/qt/ts/mgba-pt_BR.ts index 77573eb1ba2..5b8c0df522d 100644 --- a/src/platform/qt/ts/mgba-pt_BR.ts +++ b/src/platform/qt/ts/mgba-pt_BR.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) ROMs do Game Boy Advance (%1) - + Game Boy ROMs (%1) ROMs do Game Boy (%1) - + All ROMs (%1) Todas as ROMs (%1) - + %1 Video Logs (*.mvl) %1 Registros do Vídeo (*.mvl) @@ -191,17 +191,17 @@ Tamanho do download: %3 QGBA::AudioDevice - + Can't set format of context-less audio device Não pôde definir o formato do dispositivo de áudio sem contexto - + Audio device is missing its core O núcleo do dispositivo de áudio está ausente - + Writing data to read-only audio device Gravando dados no dispositivo somente-leitura do áudio @@ -209,7 +209,7 @@ Tamanho do download: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input Não pôde iniciar um processador de áudio sem entrada @@ -285,28 +285,28 @@ Tamanho do download: %3 Mostrar as opções avançadas - + BattleChip data missing Dados do BattleChip ausentes - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? Os dados do BattleChip estão ausente. Os Portais do BattleChip Gates ainda funcionarão mas alguns gráficos estarão ausentes. Você gostaria de baixar os dados agora? - - + + Select deck file Selecionar o arquivo do deck - + Incompatible deck Deck incompatível - + The selected deck is not compatible with this Chip Gate O deck selecionado não é compatível com este Portal do Chip @@ -367,19 +367,19 @@ Tamanho do download: %3 Insira os códigos aqui... - - + + Autodetect (recommended) Auto-detectar (recomendado) - - + + Select cheats file Selecionar o arquivo das trapaças - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. Algumas trapaças não puderam ser adicionadas. Por favor tenha certeza que eles estão formatadas corretamente e/ou tente outros tipos de trapaça. @@ -398,37 +398,37 @@ Tamanho do download: %3 O rebobinamento não está ativado atualmente - + Reset the game? Resetar o jogo? - + Most games will require a reset to load the new save. Do you want to reset now? A maioria dos jogos requerirão um reset pra carregar o novo save. Você quer resetar agora? - + Failed to open save file: %1 Falhou em abrir o arquivo do save: %1 - + Failed to open game file: %1 Falhou em abrir o arquivo do jogo: %1 - + Can't yank pack in unexpected platform! Não pode arrancar o pacote numa plataforma inesperada! - + Failed to open snapshot file for reading: %1 Falhou em abrir o arquivo do snapshot pra leitura: %1 - + Failed to open snapshot file for writing: %1 Falhou em abrir o arquivo do snapshot pra gravação: %1 @@ -477,6 +477,14 @@ Tamanho do download: %3 Não pôde abrir o histórico do CLI pra gravar + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Tamanho do download: %3 Resetar - + Export frame Exportar frame - + Portable Network Graphics (*.png) Gráficos Portáteis da Rede (*.png) - + None Nenhum - + Background 2º plano - + Window Janela - + Objwin Objwin - + Sprite Imagem Móvel - + Backdrop 2º Plano - + Frame Frame - + %1 %2 %1 %2 @@ -818,22 +826,22 @@ Tamanho do download: %3 QGBA::GBAKeyEditor - + Clear Button Limpar Botão - + Clear Analog Limpar Analógico - + Refresh Atualizar - + Set all Definir todos @@ -3006,8 +3014,8 @@ Tamanho do download: %3 QGBA::KeyEditor - - + + --- --- @@ -3378,23 +3386,87 @@ Tamanho do download: %3 Vertical - - - + + + N/A N/D - + Export map Exportar mapa - + Portable Network Graphics (*.png) Gráficos Portáteis da Rede (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + Explorar + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + Parar + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Tamanho do download: %3 Atualizar - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 byte%2 @@ -3750,17 +3822,17 @@ Tamanho do download: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached Tentando desconectar um jogador multiplayer que não está conectado - + Trying to get player ID for a multiplayer player that's not attached Tentando obter a ID do jogador pra um jogador multiplayer que não está conectado - + Trying to get save ID for a multiplayer player that's not attached Tentando obter a ID salva pra um jogador multiplayer que não está conectado @@ -4157,35 +4229,35 @@ Tamanho do download: %3 Exportar OBJ - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette Exportar paleta - + Windows PAL (*.pal);;Adobe Color Table (*.act) Windows PAL (*.pal);;Tabela de Cores da Adobe (*.act) - + Failed to open output palette file: %1 Falhou em abrir o arquivo de saída da paleta: %1 @@ -4259,7 +4331,7 @@ Tamanho do download: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Tamanho do download: %3 + Maker Code: + + + + + Revision: + + + + File size: Tamanho do arquivo: - + CRC32: CRC32: - + Save file: Arquivo do save: @@ -4364,62 +4446,62 @@ Tamanho do download: %3 QGBA::SaveConverter - + Save games and save states (%1) Saves dos jogos e save states (%1) - + Select save game or save state Selecione o save do jogo ou save state - + Save games (%1) Saves dos jogos (%1) - + Select save game Selecione o save do jogo - + Conversion failed A conversão falhou - + Failed to convert the save game. This is probably a bug. Falhou em converter o save do jogo. Isto é provavelmente um bug. - + No file selected Nenhum arquivo selecionado - + Could not open file Não pôde abrir o arquivo - + No valid formats found Não foram encontrados formatos válidos - + Please select a valid input file Por favor selecione um arquivo de entrada válido - + No valid conversions found Não foram encontradas conversões válidas - + Cannot convert save games between platforms Não pôde converter os saves do jogo entre as plataformas @@ -4445,97 +4527,97 @@ Tamanho do download: %3 Arquivo de saída - + %1 %2 save game %1 %2 save do jogo - + little endian little endian - + big endian big endian - + SRAM SRAM - + %1 flash %1 flash - + %1 EEPROM %1 EEPROM - + + RTC + RTC - + %1 SRAM + RTC %1 SRAM + RTC - + %1 SRAM %1 SRAM - + packed MBC2 Empacotou o MBC2 - + unpacked MBC2 Desempacotou o MBC2 - + MBC6 flash Flash do MBC6 - + MBC6 combined SRAM + flash MBC6 SRAM combinado + flash - + MBC6 SRAM SRAM do MBC6 - + TAMA5 TAMA5 - + %1 (%2) %1 (%2) - + %1 save state with embedded %2 save game %1 save state com %2 saves do jogo embutido - + %1 SharkPort %2 save game %1 SharkPort %2 save do jogo - + %1 GameShark Advance SP %2 save game %1 GameShark Advance SP %2 save do jogo @@ -4571,32 +4653,37 @@ Tamanho do download: %3 Carregar script recente - + Load script... Carregar script... - + + &Load most recent + + + + &Reset &Resetar - + 0 0 - + Select script to load Selecione o script a carregar - + Lua scripts (*.lua) Scripts do lua (*.lua) - + All files (*.*) Todos os arquivos (*.*) @@ -4689,119 +4776,117 @@ Tamanho do download: %3 QGBA::SettingsView - - + + Qt Multimedia Multimídia do Qt - + SDL SDL - + Software (Qt) Software (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL (forçar a versão 1.x) - + None Nenhum - + None (Still Image) Nenhum (Imagem Parada) - + Keyboard Teclado - + Controllers Controles - + Shortcuts Atalhos - - + + Shaders Shaders - + Select BIOS Selecionar BIOS - + Select directory Selecione o diretório - + Select image Selecionar imagem - + Image file (*.png *.jpg *.jpeg) Arquivo da imagem (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Nunca - + Just now Aconteceu agora - + Less than an hour ago Menos do que uma hora atrás - + %n hour(s) ago %n hora atrás %n horas atrás - - + %n day(s) ago %n dia atrás %n dias atrás - @@ -5139,37 +5224,37 @@ Tamanho do download: %3 Velocidade do retrocesso: - + Default color palette only Só a cor padrão da paleta - + SGB color palette if available Paleta das cores do SGB se disponível - + GBC color palette if available Paleta das cores do GBC se disponível - + SGB (preferred) or GBC color palette if available SGB (preferido) ou paleta das cores do GBC se disponível - + Game Boy Camera Câmera do Game Boy - + Driver: Driver: - + Source: Fonte: @@ -5215,7 +5300,7 @@ Tamanho do download: %3 Ativar compatibilidade dos bugs do VBA nos hacks das ROMs - + Preset: Pré-definições: @@ -5230,22 +5315,22 @@ Tamanho do download: %3 Velocidade do avanço rápido (pressionado): - + (240×160) (240×160) - + Log to file Registrar no arquivo - + Log to console Registrar no console - + Select Log File Selecionar Arquivo do Registro @@ -5383,61 +5468,56 @@ Tamanho do download: %3 Software - + OpenGL enhancements Melhorias do OpenGL - + High-resolution scale: Escala de alta-resolução: - - XQ GBA audio (experimental) - Ãudio do XQ GBA (experimental) - - - + GB BIOS file: Arquivo da BIOS do GB: - - - - - - - - - + + + + + + + + + Browse Explorar - + Use BIOS file if found Usar o arquivo da BIOS se encontrado - + Skip BIOS intro Ignorar a introdução da BIOS - + GBA BIOS file: Arquivo da BIOS do GBA: - + GBC BIOS file: Arquivo da BIOS do GBC: - + SGB BIOS file: Arquivo da BIOS do SGB: @@ -5447,91 +5527,91 @@ Tamanho do download: %3 Auto-salvar o state periodicamente - + Save games Saves dos jogos - - - - - + + + + + Same directory as the ROM O mesmo diretório que a ROM - + Save states Save states - + Screenshots Screenshots - + Patches Patches - + Cheats Trapaças - + Models Modelos - + GB only: Só pro GB: - + SGB compatible: Compatível com o SGB: - + GBC only: Só pro GBC: - + GBC compatible: Compatível com o GBC: - + SGB and GBC compatible: Compatível com o SGB e o GBC: - + Game Boy palette Paleta do Game Boy - + Default BG colors: Cores padrão do 2º plano: - + Super Game Boy borders Bordas do Super Game Boy - + Default sprite colors 1: Cores padrão da imagem móvel 1: - + Default sprite colors 2: Cores padrão da imagem móvel 2: @@ -5779,7 +5859,6 @@ Tamanho do download: %3 - WebM WebM @@ -5788,19 +5867,8 @@ Tamanho do download: %3 Format Formato - - - MKV - MKV - - - - AVI - AVI - - MP4 MP4 @@ -5844,72 +5912,6 @@ Tamanho do download: %3 &Native &Nativo - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - Nenhum - - - - FLAC - FLAC - - - - WavPack - WavPack - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - Descomprimido - Bitrate (kbps) @@ -5920,16 +5922,6 @@ Tamanho do download: %3 ABR ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5959,80 +5951,80 @@ Tamanho do download: %3 QGBA::Window - + Archives (%1) Arquivos Compactados (%1) - - + + Select ROM Selecionar ROM - + Select folder Selecionar pasta - - + + Select save Selecionar save - + Select patch Selecionar patch - + Patches (*.ips *.ups *.bps) Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode Selecionar dotcode do e-Reader - + e-Reader card (*.raw *.bin *.bmp) Cartão do e-Reader (*.raw *.bin *.bmp) - + Select image Selecionar imagem - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Arquivo de imagem (*.png *.gif *.jpg *.jpeg);;Todos os arquivos (*) - + GameShark saves (*.sps *.xps) Saves do GameShark (*.sps *.xps) - + Select video log Selecionar registro do vídeo - + Video logs (*.mvl) Registros do vídeo (*.mvl) - + Crash Crash - + The game has crashed with the following error: %1 @@ -6041,699 +6033,709 @@ Tamanho do download: %3 %1 - + Unimplemented BIOS call Chamada da BIOS não implementada - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Este jogo usa uma chamada de BIOS que não está implementada. Por favor use a BIOS oficial pra uma melhor experiência. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Falhou em criar um dispositivo de exibição apropriado, voltando a exibição por software. Os jogos podem executar lentamente, especialmente com janelas maiores. - + Really make portable? Realmente tornar portátil? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Isto fará o emulador carregar sua configuração do mesmo diretório que o executável. Você quer continuar? - + Restart needed Reiniciar é necessário - + Some changes will not take effect until the emulator is restarted. Algumas mudanças não terão efeito até o emulador ser reiniciado. - + - Player %1 of %2 - Jogador %1 de %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &Arquivo - + Load &ROM... Carregar &ROM... - + Load ROM in archive... Carregar ROM no arquivo compactado... - + Add folder to library... Adicionar pasta a biblioteca... - + Save games Saves dos jogos - + Automatically determine Determinar automaticamente - + Use player %0 save game Usar o save do jogo %0 do jogador - + Load &patch... Carregar &patch... - + Boot BIOS Dar Boot na BIOS - + Replace ROM... Substituir a ROM... - + ROM &info... Informações da &ROM... - + Recent Recentes - + Make portable Tornar portátil - + &Load state &Carregar state - + Report bug... Reportar bug... - + About... Sobre... - + Game Pak sensors... Sensores do Game Pak... - + Clear Limpar - + Load state file... Carregar arquivo do state... - + Save games (%1) Saves dos jogos (%1) - + Select save game Selecione save do jogo - + mGBA save state files (%1) Arquivos do save state do mGBA (%1) - - + + Select save state Selecione um save state - + Select e-Reader card images Selecionar imagens do cartão do e-Reader - + Image file (*.png *.jpg *.jpeg) Arquivo da imagem (*.png *.jpg *.jpeg) - + Conversion finished Conversão concluída - + %1 of %2 e-Reader cards converted successfully. %1 de %2 cartões do e-Reader convertidos com sucesso. - + Load alternate save game... Carregar save alternativo do jogo... - + Load temporary save game... Carregar save temporário do jogo... - + Convert e-Reader card image to raw... Converter imagem do cartão do e-Reader pro natural... - + &Save state &Salvar o state - + Save state file... Arquivo do save state... - + Quick load Carregamento rápido - + Quick save Salvamento rápido - + Load recent Carregar recentes - + Save recent Salvar recentes - + Undo load state Desfazer o carregamento do state - + Undo save state Desfazer o save state - - + + State &%1 State &%1 - + Load camera image... Carregar a imagem da câmera... - + Convert save game... Converter o save do jogo... - + GameShark saves (*.gsv *.sps *.xps) Saves do GameShark (*.gsv *.sps *.xps) - + Reset needed É necessário resetar - + Some changes will not take effect until the game is reset. Algumas mudanças não terão efeito até o jogo ser resetado. - + New multiplayer window Nova janela multi-jogador - + Connect to Dolphin... Conectar ao Dolphin... - + E&xit S&air - + &Emulation &Emulação - + &Reset &Resetar - + Sh&utdown De&sligar - + Yank game pak Arrancar o game pak - + &Pause &Pausar - + &Next frame &Próximo frame - + Fast forward (held) Avanço rápido (segurado) - + &Fast forward &Avanço rápido - + Fast forward speed Velocidade do avanço rápido - + Unbounded Ilimitado - + %0x %0x - + Increase fast forward speed Aumentar a velocidade do avanço rápido - + Decrease fast forward speed Diminuir a velocidade do avanço rápido - + Rewind (held) Retroceder (segurado) - + Re&wind Re&troceder - + Step backwards Voltar um passo - + Solar sensor Sensor solar - + Increase solar level Aumentar nível solar - + Decrease solar level Diminuir nível solar - + Brightest solar level Nível solar mais brilhante - + Darkest solar level Nível solar mais escuro - + Brightness %1 Brilho %1 - + Audio/&Video Ãudio/&Vídeo - + Frame size Tamanho do frame - + Toggle fullscreen Alternar tela cheia - + + &Lock frame size + + + + Lock aspect ratio Travar a proporção do aspecto - + Force integer scaling Forçar o dimensionamento do inteiro - + Bilinear filtering Filtragem bilinear - + Frame&skip Frame&skip - + Mute Mudo - + FPS target FPS alvo - + Native (59.7275) Nativo (59,7275) - + Take &screenshot Tirar &screenshot - + F12 F12 - + Game Boy Printer... Impressora do Game Boy... - + BattleChip Gate... Portal do BattleChip... - + %1× %1× - + Interframe blending Mistura do interframe - + Record A/V... Gravar A/V... - + Video layers Camadas do vídeo - + Audio channels Canais de áudio - + Adjust layer placement... Ajustar posicionamento da camada... - + &Tools &Ferramentas - + View &logs... Visualizar &registros... - + Game &overrides... Substituições &do jogo... - + Couldn't Start Não Pôde Iniciar - + Could not start game. Não pôde iniciar o jogo. - + Scan e-Reader dotcodes... Escanear dotcodes do e-Reader... - + Import GameShark Save... Importar Save do GameShark... - + Export GameShark Save... Exportar Save do GameShark... - + Record GIF/WebP/APNG... Gravar GIF/WebP/APNG... - + &Cheats... &Trapaças... - + Settings... Configurações... - + Open debugger console... Abrir console do debugger... - + Start &GDB server... Iniciar servidor do &GDB... - + Scripting... Scripting... - + Create forwarder... Criar encaminhador... - + Game state views Visualizações do estado do jogo - + View &palette... Visualizar &paleta... - + View &sprites... Visualizar &imagens móveis... - + View &tiles... Visualizar &mosaicos... - + View &map... Visualizar &mapa... - + &Frame inspector... Inspetor dos &frames... - + View memory... Visualizar memória... - + Search memory... Procurar na memória... - + View &I/O registers... Visualizar registros de &E/S... - + + Log memory &accesses... + + + + Record debug video log... Gravar registro do vídeo de debug... - + Stop debug video log Parar o registro do vídeo de debug - + Exit fullscreen Sair da tela cheia - + GameShark Button (held) Botão do GameShark (segurado) - + Autofire Auto-disparar - + Autofire A Auto-disparar A - + Autofire B Auto-disparar B - + Autofire L Auto-disparar L - + Autofire R Auto-disparar R - + Autofire Start Auto-disparar Start - + Autofire Select Auto-disparar Select - + Autofire Up Auto-disparar Pra Cima - + Autofire Right Auto-disparar Direita - + Autofire Down Auto-disparar Pra Baixo - + Autofire Left Auto-disparar Esquerda @@ -6771,17 +6773,17 @@ Tamanho do download: %3 ? - + Super (L) Super (E) - + Super (R) Super (D) - + Menu Menu @@ -6789,22 +6791,22 @@ Tamanho do download: %3 QShortcut - + Shift Shift - + Control Control - + Alt Alt - + Meta Meta diff --git a/src/platform/qt/ts/mgba-pt_PT.ts b/src/platform/qt/ts/mgba-pt_PT.ts index f3aa6bdc197..f6c819d37d5 100644 --- a/src/platform/qt/ts/mgba-pt_PT.ts +++ b/src/platform/qt/ts/mgba-pt_PT.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) ROMs do Game Boy Advance (%1) - + Game Boy ROMs (%1) ROMs do Game Boy (%1) - + All ROMs (%1) Todas as ROMs (%1) - + %1 Video Logs (*.mvl) %1 Registos do Vídeo (*.mvl) @@ -191,17 +191,17 @@ Tamanho da descarga: %3 QGBA::AudioDevice - + Can't set format of context-less audio device Não pôde definir o formato do aparelho de áudio sem contexto - + Audio device is missing its core O núcleo do aparelho de áudio está ausente - + Writing data to read-only audio device Gravando dados no aparelho somente-leitura do áudio @@ -209,7 +209,7 @@ Tamanho da descarga: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input Não pôde iniciar um processador de áudio sem entrada @@ -285,28 +285,28 @@ Tamanho da descarga: %3 Mostrar as opções avançadas - + BattleChip data missing Portal do BattleChip - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? Os dados do BattleChip estão ausentes. O BattleChip Gates ainda funcionará, mas alguns gráficos estarão ausentes. Gostaria de descarregar os dados agora? - - + + Select deck file Selecionar o ficheiro do deck - + Incompatible deck Deck incompatível - + The selected deck is not compatible with this Chip Gate O deck selecionado não é compatível com este Portal do Chip @@ -367,19 +367,19 @@ Tamanho da descarga: %3 Insira os códigos aqui... - - + + Autodetect (recommended) Auto-detetar (recomendado) - - + + Select cheats file Selecionar o ficheiro das trapaças - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. Algumas trapaças não puderam ser adicionadas. Por favor tenha certeza que eles estão formatadas corretamente e/ou tente outros tipos de trapaça. @@ -398,37 +398,37 @@ Tamanho da descarga: %3 O rebobinamento não está ativado atualmente - + Reset the game? Resetar o jogo? - + Most games will require a reset to load the new save. Do you want to reset now? A maioria dos jogos requerirão um reset para carregar o novo save. Quer resetar agora? - + Failed to open save file: %1 Falha ao abrir o ficheiro dde gravação: %1 - + Failed to open game file: %1 Falha ao abrir o ficheiro do jogo: %1 - + Can't yank pack in unexpected platform! Não pode arrancar o pacote numa plataforma inesperada! - + Failed to open snapshot file for reading: %1 Falha ao abrir o ficheiro do snapshot para leitura: %1 - + Failed to open snapshot file for writing: %1 Falha ao abrir o ficheiro do snapshot para gravação: %1 @@ -477,6 +477,14 @@ Tamanho da descarga: %3 Não pôde abrir o histórico do CLI para gravar + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Tamanho da descarga: %3 Resetar - + Export frame Exportar frame - + Portable Network Graphics (*.png) Gráficos Portáteis da Rede (*.png) - + None Nenhum - + Background 2º plano - + Window Janela - + Objwin Objwin - + Sprite Imagem Móvel - + Backdrop 2º Plano - + Frame Frame - + %1 %2 %1 %2 @@ -818,22 +826,22 @@ Tamanho da descarga: %3 QGBA::GBAKeyEditor - + Clear Button Limpar Botão - + Clear Analog Limpar Analógico - + Refresh Atualizar - + Set all Definir todos @@ -3006,8 +3014,8 @@ Tamanho da descarga: %3 QGBA::KeyEditor - - + + --- --- @@ -3378,23 +3386,87 @@ Tamanho da descarga: %3 Vertical - - - + + + N/A N/D - + Export map Exportar mapa - + Portable Network Graphics (*.png) Gráficos Portáteis da Rede (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + Explorar + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + Parar + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Tamanho da descarga: %3 Atualizar - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 byte%2 @@ -3750,17 +3822,17 @@ Tamanho da descarga: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached A tentar desconectar um jogador multiplayer que não está conectado - + Trying to get player ID for a multiplayer player that's not attached A tentar obter a ID do jogador para um jogador multiplayer que não está conectado - + Trying to get save ID for a multiplayer player that's not attached A tentar obter a ID gravada para um jogador multiplayer que não está conectado @@ -4157,35 +4229,35 @@ Tamanho da descarga: %3 Exportar OBJ - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette Exportar paleta - + Windows PAL (*.pal);;Adobe Color Table (*.act) Windows PAL (*.pal);;Tabela de Cores da Adobe (*.act) - + Failed to open output palette file: %1 Falha ao abrir o ficheiro de saída da paleta: %1 @@ -4259,7 +4331,7 @@ Tamanho da descarga: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Tamanho da descarga: %3 + Maker Code: + + + + + Revision: + + + + File size: Tamanho do ficheiro: - + CRC32: CRC32: - + Save file: Ficheiro do save: @@ -4364,62 +4446,62 @@ Tamanho da descarga: %3 QGBA::SaveConverter - + Save games and save states (%1) Saves dos jogos e save states (%1) - + Select save game or save state Selecione o save do jogo ou save state - + Save games (%1) Saves dos jogos (%1) - + Select save game Selecione o save do jogo - + Conversion failed A conversão falhou - + Failed to convert the save game. This is probably a bug. Falhou em converter o save do jogo. Isto é provavelmente um bug. - + No file selected Nenhum ficheiro selecionado - + Could not open file Não pôde abrir o ficheiro - + No valid formats found Não foram encontrados formatos válidos - + Please select a valid input file Por favor selecione um ficheiro de entrada válido - + No valid conversions found Não foram encontradas conversões válidas - + Cannot convert save games between platforms Não pôde converter os saves do jogo entre as plataformas @@ -4445,97 +4527,97 @@ Tamanho da descarga: %3 Ficheiro de saída - + %1 %2 save game %1 %2 save do jogo - + little endian little endian - + big endian big endian - + SRAM SRAM - + %1 flash %1 flash - + %1 EEPROM %1 EEPROM - + + RTC + RTC - + %1 SRAM + RTC %1 SRAM + RTC - + %1 SRAM %1 SRAM - + packed MBC2 empacotou o MBC2 - + unpacked MBC2 desempacotou o MBC2 - + MBC6 flash Flash do MBC6 - + MBC6 combined SRAM + flash MBC6 SRAM combinado + flash - + MBC6 SRAM SRAM do MBC6 - + TAMA5 TAMA5 - + %1 (%2) %1 (%2) - + %1 save state with embedded %2 save game %1 save state com %2 saves do jogo embutido - + %1 SharkPort %2 save game %1 SharkPort %2 save do jogo - + %1 GameShark Advance SP %2 save game %1 GameShark Advance SP %2 save do jogo @@ -4571,32 +4653,37 @@ Tamanho da descarga: %3 Carregar script recente - + Load script... Carregar script... - + + &Load most recent + + + + &Reset &Resetar - + 0 0 - + Select script to load Selecione o script a carregar - + Lua scripts (*.lua) Scripts do lua (*.lua) - + All files (*.*) Todos os ficheiros (*.*) @@ -4689,119 +4776,117 @@ Tamanho da descarga: %3 QGBA::SettingsView - - + + Qt Multimedia Multimídia do Qt - + SDL SDL - + Software (Qt) Software (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL (forçar a versão 1.x) - + None Nenhum - + None (Still Image) Nenhum (Imagem Parada) - + Keyboard Teclado - + Controllers Controles - + Shortcuts Atalhos - - + + Shaders Shaders - + Select BIOS Selecionar BIOS - + Select directory Selecione o diretório - + Select image Selecionar imagem - + Image file (*.png *.jpg *.jpeg) Ficheiro da imagem (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Nunca - + Just now Aconteceu agora - + Less than an hour ago Menos do que uma hora atrás - + %n hour(s) ago %n hora atrás %n horas atrás - %n horas atrás - + %n day(s) ago %n dia atrás %n dias atrás - %n dias atrás @@ -5124,37 +5209,37 @@ Tamanho da descarga: %3 Verificar agora - + Default color palette only Só a cor padrão da paleta - + SGB color palette if available Paleta das cores do SGB se disponível - + GBC color palette if available Paleta das cores do GBC se disponível - + SGB (preferred) or GBC color palette if available SGB (preferido) ou paleta das cores do GBC se disponível - + Game Boy Camera Câmara do Game Boy - + Driver: Driver: - + Source: Fonte: @@ -5331,42 +5416,42 @@ Tamanho da descarga: %3 Carregar dados extras do state: - + Models Modelos - + GB only: Só para o GB: - + SGB compatible: Compatível com o SGB: - + GBC only: Só para o GBC: - + GBC compatible: Compatível com o GBC: - + SGB and GBC compatible: Compatível com o SGB e o GBC: - + Game Boy palette Paleta do Game Boy - + Preset: Pré-definições: @@ -5403,135 +5488,130 @@ Tamanho da descarga: %3 Software - + OpenGL enhancements Melhorias do OpenGL - + High-resolution scale: Escala de alta-resolução: - + (240×160) (240×160) - - XQ GBA audio (experimental) - Ãudio do XQ GBA (experimental) - - - + GB BIOS file: Ficheiro da BIOS do GB: - - - - - - - - - + + + + + + + + + Browse Explorar - + Use BIOS file if found Usar o ficheiro da BIOS se encontrado - + Skip BIOS intro Ignorar a introdução da BIOS - + GBA BIOS file: Ficheiro da BIOS do GBA: - + GBC BIOS file: Ficheiro da BIOS do GBC: - + SGB BIOS file: Ficheiro da BIOS do SGB: - + Save games Saves dos jogos - - - - - + + + + + Same directory as the ROM O mesmo diretório que a ROM - + Save states Save states - + Screenshots Screenshots - + Patches Patches - + Cheats Trapaças - + Log to file Registar ao ficheiro - + Log to console Registar à console - + Select Log File Selecionar Ficheiro de Registo - + Default BG colors: Cores padrão do 2º plano: - + Default sprite colors 1: Cores padrão da imagem móvel 1: - + Default sprite colors 2: Cores padrão da imagem móvel 2: - + Super Game Boy borders Bordas do Super Game Boy @@ -5789,13 +5869,11 @@ Tamanho da descarga: %3 - WebM WebM - MP4 MP4 @@ -5834,82 +5912,6 @@ Tamanho da descarga: %3 Format Formato - - - MKV - MKV - - - - AVI - AVI - - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - Nenhum - - - - FLAC - FLAC - - - - WavPack - WavPack - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - Descomprimido - Bitrate (kbps) @@ -5920,16 +5922,6 @@ Tamanho da descarga: %3 ABR ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5959,80 +5951,80 @@ Tamanho da descarga: %3 QGBA::Window - + Archives (%1) Ficheiros Compactados (%1) - - + + Select ROM Selecionar ROM - + Select folder Selecionar pasta - - + + Select save Selecionar save - + Select patch Selecionar patch - + Patches (*.ips *.ups *.bps) Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode Selecionar dotcode do e-Reader - + e-Reader card (*.raw *.bin *.bmp) Cartão do e-Reader (*.raw *.bin *.bmp) - + Select image Selecionar imagem - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Ficheiro de imagem (*.png *.gif *.jpg *.jpeg);;Todos os ficheiros (*) - + GameShark saves (*.sps *.xps) Saves do GameShark (*.sps *.xps) - + Select video log Selecionar registo do vídeo - + Video logs (*.mvl) Registos do vídeo (*.mvl) - + Crash Crash - + The game has crashed with the following error: %1 @@ -6041,699 +6033,709 @@ Tamanho da descarga: %3 %1 - + Couldn't Start Não Pôde Iniciar - + Could not start game. Não pôde iniciar o jogo. - + Unimplemented BIOS call Chamada da BIOS não implementada - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Este jogo usa uma chamada de BIOS que não está implementada. Por favor use a BIOS oficial para uma melhor experiência. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Falhou em criar um aparelho de exibição apropriado, voltando a exibição por software. Os jogos podem executar lentamente, especialmente com janelas maiores. - + Really make portable? Realmente tornar portátil? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Isto fará o emulador carregar a configuração dele do mesmo diretório que o executável. Quer continuar? - + Restart needed Reiniciar é necessário - + Some changes will not take effect until the emulator is restarted. Algumas mudanças não terão efeito até o emulador ser reiniciado. - + - Player %1 of %2 - Jogador %1 de %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &Ficheiro - + Load &ROM... Carregar &ROM... - + Load ROM in archive... Carregar ROM no arquivo... - + Add folder to library... Adicionar pasta a biblioteca... - + Save games (%1) Saves dos jogos (%1) - + Select save game Selecione save do jogo - + mGBA save state files (%1) Ficheiro do save state do mGBA (%1) - - + + Select save state Selecione um save state - + Select e-Reader card images Selecionar imagens do cartão do e-Reader - + Image file (*.png *.jpg *.jpeg) Ficheiro da imagem (*.png *.jpg *.jpeg) - + Conversion finished Conversão concluída - + %1 of %2 e-Reader cards converted successfully. %1 de %2 cartões do e-Reader convertidos com sucesso. - + Load alternate save game... Carregar save alternativo do jogo... - + Load temporary save game... Carregar save temporário do jogo... - + Load &patch... Carregar &patch... - + Boot BIOS Dar Boot na BIOS - + Replace ROM... Substituir a ROM... - + Scan e-Reader dotcodes... Escanear dotcodes do e-Reader... - + Convert e-Reader card image to raw... Converter imagem do cartão do e-Reader para natural... - + ROM &info... Informações da &ROM... - + Recent Recentes - + Make portable Tornar portátil - + &Load state &Carregar state - + Load state file... Carregar ficheiro do state... - + &Save state &Gravar o state - + Save state file... Ficheiro do save state... - + Quick load Carregamento rápido - + Quick save Salvamento rápido - + Load recent Carregar recentes - + Save recent Gravar recentes - + Undo load state Desfazer o carregamento do state - + Undo save state Desfazer o save state - - + + State &%1 State &%1 - + Load camera image... Carregar a imagem da câmara... - + Convert save game... Converter o save do jogo... - + GameShark saves (*.gsv *.sps *.xps) Saves do GameShark (*.gsv *.sps *.xps) - + Reset needed É necessário resetar - + Some changes will not take effect until the game is reset. Algumas mudanças não terão efeito até o jogo ser resetado. - + Save games Saves dos jogos - + Import GameShark Save... Importar Save do GameShark... - + Export GameShark Save... Exportar Save do GameShark... - + Automatically determine Determinar automaticamente - + Use player %0 save game Usar o save do jogo %0 do jogador - + New multiplayer window Nova janela multi-jogador - + Connect to Dolphin... Conectar ao Dolphin... - + Report bug... Reportar bug... - + About... Sobre... - + E&xit S&air - + &Emulation &Emulação - + &Reset &Resetar - + Sh&utdown De&sligar - + Yank game pak Arrancar o game pak - + &Pause &Pausar - + &Next frame &Próximo frame - + Fast forward (held) Avanço rápido (segurado) - + &Fast forward &Avanço rápido - + Fast forward speed Velocidade do avanço rápido - + Unbounded Ilimitado - + %0x %0x - + Increase fast forward speed Aumentar a velocidade do avanço rápido - + Decrease fast forward speed Diminuir a velocidade do avanço rápido - + Rewind (held) Retroceder (segurado) - + Re&wind Re&troceder - + Step backwards Voltar um passo - + Solar sensor Sensor solar - + Increase solar level Aumentar nível solar - + Decrease solar level Diminuir nível solar - + Brightest solar level Nível solar mais brilhante - + Darkest solar level Nível solar mais escuro - + Brightness %1 Brilho %1 - + Game Boy Printer... Impressora do Game Boy... - + BattleChip Gate... Portal do BattleChip... - + Audio/&Video Ãudio/&Vídeo - + Frame size Tamanho do frame - + %1× %1× - + Toggle fullscreen Alternar ecrã inteiro - + + &Lock frame size + + + + Lock aspect ratio Travar a proporção do aspeto - + Force integer scaling Forçar o dimensionamento do inteiro - + Interframe blending Mistura do interframe - + Bilinear filtering Filtragem bilinear - + Frame&skip Frame&skip - + Mute Mudo - + FPS target FPS alvo - + Native (59.7275) Nativo (59,7275) - + Take &screenshot Tirar &screenshot - + F12 F12 - + Record A/V... Gravar A/V... - + Record GIF/WebP/APNG... Gravar GIF/WebP/APNG... - + Video layers Camadas do vídeo - + Audio channels Canais de áudio - + Adjust layer placement... Ajustar posicionamento da camada... - + &Tools &Ferramentas - + View &logs... Visualizar &registos... - + Game &overrides... Substituições &do jogo... - + Game Pak sensors... Sensores do Game Pak... - + &Cheats... &Trapaças... - + Create forwarder... Criar encaminhador... - + Settings... Configurações... - + Open debugger console... Abrir console do debugger... - + Start &GDB server... Iniciar servidor do &GDB... - + Scripting... Scripting... - + Game state views Visualizações do estado do jogo - + View &palette... Visualizar &paleta... - + View &sprites... Visualizar &imagens móveis... - + View &tiles... Visualizar &ladrilhos... - + View &map... Visualizar &mapa... - + &Frame inspector... Inspetor dos &frames... - + View memory... Visualizar memória... - + Search memory... Procurar na memória... - + View &I/O registers... Visualizar registos de &E/S... - + + Log memory &accesses... + + + + Record debug video log... Gravar registo do vídeo de debug... - + Stop debug video log Parar o registo do vídeo de debug - + Exit fullscreen Sair do ecrã inteiro - + GameShark Button (held) Botão do GameShark (segurado) - + Autofire Auto-disparar - + Autofire A Auto-disparar A - + Autofire B Auto-disparar B - + Autofire L Auto-disparar L - + Autofire R Auto-disparar R - + Autofire Start Auto-disparar Start - + Autofire Select Auto-disparar Select - + Autofire Up Auto-disparar Para Cima - + Autofire Right Auto-disparar Direita - + Autofire Down Auto-disparar Para Baixo - + Autofire Left Auto-disparar Esquerda - + Clear Limpar @@ -6771,17 +6773,17 @@ Tamanho da descarga: %3 ? - + Super (L) Super (E) - + Super (R) Super (D) - + Menu Menu @@ -6789,22 +6791,22 @@ Tamanho da descarga: %3 QShortcut - + Shift Shift - + Control Control - + Alt Alt - + Meta Meta diff --git a/src/platform/qt/ts/mgba-ru.ts b/src/platform/qt/ts/mgba-ru.ts index 574a66861c6..5f130f18ed2 100644 --- a/src/platform/qt/ts/mgba-ru.ts +++ b/src/platform/qt/ts/mgba-ru.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) Игры Game Boy Advance (%1) - + Game Boy ROMs (%1) Игры Game Boy (%1) - + All ROMs (%1) Ð’Ñе игры (%1) - + %1 Video Logs (*.mvl) Журналы видео %1 (*.mvl) @@ -191,17 +191,17 @@ Download size: %3 QGBA::AudioDevice - + Can't set format of context-less audio device Ðевозможно уÑтановить формат Ð´Ð»Ñ Ð°ÑƒÐ´Ð¸Ð¾ÑƒÑтройÑтва без контекÑта - + Audio device is missing its core ОтÑутÑтвует Ñдро аудиоуÑтройÑтва - + Writing data to read-only audio device ЗапиÑÑŒ данных в аудиоуÑтройÑтво только Ð´Ð»Ñ Ñ‡Ñ‚ÐµÐ½Ð¸Ñ @@ -209,7 +209,7 @@ Download size: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input Ðевозможно запуÑтить аудиопроцеÑÑор без входных данных @@ -285,28 +285,28 @@ Download size: %3 РаÑширенные наÑтройки - + BattleChip data missing ОтÑутÑтвуют данные BattleChip - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? ОтÑутÑтвуют данные BattleChip. BattleChip Gates будут работать, но чаÑÑ‚ÑŒ графики будет отÑутÑтвовать. Скачать данные ÑейчаÑ? - - + + Select deck file Выберите файл колоды - + Incompatible deck Колода неÑовмеÑтима - + The selected deck is not compatible with this Chip Gate Ð’Ñ‹Ð±Ñ€Ð°Ð½Ð½Ð°Ñ ÐºÐ¾Ð»Ð¾Ð´Ð° неÑовмеÑтима Ñ Ñтим Chip Gate @@ -367,19 +367,19 @@ Download size: %3 Введите Ñвои читкоды Ñюда... - - + + Autodetect (recommended) Ðвтоопределение (рекомендовано) - - + + Select cheats file Выберите файл Ñ Ñ‡Ð¸Ñ‚-кодами - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. Ðекоторые читы не были добавлены. УбедитеÑÑŒ, что они правильного формата, и/или измените тип чита. @@ -398,37 +398,37 @@ Download size: %3 ÐžÐ±Ñ€Ð°Ñ‚Ð½Ð°Ñ Ð¿ÐµÑ€ÐµÐ¼Ð¾Ñ‚ÐºÐ° выключена - + Reset the game? Перезагрузить игру? - + Most games will require a reset to load the new save. Do you want to reset now? БольшинÑтву игр нужна перезагрузка, чтобы загрузить новое Ñохранение. Перезагрузить ÑейчаÑ? - + Failed to open save file: %1 Ðе удалоÑÑŒ открыть файл ÑохранениÑ: %1 - + Failed to open game file: %1 Ðе удалоÑÑŒ открыть файл игры: %1 - + Can't yank pack in unexpected platform! Ðевозможно пнуть картридж на неожиданной платформе! - + Failed to open snapshot file for reading: %1 Ðе удалоÑÑŒ открыть файл Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ Ð´Ð»Ñ ÑчитываниÑ: %1 - + Failed to open snapshot file for writing: %1 Ðе удалоÑÑŒ открыть файл Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ Ð´Ð»Ñ Ð·Ð°Ð¿Ð¸Ñи: %1 @@ -477,6 +477,14 @@ Download size: %3 Ðе удалоÑÑŒ открыть иÑторию CLI на запиÑÑŒ + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Download size: %3 Ð¡Ð±Ñ€Ð¾Ñ - + Export frame ЭкÑпорт кадра - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) - + None Ðет - + Background Фон - + Window Окно - + Objwin Objwin - + Sprite Спрайт - + Backdrop Подложка - + Frame Кадр - + %1 %2 %1 %2 @@ -818,22 +826,22 @@ Download size: %3 QGBA::GBAKeyEditor - + Clear Button Ð¡Ð±Ñ€Ð¾Ñ ÐºÐ½Ð¾Ð¿ÐºÐ¸ - + Clear Analog Ð¡Ð±Ñ€Ð¾Ñ Ð°Ð½Ð°Ð»Ð¾Ð³Ð° - + Refresh Обновить - + Set all Ðазначить вÑе @@ -3006,8 +3014,8 @@ Download size: %3 QGBA::KeyEditor - - + + --- --- @@ -3378,23 +3386,87 @@ Download size: %3 Вертикально - - - + + + N/A Ð/Д - + Export map ЭкÑпорт карты - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + Открыть + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Download size: %3 Обновить - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 @@ -3750,17 +3822,17 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4157,35 +4229,35 @@ Download size: %3 ЭкÑпорт OBJ - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette ЭкÑпорт палитры - + Windows PAL (*.pal);;Adobe Color Table (*.act) Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 Ðе удалоÑÑŒ открыть файл палитры: %1 @@ -4259,7 +4331,7 @@ Download size: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Download size: %3 + Maker Code: + + + + + Revision: + + + + File size: Размер файла: - + CRC32: CRC32: - + Save file: @@ -4364,62 +4446,62 @@ Download size: %3 QGBA::SaveConverter - + Save games and save states (%1) Игровые ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ Ð¸ ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ ÑоÑтоÑний (%1) - + Select save game or save state Выбор игрового ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ Ð¸Ð»Ð¸ ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ ÑоÑтоÑÐ½Ð¸Ñ - + Save games (%1) Игровые ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ (%1) - + Select save game Выбор игрового ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ - + Conversion failed Ошибка конвертации - + Failed to convert the save game. This is probably a bug. Ðе удалоÑÑŒ Ñконвертировать игровое Ñохранение. Возможно, Ñто баг. - + No file selected Ðе выбран файл - + Could not open file Ðе удалоÑÑŒ открыть файл - + No valid formats found СовмеÑтимые форматы не найдены - + Please select a valid input file ПожалуйÑта, выберите ÑовмеÑтимый входной файл - + No valid conversions found СовмеÑтимые конверÑии не найдены - + Cannot convert save games between platforms ÐÐµÐ»ÑŒÐ·Ñ Ñконвертировать ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ Ð´Ð»Ñ Ñ€Ð°Ð·Ð½Ñ‹Ñ… платформ @@ -4445,97 +4527,97 @@ Download size: %3 Выходной файл - + %1 %2 save game - + little endian - + big endian - + SRAM SRAM - + %1 flash - + %1 EEPROM - + + RTC - + %1 SRAM + RTC - + %1 SRAM - + packed MBC2 - + unpacked MBC2 - + MBC6 flash - + MBC6 combined SRAM + flash - + MBC6 SRAM - + TAMA5 - + %1 (%2) - + %1 save state with embedded %2 save game - + %1 SharkPort %2 save game - + %1 GameShark Advance SP %2 save game @@ -4571,32 +4653,37 @@ Download size: %3 Загрузить недавний Ñкрипт - + Load script... Загрузить Ñкрипт... - + + &Load most recent + + + + &Reset Перезагрузить (&R/&К) - + 0 0 - + Select script to load Выбрать Ñкрипт Ð´Ð»Ñ Ð·Ð°Ð³Ñ€ÑƒÐ·ÐºÐ¸ - + Lua scripts (*.lua) Скрипты Lua (*.lua) - + All files (*.*) Ð’Ñе файлы (*.*) @@ -4689,105 +4776,105 @@ Download size: %3 QGBA::SettingsView - - + + Qt Multimedia Qt Multimedia - + SDL SDL - + Software (Qt) Программный рендеринг (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) - + None Ðет - + None (Still Image) Ðет (Ñтатичное изображение) - + Keyboard Клавиатура - + Controllers Контроллеры - + Shortcuts Ð¡Ð¾Ñ‡ÐµÑ‚Ð°Ð½Ð¸Ñ ÐºÐ»Ð°Ð²Ð¸Ñˆ - - + + Shaders Шейдеры - + Select BIOS Выбор BIOS - + Select directory Выбор папки - + Select image Выбор Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ - + Image file (*.png *.jpg *.jpeg) Файл Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Ðикогда - + Just now Только ÑÐµÐ¹Ñ‡Ð°Ñ - + Less than an hour ago Менее чаÑа назад - + %n hour(s) ago %n Ñ‡Ð°Ñ Ð½Ð°Ð·Ð°Ð´ @@ -4796,7 +4883,7 @@ Download size: %3 - + %n day(s) ago %n день назад @@ -5144,72 +5231,72 @@ Download size: %3 СкороÑÑ‚ÑŒ перемотки: - + Models Модели - + GB only: Только GB: - + SGB compatible: СовмеÑтимоÑÑ‚ÑŒ Ñ SGB: - + GBC only: Только GBC: - + GBC compatible: СовмеÑтимоÑÑ‚ÑŒ Ñ GBC: - + SGB and GBC compatible: СовмеÑтимоÑÑ‚ÑŒ Ñ GBC и SGB: - + Game Boy palette Палитра Game Boy - + Default color palette only Только Ñ†Ð²ÐµÑ‚Ð¾Ð²Ð°Ñ Ð¿Ð°Ð»Ð¸Ñ‚Ñ€Ð° по умолчанию - + SGB color palette if available Ð¦Ð²ÐµÑ‚Ð¾Ð²Ð°Ñ Ð¿Ð°Ð»Ð¸Ñ‚Ñ€Ð° SGB (еÑли доÑтупна) - + GBC color palette if available Ð¦Ð²ÐµÑ‚Ð¾Ð²Ð°Ñ Ð¿Ð°Ð»Ð¸Ñ‚Ñ€Ð° GBC (еÑли доÑтупна) - + SGB (preferred) or GBC color palette if available Ð¦Ð²ÐµÑ‚Ð¾Ð²Ð°Ñ Ð¿Ð°Ð»Ð¸Ñ‚Ñ€Ð° SGB (предпочтительно) или GBC (еÑли доÑтупны) - + Game Boy Camera - + Driver: Драйвер: - + Source: ИÑточник: @@ -5300,7 +5387,7 @@ Download size: %3 Включить ÑовмеÑтимоÑÑ‚ÑŒ Ñ VBA Ð´Ð»Ñ ROM-хаков - + Preset: ПреÑет: @@ -5403,135 +5490,130 @@ Download size: %3 Программный - + OpenGL enhancements Ð£Ð»ÑƒÑ‡ÑˆÐµÐ½Ð¸Ñ OpenGL - + High-resolution scale: МаÑштаб выÑокого разрешениÑ: - + (240×160) (240×160) - - XQ GBA audio (experimental) - Ðудио XQ GBA (ÑкÑпериментально) - - - + GB BIOS file: Файл GB BIOS: - - - - - - - - - + + + + + + + + + Browse Открыть - + Use BIOS file if found ИÑпользовать файл BIOS, еÑли найден - + Skip BIOS intro ПропуÑтить интро BIOS - + GBA BIOS file: Файл GBA BIOS: - + GBC BIOS file: Файл GBC BIOS: - + SGB BIOS file: Файл SGB BIOS: - + Save games Ð¡Ð¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ - - - - - + + + + + Same directory as the ROM ДиректориÑ, в которой находитÑÑ ROM - + Save states Ð¡Ð¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ ÑоÑтоÑÐ½Ð¸Ñ - + Screenshots Скриншоты - + Patches Патчи - + Cheats Читы - + Log to file СохранÑÑ‚ÑŒ журнал в файл - + Log to console Выводить на конÑоль - + Select Log File Выбрать файл журнала - + Default BG colors: Цвета фона по умолчанию: - + Super Game Boy borders Рамки Super Game Boy - + Default sprite colors 1: 1-е цвета по умолчанию Ð´Ð»Ñ Ñпрайта: - + Default sprite colors 2: 2-е цвета по умолчанию Ð´Ð»Ñ Ñпрайта: @@ -5789,7 +5871,6 @@ Download size: %3 - WebM WebM @@ -5823,19 +5904,8 @@ Download size: %3 Format Формат - - - MKV - MKV - - - - AVI - AVI - - MP4 MP4 @@ -5844,72 +5914,6 @@ Download size: %3 4K 4K - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - Ðет - - - - FLAC - FLAC - - - - WavPack - WavPack - - - - Opus - Opus - - - - Vorbis - - - - - MP3 - MP3 - - - - AAC - - - - - Uncompressed - Без ÑÐ¶Ð°Ñ‚Ð¸Ñ - Bitrate (kbps) @@ -5920,16 +5924,6 @@ Download size: %3 ABR - - - H.264 - - - - - H.264 (NVENC) - - VBR @@ -5959,80 +5953,80 @@ Download size: %3 QGBA::Window - + Archives (%1) Ðрхивы (%1) - - + + Select ROM Выбор игры - + Select folder Выбор папки - - + + Select save Выбор ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ - + Select patch Выбор патча - + Patches (*.ips *.ups *.bps) Патчи (*.ips *.ups *.bps) - + Select e-Reader dotcode Выбор карточки e-Reader - + e-Reader card (*.raw *.bin *.bmp) Карточка e-Reader (*.raw *.bin *.bmp) - + Select image Выбор Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Файл Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) Ð¡Ð¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ GameShark (*.sps *.xps) - + Select video log Выбор видеолога - + Video logs (*.mvl) Видеологи (*.mvl) - + Crash Сбой - + The game has crashed with the following error: %1 @@ -6041,699 +6035,709 @@ Download size: %3 %1 - + Couldn't Start ЗапуÑк не удалÑÑ - + Could not start game. Ðе удалоÑÑŒ запуÑтить игру. - + Unimplemented BIOS call ÐеизвеÑтный вызов BIOS - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Игра иÑпользует нереализованный вызов BIOS. ПожалуйÑта, воÑпользуйтеÑÑŒ официальным BIOS Ð´Ð»Ñ Ð»ÑƒÑ‡ÑˆÐµÐ¹ ÑовмеÑтимоÑти. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Ðе удалоÑÑŒ Ñоздать уÑтройÑтво отображениÑ, возврат к программному режиму. Игры могут идти медленнее, оÑобенно в окнах больших размеров. - + Really make portable? Перейти в портативный режим? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? ПоÑле Ñтого ÑмулÑтор будет загружать конфигурацию из папки Ñ Ð¸ÑполнÑемым файлом. Продолжить? - + Restart needed ТребуетÑÑ Ð¿ÐµÑ€ÐµÐ·Ð°Ð¿ÑƒÑк - + Some changes will not take effect until the emulator is restarted. Ð”Ð»Ñ Ð¿Ñ€Ð¸Ð¼ÐµÐ½ÐµÐ½Ð¸Ñ Ð½ÐµÐºÐ¾Ñ‚Ð¾Ñ€Ñ‹Ñ… изменений требуетÑÑ Ð¿ÐµÑ€ÐµÐ·Ð°Ð¿ÑƒÑтить ÑмулÑтор. - + - Player %1 of %2 - Игрок %1 из %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File &Файл - + Load &ROM... Загрузить &ROM... - + Load ROM in archive... Загрузить игру из архива... - + Add folder to library... Добавить папку в библиотеку... - + Save games (%1) Игровые ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ (%1) - + Select save game Выбор игрового ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ - + mGBA save state files (%1) Файл ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ ÑоÑтоÑÐ½Ð¸Ñ mGBA (%1) - - + + Select save state Выбор ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ ÑоÑтоÑÐ½Ð¸Ñ - + Select e-Reader card images Выбор Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ ÐºÐ°Ñ€Ñ‚Ð¾Ñ‡ÐºÐ¸ e-Reader - + Image file (*.png *.jpg *.jpeg) Файл Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ (*.png *.jpg *.jpeg) - + Conversion finished ÐšÐ¾Ð½Ð²ÐµÑ€Ñ‚Ð°Ñ†Ð¸Ñ Ð·Ð°Ð²ÐµÑ€ÑˆÐµÐ½Ð° - + %1 of %2 e-Reader cards converted successfully. %1 из %2 карточек e-Reader уÑпешно Ñконвертировано. - + Load alternate save game... Загрузить альтернативное Ñохранение... - + Load temporary save game... Загрузить временное Ñохранение... - + Load &patch... Загрузить &патч... - + Boot BIOS ЗагрузитьÑÑ Ð² BIOS - + Replace ROM... Заменить ROM... - + Scan e-Reader dotcodes... Сканировать dot-коды e-Reader... - + Convert e-Reader card image to raw... Конвертировать карту e-Reader в raw... - + ROM &info... Ð˜Ð½Ñ„Ð¾Ñ€Ð¼Ð°Ñ†Ð¸Ñ Ð¾Ð± &игре... - + Recent Ðедавние - + Make portable Портативный режим - + &Load state &Загрузить ÑоÑтоÑние - + Load state file... Загрузить ÑоÑтоÑние из файла... - + &Save state &Сохранить ÑоÑтоÑние - + Save state file... Сохранить ÑоÑтоÑние в файл... - + Quick load БыÑÑ‚Ñ€Ð°Ñ Ð·Ð°Ð³Ñ€ÑƒÐ·ÐºÐ° - + Quick save БыÑтрое Ñохранение - + Load recent Загрузить недавнее - + Save recent Сохранить в недавнее - + Undo load state Отмена загрузки ÑоÑтоÑÐ½Ð¸Ñ - + Undo save state Отмена ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ ÑоÑтоÑÐ½Ð¸Ñ - - + + State &%1 Слот &%1 - + Load camera image... Загрузить изображение Ñ ÐºÐ°Ð¼ÐµÑ€Ñ‹... - + Convert save game... Конвертировать игровое Ñохранение... - + GameShark saves (*.gsv *.sps *.xps) Ð¡Ð¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ GameShark (*.gsv *.sps *.xps) - + Reset needed Ðеобходима перезагрузка - + Some changes will not take effect until the game is reset. Ðекоторые Ð¸Ð·Ð¼ÐµÐ½ÐµÐ½Ð¸Ñ Ð½Ðµ войдут в Ñилу, пока игра не перезагружена. - + Save games Ð¡Ð¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ - + Import GameShark Save... Импорт ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ GameShark... - + Export GameShark Save... ЭкÑпорт ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ GameShark... - + Automatically determine Определить автоматичеÑки - + Use player %0 save game ИÑпользовать Ñохранение игрока %0 - + New multiplayer window Ðовое окно мультиплеера - + Connect to Dolphin... Соединение Ñ Dolphin... - + Report bug... Сообщить об ошибке... - + About... О программе... - + E&xit &Выход - + &Emulation &ЭмулÑÑ†Ð¸Ñ - + &Reset Перезагрузить (&R/&К) - + Sh&utdown Выключить (&U/&Г) - + Yank game pak Пнуть картридж - + &Pause Пау&за - + &Next frame Следующий кадр (&N/&Т) - + Fast forward (held) Перемотка (удержание) - + &Fast forward Перемотк&а - + Fast forward speed СкороÑÑ‚ÑŒ перемотки - + Unbounded ÐÐµÐ¾Ð³Ñ€Ð°Ð½Ð¸Ñ‡ÐµÐ½Ð½Ð°Ñ - + %0x %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) ÐžÐ±Ñ€Ð°Ñ‚Ð½Ð°Ñ Ð¿ÐµÑ€ÐµÐ¼Ð¾Ñ‚ÐºÐ° (удержание) - + Re&wind ÐžÐ±Ñ€Ð°Ñ‚Ð½Ð°Ñ Ð¿ÐµÑ€ÐµÐ¼Ð¾Ñ‚ÐºÐ° (&W/&Ц) - + Step backwards Шаг назад - + Solar sensor Датчик Ñолнца - + Increase solar level УÑилить Ñолнечный Ñвет - + Decrease solar level ОÑлабить Ñолнечный Ñвет - + Brightest solar level Ярчайшее Ñолнце - + Darkest solar level ТуÑклейшее Ñолнце - + Brightness %1 ЯркоÑÑ‚ÑŒ %1 - + Game Boy Printer... - + BattleChip Gate... - + Audio/&Video Ðудио/Видео (&V/&Ðœ) - + Frame size Размер кадра - + %1× %1× - + Toggle fullscreen Переключить полноÑкранный режим - + + &Lock frame size + + + + Lock aspect ratio ЗафикÑировать Ñоотношение Ñторон - + Force integer scaling Принудительное целочиÑленное маÑштабирование - + Interframe blending Межкадровое Ñмешение - + Bilinear filtering Ð‘Ð¸Ð»Ð¸Ð½ÐµÐ¹Ð½Ð°Ñ Ñ„Ð¸Ð»ÑŒÑ‚Ñ€Ð°Ñ†Ð¸Ñ - + Frame&skip ПропуÑк кадров (&S/&Ы) - + Mute Выключить звук - + FPS target Целевой FPS - + Native (59.7275) Родной (59.7275) - + Take &screenshot СнÑÑ‚ÑŒ Ñкриншот (&S/&Ы) - + F12 F12 - + Record A/V... ЗапиÑать аудио/видео... - + Record GIF/WebP/APNG... ЗапиÑать GIF/WebP/APNG... - + Video layers ВидеоÑлои - + Audio channels Ðудиоканалы - + Adjust layer placement... ÐаÑтроить раÑположение Ñлоёв... - + &Tools ИнÑтрум&енты - + View &logs... ПоÑмотреть в журнал... (&L/&Д) - + Game &overrides... ÐŸÐµÑ€ÐµÐ¾Ð¿Ñ€ÐµÐ´ÐµÐ»ÐµÐ½Ð¸Ñ Ð´Ð»Ñ Ñтой игры... (&О/&Щ) - + Game Pak sensors... Датчики в Game Pak... - + &Cheats... Читы... (&C/&С) - + Create forwarder... - + Settings... ÐаÑтройки... - + Open debugger console... Открыть конÑоль отладки... - + Start &GDB server... ЗапуÑтить Ñервер &GDB... - + Scripting... Скрипты... - + Game state views ПроÑмотр ÑоÑтоÑÐ½Ð¸Ñ Ð¸Ð³Ñ€Ñ‹ - + View &palette... ПроÑмотр палитры... (&P/&З) - + View &sprites... ПроÑмотр Ñпрайтов... (&S/&Ы) - + View &tiles... ПроÑмотр тайлов... (&T/&Е) - + View &map... ПроÑмотр карты... (&M/&Ь) - + &Frame inspector... Изучение фрейм&а... - + View memory... ПроÑмотр памÑти... - + Search memory... ПоиÑк в памÑти... - + View &I/O registers... ПроÑмотр региÑтров &I/O... - + + Log memory &accesses... + + + + Record debug video log... ЗапиÑÑŒ отладочного видеожурнала... - + Stop debug video log Закончить запиÑÑŒ отладочного видеожурнала - + Exit fullscreen Выйти из полноÑкранного режима - + GameShark Button (held) Кнопка GameShark (удерживаетÑÑ) - + Autofire ÐвтоÑтрельба - + Autofire A A (автоÑтрельба) - + Autofire B B (автоÑтрельба) - + Autofire L L (автоÑтрельба) - + Autofire R R (автоÑтрельба) - + Autofire Start Start (автоÑтрельба) - + Autofire Select Select (автоÑтрельба) - + Autofire Up Вверх (автоÑтрельба) - + Autofire Right Вправо (автоÑтрельба) - + Autofire Down Вниз (автоÑтрельба) - + Autofire Left Влево (автоÑтрельба) - + Clear ОчиÑтить @@ -6771,17 +6775,17 @@ Download size: %3 ? - + Super (L) - + Super (R) - + Menu Меню @@ -6789,22 +6793,22 @@ Download size: %3 QShortcut - + Shift - + Control - + Alt - + Meta diff --git a/src/platform/qt/ts/mgba-sv.ts b/src/platform/qt/ts/mgba-sv.ts index 55df22b5214..4017ea4899d 100644 --- a/src/platform/qt/ts/mgba-sv.ts +++ b/src/platform/qt/ts/mgba-sv.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) - + Game Boy ROMs (%1) - + All ROMs (%1) - + %1 Video Logs (*.mvl) @@ -191,17 +191,17 @@ Nedladdningsstorlek: %3 QGBA::AudioDevice - + Can't set format of context-less audio device Det gÃ¥r inte att ställa in formatet för kontextlös ljudenhet - + Audio device is missing its core Ljudenheten saknar kärnan - + Writing data to read-only audio device Skriver data till skrivskyddad ljudenhet @@ -209,7 +209,7 @@ Nedladdningsstorlek: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input Kan inte starta en ljudprocessor utan ingÃ¥ng @@ -285,28 +285,28 @@ Nedladdningsstorlek: %3 Visa avancerat - + BattleChip data missing BattleChip-data saknas - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? BattleChip-data saknas. BattleChip Gates fungerar fortfarande, men viss grafik kommer att saknas. Vill du ladda ner datan nu? - - + + Select deck file Välj deck-fil - + Incompatible deck Inkompatibelt deck - + The selected deck is not compatible with this Chip Gate Den valda deck är inte kompatibel med denna Chip Gate @@ -367,19 +367,19 @@ Nedladdningsstorlek: %3 - - + + Autodetect (recommended) - - + + Select cheats file - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. @@ -398,37 +398,37 @@ Nedladdningsstorlek: %3 - + Reset the game? - + Most games will require a reset to load the new save. Do you want to reset now? - + Failed to open save file: %1 - + Failed to open game file: %1 - + Can't yank pack in unexpected platform! - + Failed to open snapshot file for reading: %1 - + Failed to open snapshot file for writing: %1 @@ -477,6 +477,14 @@ Nedladdningsstorlek: %3 + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Nedladdningsstorlek: %3 - + Export frame - + Portable Network Graphics (*.png) - + None - + Background - + Window - + Objwin - + Sprite - + Backdrop - + Frame - + %1 %2 @@ -818,22 +826,22 @@ Nedladdningsstorlek: %3 QGBA::GBAKeyEditor - + Clear Button - + Clear Analog - + Refresh - + Set all @@ -3006,8 +3014,8 @@ Nedladdningsstorlek: %3 QGBA::KeyEditor - - + + --- @@ -3378,23 +3386,87 @@ Nedladdningsstorlek: %3 - - - + + + N/A - + Export map - + Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Nedladdningsstorlek: %3 - + (%0/%1×) - + (â…Ÿ%0×) - + (%0×) - + %1 byte%2 @@ -3750,17 +3822,17 @@ Nedladdningsstorlek: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4157,35 +4229,35 @@ Nedladdningsstorlek: %3 - + #%0 - + 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette - + Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 @@ -4259,7 +4331,7 @@ Nedladdningsstorlek: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Nedladdningsstorlek: %3 - File size: + Maker Code: - CRC32: + Revision: + File size: + + + + + CRC32: + + + + Save file: @@ -4364,62 +4446,62 @@ Nedladdningsstorlek: %3 QGBA::SaveConverter - + Save games and save states (%1) - + Select save game or save state - + Save games (%1) - + Select save game - + Conversion failed - + Failed to convert the save game. This is probably a bug. - + No file selected - + Could not open file - + No valid formats found - + Please select a valid input file - + No valid conversions found - + Cannot convert save games between platforms @@ -4445,97 +4527,97 @@ Nedladdningsstorlek: %3 - + %1 %2 save game - + little endian - + big endian - + SRAM - + %1 flash - + %1 EEPROM - + + RTC - + %1 SRAM + RTC - + %1 SRAM - + packed MBC2 - + unpacked MBC2 - + MBC6 flash - + MBC6 combined SRAM + flash - + MBC6 SRAM - + TAMA5 - + %1 (%2) - + %1 save state with embedded %2 save game - + %1 SharkPort %2 save game - + %1 GameShark Advance SP %2 save game @@ -4571,32 +4653,37 @@ Nedladdningsstorlek: %3 - + Load script... - + + &Load most recent + + + + &Reset - + 0 - + Select script to load - + Lua scripts (*.lua) - + All files (*.*) @@ -4689,105 +4776,105 @@ Nedladdningsstorlek: %3 QGBA::SettingsView - - + + Qt Multimedia - + SDL - + Software (Qt) - + OpenGL - + OpenGL (force version 1.x) - + None - + None (Still Image) - + Keyboard - + Controllers - + Shortcuts - - + + Shaders - + Select BIOS - + Select directory - + Select image - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago @@ -4795,7 +4882,7 @@ Nedladdningsstorlek: %3 - + %n day(s) ago @@ -5122,37 +5209,37 @@ Nedladdningsstorlek: %3 - + Default color palette only - + SGB color palette if available - + GBC color palette if available - + SGB (preferred) or GBC color palette if available - + Game Boy Camera - + Driver: - + Source: @@ -5329,42 +5416,42 @@ Nedladdningsstorlek: %3 - + Models - + GB only: - + SGB compatible: - + GBC only: - + GBC compatible: - + SGB and GBC compatible: - + Game Boy palette - + Preset: @@ -5401,135 +5488,130 @@ Nedladdningsstorlek: %3 - + OpenGL enhancements - + High-resolution scale: - + (240×160) - - XQ GBA audio (experimental) - - - - + GB BIOS file: - - - - - - - - - + + + + + + + + + Browse - + Use BIOS file if found - + Skip BIOS intro - + GBA BIOS file: - + GBC BIOS file: - + SGB BIOS file: - + Save games - - - - - + + + + + Same directory as the ROM - + Save states - + Screenshots - + Patches - + Cheats Cheats - + Log to file - + Log to console - + Select Log File - + Default BG colors: - + Default sprite colors 1: - + Default sprite colors 2: - + Super Game Boy borders @@ -5787,13 +5869,11 @@ Nedladdningsstorlek: %3 - WebM - MP4 @@ -5832,82 +5912,6 @@ Nedladdningsstorlek: %3 Format - - - MKV - - - - - AVI - - - - - HEVC - - - - - HEVC (NVENC) - - - - - VP8 - - - - - VP9 - - - - - FFV1 - - - - - - None - - - - - FLAC - - - - - WavPack - - - - - Opus - - - - - Vorbis - - - - - MP3 - - - - - AAC - - - - - Uncompressed - - Bitrate (kbps) @@ -5918,16 +5922,6 @@ Nedladdningsstorlek: %3 ABR - - - H.264 - - - - - H.264 (NVENC) - - VBR @@ -5957,779 +5951,789 @@ Nedladdningsstorlek: %3 QGBA::Window - + Archives (%1) - - + + Select ROM - + Select folder - - + + Select save - + Select patch - + Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) - + Select image - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) - + Select video log - + Video logs (*.mvl) - + Crash - + The game has crashed with the following error: %1 - + Couldn't Start - + Could not start game. - + Unimplemented BIOS call - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + Really make portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + Restart needed - + Some changes will not take effect until the emulator is restarted. - + - Player %1 of %2 - + %1 - %2 - + %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File - + Load &ROM... - + Load ROM in archive... - + Add folder to library... - + Save games (%1) - + Select save game - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Load &patch... - + Boot BIOS - + Replace ROM... - + Scan e-Reader dotcodes... - + Convert e-Reader card image to raw... - + ROM &info... - + Recent - + Make portable - + &Load state - + Load state file... - + &Save state - + Save state file... - + Quick load - + Quick save - + Load recent - + Save recent - + Undo load state - + Undo save state - - + + State &%1 - + Load camera image... - + Convert save game... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games - + Import GameShark Save... - + Export GameShark Save... - + Automatically determine - + Use player %0 save game - + New multiplayer window - + Connect to Dolphin... - + Report bug... - + About... - + E&xit - + &Emulation - + &Reset - + Sh&utdown - + Yank game pak - + &Pause - + &Next frame - + Fast forward (held) - + &Fast forward - + Fast forward speed - + Unbounded - + %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) - + Re&wind - + Step backwards - + Solar sensor - + Increase solar level - + Decrease solar level - + Brightest solar level - + Darkest solar level - + Brightness %1 - + Game Boy Printer... - + BattleChip Gate... - + Audio/&Video - + Frame size - + %1× - + Toggle fullscreen - + + &Lock frame size + + + + Lock aspect ratio - + Force integer scaling - + Interframe blending - + Bilinear filtering - + Frame&skip - + Mute - + FPS target - + Native (59.7275) - + Take &screenshot - + F12 - + Record A/V... - + Record GIF/WebP/APNG... - + Video layers - + Audio channels - + Adjust layer placement... - + &Tools - + View &logs... - + Game &overrides... - + Game Pak sensors... - + &Cheats... - + Create forwarder... - + Settings... - + Open debugger console... - + Start &GDB server... - + Scripting... - + Game state views - + View &palette... - + View &sprites... - + View &tiles... - + View &map... - + &Frame inspector... - + View memory... - + Search memory... - + View &I/O registers... - + + Log memory &accesses... + + + + Record debug video log... - + Stop debug video log - + Exit fullscreen - + GameShark Button (held) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear @@ -6767,17 +6771,17 @@ Nedladdningsstorlek: %3 - + Super (L) - + Super (R) - + Menu @@ -6785,22 +6789,22 @@ Nedladdningsstorlek: %3 QShortcut - + Shift - + Control - + Alt - + Meta diff --git a/src/platform/qt/ts/mgba-template.ts b/src/platform/qt/ts/mgba-template.ts index 61b57b820db..8cd293d9b85 100644 --- a/src/platform/qt/ts/mgba-template.ts +++ b/src/platform/qt/ts/mgba-template.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) - + Game Boy ROMs (%1) - + All ROMs (%1) - + %1 Video Logs (*.mvl) @@ -185,17 +185,17 @@ Download size: %3 QGBA::AudioDevice - + Can't set format of context-less audio device - + Audio device is missing its core - + Writing data to read-only audio device @@ -203,7 +203,7 @@ Download size: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input @@ -279,28 +279,28 @@ Download size: %3 - + BattleChip data missing - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? - - + + Select deck file - + Incompatible deck - + The selected deck is not compatible with this Chip Gate @@ -361,19 +361,19 @@ Download size: %3 - - + + Autodetect (recommended) - - + + Select cheats file - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. @@ -392,37 +392,37 @@ Download size: %3 - + Reset the game? - + Most games will require a reset to load the new save. Do you want to reset now? - + Failed to open save file: %1 - + Failed to open game file: %1 - + Can't yank pack in unexpected platform! - + Failed to open snapshot file for reading: %1 - + Failed to open snapshot file for writing: %1 @@ -471,6 +471,14 @@ Download size: %3 + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -751,52 +759,52 @@ Download size: %3 - + Export frame - + Portable Network Graphics (*.png) - + None - + Background - + Window - + Objwin - + Sprite - + Backdrop - + Frame - + %1 %2 @@ -812,22 +820,22 @@ Download size: %3 QGBA::GBAKeyEditor - + Clear Button - + Clear Analog - + Refresh - + Set all @@ -3000,8 +3008,8 @@ Download size: %3 QGBA::KeyEditor - - + + --- @@ -3372,23 +3380,87 @@ Download size: %3 - - - + + + N/A - + Export map - + Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3635,22 +3707,22 @@ Download size: %3 - + (%0/%1×) - + (â…Ÿ%0×) - + (%0×) - + %1 byte%2 @@ -3744,17 +3816,17 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4151,35 +4223,35 @@ Download size: %3 - + #%0 - + 0x%0 + + - - 0x%0 (%1) - + Export palette - + Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 @@ -4253,7 +4325,7 @@ Download size: %3 QGBA::ROMInfo - + @@ -4293,16 +4365,26 @@ Download size: %3 - File size: + Maker Code: - CRC32: + Revision: + File size: + + + + + CRC32: + + + + Save file: @@ -4358,62 +4440,62 @@ Download size: %3 QGBA::SaveConverter - + Save games and save states (%1) - + Select save game or save state - + Save games (%1) - + Select save game - + Conversion failed - + Failed to convert the save game. This is probably a bug. - + No file selected - + Could not open file - + No valid formats found - + Please select a valid input file - + No valid conversions found - + Cannot convert save games between platforms @@ -4439,97 +4521,97 @@ Download size: %3 - + %1 %2 save game - + little endian - + big endian - + SRAM - + %1 flash - + %1 EEPROM - + + RTC - + %1 SRAM + RTC - + %1 SRAM - + packed MBC2 - + unpacked MBC2 - + MBC6 flash - + MBC6 combined SRAM + flash - + MBC6 SRAM - + TAMA5 - + %1 (%2) - + %1 save state with embedded %2 save game - + %1 SharkPort %2 save game - + %1 GameShark Advance SP %2 save game @@ -4565,32 +4647,37 @@ Download size: %3 - + Load script... - + + &Load most recent + + + + &Reset - + 0 - + Select script to load - + Lua scripts (*.lua) - + All files (*.*) @@ -4683,112 +4770,112 @@ Download size: %3 QGBA::SettingsView - - + + Qt Multimedia - + SDL - + Software (Qt) - + OpenGL - + OpenGL (force version 1.x) - + None - + None (Still Image) - + Keyboard - + Controllers - + Shortcuts - - + + Shaders - + Select BIOS - + Select directory - + Select image - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago - + %n day(s) ago @@ -5114,37 +5201,37 @@ Download size: %3 - + Default color palette only - + SGB color palette if available - + GBC color palette if available - + SGB (preferred) or GBC color palette if available - + Game Boy Camera - + Driver: - + Source: @@ -5321,42 +5408,42 @@ Download size: %3 - + Models - + GB only: - + SGB compatible: - + GBC only: - + GBC compatible: - + SGB and GBC compatible: - + Game Boy palette - + Preset: @@ -5393,135 +5480,130 @@ Download size: %3 - + OpenGL enhancements - + High-resolution scale: - + (240×160) - - XQ GBA audio (experimental) - - - - + GB BIOS file: - - - - - - - - - + + + + + + + + + Browse - + Use BIOS file if found - + Skip BIOS intro - + GBA BIOS file: - + GBC BIOS file: - + SGB BIOS file: - + Save games - - - - - + + + + + Same directory as the ROM - + Save states - + Screenshots - + Patches - + Cheats - + Log to file - + Log to console - + Select Log File - + Default BG colors: - + Default sprite colors 1: - + Default sprite colors 2: - + Super Game Boy borders @@ -5779,13 +5861,11 @@ Download size: %3 - WebM - MP4 @@ -5824,82 +5904,6 @@ Download size: %3 Format - - - MKV - - - - - AVI - - - - - HEVC - - - - - HEVC (NVENC) - - - - - VP8 - - - - - VP9 - - - - - FFV1 - - - - - - None - - - - - FLAC - - - - - WavPack - - - - - Opus - - - - - Vorbis - - - - - MP3 - - - - - AAC - - - - - Uncompressed - - Bitrate (kbps) @@ -5910,16 +5914,6 @@ Download size: %3 ABR - - - H.264 - - - - - H.264 (NVENC) - - VBR @@ -5949,779 +5943,789 @@ Download size: %3 QGBA::Window - + Archives (%1) - - + + Select ROM - + Select folder - - + + Select save - + Select patch - + Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) - + Select image - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) - + Select video log - + Video logs (*.mvl) - + Crash - + The game has crashed with the following error: %1 - + Couldn't Start - + Could not start game. - + Unimplemented BIOS call - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + Really make portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + Restart needed - + Some changes will not take effect until the emulator is restarted. - + - Player %1 of %2 - + %1 - %2 - + %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File - + Load &ROM... - + Load ROM in archive... - + Add folder to library... - + Save games (%1) - + Select save game - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Load &patch... - + Boot BIOS - + Replace ROM... - + Scan e-Reader dotcodes... - + Convert e-Reader card image to raw... - + ROM &info... - + Recent - + Make portable - + &Load state - + Load state file... - + &Save state - + Save state file... - + Quick load - + Quick save - + Load recent - + Save recent - + Undo load state - + Undo save state - - + + State &%1 - + Load camera image... - + Convert save game... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games - + Import GameShark Save... - + Export GameShark Save... - + Automatically determine - + Use player %0 save game - + New multiplayer window - + Connect to Dolphin... - + Report bug... - + About... - + E&xit - + &Emulation - + &Reset - + Sh&utdown - + Yank game pak - + &Pause - + &Next frame - + Fast forward (held) - + &Fast forward - + Fast forward speed - + Unbounded - + %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) - + Re&wind - + Step backwards - + Solar sensor - + Increase solar level - + Decrease solar level - + Brightest solar level - + Darkest solar level - + Brightness %1 - + Game Boy Printer... - + BattleChip Gate... - + Audio/&Video - + Frame size - + %1× - + Toggle fullscreen - + + &Lock frame size + + + + Lock aspect ratio - + Force integer scaling - + Interframe blending - + Bilinear filtering - + Frame&skip - + Mute - + FPS target - + Native (59.7275) - + Take &screenshot - + F12 - + Record A/V... - + Record GIF/WebP/APNG... - + Video layers - + Audio channels - + Adjust layer placement... - + &Tools - + View &logs... - + Game &overrides... - + Game Pak sensors... - + &Cheats... - + Create forwarder... - + Settings... - + Open debugger console... - + Start &GDB server... - + Scripting... - + Game state views - + View &palette... - + View &sprites... - + View &tiles... - + View &map... - + &Frame inspector... - + View memory... - + Search memory... - + View &I/O registers... - + + Log memory &accesses... + + + + Record debug video log... - + Stop debug video log - + Exit fullscreen - + GameShark Button (held) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear @@ -6759,17 +6763,17 @@ Download size: %3 - + Super (L) - + Super (R) - + Menu @@ -6777,22 +6781,22 @@ Download size: %3 QShortcut - + Shift - + Control - + Alt - + Meta diff --git a/src/platform/qt/ts/mgba-tr.ts b/src/platform/qt/ts/mgba-tr.ts index a98e0639b0c..59e0855316f 100644 --- a/src/platform/qt/ts/mgba-tr.ts +++ b/src/platform/qt/ts/mgba-tr.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) Game Boy Advance ROM'ları (%1) - + Game Boy ROMs (%1) Game Boy ROM'ları (%1) - + All ROMs (%1) Bütün ROM'lar (%1) - + %1 Video Logs (*.mvl) %1 Video Günlükleri (*.mvl) @@ -191,17 +191,17 @@ Yeni sürüm: %2 QGBA::AudioDevice - + Can't set format of context-less audio device BaÄŸlamdan bağımsız ses cihazının formatı ayarlanamıyor - + Audio device is missing its core Ses cihazının çekirdeÄŸi eksik - + Writing data to read-only audio device Salt okunur ses cihazına veri yazma @@ -209,7 +209,7 @@ Yeni sürüm: %2 QGBA::AudioProcessorQt - + Can't start an audio processor without input GiriÅŸsiz ses iÅŸlemcisi baÅŸlatılamaz @@ -285,28 +285,28 @@ Yeni sürüm: %2 GeliÅŸmiÅŸi göster - + BattleChip data missing BattleChip verisi yok - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? BattleChip verisi yok. Bazı grafikler olmadan BattleChip Gates hala çalışır. Verileri ÅŸimdi indirmek istermisin? - - + + Select deck file Deste dosyası seç - + Incompatible deck Uyumsuz deste - + The selected deck is not compatible with this Chip Gate Seçilen deste bu Chip Gate ile uyumlu deÄŸildir @@ -367,19 +367,19 @@ Yeni sürüm: %2 Kodları buraya gir... - - + + Autodetect (recommended) Otoseç (tavsiye edilir) - - + + Select cheats file Oyun hileleri seçin - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. Bazı hileler eklenemedi. Lütfen onların doÄŸru formatlandığından emin ol ve/yada baÅŸa hile tiplerini dene. @@ -398,37 +398,37 @@ Yeni sürüm: %2 - + Reset the game? Oyun sıfırlansım mı? - + Most games will require a reset to load the new save. Do you want to reset now? - + Failed to open save file: %1 Kayıt dosyası açılamadı: %1 - + Failed to open game file: %1 Oyun dosyası açılamadı: %1 - + Can't yank pack in unexpected platform! Beklenmedik bir platformda kartı çıkaramazsın! - + Failed to open snapshot file for reading: %1 Anlık görüntü dosyası okuma için açılamadı: %1 - + Failed to open snapshot file for writing: %1 Anlık görüntü dosyası yazma için açılamadı: %1 @@ -477,6 +477,14 @@ Yeni sürüm: %2 + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Yeni sürüm: %2 Sıfırla - + Export frame Kareyi Dışarı Aktar - + Portable Network Graphics (*.png) Portable Network Graphics (*.png) - + None Hiçbiri - + Background Arka Plan - + Window Pencere - + Objwin Nes. Pen. - + Sprite Sprite - + Backdrop Arka fon - + Frame Kare - + %1 %2 %1 %2 @@ -818,22 +826,22 @@ Yeni sürüm: %2 QGBA::GBAKeyEditor - + Clear Button TuÅŸu Temizle - + Clear Analog Analogu Temizle - + Refresh Yenile - + Set all Tümüne ayarla @@ -3006,8 +3014,8 @@ Yeni sürüm: %2 QGBA::KeyEditor - - + + --- @@ -3378,23 +3386,87 @@ Yeni sürüm: %2 Dikey - - - + + + N/A N/A - + Export map Haritayı dışarı aktar - + Portable Network Graphics (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + Gözat + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + BaÅŸlat + + + + Stop + Durdur + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Yeni sürüm: %2 Yenile - + (%0/%1×) - + (â…Ÿ%0×) - + (%0×) - + %1 byte%2 @@ -3750,17 +3822,17 @@ Yeni sürüm: %2 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4157,35 +4229,35 @@ Yeni sürüm: %2 OBJ dışarı aktar - + #%0 - + 0x%0 + + - - 0x%0 (%1) - + Export palette Paleti dışarı aktar - + Windows PAL (*.pal);;Adobe Color Table (*.act) - + Failed to open output palette file: %1 Çıkış paleti dosyası açılamadı:%1 @@ -4259,7 +4331,7 @@ Yeni sürüm: %2 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Yeni sürüm: %2 + Maker Code: + + + + + Revision: + + + + File size: Dosya boyutu: - + CRC32: - + Save file: @@ -4364,62 +4446,62 @@ Yeni sürüm: %2 QGBA::SaveConverter - + Save games and save states (%1) Kayıtlı oyunlar ve kayıtlı durumlar (%1) - + Select save game or save state Kayıtlı oyun veya kayıtlı durum seç - + Save games (%1) Kayıtlı oyunlar (%1) - + Select save game Kayıtlı oyun seç - + Conversion failed Dönüştürme baÅŸarısız - + Failed to convert the save game. This is probably a bug. Kayıtlı oyunu dönüştürme baÅŸarısız. Muhtemelen bir hata meydana geldi. - + No file selected Seçili dosya yok - + Could not open file Dosya açılamadı - + No valid formats found Geçerli türler bulunamadı - + Please select a valid input file Lütfen geçerli bir giriÅŸ dosyası seç - + No valid conversions found Geçerli dönüştürme bulunamadı - + Cannot convert save games between platforms Kayıtlı oyunlar platformlar arasında dönüştürülemez @@ -4445,97 +4527,97 @@ Yeni sürüm: %2 Çıkış dosyası - + %1 %2 save game %1 %2 kayıtlı oyun - + little endian little endian - + big endian big endian - + SRAM SRAM - + %1 flash %1 flash - + %1 EEPROM %1 EEPROM - + + RTC - + %1 SRAM + RTC %1 SRAM + RTC - + %1 SRAM %1 SRAM - + packed MBC2 paketli MBC2 - + unpacked MBC2 paketlenmemiÅŸ MBC2 - + MBC6 flash MBC6 flash - + MBC6 combined SRAM + flash MBC6 ile birleÅŸtirilmiÅŸ SRAM + flash - + MBC6 SRAM MBC6 SRAM - + TAMA5 TAMA5 - + %1 (%2) %1 (%2) - + %1 save state with embedded %2 save game Gömülü %2 kayıtlı oyunla %1 kayıt durumu - + %1 SharkPort %2 save game - + %1 GameShark Advance SP %2 save game @@ -4571,32 +4653,37 @@ Yeni sürüm: %2 - + Load script... - + + &Load most recent + + + + &Reset &Reset - + 0 4K {0?} - + Select script to load - + Lua scripts (*.lua) - + All files (*.*) @@ -4689,112 +4776,112 @@ Yeni sürüm: %2 QGBA::SettingsView - - + + Qt Multimedia - + SDL - + Software (Qt) Yazılım - + OpenGL OpenGL - + OpenGL (force version 1.x) - + None Hiçbiri - + None (Still Image) - + Keyboard Klavye - + Controllers - + Shortcuts Kısayollar - - + + Shaders Gölgelendiricler - + Select BIOS BIOS seç - + Select directory Yolu seç - + Select image Resim seç - + Image file (*.png *.jpg *.jpeg) Görüntü dosyası (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago - + %n day(s) ago @@ -5140,72 +5227,72 @@ Yeni sürüm: %2 - + Models Modeller - + GB only: Sadece GB: - + SGB compatible: SGB uyumlu: - + GBC only: Sadece GBC: - + GBC compatible: Uyumlu GBC: - + SGB and GBC compatible: Uyumlu SGB ve GBC: - + Game Boy palette Game Boy paleti - + Default color palette only Sadece varsayılan renk paleti - + SGB color palette if available Mevcutsa SGB renk paketi - + GBC color palette if available Mevcutsa GBC renk paketi - + SGB (preferred) or GBC color palette if available Mevcutsa SGB (tercih edilen) ya da GBC renk paketi - + Game Boy Camera Game Boy Kamera - + Driver: Sürücü: - + Source: Kaynak: @@ -5296,7 +5383,7 @@ Yeni sürüm: %2 ROM hacklerinde VBA hata uyumluluÄŸunu etkinleÅŸtir - + Preset: Ön ayar: @@ -5399,135 +5486,130 @@ Yeni sürüm: %2 Yazılım - + OpenGL enhancements OpenGL geliÅŸtirmeleri - + High-resolution scale: Yüksek kalite ölçeÄŸi: - + (240×160) (240×160) - - XQ GBA audio (experimental) - XQ GBA ses (deneysel) - - - + GB BIOS file: GB BIOS dosyası: - - - - - - - - - + + + + + + + + + Browse Gözat - + Use BIOS file if found Varsa BIOS dosyasını kullan - + Skip BIOS intro BIOS giriÅŸini atla - + GBA BIOS file: GBA BIOS dosyası: - + GBC BIOS file: GBC BIOS dosyası: - + SGB BIOS file: SGB BIOS dosyası: - + Save games Oyunları kaydet - - - - - + + + + + Same directory as the ROM ROM ile aynı dizin - + Save states Konum kaydedici - + Screenshots Ekran Görüntüleri - + Patches Yamalar - + Cheats Hileler - + Log to file Dosyaya günlüğünü gir - + Log to console Konsola günlüğünü gir - + Select Log File Günlük Dosyasını Seç - + Default BG colors: - + Super Game Boy borders Super Game Boy sınırları - + Default sprite colors 1: Varsayılan sprite renkleri 1: - + Default sprite colors 2: Varsayılan sprite renkleri 2: @@ -5785,7 +5867,6 @@ Yeni sürüm: %2 - WebM @@ -5819,19 +5900,8 @@ Yeni sürüm: %2 Format Format - - - MKV - - - - - AVI - - - MP4 @@ -5840,72 +5910,6 @@ Yeni sürüm: %2 4K 4K - - - HEVC - - - - - HEVC (NVENC) - - - - - VP8 - - - - - VP9 - - - - - FFV1 - - - - - - None - Hiçbiri - - - - FLAC - - - - - WavPack - - - - - Opus - - - - - Vorbis - - - - - MP3 - - - - - AAC - - - - - Uncompressed - Sıkıştırılmamış - Bitrate (kbps) @@ -5916,16 +5920,6 @@ Yeni sürüm: %2 ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5955,100 +5949,100 @@ Yeni sürüm: %2 QGBA::Window - + Archives (%1) ArÅŸivler (%1) - - + + Select ROM ROM seç - + Select folder Klasör seç - - + + Select save Kayıt seç - + Select patch Yama seç - + Patches (*.ips *.ups *.bps) Yamalar (*.ips *.ups *.bps) - + Select e-Reader dotcode e-Okuyucu nokta kodunu seç - + e-Reader card (*.raw *.bin *.bmp) e-Okuyucu kart (*.raw *.bin *.bmp) - + Select e-Reader card images e-Okuyucu kartından görüntüleri seç - + Image file (*.png *.jpg *.jpeg) Görüntü dosyası (*.png *.jpg *.jpeg) - + Conversion finished Dönüştürme tamamlandı - + %1 of %2 e-Reader cards converted successfully. %1 / %2 e-Okuyucu kartları dönüştürme tamamlandı. - + Select image Resim seç - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Resim dosyası (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) GameShark kayıtları (*.sps *.xps) - + Select video log Video günlüğü seç - + Video logs (*.mvl) Video günlükleri (*.mvl) - + Crash Çökme - + The game has crashed with the following error: %1 @@ -6057,679 +6051,689 @@ Yeni sürüm: %2 %1 - + Unimplemented BIOS call Uygulanmamış BIOS giriÅŸi - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Oyun BIOS dosyasına ihtiyacı var. Lütfen en iyi deneyim için resmi BIOS'u kullanın. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Uygun görüntü cihazı oluÅŸturma baÅŸarısız, yazılım ekranına dönülüyor. Oyunlar özellikle daha büyük ekranlarda yavaÅŸ çalışabilir. - + Really make portable? Taşınabilir yapılsın mı? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Öyküncünün yapılandırmasını yürütülebilir dosya ile aynı dizinden yüklemesini saÄŸlar. Devam etmek istiyor musunuz? - + Restart needed Yeniden baÅŸlatma gerekli - + Some changes will not take effect until the emulator is restarted. Bazı deÄŸiÅŸiklikler öyküncü yeniden baÅŸlatılıncaya kadar etkili olmaz. - + - Player %1 of %2 - + %1 - %2 - + %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File - + Load &ROM... &ROM yükle... - + Load ROM in archive... ROM'u arÅŸivden yükle ... - + Add folder to library... Kütüphaneye klasör ekle ... - + Save games Oyunları kaydet - + Automatically determine - + Use player %0 save game - + Load &patch... &Patch yükle... - + Boot BIOS BIOS boot et - + Replace ROM... ROM deÄŸiÅŸti... - + Create forwarder... - + Game state views - + + Log memory &accesses... + + + + Convert e-Reader card image to raw... e-Okuyucu kart resimlerini rawa dönüştür... - + ROM &info... ROM &info... - + Recent Son kullanılanlar - + Make portable Portatif yap - + &Load state &KaydedilmiÅŸ konum yükle - + Load state file... KaydedilmiÅŸ konum dosyası yükle... - + &Save state &Konumu kaydet - + Save state file... Konum dosyasını kaydet... - + Quick load Hızlı Yükle - + Quick save Hızlı kaydet - + Load recent En son yükle - + Save recent Hızlı kaydet - + Undo load state Kaydedilen konum yüklemeyi geri al - + Undo save state Konum kaydetmeyi geri al - - + + State &%1 Konum &%1 - + Load camera image... Kamera resmini yükle ... - + Convert save game... Kayıtlı oyun dömnüştürülüyor... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + New multiplayer window Yeni çokoyunculu ekranı - + Connect to Dolphin... Dolphin'e BaÄŸlan... - + Report bug... Hata rapor et... - + About... Hakkında... - + E&xit Çıkış - + &Emulation Emülasyon - + &Reset &Reset - + Sh&utdown Kapat - + Yank game pak - + &Pause &Durdur - + &Next frame &Sonraki kare - + Fast forward (held) Ä°leriye sar(basılı tutun) - + &Fast forward &Ä°leriye sar - + Fast forward speed Ä°leriye sarma hızı - + Unbounded - + %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) Geri sar (basılı tutun) - + Re&wind Geri sar - + Step backwards Geriye doÄŸru adım - + Solar sensor - + Increase solar level Solar seviyesini arttır - + Decrease solar level Solar seviyesini düşür - + Brightest solar level En parlak solar seviyesi - + Darkest solar level En karanlık solar seviyesi - + Brightness %1 Parlaklık:%1 - + Game Boy Printer... Game Boy yazıcısı... - + BattleChip Gate... - + Audio/&Video Ses/&Video - + Frame size Çerçeve boyutu - + Toggle fullscreen Tamekranı aç/kapa - + + &Lock frame size + + + + Lock aspect ratio En boy oranını kilitle - + Force integer scaling Tamsayılı ölçeklendirmeyi zorla - + Bilinear filtering Bilinear filtreleme - + Frame&skip Kare atlama - + Mute Sessiz - + FPS target FPS hedefi - + Native (59.7275) - + Take &screenshot Ekran görüntüsü al - + F12 - + Video layers - + Audio channels Ses kanalları - + Adjust layer placement... Katman yerleÅŸimini ayarlayın... - + &Tools &Araçlar - + View &logs... Kayıtları görüntüle... - + Game &overrides... & Oyunun üzerine yazılanlar... - + Couldn't Start BaÅŸlatılamadı - + Save games (%1) Kayıtlı oyunlar (%1) - + Select save game Kayıtlı oyun seç - + mGBA save state files (%1) mGBA kayıt durum dosyası (%1) - - + + Select save state Kayıt durumu seç - + Could not start game. Oyun baÅŸlatılamadı. - + Load alternate save game... Alternatif kayıtlı oyun yükle... - + Load temporary save game... Geçici kayıtlı oyunu yükle... - + Scan e-Reader dotcodes... e-Okuyucu noktakodları tara... - + Import GameShark Save... GameShark kaydını içeri aktar... - + Export GameShark Save... GameShark kaydını dışarı aktar... - + %1× %1× - + Interframe blending Kareler-arası Karıştırma - + Record A/V... A/V Kayıt... - + Record GIF/WebP/APNG... GIF/WebP/APNG Kayıt... - + Game Pak sensors... Oyun KartuÅŸ sensörleri... - + &Cheats... &Hileler... - + Settings... Ayarlar... - + Open debugger console... Hata ayıklayıcı konsolunu aç ... - + Start &GDB server... &GDB sunucusunu baÅŸlat... - + Scripting... - + View &palette... &Renk Paletini gör... - + View &sprites... &Spriteları gör... - + View &tiles... &Desenleri gör... - + View &map... &Haritayı gör - + &Frame inspector... &Kare denetçisi... - + View memory... Hafıza gör... - + Search memory... Hafızada ara... - + View &I/O registers... &I/O kayıtlarını görüntüle - + Record debug video log... Hata ayıklama video günlüğünü kaydet... - + Stop debug video log Hata ayıklama video günlüğünü durdur - + Exit fullscreen Tam ekrandan çık - + GameShark Button (held) GameShark Butonu (basılı tutun) - + Autofire Otomatik basma - + Autofire A Otomatik basma A - + Autofire B Otomatik basma B - + Autofire L Otomatik basma L - + Autofire R Otomatik basma R - + Autofire Start Otomatik basma Start - + Autofire Select Otomatik basma Select - + Autofire Up Otomatik basma Up - + Autofire Right Otomatik basma Right - + Autofire Down Otomatik basma Down - + Autofire Left Otomatik basma Sol - + Clear Temizle @@ -6767,17 +6771,17 @@ Yeni sürüm: %2 - + Super (L) Süper (L) - + Super (R) Süper (R) - + Menu Menü @@ -6785,22 +6789,22 @@ Yeni sürüm: %2 QShortcut - + Shift Shift - + Control Kontrol - + Alt Alt - + Meta Derece diff --git a/src/platform/qt/ts/mgba-zh_CN.ts b/src/platform/qt/ts/mgba-zh_CN.ts index 4e570c19626..0a0dfef755b 100644 --- a/src/platform/qt/ts/mgba-zh_CN.ts +++ b/src/platform/qt/ts/mgba-zh_CN.ts @@ -4,22 +4,22 @@ QGBA - + Game Boy Advance ROMs (%1) Game Boy Advance ROMs (%1) - + Game Boy ROMs (%1) Game Boy ROMs (%1) - + All ROMs (%1) 所有 ROMs (%1) - + %1 Video Logs (*.mvl) %1 视频日志 (*.mvl) @@ -191,17 +191,17 @@ Download size: %3 QGBA::AudioDevice - + Can't set format of context-less audio device æ— æ³•è®¾ç½®æ— ä¸Šä¸‹æ–‡éŸ³é¢‘è®¾å¤‡çš„æ ¼å¼ - + Audio device is missing its core 音频设备缺少其核心 - + Writing data to read-only audio device 将数æ®å†™å…¥åªè¯»éŸ³é¢‘设备 @@ -209,7 +209,7 @@ Download size: %3 QGBA::AudioProcessorQt - + Can't start an audio processor without input 没有输入无法å¯åŠ¨éŸ³é¢‘处ç†å™¨ @@ -285,28 +285,28 @@ Download size: %3 显示高级选项 - + BattleChip data missing 缺失 BattleChip æ•°æ® - + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? 缺少 BattleChip æ•°æ®ã€‚BattleChip Gate ä»ç„¶å¯ä»¥ä½¿ç”¨,但一些图形将会丢失。您è¦ç«‹å³ä¸‹è½½æ•°æ®å—? - - + + Select deck file 选择å¡åº§æ–‡ä»¶ - + Incompatible deck ä¸å…¼å®¹çš„å¡åº§ - + The selected deck is not compatible with this Chip Gate 选定的å¡åº§ä¸Žæ­¤ Chip Gate ä¸å…¼å®¹ @@ -367,19 +367,19 @@ Download size: %3 在此处输入代ç ... - - + + Autodetect (recommended) 自动检测(推è) - - + + Select cheats file 选择作弊ç æ–‡ä»¶ - + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. 无法添加æŸäº›ä½œå¼Šç ã€‚请确认它们的格å¼æ˜¯å¦æ­£ç¡®å¹¶ä¸”/或å°è¯•å…¶å®ƒçš„作弊类型。 @@ -398,37 +398,37 @@ Download size: %3 当å‰æœªå¼€å¯å€’带 - + Reset the game? è¦é‡ç½®æ¸¸æˆå—? - + Most games will require a reset to load the new save. Do you want to reset now? 大多数游æˆéœ€è¦é‡ç½®æ‰èƒ½åŠ è½½æ–°çš„存档。您è¦ç«‹å³é‡å¯å—? - + Failed to open save file: %1 打开存档失败: %1 - + Failed to open game file: %1 打开游æˆæ–‡ä»¶å¤±è´¥: %1 - + Can't yank pack in unexpected platform! 无法在æ„外平å°ä¸ŠæŠ½å‡ºå¡å¸¦ï¼ - + Failed to open snapshot file for reading: %1 读å–快照文件失败: %1 - + Failed to open snapshot file for writing: %1 写入快照文件失败: %1 @@ -477,6 +477,14 @@ Download size: %3 无法打开用于写入的 CLI åŽ†å² + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + QGBA::DolphinConnector @@ -757,52 +765,52 @@ Download size: %3 é‡ç½® - + Export frame 导出框架 - + Portable Network Graphics (*.png) 便æºå¼ç½‘络图形 (*.png) - + None æ—  - + Background 背景 - + Window çª—å£ - + Objwin Objwin - + Sprite ç²¾çµå›¾ - + Backdrop 背幕 - + Frame 帧 - + %1 %2 %1 %2 @@ -818,22 +826,22 @@ Download size: %3 QGBA::GBAKeyEditor - + Clear Button 清除按键 - + Clear Analog 清除模拟控制 - + Refresh 刷新 - + Set all 全部设置 @@ -3006,8 +3014,8 @@ Download size: %3 QGBA::KeyEditor - - + + --- --- @@ -3378,23 +3386,87 @@ Download size: %3 åž‚ç›´ - - - + + + N/A æ—  - + Export map 导出映射 - + Portable Network Graphics (*.png) 便æºå¼ç½‘络图形 (*.png) + + QGBA::MemoryAccessLogView + + + Memory access logging + + + + + Log file + + + + + Browse + æµè§ˆ + + + + Log additional information (uses 3× space) + + + + + Load existing file if present + + + + + Regions + + + + + Export ROM snapshot + + + + + Start + + + + + Stop + åœæ­¢ + + + + Failed to open memory log file + + + + + + Select access log file + + + + + Memory access logs (*.mal) + + + QGBA::MemoryDump @@ -3641,22 +3713,22 @@ Download size: %3 刷新 - + (%0/%1×) (%0/%1×) - + (â…Ÿ%0×) (â…Ÿ%0×) - + (%0×) (%0×) - + %1 byte%2 %1 字节%2 @@ -3750,17 +3822,17 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached å°è¯•æ–­å¼€ä¸Žæœªè¿žæŽ¥çš„多人玩家的连接 - + Trying to get player ID for a multiplayer player that's not attached å°è¯•èŽ·å–未连接的多人玩家的 ID - + Trying to get save ID for a multiplayer player that's not attached å°è¯•èŽ·å–未连接的多人玩家的存档 ID @@ -4157,35 +4229,35 @@ Download size: %3 导出 OBJ - + #%0 #%0 - + 0x%0 0x%0 + + - - 0x%0 (%1) 0x%0 (%1) - + Export palette å¯¼å‡ºè°ƒè‰²æ¿ - + Windows PAL (*.pal);;Adobe Color Table (*.act) Windows è°ƒè‰²æ¿ (*.pal);;Adobe 颜色表 (*.act) - + Failed to open output palette file: %1 打开输出调色æ¿æ–‡ä»¶å¤±è´¥: %1 @@ -4259,7 +4331,7 @@ Download size: %3 QGBA::ROMInfo - + @@ -4299,16 +4371,26 @@ Download size: %3 + Maker Code: + + + + + Revision: + + + + File size: 文件大å°: - + CRC32: CRC32: - + Save file: ä¿å­˜æ–‡ä»¶: @@ -4364,62 +4446,62 @@ Download size: %3 QGBA::SaveConverter - + Save games and save states (%1) ä¿å­˜æ¸¸æˆå’Œå³æ—¶å­˜æ¡£ (%1) - + Select save game or save state 选择ä¿å­˜æ¸¸æˆæˆ–å³æ—¶å­˜æ¡£ - + Save games (%1) ä¿å­˜æ¸¸æˆ (%1) - + Select save game 选择ä¿å­˜æ¸¸æˆ - + Conversion failed 转æ¢å¤±è´¥ - + Failed to convert the save game. This is probably a bug. 未能转æ¢ä¿å­˜æ¸¸æˆã€‚è¿™å¯èƒ½æ˜¯ä¸€ä¸ªé”™è¯¯ã€‚ - + No file selected 未选择文件 - + Could not open file 无法打开文件 - + No valid formats found æœªæ‰¾åˆ°æœ‰æ•ˆæ ¼å¼ - + Please select a valid input file 请选择一个有效的输入文件 - + No valid conversions found 未å‘çŽ°æœ‰æ•ˆè½¬æ¢ - + Cannot convert save games between platforms 无法在平å°ä¹‹é—´è½¬æ¢ä¿å­˜æ¸¸æˆ @@ -4445,97 +4527,97 @@ Download size: %3 输出文件 - + %1 %2 save game %1 %2 ä¿å­˜æ¸¸æˆ - + little endian å°ç«¯ - + big endian 大端 - + SRAM - + %1 flash %1 闪存 - + %1 EEPROM - + + RTC - + %1 SRAM + RTC - + %1 SRAM - + packed MBC2 包装的 MBC2 - + unpacked MBC2 未包装的 MBC2 - + MBC6 flash MBC6 闪存 - + MBC6 combined SRAM + flash MBC6组åˆSRAM+闪存 - + MBC6 SRAM MBC6 SRAM - + TAMA5 - + %1 (%2) %1(%2) - + %1 save state with embedded %2 save game 带嵌入的 %2 ä¿å­˜æ¸¸æˆçš„ %1 ä¿å­˜çŠ¶æ€ - + %1 SharkPort %2 save game %1 SharkPort %2 存档 - + %1 GameShark Advance SP %2 save game %1 GameShark Advance SP %2 存档 @@ -4571,32 +4653,37 @@ Download size: %3 载入历å²è„šæœ¬ - + Load script... 载入脚本... - + + &Load most recent + + + + &Reset é‡ç½®(&R) - + 0 - + Select script to load 选择è¦è½½å…¥çš„脚本 - + Lua scripts (*.lua) Lua 脚本 (*.lua) - + All files (*.*) 所有文件 (*.*) @@ -4689,112 +4776,112 @@ Download size: %3 QGBA::SettingsView - - + + Qt Multimedia Qt Multimedia - + SDL SDL - + Software (Qt) 软件渲染 (Qt) - + OpenGL OpenGL - + OpenGL (force version 1.x) OpenGL (强制版本 1.x) - + None æ—  - + None (Still Image) æ—  (é™æ­¢å›¾åƒ) - + Keyboard 键盘 - + Controllers 控制器 - + Shortcuts å¿«æ·é”® - - + + Shaders ç€è‰²å™¨ - + Select BIOS 选择 BIOS - + Select directory 选择目录 - + Select image 选择图片 - + Image file (*.png *.jpg *.jpeg) 图åƒæ–‡ä»¶ï¼ˆ*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never ä»Žä¸ - + Just now 刚刚 - + Less than an hour ago ä¸åˆ°ä¸€å°æ—¶å‰ - + %n hour(s) ago %n å°æ—¶å‰ - + %n day(s) ago %n å¤©å‰ @@ -5120,37 +5207,37 @@ Download size: %3 ç«‹å³æ£€æŸ¥æ›´æ–° - + Default color palette only åªä½¿ç”¨é»˜è®¤è°ƒè‰²æ¿ - + SGB color palette if available å¯ç”¨æ—¶ä½¿ç”¨ SGB è°ƒè‰²æ¿ - + GBC color palette if available å¯ç”¨æ—¶ä½¿ç”¨ GBC è°ƒè‰²æ¿ - + SGB (preferred) or GBC color palette if available å¯ç”¨æ—¶ä½¿ç”¨ SGB(首选)或 GBC è°ƒè‰²æ¿ - + Game Boy Camera Game Boy Camera - + Driver: 驱动: - + Source: æ¥æºï¼š @@ -5327,42 +5414,42 @@ Download size: %3 载入存档附加数æ®ï¼š - + Models åž‹å· - + GB only: ä»… GB: - + SGB compatible: 兼容 SGB: - + GBC only: ä»… GBC: - + GBC compatible: 兼容 GBC: - + SGB and GBC compatible: 兼容 SGB å’Œ GBC: - + Game Boy palette Game Boy è°ƒè‰²æ¿ - + Preset: 预设: @@ -5399,135 +5486,130 @@ Download size: %3 软件 - + OpenGL enhancements OpenGL 增强 - + High-resolution scale: 高分辨率比例: - + (240×160) (240×160) - - XQ GBA audio (experimental) - XQ GBA 音频 (实验性) - - - + GB BIOS file: GB BIOS 文件: - - - - - - - - - + + + + + + + + + Browse æµè§ˆ - + Use BIOS file if found 当å¯ç”¨æ—¶ä½¿ç”¨ BIOS 文件 - + Skip BIOS intro 跳过 BIOS å¯åŠ¨ç”»é¢ - + GBA BIOS file: GBA BIOS 文件: - + GBC BIOS file: GBC BIOS 文件: - + SGB BIOS file: SGB BIOS 文件: - + Save games 游æˆå­˜æ¡£ - - - - - + + + + + Same directory as the ROM 与 ROM æ‰€åœ¨ç›®å½•ç›¸åŒ - + Save states å³æ—¶å­˜æ¡£ - + Screenshots 截图 - + Patches è¡¥ä¸ - + Cheats ä½œå¼Šç  - + Log to file 记录日志到文件 - + Log to console è®°å½•æ—¥å¿—åˆ°æŽ§åˆ¶å° - + Select Log File 选择日志文件 - + Default BG colors: 默认背景色: - + Default sprite colors 1: 默认精çµå›¾é¢œè‰² 1: - + Default sprite colors 2: 默认精çµå›¾é¢œè‰² 2: - + Super Game Boy borders Super Game Boy 边框 @@ -5785,13 +5867,11 @@ Download size: %3 - WebM WebM - MP4 MP4 @@ -5830,82 +5910,6 @@ Download size: %3 Format æ ¼å¼ - - - MKV - MKV - - - - AVI - AVI - - - - HEVC - HEVC - - - - HEVC (NVENC) - HEVC (NVENC) - - - - VP8 - VP8 - - - - VP9 - VP9 - - - - FFV1 - FFV1 - - - - - None - æ—  - - - - FLAC - FLAC - - - - WavPack - WavPack - - - - Opus - Opus - - - - Vorbis - Vorbis - - - - MP3 - MP3 - - - - AAC - AAC - - - - Uncompressed - 未压缩 - Bitrate (kbps) @@ -5916,16 +5920,6 @@ Download size: %3 ABR ABR - - - H.264 - H.264 - - - - H.264 (NVENC) - H.264 (NVENC) - VBR @@ -5955,80 +5949,80 @@ Download size: %3 QGBA::Window - + Archives (%1) 压缩文件 (%1) - - + + Select ROM 选择 ROM - + Select folder 选择文件夹 - - + + Select save 选择存档 - + Select patch é€‰æ‹©è¡¥ä¸ - + Patches (*.ips *.ups *.bps) è¡¥ä¸ (*.ips *.ups *.bps) - + Select e-Reader dotcode 选择 e-Reader ç‚¹ç  - + e-Reader card (*.raw *.bin *.bmp) e-Reader å¡ (*.raw *.bin *.bmp) - + Select image 选择图片 - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) 图åƒæ–‡ä»¶ (*.png *.gif *.jpg *.jpeg);;所有文件 (*) - + GameShark saves (*.sps *.xps) GameShark 存档 (*.sps *.xps) - + Select video log 选择视频日志 - + Video logs (*.mvl) 视频日志文件 (*.mvl) - + Crash 崩溃 - + The game has crashed with the following error: %1 @@ -6037,699 +6031,709 @@ Download size: %3 %1 - + Couldn't Start 无法å¯åŠ¨ - + Could not start game. 无法å¯åŠ¨æ¸¸æˆã€‚ - + Unimplemented BIOS call 未实现的 BIOS 调用 - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. 此游æˆä½¿ç”¨å°šæœªå®žçŽ°çš„ BIOS 调用。请使用官方 BIOS 以获得最佳体验。 - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. 无法创建适åˆçš„显示设备,正在回滚到软件显示。游æˆçš„è¿è¡Œé€Ÿåº¦ï¼ˆç‰¹åˆ«åœ¨å¤§çª—å£çš„情况下)å¯èƒ½ä¼šå˜æ…¢ã€‚ - + Really make portable? 确定进行程åºä¾¿æºåŒ–? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? 进行此æ“作åŽï¼Œæ¨¡æ‹Ÿå™¨å°†ä»Žå…¶å¯æ‰§è¡Œæ–‡ä»¶æ‰€åœ¨ç›®å½•ä¸­è½½å…¥æ¨¡æ‹Ÿå™¨é…置。您想继续å—? - + Restart needed 需è¦é‡æ–°å¯åŠ¨ - + Some changes will not take effect until the emulator is restarted. 更改将在模拟器下次é‡æ–°å¯åŠ¨æ—¶ç”Ÿæ•ˆã€‚ - + - Player %1 of %2 - 玩家 %1 å…± %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File 文件(&F) - + Load &ROM... 载入 ROM(&R)... - + Load ROM in archive... 从压缩文件中载入 ROM... - + Add folder to library... 将文件夹添加到库中... - + Save games (%1) ä¿å­˜æ¸¸æˆ (%1) - + Select save game 选择ä¿å­˜æ¸¸æˆ - + mGBA save state files (%1) mGBA å³æ—¶å­˜æ¡£æ–‡ä»¶ (%1) - - + + Select save state 选择å³æ—¶å­˜æ¡£ - + Select e-Reader card images 选择 e-Reader å¡ç‰‡å›¾åƒ - + Image file (*.png *.jpg *.jpeg) 图åƒæ–‡ä»¶ï¼ˆ*.png *.jpg *.jpeg) - + Conversion finished 转æ¢å®Œæˆ - + %1 of %2 e-Reader cards converted successfully. æˆåŠŸè½¬æ¢äº† %1 张(共 %2 张)e-Reader å¡ç‰‡ã€‚ - + Load alternate save game... 加载备用ä¿å­˜æ¸¸æˆ... - + Load temporary save game... 加载临时ä¿å­˜æ¸¸æˆ... - + Load &patch... 载入补ä¸(&P)... - + Boot BIOS 引导 BIOS - + Replace ROM... æ›¿æ¢ ROM... - + Scan e-Reader dotcodes... 扫æ e-Reader 点ç ... - + Convert e-Reader card image to raw... å°† e-Reader å¡ç‰‡å›¾åƒè½¬æ¢ä¸ºåŽŸå§‹æ•°æ®... - + ROM &info... ROM ä¿¡æ¯(&I)... - + Recent 最近打开 - + Make portable 程åºä¾¿æºåŒ– - + &Load state 载入å³æ—¶å­˜æ¡£(&L) - + Load state file... 载入å³æ—¶å­˜æ¡£æ–‡ä»¶... - + &Save state ä¿å­˜å³æ—¶å­˜æ¡£(&S) - + Save state file... ä¿å­˜å³æ—¶å­˜æ¡£æ–‡ä»¶... - + Quick load 快速读档 - + Quick save 快速存档 - + Load recent 载入最近存档 - + Save recent ä¿å­˜æœ€è¿‘存档 - + Undo load state 撤消读档 - + Undo save state 撤消存档 - - + + State &%1 å³æ—¶å­˜æ¡£ (&%1) - + Load camera image... 载入相机图片... - + Convert save game... 转æ¢ä¿å­˜æ¸¸æˆ... - + GameShark saves (*.gsv *.sps *.xps) GameShark 存档 (*.gsv *.sps *.xps) - + Reset needed 需è¦é‡å¯ - + Some changes will not take effect until the game is reset. æŸäº›æ”¹åŠ¨éœ€è¦é‡æ–°å¯åŠ¨æ‰ä¼šç”Ÿæ•ˆã€‚ - + Save games 游æˆå­˜æ¡£ - + Import GameShark Save... 导入 GameShark 存档... - + Export GameShark Save... 导出 GameShark 存档... - + Automatically determine 自动终止 - + Use player %0 save game 使用玩家 %0 存档 - + New multiplayer window 新建多人游æˆçª—å£ - + Connect to Dolphin... 连接到 Dolphin... - + Report bug... 报告错误... - + About... 关于... - + E&xit 退出(&X) - + &Emulation 模拟(&E) - + &Reset é‡ç½®(&R) - + Sh&utdown 关机(&U) - + Yank game pak 快速抽出游æˆå¡å¸¦ - + &Pause æš‚åœ(&P) - + &Next frame 下一帧(&N) - + Fast forward (held) å¿«è¿› (长按) - + &Fast forward å¿«è¿›(&F) - + Fast forward speed 快进速度 - + Unbounded ä¸é™åˆ¶ - + %0x %0x - + Increase fast forward speed 加快快进速度 - + Decrease fast forward speed é™ä½Žå¿«è¿›é€Ÿåº¦ - + Rewind (held) 倒带 (长按) - + Re&wind 倒带(&W) - + Step backwards 步退 - + Solar sensor 太阳光传感器 - + Increase solar level 增加太阳光等级 - + Decrease solar level é™ä½Žå¤ªé˜³å…‰ç­‰çº§ - + Brightest solar level 太阳光等级为最亮 - + Darkest solar level 太阳光等级为最暗 - + Brightness %1 亮度 %1 - + Game Boy Printer... Game Boy 打å°æœº... - + BattleChip Gate... BattleChip Gate... - + Audio/&Video 音频/视频(&V) - + Frame size ç”»é¢å¤§å° - + %1× %1× - + Toggle fullscreen 切æ¢å…¨å± - + + &Lock frame size + + + + Lock aspect ratio é”定纵横比 - + Force integer scaling 强制整数缩放 - + Interframe blending å¸§é—´æ··åˆ - + Bilinear filtering åŒçº¿æ€§è¿‡æ»¤ - + Frame&skip 跳帧(&S) - + Mute é™éŸ³ - + FPS target 目标 FPS - + Native (59.7275) 原生 (59.7275) - + Take &screenshot 截图(&S) - + F12 F12 - + Record A/V... 录制音频/视频... - + Record GIF/WebP/APNG... 录制 GIF/WebP/APNG... - + Video layers 视频图层 - + Audio channels éŸ³é¢‘å£°é“ - + Adjust layer placement... 调整图层布局... - + &Tools 工具(&T) - + View &logs... 查看日志(&L)... - + Game &overrides... 覆写游æˆ(&O)... - + Game Pak sensors... 游æˆå¡å¸¦ä¼ æ„Ÿå™¨... - + &Cheats... 作弊ç (&C)... - + Create forwarder... 创建转å‘器... - + Settings... 设置... - + Open debugger console... 打开调试器控制å°... - + Start &GDB server... 打开 GDB æœåŠ¡å™¨(&G)... - + Scripting... 脚本... - + Game state views 游æˆçŠ¶æ€è§†å›¾ - + View &palette... 查看调色æ¿(&P)... - + View &sprites... 查看精çµå›¾(&S)... - + View &tiles... 查看图å—(&T)... - + View &map... 查看映射(&M)... - + &Frame inspector... 帧检查器(&F)... - + View memory... 查看内存... - + Search memory... æœç´¢å†…å­˜... - + View &I/O registers... 查看 I/O 寄存器(&I)... - + + Log memory &accesses... + + + + Record debug video log... 记录调试视频日志... - + Stop debug video log åœæ­¢è®°å½•è°ƒè¯•è§†é¢‘日志 - + Exit fullscreen é€€å‡ºå…¨å± - + GameShark Button (held) GameShark é”® (长按) - + Autofire è¿žå‘ - + Autofire A è¿žå‘ A - + Autofire B è¿žå‘ B - + Autofire L è¿žå‘ L - + Autofire R è¿žå‘ R - + Autofire Start è¿žå‘ Start - + Autofire Select è¿žå‘ Select - + Autofire Up è¿žå‘ ä¸Š - + Autofire Right è¿žå‘ å³ - + Autofire Down è¿žå‘ ä¸‹ - + Autofire Left è¿žå‘ å·¦ - + Clear 清除 @@ -6767,17 +6771,17 @@ Download size: %3 ? - + Super (L) Super (L) - + Super (R) Super (R) - + Menu èœå• @@ -6785,22 +6789,22 @@ Download size: %3 QShortcut - + Shift Shift - + Control Control - + Alt Alt - + Meta Meta From 271c6dc1298f07eb34338f886fe2dbdcfdc04ceb Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 16 Sep 2024 03:51:08 -0700 Subject: [PATCH 197/338] Res: Update gba-colors shader (closes #2976) --- res/shaders/gba-color.shader/gba-color.fs | 35 +++++++---------------- res/shaders/gba-color.shader/gba-color.vs | 34 ++++++++++++++++++++++ res/shaders/gba-color.shader/manifest.ini | 8 ++++++ 3 files changed, 53 insertions(+), 24 deletions(-) create mode 100644 res/shaders/gba-color.shader/gba-color.vs diff --git a/res/shaders/gba-color.shader/gba-color.fs b/res/shaders/gba-color.shader/gba-color.fs index 09177ddfee3..461228c2011 100644 --- a/res/shaders/gba-color.shader/gba-color.fs +++ b/res/shaders/gba-color.shader/gba-color.fs @@ -1,34 +1,21 @@ +// Shader that replicates the LCD Colorspace from Gameboy Advance -- varying vec2 texCoord; +varying mat4 profile; uniform sampler2D tex; uniform vec2 texSize; uniform float darken_screen; -const float target_gamma = 2.2; -const float display_gamma = 2.5; -const float sat = 1.0; -const float lum = 0.99; -const float contrast = 1.0; -const vec3 bl = vec3(0.0, 0.0, 0.0); -const vec3 r = vec3(0.84, 0.09, 0.15); -const vec3 g = vec3(0.18, 0.67, 0.10); -const vec3 b = vec3(0.0, 0.26, 0.73); +const float target_gamma = 2.0; +const float display_gamma = 2.0; void main() { + // bring out our stored luminance value + float lum = profile[3].w; + + // our adjustments need to happen in linear gamma vec4 screen = pow(texture2D(tex, texCoord), vec4(target_gamma + darken_screen)).rgba; - vec4 avglum = vec4(0.5); - screen = mix(screen, avglum, (1.0 - contrast)); - - mat4 color = mat4( r.r, r.g, r.b, 0.0, - g.r, g.g, g.b, 0.0, - b.r, b.g, b.b, 0.0, - bl.r, bl.g, bl.b, 1.0); - - mat4 adjust = mat4( (1.0 - sat) * 0.3086 + sat, (1.0 - sat) * 0.3086, (1.0 - sat) * 0.3086, 1.0, - (1.0 - sat) * 0.6094, (1.0 - sat) * 0.6094 + sat, (1.0 - sat) * 0.6094, 1.0, - (1.0 - sat) * 0.0820, (1.0 - sat) * 0.0820, (1.0 - sat) * 0.0820 + sat, 1.0, - 0.0, 0.0, 0.0, 1.0); - color *= adjust; + screen = clamp(screen * lum, 0.0, 1.0); - screen = color * screen; - gl_FragColor = pow(screen, vec4(1.0 / display_gamma + (darken_screen * 0.125))); + screen = profile * screen; + gl_FragColor = pow(screen, vec4(1.0 / display_gamma)); } diff --git a/res/shaders/gba-color.shader/gba-color.vs b/res/shaders/gba-color.shader/gba-color.vs new file mode 100644 index 00000000000..bbf4062788c --- /dev/null +++ b/res/shaders/gba-color.shader/gba-color.vs @@ -0,0 +1,34 @@ +uniform int color_mode; +attribute vec4 position; +varying vec2 texCoord; +varying mat4 profile; + +const mat4 GBA_sRGB = mat4( + 0.80, 0.135, 0.195, 0.0, //red channel + 0.275, 0.64, 0.155, 0.0, //green channel + -0.075, 0.225, 0.65, 0.0, //blue channel + 0.0, 0.0, 0.0, 0.93 //alpha channel +); + +const mat4 GBA_DCI = mat4( + 0.685, 0.16, 0.20, 0.0, //red channel + 0.34, 0.629, 0.19, 0.0, //green channel + -0.025, 0.211, 0.61, 0.0, //blue channel + 0.0, 0.0, 0.0, 0.975 //alpha channel +); + +const mat4 GBA_Rec2020 = mat4( + 0.555, 0.1825, 0.20, 0.0, //red channel + 0.395, 0.61, 0.195, 0.0, //green channel + 0.05, 0.2075, 0.605, 0.0, //blue channel + 0.0, 0.0, 0.0, 1.0 //alpha channel +); + +void main() { + if (color_mode == 1) profile = GBA_sRGB; + else if (color_mode == 2) profile = GBA_DCI; + else if (color_mode == 3) profile = GBA_Rec2020; + + gl_Position = position; + texCoord = (position.st + vec2(1.0, 1.0)) * vec2(0.5, 0.5); +} diff --git a/res/shaders/gba-color.shader/manifest.ini b/res/shaders/gba-color.shader/manifest.ini index 8f9735aa31c..ed16900cd83 100644 --- a/res/shaders/gba-color.shader/manifest.ini +++ b/res/shaders/gba-color.shader/manifest.ini @@ -6,6 +6,7 @@ passes=1 [pass.0] fragmentShader=gba-color.fs +vertexShader=gba-color.vs blend=1 width=-1 height=-1 @@ -14,3 +15,10 @@ height=-1 type=float default=0.5 readableName=Darken Screen + +[pass.0.uniform.color_mode] +type=int +default=1 +min=1 +max=3 +readableName=Color Profile (1=sRGB, 2=DCI, 3=Rec2020) From 11787df6cd48e93ef4552b1b61393d5a734fe3c0 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 16 Sep 2024 03:58:39 -0700 Subject: [PATCH 198/338] Res: Port NSO-gba-colors shader (closes #2834) --- CHANGES | 1 + res/shaders/nso-gba-color.shader/manifest.ini | 24 +++++++++++++ .../nso-gba-color.shader/nso-gba-color.fs | 21 ++++++++++++ .../nso-gba-color.shader/nso-gba-color.vs | 34 +++++++++++++++++++ 4 files changed, 80 insertions(+) create mode 100644 res/shaders/nso-gba-color.shader/manifest.ini create mode 100644 res/shaders/nso-gba-color.shader/nso-gba-color.fs create mode 100644 res/shaders/nso-gba-color.shader/nso-gba-color.vs diff --git a/CHANGES b/CHANGES index 3aef9e24604..ef075bd9cba 100644 --- a/CHANGES +++ b/CHANGES @@ -52,6 +52,7 @@ Misc: - Qt: Remove maligned double-click-to-fullscreen shortcut (closes mgba.io/i/2632) - Qt: Pass logging context through to video proxy thread (fixes mgba.io/i/3095) - Qt: Show maker code and game version in ROM info + - Res: Port NSO-gba-colors shader (closes mgba.io/i/2834) - Scripting: Add `callbacks:oneshot` for single-call callbacks - Switch: Add bilinear filtering option (closes mgba.io/i/3111) - Vita: Add imc0 and xmc0 mount point support diff --git a/res/shaders/nso-gba-color.shader/manifest.ini b/res/shaders/nso-gba-color.shader/manifest.ini new file mode 100644 index 00000000000..42faa25bd58 --- /dev/null +++ b/res/shaders/nso-gba-color.shader/manifest.ini @@ -0,0 +1,24 @@ +[shader] +name=NSO GBA Color +author=Pokefan531 and hunterk +description=Shader that replicates the Nintendo Switch Online's GBA color filter. +passes=1 + +[pass.0] +fragmentShader=nso-gba-color.fs +vertexShader=nso-gba-color.vs +blend=1 +width=-1 +height=-1 + +[pass.0.uniform.darken_screen] +type=float +default=0.8 +readableName=Darken Screen + +[pass.0.uniform.color_mode] +type=int +default=1 +min=1 +max=3 +readableName=Color Profile (1=sRGB, 2=DCI, 3=Rec2020) diff --git a/res/shaders/nso-gba-color.shader/nso-gba-color.fs b/res/shaders/nso-gba-color.shader/nso-gba-color.fs new file mode 100644 index 00000000000..8d8a0ec928e --- /dev/null +++ b/res/shaders/nso-gba-color.shader/nso-gba-color.fs @@ -0,0 +1,21 @@ +// Shader that replicates the LCD Colorspace from Gameboy Advance -- +varying vec2 texCoord; +varying mat4 profile; +uniform sampler2D tex; +uniform vec2 texSize; + +uniform float darken_screen; +const float target_gamma = 2.2; +const float display_gamma = 2.2; + +void main() { + // bring out our stored luminance value + float lum = profile[3].w; + + // our adjustments need to happen in linear gamma + vec4 screen = pow(texture2D(tex, texCoord), vec4(target_gamma + darken_screen)).rgba; + + screen = clamp(screen * lum, 0.0, 1.0); + screen = profile * screen; + gl_FragColor = pow(screen, vec4(1.0 / display_gamma)); +} diff --git a/res/shaders/nso-gba-color.shader/nso-gba-color.vs b/res/shaders/nso-gba-color.shader/nso-gba-color.vs new file mode 100644 index 00000000000..c9c89181b8c --- /dev/null +++ b/res/shaders/nso-gba-color.shader/nso-gba-color.vs @@ -0,0 +1,34 @@ +uniform int color_mode; +attribute vec4 position; +varying vec2 texCoord; +varying mat4 profile; + +const mat4 GBA_sRGB = mat4( + 0.865, 0.0575, 0.0575, 0.0, //red channel + 0.1225, 0.925, 0.1225, 0.0, //green channel + 0.0125, 0.0125, 0.82, 0.0, //blue channel + 0.0, 0.0, 0.0, 1.0 //alpha channel +); + +const mat4 GBA_DCI = mat4( + 0.72, 0.0875, 0.0725, 0.0, //red channel + 0.2675, 0.9, 0.185, 0.0, //green channel + 0.0125, 0.0125, 0.7425, 0.0, //blue channel + 0.0, 0.0, 0.0, 1.0 //alpha channel +); + +const mat4 GBA_Rec2020 = mat4( + 0.57, 0.115, 0.0725, 0.0, //red channel + 0.3825, 0.8625, 0.195, 0.0, //green channel + 0.0475, 0.0225, 0.7325, 0.0, //blue channel + 0.0, 0.0, 0.0, 1.0 //alpha channel +); + +void main() { + if (color_mode == 1) profile = GBA_sRGB; + else if (color_mode == 2) profile = GBA_DCI; + else if (color_mode == 3) profile = GBA_Rec2020; + + gl_Position = position; + texCoord = (position.st + vec2(1.0, 1.0)) * vec2(0.5, 0.5); +} From c64dbd6631d0eed88b6ef1cbceddc47cde3000ec Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 19 Sep 2024 00:05:58 -0700 Subject: [PATCH 199/338] Qt: Make window corners square on Windows 11 (fixes #3285) --- CHANGES | 1 + src/platform/qt/Window.cpp | 9 +++++++++ 2 files changed, 10 insertions(+) diff --git a/CHANGES b/CHANGES index ef075bd9cba..f225b8b1508 100644 --- a/CHANGES +++ b/CHANGES @@ -52,6 +52,7 @@ Misc: - Qt: Remove maligned double-click-to-fullscreen shortcut (closes mgba.io/i/2632) - Qt: Pass logging context through to video proxy thread (fixes mgba.io/i/3095) - Qt: Show maker code and game version in ROM info + - Qt: Make window corners square on Windows 11 (fixes mgba.io/i/3285) - Res: Port NSO-gba-colors shader (closes mgba.io/i/2834) - Scripting: Add `callbacks:oneshot` for single-call callbacks - Switch: Add bilinear filtering option (closes mgba.io/i/3111) diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index 010dde78289..0e3d73b00ce 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -14,6 +14,10 @@ #include #include +#ifdef Q_OS_WIN +#include +#endif + #ifdef USE_SQLITE3 #include "ArchiveInspector.h" #include "library/LibraryController.h" @@ -717,6 +721,11 @@ void Window::showEvent(QShowEvent* event) { return; } m_wasOpened = true; +#ifdef Q_OS_WIN + HWND hwnd = reinterpret_cast(winId()); + DWM_WINDOW_CORNER_PREFERENCE cornerPref = DWMWCP_DONOTROUND; + DwmSetWindowAttribute(hwnd, DWMWA_WINDOW_CORNER_PREFERENCE, &cornerPref, sizeof(cornerPref)); +#endif if (m_initialSize.isValid()) { resizeFrame(m_initialSize); } From f75f9fd5fdf0868a01732a60aa5b971e828ebecd Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 19 Sep 2024 01:01:35 -0700 Subject: [PATCH 200/338] Appveyor: Use Windows 11 SDK --- .appveyor.yml | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/.appveyor.yml b/.appveyor.yml index 552fdbd2f83..586eb059e47 100644 --- a/.appveyor.yml +++ b/.appveyor.yml @@ -12,7 +12,11 @@ install: - vcpkg --no-dry-run upgrade - rd /Q /S C:\Tools\vcpkg\buildtrees before_build: -- cmake . -DCMAKE_PREFIX_PATH=C:\Qt\5.15\msvc2019_64 -DCMAKE_TOOLCHAIN_FILE=C:\Tools\vcpkg\scripts\buildsystems\vcpkg.cmake -DVCPKG_TARGET_TRIPLET=x64-windows-release -DCMAKE_CONFIGURATION_TYPES=Release +- cmake . -DCMAKE_PREFIX_PATH=C:\Qt\5.15\msvc2019_64 \ + -DCMAKE_TOOLCHAIN_FILE=C:\Tools\vcpkg\scripts\buildsystems\vcpkg.cmake \ + -DVCPKG_TARGET_TRIPLET=x64-windows-release \ + -DCMAKE_CONFIGURATION_TYPES=Release \ + -DCMAKE_SYSTEM_VERSION=10.0.22000.1 build: parallel: true project: mGBA.sln From 49fa1a30c581cd868365c76d6136885a1bdcf238 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 19 Sep 2024 02:09:20 -0700 Subject: [PATCH 201/338] Qt: Fix Windows shared build --- src/platform/qt/CMakeLists.txt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index 041ad0830a6..51aa22401f3 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -427,6 +427,7 @@ set_target_properties(${BINARY_NAME}-qt PROPERTIES MACOSX_BUNDLE_INFO_PLIST ${PR if(WIN32) set_target_properties(${BINARY_NAME}-qt PROPERTIES RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}") + target_link_libraries(${BINARY_NAME}-qt dwmapi) if(NOT MSVC) target_link_libraries(${BINARY_NAME}-qt -municode) endif() @@ -445,7 +446,7 @@ if(QT_STATIC) if(CMAKE_CROSSCOMPILING) set(QWINDOWS_DEPS ${QT}EventDispatcherSupport ${QT}FontDatabaseSupport ${QT}ThemeSupport ${QT}WindowsUIAutomationSupport) endif() - list(APPEND QT_LIBRARIES ${QT}::QWindowsIntegrationPlugin ${QWINDOWS_DEPS} amstrmid dwmapi uxtheme imm32 -static-libgcc -static-libstdc++) + list(APPEND QT_LIBRARIES ${QT}::QWindowsIntegrationPlugin ${QWINDOWS_DEPS} amstrmid uxtheme imm32 -static-libgcc -static-libstdc++) set_target_properties(${QT}::Core PROPERTIES INTERFACE_LINK_LIBRARIES "${QTPCRE};version;winmm;ssl;crypto;ws2_32;iphlpapi;crypt32;userenv;netapi32;wtsapi32") set_target_properties(${QT}::Gui PROPERTIES INTERFACE_LINK_LIBRARIES ${OPENGL_LIBRARY} ${OPENGLES2_LIBRARY}) elseif(APPLE) From 1636078b34195b9801748eed68a7641771b7ef96 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 20 Sep 2024 03:12:06 -0700 Subject: [PATCH 202/338] GBA I/O: Fix audio register 8-bit write behavior (fixes #3086) --- CHANGES | 1 + src/gba/io.c | 106 ++++++++++++++++++++++++++++++++++++++++++++++----- 2 files changed, 98 insertions(+), 9 deletions(-) diff --git a/CHANGES b/CHANGES index f225b8b1508..9a1694d6938 100644 --- a/CHANGES +++ b/CHANGES @@ -16,6 +16,7 @@ Emulation fixes: - GBA: Add baseline CP0 (Wii U VC) and CP1 (DCC) implementations - GBA GPIO: Fix gyro read-out start (fixes mgba.io/i/3141) - GBA I/O: Fix HALTCNT access behavior (fixes mgba.io/i/2309) + - GBA I/O: Fix audio register 8-bit write behavior (fixes mgba.io/i/3086) - GBA Serialize: Fix some minor save state edge cases - GBA SIO: Fix MULTI mode SIOCNT bit 7 writes on secondary GBAs (fixes mgba.io/i/3110) - GBA Video: Disable BG target 1 blending when OBJ blending (fixes mgba.io/i/2722) diff --git a/src/gba/io.c b/src/gba/io.c index 397eb925366..8853e4d6fb9 100644 --- a/src/gba/io.c +++ b/src/gba/io.c @@ -326,17 +326,19 @@ void GBAIOWrite(struct GBA* gba, uint32_t address, uint16_t value) { break; case GBA_REG_SOUND1CNT_HI: GBAAudioWriteSOUND1CNT_HI(&gba->audio, value); + value &= 0xFFC0; break; case GBA_REG_SOUND1CNT_X: GBAAudioWriteSOUND1CNT_X(&gba->audio, value); - value &= 0x47FF; + value &= 0x4000; break; case GBA_REG_SOUND2CNT_LO: GBAAudioWriteSOUND2CNT_LO(&gba->audio, value); + value &= 0xFFC0; break; case GBA_REG_SOUND2CNT_HI: GBAAudioWriteSOUND2CNT_HI(&gba->audio, value); - value &= 0x47FF; + value &= 0x4000; break; case GBA_REG_SOUND3CNT_LO: GBAAudioWriteSOUND3CNT_LO(&gba->audio, value); @@ -344,16 +346,15 @@ void GBAIOWrite(struct GBA* gba, uint32_t address, uint16_t value) { break; case GBA_REG_SOUND3CNT_HI: GBAAudioWriteSOUND3CNT_HI(&gba->audio, value); - value &= 0xE03F; + value &= 0xE000; break; case GBA_REG_SOUND3CNT_X: GBAAudioWriteSOUND3CNT_X(&gba->audio, value); - // TODO: The low bits need to not be readable, but still 8-bit writable - value &= 0x47FF; + value &= 0x4000; break; case GBA_REG_SOUND4CNT_LO: GBAAudioWriteSOUND4CNT_LO(&gba->audio, value); - value &= 0xFF3F; + value &= 0xFF00; break; case GBA_REG_SOUND4CNT_HI: GBAAudioWriteSOUND4CNT_HI(&gba->audio, value); @@ -585,9 +586,96 @@ void GBAIOWrite8(struct GBA* gba, uint32_t address, uint8_t value) { if (address > GBA_SIZE_IO) { return; } - uint16_t value16 = value << (8 * (address & 1)); - value16 |= (gba->memory.io[(address & (GBA_SIZE_IO - 1)) >> 1]) & ~(0xFF << (8 * (address & 1))); - GBAIOWrite(gba, address & 0xFFFFFFFE, value16); + uint16_t value16; + + switch (address) { + case GBA_REG_SOUND1CNT_HI: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR11(&gba->audio.psg, value); + gba->memory.io[GBA_REG(SOUND1CNT_HI)] &= 0xFF00; + gba->memory.io[GBA_REG(SOUND1CNT_HI)] |= value & 0xC0; + break; + case GBA_REG_SOUND1CNT_HI + 1: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR12(&gba->audio.psg, value); + gba->memory.io[GBA_REG(SOUND1CNT_HI)] &= 0x00C0; + gba->memory.io[GBA_REG(SOUND1CNT_HI)] |= value << 8; + break; + case GBA_REG_SOUND1CNT_X: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR13(&gba->audio.psg, value); + break; + case GBA_REG_SOUND1CNT_X + 1: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR14(&gba->audio.psg, value); + gba->memory.io[GBA_REG(SOUND1CNT_X)] = (value & 0x40) << 8; + break; + case GBA_REG_SOUND2CNT_LO: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR21(&gba->audio.psg, value); + gba->memory.io[GBA_REG(SOUND2CNT_LO)] &= 0xFF00; + gba->memory.io[GBA_REG(SOUND2CNT_LO)] |= value & 0xC0; + break; + case GBA_REG_SOUND2CNT_LO + 1: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR22(&gba->audio.psg, value); + gba->memory.io[GBA_REG(SOUND2CNT_LO)] &= 0x00C0; + gba->memory.io[GBA_REG(SOUND2CNT_LO)] |= value << 8; + break; + case GBA_REG_SOUND2CNT_HI: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR23(&gba->audio.psg, value); + break; + case GBA_REG_SOUND2CNT_HI + 1: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR24(&gba->audio.psg, value); + gba->memory.io[GBA_REG(SOUND2CNT_HI)] = (value & 0x40) << 8; + break; + case GBA_REG_SOUND3CNT_HI: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR31(&gba->audio.psg, value); + break; + case GBA_REG_SOUND3CNT_HI + 1: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + gba->audio.psg.ch3.volume = GBAudioRegisterBankVolumeGetVolumeGBA(value); + gba->memory.io[GBA_REG(SOUND3CNT_HI)] = (value & 0xE0) << 8; + break; + case GBA_REG_SOUND3CNT_X: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR33(&gba->audio.psg, value); + break; + case GBA_REG_SOUND3CNT_X + 1: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR34(&gba->audio.psg, value); + gba->memory.io[GBA_REG(SOUND3CNT_X)] = (value & 0x40) << 8; + break; + case GBA_REG_SOUND4CNT_LO: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR41(&gba->audio.psg, value); + break; + case GBA_REG_SOUND4CNT_LO + 1: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR42(&gba->audio.psg, value); + gba->memory.io[GBA_REG(SOUND4CNT_LO)] = value << 8; + break; + case GBA_REG_SOUND4CNT_HI: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR43(&gba->audio.psg, value); + gba->memory.io[GBA_REG(SOUND4CNT_HI)] &= 0x4000; + gba->memory.io[GBA_REG(SOUND4CNT_HI)] |= value; + break; + case GBA_REG_SOUND4CNT_HI + 1: + GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); + GBAudioWriteNR44(&gba->audio.psg, value); + gba->memory.io[GBA_REG(SOUND4CNT_HI)] &= 0x00FF; + gba->memory.io[GBA_REG(SOUND4CNT_HI)] = (value & 0x40) << 8; + break; + default: + value16 = value << (8 * (address & 1)); + value16 |= (gba->memory.io[(address & (GBA_SIZE_IO - 1)) >> 1]) & ~(0xFF << (8 * (address & 1))); + GBAIOWrite(gba, address & 0xFFFFFFFE, value16); + break; + } } void GBAIOWrite32(struct GBA* gba, uint32_t address, uint32_t value) { From c564a20970312ab463f5fcee7f8b72f78380b7c0 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 20 Sep 2024 23:21:14 -0700 Subject: [PATCH 203/338] GBA I/O: Fix 8-bit NR44 write --- src/gba/io.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gba/io.c b/src/gba/io.c index 8853e4d6fb9..ea9d8d8b063 100644 --- a/src/gba/io.c +++ b/src/gba/io.c @@ -668,7 +668,7 @@ void GBAIOWrite8(struct GBA* gba, uint32_t address, uint8_t value) { GBAAudioSample(&gba->audio, mTimingCurrentTime(&gba->timing)); GBAudioWriteNR44(&gba->audio.psg, value); gba->memory.io[GBA_REG(SOUND4CNT_HI)] &= 0x00FF; - gba->memory.io[GBA_REG(SOUND4CNT_HI)] = (value & 0x40) << 8; + gba->memory.io[GBA_REG(SOUND4CNT_HI)] |= (value & 0x40) << 8; break; default: value16 = value << (8 * (address & 1)); From 4b0b6b5d37406f1bb8a4d58ec4a378d756082569 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 26 Sep 2024 21:22:08 -0700 Subject: [PATCH 204/338] Scripting: Fix readRegister return type --- src/core/scripting.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/core/scripting.c b/src/core/scripting.c index a00d5cbdca6..dc56c178392 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -520,7 +520,7 @@ mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mCore, busWrite16, 2, U32, address, U16, va mSCRIPT_DECLARE_STRUCT_VOID_D_METHOD(mCore, busWrite32, 2, U32, address, U32, value); // Register functions -mSCRIPT_DECLARE_STRUCT_METHOD(mCore, WSTR, readRegister, _mScriptCoreReadRegister, 1, CHARP, regName); +mSCRIPT_DECLARE_STRUCT_METHOD(mCore, WRAPPER, readRegister, _mScriptCoreReadRegister, 1, CHARP, regName); mSCRIPT_DECLARE_STRUCT_VOID_METHOD(mCore, writeRegister, _mScriptCoreWriteRegister, 2, CHARP, regName, S32, value); // Savestate functions From 4cfa9c65457e92ffce0a49985e9f6d4a319482d1 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 12 Sep 2024 02:40:03 -0700 Subject: [PATCH 205/338] Python: Remove SIO API pending revamp --- src/platform/python/mgba/gba.py | 66 ------------------------- src/platform/python/sio.c | 88 --------------------------------- src/platform/python/sio.h | 42 ---------------- 3 files changed, 196 deletions(-) delete mode 100644 src/platform/python/sio.c delete mode 100644 src/platform/python/sio.h diff --git a/src/platform/python/mgba/gba.py b/src/platform/python/mgba/gba.py index 109de4d508e..0c249cec587 100644 --- a/src/platform/python/mgba/gba.py +++ b/src/platform/python/mgba/gba.py @@ -52,72 +52,6 @@ def _load(self): super(GBA, self)._load() self.memory = GBAMemory(self._core, self._native.memory.romSize) - def attach_sio(self, link, mode=lib.GBA_SIO_MULTI): - self._sio.add(mode) - lib.GBASIOSetDriver(ffi.addressof(self._native.sio), link._native, mode) - - def __del__(self): - for mode in self._sio: - lib.GBASIOSetDriver(ffi.addressof(self._native.sio), ffi.NULL, mode) - - -create_callback("GBASIOPythonDriver", "init") -create_callback("GBASIOPythonDriver", "deinit") -create_callback("GBASIOPythonDriver", "load") -create_callback("GBASIOPythonDriver", "unload") -create_callback("GBASIOPythonDriver", "writeRegister") - - -class GBASIODriver(object): - def __init__(self): - super(GBASIODriver, self).__init__() - - self._handle = ffi.new_handle(self) - self._native = ffi.gc(lib.GBASIOPythonDriverCreate(self._handle), lib.free) - - def init(self): - return True - - def deinit(self): - pass - - def load(self): - return True - - def unload(self): - return True - - def write_register(self, address, value): - return value - - -class GBASIOJOYDriver(GBASIODriver): - RESET = lib.JOY_RESET - POLL = lib.JOY_POLL - TRANS = lib.JOY_TRANS - RECV = lib.JOY_RECV - - def __init__(self): - super(GBASIOJOYDriver, self).__init__() - - self._native = ffi.gc(lib.GBASIOJOYPythonDriverCreate(self._handle), lib.free) - - def send_command(self, cmd, data): - buffer = ffi.new('uint8_t[5]') - try: - buffer[0] = data[0] - buffer[1] = data[1] - buffer[2] = data[2] - buffer[3] = data[3] - buffer[4] = data[4] - except IndexError: - pass - - outlen = lib.GBASIOJOYSendCommand(self._native, cmd, buffer) - if outlen > 0 and outlen <= 5: - return bytes(buffer[0:outlen]) - return None - class GBAMemory(Memory): def __init__(self, core, romSize=lib.SIZE_CART0): diff --git a/src/platform/python/sio.c b/src/platform/python/sio.c deleted file mode 100644 index fbb4078313d..00000000000 --- a/src/platform/python/sio.c +++ /dev/null @@ -1,88 +0,0 @@ -/* Copyright (c) 2013-2017 Jeffrey Pfau - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include - -#define CREATE_SHIM(PLAT, NAME, RETURN) \ - RETURN _py ## PLAT ## SIOPythonDriver ## NAME (void* driver); \ - static RETURN _py ## PLAT ## SIOPythonDriver ## NAME ## Shim(struct PLAT ## SIODriver* driver) { \ - struct PLAT ## SIODriver* py = (struct PLAT ## SIODriver*) driver; \ - return _py ## PLAT ## SIOPythonDriver ## NAME(py); \ - } - -#define CREATE_SHIM_ARGS(PLAT, NAME, RETURN, TYPES, ...) \ - RETURN _py ## PLAT ## SIOPythonDriver ## NAME TYPES; \ - static RETURN _py ## PLAT ## SIOPythonDriver ## NAME ## Shim TYPES { \ - struct PLAT ## SIODriver* py = (struct PLAT ## SIODriver*) driver; \ - return _py ## PLAT ## SIOPythonDriver ## NAME(py, __VA_ARGS__); \ - } - -#ifdef M_CORE_GBA - -#include - -struct GBASIOPythonDriver { - struct GBASIODriver d; - void* pyobj; -}; - -CREATE_SHIM(GBA, Init, bool); -CREATE_SHIM(GBA, Deinit, void); -CREATE_SHIM(GBA, Load, bool); -CREATE_SHIM(GBA, Unload, bool); -CREATE_SHIM_ARGS(GBA, WriteRegister, uint16_t, (struct GBASIODriver* driver, uint32_t address, uint16_t value), address, value); - -struct GBASIODriver* GBASIOPythonDriverCreate(void* pyobj) { - struct GBASIOPythonDriver* driver = malloc(sizeof(*driver)); - driver->d.init = _pyGBASIOPythonDriverInitShim; - driver->d.deinit = _pyGBASIOPythonDriverDeinitShim; - driver->d.load = _pyGBASIOPythonDriverLoadShim; - driver->d.unload = _pyGBASIOPythonDriverUnloadShim; - driver->d.writeRegister = _pyGBASIOPythonDriverWriteRegisterShim; - - driver->pyobj = pyobj; - return &driver->d; -} - -struct GBASIODriver* GBASIOJOYPythonDriverCreate(void* pyobj) { - struct GBASIOPythonDriver* driver = malloc(sizeof(*driver)); - GBASIOJOYCreate(&driver->d); - driver->d.init = _pyGBASIOPythonDriverInitShim; - driver->d.deinit = _pyGBASIOPythonDriverDeinitShim; - driver->d.load = _pyGBASIOPythonDriverLoadShim; - driver->d.unload = _pyGBASIOPythonDriverUnloadShim; - - driver->pyobj = pyobj; - return &driver->d; -} - -#endif - -#ifdef M_CORE_GB - -#include - -struct GBSIOPythonDriver { - struct GBSIODriver d; - void* pyobj; -}; - -CREATE_SHIM(GB, Init, bool); -CREATE_SHIM(GB, Deinit, void); -CREATE_SHIM_ARGS(GB, WriteSB, void, (struct GBSIODriver* driver, uint8_t value), value); -CREATE_SHIM_ARGS(GB, WriteSC, uint8_t, (struct GBSIODriver* driver, uint8_t value), value); - -struct GBSIODriver* GBSIOPythonDriverCreate(void* pyobj) { - struct GBSIOPythonDriver* driver = malloc(sizeof(*driver)); - driver->d.init = _pyGBSIOPythonDriverInitShim; - driver->d.deinit = _pyGBSIOPythonDriverDeinitShim; - driver->d.writeSB = _pyGBSIOPythonDriverWriteSBShim; - driver->d.writeSC = _pyGBSIOPythonDriverWriteSCShim; - - driver->pyobj = pyobj; - return &driver->d; -} - -#endif diff --git a/src/platform/python/sio.h b/src/platform/python/sio.h deleted file mode 100644 index 23b05942729..00000000000 --- a/src/platform/python/sio.h +++ /dev/null @@ -1,42 +0,0 @@ -/* Copyright (c) 2013-2017 Jeffrey Pfau - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#ifdef M_CORE_GBA - -#include - -struct GBASIOPythonDriver { - struct GBASIODriver d; - void* pyobj; -}; - -struct GBASIODriver* GBASIOPythonDriverCreate(void* pyobj); -struct GBASIODriver* GBASIOJOYPythonDriverCreate(void* pyobj); - -PYEXPORT bool _pyGBASIOPythonDriverInit(void* driver); -PYEXPORT void _pyGBASIOPythonDriverDeinit(void* driver); -PYEXPORT bool _pyGBASIOPythonDriverLoad(void* driver); -PYEXPORT bool _pyGBASIOPythonDriverUnload(void* driver); -PYEXPORT uint16_t _pyGBASIOPythonDriverWriteRegister(void* driver, uint32_t address, uint16_t value); - -#endif - -#ifdef M_CORE_GB - -#include - -struct GBSIOPythonDriver { - struct GBSIODriver d; - void* pyobj; -}; - -struct GBSIODriver* GBSIOPythonDriverCreate(void* pyobj); - -PYEXPORT bool _pyGBSIOPythonDriverInit(void* driver); -PYEXPORT void _pyGBSIOPythonDriverDeinit(void* driver); -PYEXPORT void _pyGBSIOPythonDriverWriteSB(void* driver, uint8_t value); -PYEXPORT uint8_t _pyGBSIOPythonDriverWriteSC(void* driver, uint8_t value); - -#endif From 451da0f8a4d486987192e1c34348ad1fa3ab08fe Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 16 May 2024 15:11:19 -0700 Subject: [PATCH 206/338] GBA SIO: Start adding new SIO callbacks for revamped API --- include/mgba/gba/interface.h | 5 ++++ src/gba/extra/battlechip.c | 22 +++++++++++++++ src/gba/sio.c | 9 +++++++ src/gba/sio/gbp.c | 24 ++++++++++++++--- src/gba/sio/joybus.c | 16 +++++++++++ src/gba/sio/lockstep.c | 52 +++++++++++++++++++++++++++++++++++- 6 files changed, 123 insertions(+), 5 deletions(-) diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index 97e0a5b9c04..6b663b4a70d 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -110,8 +110,13 @@ struct GBASIODriver { bool (*init)(struct GBASIODriver* driver); void (*deinit)(struct GBASIODriver* driver); + void (*reset)(struct GBASIODriver* driver); bool (*load)(struct GBASIODriver* driver); bool (*unload)(struct GBASIODriver* driver); + void (*setMode)(struct GBASIODriver* driver, enum GBASIOMode mode); + bool (*handlesMode)(struct GBASIODriver* driver, enum GBASIOMode mode); + int (*connectedDevices)(struct GBASIODriver* driver); + int (*deviceId)(struct GBASIODriver* driver); uint16_t (*writeRegister)(struct GBASIODriver* driver, uint32_t address, uint16_t value); }; diff --git a/src/gba/extra/battlechip.c b/src/gba/extra/battlechip.c index 3ab9f140314..841981fb785 100644 --- a/src/gba/extra/battlechip.c +++ b/src/gba/extra/battlechip.c @@ -35,6 +35,8 @@ enum { static bool GBASIOBattlechipGateLoad(struct GBASIODriver* driver); static uint16_t GBASIOBattlechipGateWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value); +static bool GBASIOBattlechipGateHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); +static int GBASIOBattlechipGateConnectedDevices(struct GBASIODriver* driver); static void _battlechipTransfer(struct GBASIOBattlechipGate* gate); static void _battlechipTransferEvent(struct mTiming* timing, void* user, uint32_t cyclesLate); @@ -45,6 +47,10 @@ void GBASIOBattlechipGateCreate(struct GBASIOBattlechipGate* gate) { gate->d.load = GBASIOBattlechipGateLoad; gate->d.unload = NULL; gate->d.writeRegister = GBASIOBattlechipGateWriteRegister; + gate->d.setMode = NULL; + gate->d.handlesMode = GBASIOBattlechipGateHandlesMode; + gate->d.connectedDevices = GBASIOBattlechipGateConnectedDevices; + gate->d.deviceId = NULL; gate->event.context = gate; gate->event.callback = _battlechipTransferEvent; @@ -82,6 +88,22 @@ uint16_t GBASIOBattlechipGateWriteRegister(struct GBASIODriver* driver, uint32_t return value; } +static bool GBASIOBattlechipGateHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { + UNUSED(driver); + switch (mode) { + case GBA_SIO_NORMAL_32: + case GBA_SIO_MULTI: + return true; + default: + return false; + } +} + +static int GBASIOBattlechipGateConnectedDevices(struct GBASIODriver* driver) { + UNUSED(driver); + return 1; +} + void _battlechipTransfer(struct GBASIOBattlechipGate* gate) { int32_t cycles; if (gate->d.p->mode == GBA_SIO_NORMAL_32) { diff --git a/src/gba/sio.c b/src/gba/sio.c index 4ffeb63880a..ae1132dfe12 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -103,6 +103,15 @@ void GBASIOReset(struct GBASIO* sio) { if (sio->activeDriver && sio->activeDriver->unload) { sio->activeDriver->unload(sio->activeDriver); } + if (sio->drivers.multiplayer && sio->drivers.multiplayer->reset) { + sio->drivers.multiplayer->reset(sio->drivers.multiplayer); + } + if (sio->drivers.joybus && sio->drivers.joybus->reset) { + sio->drivers.joybus->reset(sio->drivers.joybus); + } + if (sio->drivers.normal && sio->drivers.normal->reset) { + sio->drivers.normal->reset(sio->drivers.normal); + } sio->rcnt = RCNT_INITIAL; sio->siocnt = 0; sio->mode = -1; diff --git a/src/gba/sio/gbp.c b/src/gba/sio/gbp.c index d992ebe2efd..e1f00827443 100644 --- a/src/gba/sio/gbp.c +++ b/src/gba/sio/gbp.c @@ -14,6 +14,8 @@ static uint16_t _gbpRead(struct mKeyCallback*); static uint16_t _gbpSioWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value); +static bool _gbpSioHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); +static int _gbpSioConnectedDevices(struct GBASIODriver* driver); static void _gbpSioProcessEvents(struct mTiming* timing, void* user, uint32_t cyclesLate); static const uint8_t _logoPalette[] = { @@ -43,11 +45,15 @@ void GBASIOPlayerInit(struct GBASIOPlayer* gbp) { gbp->callback.d.readKeys = _gbpRead; gbp->callback.d.requireOpposingDirections = true; gbp->callback.p = gbp; - gbp->d.init = 0; - gbp->d.deinit = 0; - gbp->d.load = 0; - gbp->d.unload = 0; + gbp->d.init = NULL; + gbp->d.deinit = NULL; + gbp->d.load = NULL; + gbp->d.unload = NULL; gbp->d.writeRegister = _gbpSioWriteRegister; + gbp->d.setMode = NULL; + gbp->d.handlesMode = _gbpSioHandlesMode; + gbp->d.connectedDevices = _gbpSioConnectedDevices; + gbp->d.deviceId = NULL; gbp->event.context = gbp; gbp->event.name = "GBA SIO Game Boy Player"; gbp->event.callback = _gbpSioProcessEvents; @@ -125,6 +131,16 @@ uint16_t _gbpSioWriteRegister(struct GBASIODriver* driver, uint32_t address, uin return value; } +static bool _gbpSioHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { + UNUSED(driver); + return mode == GBA_SIO_NORMAL_32; +} + +static int _gbpSioConnectedDevices(struct GBASIODriver* driver) { + UNUSED(driver); + return 1; +} + void _gbpSioProcessEvents(struct mTiming* timing, void* user, uint32_t cyclesLate) { UNUSED(timing); UNUSED(cyclesLate); diff --git a/src/gba/sio/joybus.c b/src/gba/sio/joybus.c index 9415274397c..f1e86d6edc0 100644 --- a/src/gba/sio/joybus.c +++ b/src/gba/sio/joybus.c @@ -9,6 +9,8 @@ #include static uint16_t GBASIOJOYWriteRegister(struct GBASIODriver* sio, uint32_t address, uint16_t value); +static bool GBASIOJOYHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); +static int GBASIOJOYConnectedDevices(struct GBASIODriver* driver); void GBASIOJOYCreate(struct GBASIODriver* sio) { sio->init = NULL; @@ -16,6 +18,10 @@ void GBASIOJOYCreate(struct GBASIODriver* sio) { sio->load = NULL; sio->unload = NULL; sio->writeRegister = GBASIOJOYWriteRegister; + sio->setMode = NULL; + sio->handlesMode = GBASIOJOYHandlesMode; + sio->connectedDevices = GBASIOJOYConnectedDevices; + sio->deviceId = NULL; } uint16_t GBASIOJOYWriteRegister(struct GBASIODriver* sio, uint32_t address, uint16_t value) { @@ -41,6 +47,16 @@ uint16_t GBASIOJOYWriteRegister(struct GBASIODriver* sio, uint32_t address, uint return value; } +static bool GBASIOJOYHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { + UNUSED(driver); + return mode == GBA_SIO_JOYBUS; +} + +static int GBASIOJOYConnectedDevices(struct GBASIODriver* driver) { + UNUSED(driver); + return 1; +} + int GBASIOJOYSendCommand(struct GBASIODriver* sio, enum GBASIOJOYCommand command, uint8_t* data) { switch (command) { case JOY_RESET: diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index ba620911e5d..9ac1e7174fe 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -15,6 +15,10 @@ static bool GBASIOLockstepNodeInit(struct GBASIODriver* driver); static void GBASIOLockstepNodeDeinit(struct GBASIODriver* driver); static bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver); static bool GBASIOLockstepNodeUnload(struct GBASIODriver* driver); +static void GBASIOLockstepNodeSetMode(struct GBASIODriver* driver, enum GBASIOMode mode); +static bool GBASIOLockstepNodeHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); +static int GBASIOLockstepNodeConnectedDevices(struct GBASIODriver* driver); +static int GBASIOLockstepNodeDeviceId(struct GBASIODriver* driver); static uint16_t GBASIOLockstepNodeMultiWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value); static uint16_t GBASIOLockstepNodeNormalWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value); static void _GBASIOLockstepNodeProcessEvents(struct mTiming* timing, void* driver, uint32_t cyclesLate); @@ -38,7 +42,11 @@ void GBASIOLockstepNodeCreate(struct GBASIOLockstepNode* node) { node->d.deinit = GBASIOLockstepNodeDeinit; node->d.load = GBASIOLockstepNodeLoad; node->d.unload = GBASIOLockstepNodeUnload; - node->d.writeRegister = 0; + node->d.setMode = GBASIOLockstepNodeSetMode; + node->d.handlesMode = GBASIOLockstepNodeHandlesMode; + node->d.connectedDevices = GBASIOLockstepNodeConnectedDevices; + node->d.deviceId = GBASIOLockstepNodeDeviceId; + node->d.writeRegister = NULL; } bool GBASIOLockstepAttachNode(struct GBASIOLockstep* lockstep, struct GBASIOLockstepNode* node) { @@ -186,6 +194,48 @@ bool GBASIOLockstepNodeUnload(struct GBASIODriver* driver) { return true; } +static void GBASIOLockstepNodeSetMode(struct GBASIODriver* driver, enum GBASIOMode mode) { + struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; + mLockstepLock(&node->p->d); + node->mode = mode; + mLockstepUnlock(&node->p->d); +} + +static bool GBASIOLockstepNodeHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { + UNUSED(driver); + switch (mode) { + case GBA_SIO_NORMAL_8: + case GBA_SIO_NORMAL_32: + case GBA_SIO_MULTI: + return true; + default: + return false; + } +} + +static int GBASIOLockstepNodeConnectedDevices(struct GBASIODriver* driver) { + struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; + int attached = 0; + + switch (node->mode) { + case GBA_SIO_NORMAL_8: + case GBA_SIO_NORMAL_32: + ATOMIC_LOAD(attached, node->p->attachedNormal); + break; + case GBA_SIO_MULTI: + ATOMIC_LOAD(attached, node->p->attachedMulti); + break; + default: + break; + } + return attached - 1; +} + +static int GBASIOLockstepNodeDeviceId(struct GBASIODriver* driver) { + struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; + return node->id; +} + static uint16_t GBASIOLockstepNodeMultiWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value) { struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; From 09a69a32c0da1bbb21b725786449e1b5cfd7a199 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 16 May 2024 23:06:18 -0700 Subject: [PATCH 207/338] GBA SIO: Start moving common SIO logic out of drivers --- include/mgba/gba/interface.h | 2 - src/gba/CMakeLists.txt | 1 - src/gba/sio.c | 100 ++++++++++++++++++++++++++++++-- src/gba/sio/dolphin.c | 18 +++++- src/gba/sio/joybus.c | 108 ----------------------------------- src/gba/sio/lockstep.c | 2 +- 6 files changed, 114 insertions(+), 117 deletions(-) delete mode 100644 src/gba/sio/joybus.c diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index 6b663b4a70d..c2a4fb5d2bb 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -120,8 +120,6 @@ struct GBASIODriver { uint16_t (*writeRegister)(struct GBASIODriver* driver, uint32_t address, uint16_t value); }; -void GBASIOJOYCreate(struct GBASIODriver* sio); - enum GBASIOBattleChipGateFlavor { GBA_FLAVOR_BATTLECHIP_GATE = 4, GBA_FLAVOR_PROGRESS_GATE = 5, diff --git a/src/gba/CMakeLists.txt b/src/gba/CMakeLists.txt index 933ba3facce..01a968a41b3 100644 --- a/src/gba/CMakeLists.txt +++ b/src/gba/CMakeLists.txt @@ -31,7 +31,6 @@ set(SOURCE_FILES sharkport.c sio.c sio/gbp.c - sio/joybus.c timer.c video.c) diff --git a/src/gba/sio.c b/src/gba/sio.c index ae1132dfe12..27702dfbf4a 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -186,7 +186,32 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { sio->siocnt = value & 0x3000; _switchMode(sio); } - if (sio->activeDriver && sio->activeDriver->writeRegister) { + int id = 0; + int connected = 0; + bool handled = false; + if (sio->activeDriver) { + handled = sio->activeDriver->handlesMode(sio->activeDriver, sio->mode); + if (handled) { + if (sio->activeDriver->deviceId) { + id = sio->activeDriver->deviceId(sio->activeDriver); + } + connected = sio->activeDriver->connectedDevices(sio->activeDriver); + handled = !!sio->activeDriver->writeRegister; + } + } + + switch (sio->mode) { + case GBA_SIO_MULTI: + value &= 0xFF83; + value = GBASIOMultiplayerSetSlave(value, id || !connected); + value = GBASIOMultiplayerSetId(value, id); + value |= sio->siocnt & 0x00FC; + break; + default: + // TODO + break; + } + if (handled) { value = sio->activeDriver->writeRegister(sio->activeDriver, GBA_REG_SIOCNT, value); } else { // Dummy drivers @@ -203,8 +228,7 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { } break; case GBA_SIO_MULTI: - value &= 0xFF83; - value |= 0xC; + value = GBASIOMultiplayerFillReady(value); break; default: // TODO @@ -215,7 +239,12 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { } uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t value) { - if (sio->activeDriver && sio->activeDriver->writeRegister) { + bool handled = false; + if (sio->activeDriver) { + handled = sio->activeDriver->writeRegister && sio->activeDriver->handlesMode(sio->activeDriver, sio->mode); + } + + if (handled) { return sio->activeDriver->writeRegister(sio->activeDriver, address, value); } // Dummy drivers @@ -223,9 +252,22 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu case GBA_SIO_JOYBUS: switch (address) { case GBA_REG_JOYCNT: + mLOG(GBA_SIO, DEBUG, "JOY write: CNT <- %04X", value); return (value & 0x0040) | (sio->p->memory.io[GBA_REG(JOYCNT)] & ~(value & 0x7) & ~0x0040); case GBA_REG_JOYSTAT: + mLOG(GBA_SIO, DEBUG, "JOY write: STAT <- %04X", value); return (value & 0x0030) | (sio->p->memory.io[GBA_REG(JOYSTAT)] & ~0x30); + case GBA_REG_JOY_TRANS_LO: + mLOG(GBA_SIO, DEBUG, "JOY write: TRANS_LO <- %04X", value); + break; + case GBA_REG_JOY_TRANS_HI: + mLOG(GBA_SIO, DEBUG, "JOY write: TRANS_HI <- %04X", value); + break; + default: + mLOG(GBA_SIO, DEBUG, "JOY write: Unknown reg %03X <- %04X", address, value); + break; + case GBA_REG_RCNT: + break; } break; default: @@ -234,3 +276,53 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu } return value; } + +int GBASIOJOYSendCommand(struct GBASIODriver* sio, enum GBASIOJOYCommand command, uint8_t* data) { + switch (command) { + case JOY_RESET: + sio->p->p->memory.io[GBA_REG(JOYCNT)] |= JOYCNT_RESET; + if (sio->p->p->memory.io[GBA_REG(JOYCNT)] & 0x40) { + GBARaiseIRQ(sio->p->p, GBA_IRQ_SIO, 0); + } + // Fall through + case JOY_POLL: + data[0] = 0x00; + data[1] = 0x04; + data[2] = sio->p->p->memory.io[GBA_REG(JOYSTAT)]; + + mLOG(GBA_SIO, DEBUG, "JOY %s: %02X (%02X)", command == JOY_POLL ? "poll" : "reset", data[2], sio->p->p->memory.io[GBA_REG(JOYCNT)]); + return 3; + case JOY_RECV: + sio->p->p->memory.io[GBA_REG(JOYCNT)] |= JOYCNT_RECV; + sio->p->p->memory.io[GBA_REG(JOYSTAT)] |= JOYSTAT_RECV; + + sio->p->p->memory.io[GBA_REG(JOY_RECV_LO)] = data[0] | (data[1] << 8); + sio->p->p->memory.io[GBA_REG(JOY_RECV_HI)] = data[2] | (data[3] << 8); + + data[0] = sio->p->p->memory.io[GBA_REG(JOYSTAT)]; + + mLOG(GBA_SIO, DEBUG, "JOY recv: %02X (%02X)", data[0], sio->p->p->memory.io[GBA_REG(JOYCNT)]); + + if (sio->p->p->memory.io[GBA_REG(JOYCNT)] & 0x40) { + GBARaiseIRQ(sio->p->p, GBA_IRQ_SIO, 0); + } + return 1; + case JOY_TRANS: + data[0] = sio->p->p->memory.io[GBA_REG(JOY_TRANS_LO)]; + data[1] = sio->p->p->memory.io[GBA_REG(JOY_TRANS_LO)] >> 8; + data[2] = sio->p->p->memory.io[GBA_REG(JOY_TRANS_HI)]; + data[3] = sio->p->p->memory.io[GBA_REG(JOY_TRANS_HI)] >> 8; + data[4] = sio->p->p->memory.io[GBA_REG(JOYSTAT)]; + + sio->p->p->memory.io[GBA_REG(JOYCNT)] |= JOYCNT_TRANS; + sio->p->p->memory.io[GBA_REG(JOYSTAT)] &= ~JOYSTAT_TRANS; + + mLOG(GBA_SIO, DEBUG, "JOY trans: %02X%02X%02X%02X:%02X (%02X)", data[0], data[1], data[2], data[3], data[4], sio->p->p->memory.io[GBA_REG(JOYCNT)]); + + if (sio->p->p->memory.io[GBA_REG(JOYCNT)] & 0x40) { + GBARaiseIRQ(sio->p->p, GBA_IRQ_SIO, 0); + } + return 5; + } + return 0; +} diff --git a/src/gba/sio/dolphin.c b/src/gba/sio/dolphin.c index 896d17d3e78..badbd05f7f0 100644 --- a/src/gba/sio/dolphin.c +++ b/src/gba/sio/dolphin.c @@ -25,16 +25,22 @@ enum { static bool GBASIODolphinInit(struct GBASIODriver* driver); static bool GBASIODolphinLoad(struct GBASIODriver* driver); static bool GBASIODolphinUnload(struct GBASIODriver* driver); +static bool GBASIODolphinHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); +static int GBASIODolphinConnectedDevices(struct GBASIODriver* driver); static void GBASIODolphinProcessEvents(struct mTiming* timing, void* context, uint32_t cyclesLate); static int32_t _processCommand(struct GBASIODolphin* dol, uint32_t cyclesLate); static void _flush(struct GBASIODolphin* dol); void GBASIODolphinCreate(struct GBASIODolphin* dol) { - GBASIOJOYCreate(&dol->d); dol->d.init = GBASIODolphinInit; dol->d.load = GBASIODolphinLoad; dol->d.unload = GBASIODolphinUnload; + dol->d.writeRegister = NULL; + dol->d.setMode = NULL; + dol->d.handlesMode = GBASIODolphinHandlesMode; + dol->d.connectedDevices = GBASIODolphinConnectedDevices; + dol->d.deviceId = NULL; dol->event.context = dol; dol->event.name = "GB SIO Lockstep"; dol->event.callback = GBASIODolphinProcessEvents; @@ -116,6 +122,16 @@ static bool GBASIODolphinUnload(struct GBASIODriver* driver) { return true; } +static bool GBASIODolphinHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { + UNUSED(driver); + return mode == GBA_SIO_JOYBUS; +} + +static int GBASIODolphinConnectedDevices(struct GBASIODriver* driver) { + UNUSED(driver); + return 1; +} + void GBASIODolphinProcessEvents(struct mTiming* timing, void* context, uint32_t cyclesLate) { struct GBASIODolphin* dol = context; if (SOCKET_FAILED(dol->data)) { diff --git a/src/gba/sio/joybus.c b/src/gba/sio/joybus.c deleted file mode 100644 index f1e86d6edc0..00000000000 --- a/src/gba/sio/joybus.c +++ /dev/null @@ -1,108 +0,0 @@ -/* Copyright (c) 2013-2017 Jeffrey Pfau - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include - -#include -#include - -static uint16_t GBASIOJOYWriteRegister(struct GBASIODriver* sio, uint32_t address, uint16_t value); -static bool GBASIOJOYHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); -static int GBASIOJOYConnectedDevices(struct GBASIODriver* driver); - -void GBASIOJOYCreate(struct GBASIODriver* sio) { - sio->init = NULL; - sio->deinit = NULL; - sio->load = NULL; - sio->unload = NULL; - sio->writeRegister = GBASIOJOYWriteRegister; - sio->setMode = NULL; - sio->handlesMode = GBASIOJOYHandlesMode; - sio->connectedDevices = GBASIOJOYConnectedDevices; - sio->deviceId = NULL; -} - -uint16_t GBASIOJOYWriteRegister(struct GBASIODriver* sio, uint32_t address, uint16_t value) { - switch (address) { - case GBA_REG_JOYCNT: - mLOG(GBA_SIO, DEBUG, "JOY write: CNT <- %04X", value); - return (value & 0x0040) | (sio->p->p->memory.io[GBA_REG(JOYCNT)] & ~(value & 0x7) & ~0x0040); - case GBA_REG_JOYSTAT: - mLOG(GBA_SIO, DEBUG, "JOY write: STAT <- %04X", value); - return (value & 0x0030) | (sio->p->p->memory.io[GBA_REG(JOYSTAT)] & ~0x30); - case GBA_REG_JOY_TRANS_LO: - mLOG(GBA_SIO, DEBUG, "JOY write: TRANS_LO <- %04X", value); - break; - case GBA_REG_JOY_TRANS_HI: - mLOG(GBA_SIO, DEBUG, "JOY write: TRANS_HI <- %04X", value); - break; - default: - mLOG(GBA_SIO, DEBUG, "JOY write: Unknown reg %03X <- %04X", address, value); - // Fall through - case GBA_REG_RCNT: - break; - } - return value; -} - -static bool GBASIOJOYHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { - UNUSED(driver); - return mode == GBA_SIO_JOYBUS; -} - -static int GBASIOJOYConnectedDevices(struct GBASIODriver* driver) { - UNUSED(driver); - return 1; -} - -int GBASIOJOYSendCommand(struct GBASIODriver* sio, enum GBASIOJOYCommand command, uint8_t* data) { - switch (command) { - case JOY_RESET: - sio->p->p->memory.io[GBA_REG(JOYCNT)] |= JOYCNT_RESET; - if (sio->p->p->memory.io[GBA_REG(JOYCNT)] & 0x40) { - GBARaiseIRQ(sio->p->p, GBA_IRQ_SIO, 0); - } - // Fall through - case JOY_POLL: - data[0] = 0x00; - data[1] = 0x04; - data[2] = sio->p->p->memory.io[GBA_REG(JOYSTAT)]; - - mLOG(GBA_SIO, DEBUG, "JOY %s: %02X (%02X)", command == JOY_POLL ? "poll" : "reset", data[2], sio->p->p->memory.io[GBA_REG(JOYCNT)]); - return 3; - case JOY_RECV: - sio->p->p->memory.io[GBA_REG(JOYCNT)] |= JOYCNT_RECV; - sio->p->p->memory.io[GBA_REG(JOYSTAT)] |= JOYSTAT_RECV; - - sio->p->p->memory.io[GBA_REG(JOY_RECV_LO)] = data[0] | (data[1] << 8); - sio->p->p->memory.io[GBA_REG(JOY_RECV_HI)] = data[2] | (data[3] << 8); - - data[0] = sio->p->p->memory.io[GBA_REG(JOYSTAT)]; - - mLOG(GBA_SIO, DEBUG, "JOY recv: %02X (%02X)", data[0], sio->p->p->memory.io[GBA_REG(JOYCNT)]); - - if (sio->p->p->memory.io[GBA_REG(JOYCNT)] & 0x40) { - GBARaiseIRQ(sio->p->p, GBA_IRQ_SIO, 0); - } - return 1; - case JOY_TRANS: - data[0] = sio->p->p->memory.io[GBA_REG(JOY_TRANS_LO)]; - data[1] = sio->p->p->memory.io[GBA_REG(JOY_TRANS_LO)] >> 8; - data[2] = sio->p->p->memory.io[GBA_REG(JOY_TRANS_HI)]; - data[3] = sio->p->p->memory.io[GBA_REG(JOY_TRANS_HI)] >> 8; - data[4] = sio->p->p->memory.io[GBA_REG(JOYSTAT)]; - - sio->p->p->memory.io[GBA_REG(JOYCNT)] |= JOYCNT_TRANS; - sio->p->p->memory.io[GBA_REG(JOYSTAT)] &= ~JOYSTAT_TRANS; - - mLOG(GBA_SIO, DEBUG, "JOY trans: %02X%02X%02X%02X:%02X (%02X)", data[0], data[1], data[2], data[3], data[4], sio->p->p->memory.io[GBA_REG(JOYCNT)]); - - if (sio->p->p->memory.io[GBA_REG(JOYCNT)] & 0x40) { - GBARaiseIRQ(sio->p->p, GBA_IRQ_SIO, 0); - } - return 5; - } - return 0; -} diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 9ac1e7174fe..edd1707487b 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -215,7 +215,7 @@ static bool GBASIOLockstepNodeHandlesMode(struct GBASIODriver* driver, enum GBAS static int GBASIOLockstepNodeConnectedDevices(struct GBASIODriver* driver) { struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; - int attached = 0; + int attached = 1; switch (node->mode) { case GBA_SIO_NORMAL_8: From f9e15c53d953b8a23611fb125870513a816fc27b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 18 May 2024 16:26:33 -0700 Subject: [PATCH 208/338] GBA SIO: Move more SIO logic out of drivers --- src/gba/sio.c | 63 ++++++++++++++++++++++++++++++++++-------- src/gba/sio/lockstep.c | 5 ---- 2 files changed, 52 insertions(+), 16 deletions(-) diff --git a/src/gba/sio.c b/src/gba/sio.c index 27702dfbf4a..4eb9cfa3c88 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -69,6 +69,23 @@ static void _switchMode(struct GBASIO* sio) { if (sio->activeDriver && sio->activeDriver->load) { sio->activeDriver->load(sio->activeDriver); } + + int id = 0; + switch (newMode) { + case GBA_SIO_MULTI: + if (sio->activeDriver && sio->activeDriver->deviceId) { + id = sio->activeDriver->deviceId(sio->activeDriver); + } + if (id) { + sio->rcnt |= 4; + } else { + sio->rcnt &= ~4; + } + break; + default: + // TODO + break; + } } } @@ -239,24 +256,17 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { } uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t value) { - bool handled = false; - if (sio->activeDriver) { - handled = sio->activeDriver->writeRegister && sio->activeDriver->handlesMode(sio->activeDriver, sio->mode); - } - - if (handled) { - return sio->activeDriver->writeRegister(sio->activeDriver, address, value); - } - // Dummy drivers switch (sio->mode) { case GBA_SIO_JOYBUS: switch (address) { case GBA_REG_JOYCNT: mLOG(GBA_SIO, DEBUG, "JOY write: CNT <- %04X", value); - return (value & 0x0040) | (sio->p->memory.io[GBA_REG(JOYCNT)] & ~(value & 0x7) & ~0x0040); + value = (value & 0x0040) | (sio->p->memory.io[GBA_REG(JOYCNT)] & ~(value & 0x7) & ~0x0040); + break; case GBA_REG_JOYSTAT: mLOG(GBA_SIO, DEBUG, "JOY write: STAT <- %04X", value); - return (value & 0x0030) | (sio->p->memory.io[GBA_REG(JOYSTAT)] & ~0x30); + value = (value & 0x0030) | (sio->p->memory.io[GBA_REG(JOYSTAT)] & ~0x30); + break; case GBA_REG_JOY_TRANS_LO: mLOG(GBA_SIO, DEBUG, "JOY write: TRANS_LO <- %04X", value); break; @@ -270,10 +280,41 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu break; } break; + case GBA_SIO_NORMAL_8: + switch (address) { + case GBA_REG_SIODATA8: + mLOG(GBA_SIO, DEBUG, "NORMAL8 write: SIODATA8 <- %02X", value); + break; + default: + mLOG(GBA_SIO, DEBUG, "NORMAL8 write: Unknown reg %03X <- %04X", address, value); + break; + case GBA_REG_RCNT: + break; + } + break; + case GBA_SIO_NORMAL_32: + switch (address) { + case GBA_REG_SIODATA32_LO: + mLOG(GBA_SIO, DEBUG, "NORMAL32 write: SIODATA32_LO <- %04X", value); + break; + case GBA_REG_SIODATA32_HI: + mLOG(GBA_SIO, DEBUG, "NORMAL32 write: SIODATA32_HI <- %04X", value); + break; + default: + mLOG(GBA_SIO, DEBUG, "NORMAL32 write: Unknown reg %03X <- %04X", address, value); + break; + case GBA_REG_RCNT: + break; + } + break; default: // TODO break; } + + if (sio->activeDriver && sio->activeDriver->writeRegister && sio->activeDriver->handlesMode(sio->activeDriver, sio->mode)) { + sio->activeDriver->writeRegister(sio->activeDriver, address, value); + } return value; } diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index edd1707487b..9709f633bb3 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -117,8 +117,6 @@ bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver) { node->d.p->siocnt = GBASIOMultiplayerSetReady(node->d.p->siocnt, node->p->attachedMulti == node->p->d.attached); if (node->id) { node->d.p->rcnt |= 4; - node->d.p->siocnt = GBASIOMultiplayerFillSlave(node->d.p->siocnt); - int try; for (try = 0; try < 3; ++try) { uint16_t masterSiocnt; @@ -127,9 +125,6 @@ bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver) { break; } } - } else { - node->d.p->rcnt &= ~4; - node->d.p->siocnt = GBASIOMultiplayerClearSlave(node->d.p->siocnt); } break; case GBA_SIO_NORMAL_8: From cd4132fba3c94ea303264bfc1f2d0231c997a749 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 18 May 2024 16:42:20 -0700 Subject: [PATCH 209/338] GBA SIO: Move MULTI finishing logic out of drivers --- include/mgba/internal/gba/sio.h | 2 ++ src/gba/extra/battlechip.c | 16 +++++----------- src/gba/sio.c | 17 +++++++++++++++++ src/gba/sio/lockstep.c | 11 +---------- 4 files changed, 25 insertions(+), 21 deletions(-) diff --git a/include/mgba/internal/gba/sio.h b/include/mgba/internal/gba/sio.h index 260772f559e..a546017dcd1 100644 --- a/include/mgba/internal/gba/sio.h +++ b/include/mgba/internal/gba/sio.h @@ -85,6 +85,8 @@ void GBASIOWriteRCNT(struct GBASIO* sio, uint16_t value); void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value); uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t value); +void GBASIOMultiplayerFinishTransfer(struct GBASIO* sio, uint16_t data[4], uint32_t cyclesLate); + int GBASIOJOYSendCommand(struct GBASIODriver* sio, enum GBASIOJOYCommand command, uint8_t* data); CXX_GUARD_END diff --git a/src/gba/extra/battlechip.c b/src/gba/extra/battlechip.c index 841981fb785..12750f67b25 100644 --- a/src/gba/extra/battlechip.c +++ b/src/gba/extra/battlechip.c @@ -131,11 +131,6 @@ void _battlechipTransferEvent(struct mTiming* timing, void* user, uint32_t cycle uint16_t cmd = gate->d.p->p->memory.io[GBA_REG(SIOMLT_SEND)]; uint16_t reply = 0xFFFF; - gate->d.p->p->memory.io[GBA_REG(SIOMULTI0)] = cmd; - gate->d.p->p->memory.io[GBA_REG(SIOMULTI2)] = 0xFFFF; - gate->d.p->p->memory.io[GBA_REG(SIOMULTI3)] = 0xFFFF; - gate->d.p->siocnt = GBASIOMultiplayerClearBusy(gate->d.p->siocnt); - gate->d.p->siocnt = GBASIOMultiplayerSetId(gate->d.p->siocnt, 0); mLOG(GBA_BATTLECHIP, DEBUG, "Game: %04X (%i)", cmd, gate->state); @@ -168,7 +163,7 @@ void _battlechipTransferEvent(struct mTiming* timing, void* user, uint32_t cycle case 0xA3D0: // EXE 4 case 0xA6C0: - mLOG(GBA_BATTLECHIP, DEBUG, "Resync detected"); + mLOG(GBA_BATTLECHIP, DEBUG, "Resync detected"); gate->state = BATTLECHIP_STATE_SYNC; break; } @@ -213,9 +208,8 @@ void _battlechipTransferEvent(struct mTiming* timing, void* user, uint32_t cycle mLOG(GBA_BATTLECHIP, DEBUG, "Gate: %04X (%i)", reply, gate->state); ++gate->state; - gate->d.p->p->memory.io[GBA_REG(SIOMULTI1)] = reply; - - if (GBASIOMultiplayerIsIrq(gate->d.p->siocnt)) { - GBARaiseIRQ(gate->d.p->p, GBA_IRQ_SIO, cyclesLate); - } + uint16_t data[4] = { + cmd, reply, 0xFFFF, 0xFFFF + }; + GBASIOMultiplayerFinishTransfer(gate->d.p, data, cyclesLate); } diff --git a/src/gba/sio.c b/src/gba/sio.c index 4eb9cfa3c88..cdccf1ea35a 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -318,6 +318,23 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu return value; } +void GBASIOMultiplayerFinishTransfer(struct GBASIO* sio, uint16_t data[4], uint32_t cyclesLate) { + int id = 0; + if (sio->activeDriver && sio->activeDriver->deviceId) { + id = sio->activeDriver->deviceId(sio->activeDriver); + } + sio->p->memory.io[GBA_REG(SIOMULTI0)] = data[0]; + sio->p->memory.io[GBA_REG(SIOMULTI1)] = data[1]; + sio->p->memory.io[GBA_REG(SIOMULTI2)] = data[2]; + sio->p->memory.io[GBA_REG(SIOMULTI3)] = data[3]; + sio->rcnt |= 1; + sio->siocnt = GBASIOMultiplayerClearBusy(sio->siocnt); + sio->siocnt = GBASIOMultiplayerSetId(sio->siocnt, id); + if (GBASIOMultiplayerIsIrq(sio->siocnt)) { + GBARaiseIRQ(sio->p, GBA_IRQ_SIO, cyclesLate); + } +} + int GBASIOJOYSendCommand(struct GBASIODriver* sio, enum GBASIOJOYCommand command, uint8_t* data) { switch (command) { case JOY_RESET: diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 9709f633bb3..b7f5752b491 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -280,16 +280,7 @@ static void _finishTransfer(struct GBASIOLockstepNode* node) { struct GBASIO* sio = node->d.p; switch (node->mode) { case GBA_SIO_MULTI: - sio->p->memory.io[GBA_REG(SIOMULTI0)] = node->p->multiRecv[0]; - sio->p->memory.io[GBA_REG(SIOMULTI1)] = node->p->multiRecv[1]; - sio->p->memory.io[GBA_REG(SIOMULTI2)] = node->p->multiRecv[2]; - sio->p->memory.io[GBA_REG(SIOMULTI3)] = node->p->multiRecv[3]; - sio->rcnt |= 1; - sio->siocnt = GBASIOMultiplayerClearBusy(sio->siocnt); - sio->siocnt = GBASIOMultiplayerSetId(sio->siocnt, node->id); - if (GBASIOMultiplayerIsIrq(sio->siocnt)) { - GBARaiseIRQ(sio->p, GBA_IRQ_SIO, 0); - } + GBASIOMultiplayerFinishTransfer(sio, node->p->multiRecv, 0); break; case GBA_SIO_NORMAL_8: // TODO From 1b0b540de6743d306e1e53583b1ed24215a25334 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 21 May 2024 23:24:06 -0700 Subject: [PATCH 210/338] GBA SIO: Move cycle estimation values into core --- include/mgba/internal/gba/sio.h | 4 ++-- src/gba/extra/battlechip.c | 7 +------ src/gba/sio.c | 27 ++++++++++++++++++++++++++- src/gba/sio/lockstep.c | 14 +++----------- 4 files changed, 32 insertions(+), 20 deletions(-) diff --git a/include/mgba/internal/gba/sio.h b/include/mgba/internal/gba/sio.h index a546017dcd1..2576dfffef3 100644 --- a/include/mgba/internal/gba/sio.h +++ b/include/mgba/internal/gba/sio.h @@ -16,8 +16,6 @@ CXX_GUARD_START #define MAX_GBAS 4 -extern const int GBASIOCyclesPerTransfer[4][MAX_GBAS]; - mLOG_DECLARE_CATEGORY(GBA_SIO); enum { @@ -85,6 +83,8 @@ void GBASIOWriteRCNT(struct GBASIO* sio, uint16_t value); void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value); uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t value); +int32_t GBASIOTransferCycles(struct GBASIO* sio); + void GBASIOMultiplayerFinishTransfer(struct GBASIO* sio, uint16_t data[4], uint32_t cyclesLate); int GBASIOJOYSendCommand(struct GBASIODriver* sio, enum GBASIOJOYCommand command, uint8_t* data); diff --git a/src/gba/extra/battlechip.c b/src/gba/extra/battlechip.c index 12750f67b25..3314ff02c53 100644 --- a/src/gba/extra/battlechip.c +++ b/src/gba/extra/battlechip.c @@ -105,12 +105,7 @@ static int GBASIOBattlechipGateConnectedDevices(struct GBASIODriver* driver) { } void _battlechipTransfer(struct GBASIOBattlechipGate* gate) { - int32_t cycles; - if (gate->d.p->mode == GBA_SIO_NORMAL_32) { - cycles = GBA_ARM7TDMI_FREQUENCY / 0x40000; - } else { - cycles = GBASIOCyclesPerTransfer[GBASIOMultiplayerGetBaud(gate->d.p->siocnt)][1]; - } + int32_t cycles = GBASIOTransferCycles(gate->d.p); mTimingDeschedule(&gate->d.p->p->timing, &gate->event); mTimingSchedule(&gate->d.p->p->timing, &gate->event, cycles); } diff --git a/src/gba/sio.c b/src/gba/sio.c index cdccf1ea35a..76d2ea144b4 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -11,7 +11,7 @@ mLOG_DEFINE_CATEGORY(GBA_SIO, "GBA Serial I/O", "gba.sio"); -const int GBASIOCyclesPerTransfer[4][MAX_GBAS] = { +static const int GBASIOCyclesPerTransfer[4][MAX_GBAS] = { { 31976, 63427, 94884, 125829 }, { 8378, 16241, 24104, 31457 }, { 5750, 10998, 16241, 20972 }, @@ -318,6 +318,31 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu return value; } +int32_t GBASIOTransferCycles(struct GBASIO* sio) { + int connected = 0; + if (sio->activeDriver) { + connected = sio->activeDriver->connectedDevices(sio->activeDriver); + } + + if (connected < 0 || connected >= MAX_GBAS) { + mLOG(GBA_SIO, ERROR, "SIO driver returned invalid device count %i", connected); + return 0; + } + + switch (sio->mode) { + case GBA_SIO_MULTI: + return GBASIOCyclesPerTransfer[GBASIOMultiplayerGetBaud(sio->siocnt)][connected]; + case GBA_SIO_NORMAL_8: + return 8 * GBA_ARM7TDMI_FREQUENCY / ((GBASIONormalIsInternalSc(sio->siocnt) ? 2048 : 256) * 1024); + case GBA_SIO_NORMAL_32: + return 32 * GBA_ARM7TDMI_FREQUENCY / ((GBASIONormalIsInternalSc(sio->siocnt) ? 2048 : 256) * 1024); + default: + mLOG(GBA_SIO, STUB, "No cycle count implemented for mode %s", _modeName(sio->mode)); + break; + } + return 0; +} + void GBASIOMultiplayerFinishTransfer(struct GBASIO* sio, uint16_t data[4], uint32_t cyclesLate) { int id = 0; if (sio->activeDriver && sio->activeDriver->deviceId) { diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index b7f5752b491..08c586ae501 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -250,7 +250,7 @@ static uint16_t GBASIOLockstepNodeMultiWriteRegister(struct GBASIODriver* driver if (!node->id && attached > 1 && GBASIOMultiplayerIsReady(node->d.p->siocnt)) { mLOG(GBA_SIO, DEBUG, "Lockstep %i: Transfer initiated", node->id); ATOMIC_STORE(node->p->d.transferActive, TRANSFER_STARTING); - ATOMIC_STORE(node->p->d.transferCycles, GBASIOCyclesPerTransfer[GBASIOMultiplayerGetBaud(node->d.p->siocnt)][node->p->d.attached - 1]); + ATOMIC_STORE(node->p->d.transferCycles, GBASIOTransferCycles(node->d.p)); if (mTimingIsScheduled(&driver->p->p->timing, &node->event)) { node->eventDiff -= node->event.when - mTimingCurrentTime(&driver->p->p->timing); @@ -502,7 +502,7 @@ static void _GBASIOLockstepNodeProcessEvents(struct mTiming* timing, void* user, if (node->p->d.attached < 2) { switch (node->mode) { case GBA_SIO_MULTI: - cycles = GBASIOCyclesPerTransfer[GBASIOMultiplayerGetBaud(node->d.p->siocnt)][0]; + cycles = GBASIOTransferCycles(node->d.p); break; case GBA_SIO_NORMAL_8: case GBA_SIO_NORMAL_32: @@ -568,15 +568,7 @@ static uint16_t GBASIOLockstepNodeNormalWriteRegister(struct GBASIODriver* drive if ((value & 0x0081) == 0x0081) { if (!node->id) { // Frequency - int32_t cycles; - if (value & 2) { - cycles = 8 * 8; - } else { - cycles = 64 * 8; - } - if (value & 0x1000) { - cycles *= 4; - } + int32_t cycles = GBASIOTransferCycles(node->d.p); if (transferActive == TRANSFER_IDLE) { mLOG(GBA_SIO, DEBUG, "Lockstep %i: Transfer initiated", node->id); From 54c9e9d411bbc03a27ab9ae418227162c3855aef Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 21 May 2024 23:39:15 -0700 Subject: [PATCH 211/338] GBA SIO: Move NORMAL finishing logic out of drivers --- include/mgba/internal/gba/sio.h | 2 ++ src/gba/extra/battlechip.c | 7 +------ src/gba/sio.c | 17 +++++++++++++++++ src/gba/sio/gbp.c | 9 +-------- src/gba/sio/lockstep.c | 20 ++++---------------- 5 files changed, 25 insertions(+), 30 deletions(-) diff --git a/include/mgba/internal/gba/sio.h b/include/mgba/internal/gba/sio.h index 2576dfffef3..43acaa7b8c7 100644 --- a/include/mgba/internal/gba/sio.h +++ b/include/mgba/internal/gba/sio.h @@ -86,6 +86,8 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu int32_t GBASIOTransferCycles(struct GBASIO* sio); void GBASIOMultiplayerFinishTransfer(struct GBASIO* sio, uint16_t data[4], uint32_t cyclesLate); +void GBASIONormal8FinishTransfer(struct GBASIO* sio, uint8_t data, uint32_t cyclesLate); +void GBASIONormal32FinishTransfer(struct GBASIO* sio, uint32_t data, uint32_t cyclesLate); int GBASIOJOYSendCommand(struct GBASIODriver* sio, enum GBASIOJOYCommand command, uint8_t* data); diff --git a/src/gba/extra/battlechip.c b/src/gba/extra/battlechip.c index 3314ff02c53..040ec80b8c0 100644 --- a/src/gba/extra/battlechip.c +++ b/src/gba/extra/battlechip.c @@ -115,12 +115,7 @@ void _battlechipTransferEvent(struct mTiming* timing, void* user, uint32_t cycle struct GBASIOBattlechipGate* gate = user; if (gate->d.p->mode == GBA_SIO_NORMAL_32) { - gate->d.p->p->memory.io[GBA_REG(SIODATA32_LO)] = 0; - gate->d.p->p->memory.io[GBA_REG(SIODATA32_HI)] = 0; - gate->d.p->siocnt = GBASIONormalClearStart(gate->d.p->siocnt); - if (GBASIONormalIsIrq(gate->d.p->siocnt)) { - GBARaiseIRQ(gate->d.p->p, GBA_IRQ_SIO, cyclesLate); - } + GBASIONormal32FinishTransfer(gate->d.p, 0, cyclesLate); return; } diff --git a/src/gba/sio.c b/src/gba/sio.c index 76d2ea144b4..56dc55a9f03 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -360,6 +360,23 @@ void GBASIOMultiplayerFinishTransfer(struct GBASIO* sio, uint16_t data[4], uint3 } } +void GBASIONormal8FinishTransfer(struct GBASIO* sio, uint8_t data, uint32_t cyclesLate) { + sio->siocnt = GBASIONormalClearStart(sio->siocnt); + sio->p->memory.io[GBA_REG(SIODATA8)] = data; + if (GBASIONormalIsIrq(sio->siocnt)) { + GBARaiseIRQ(sio->p, GBA_IRQ_SIO, cyclesLate); + } +} + +void GBASIONormal32FinishTransfer(struct GBASIO* sio, uint32_t data, uint32_t cyclesLate) { + sio->siocnt = GBASIONormalClearStart(sio->siocnt); + sio->p->memory.io[GBA_REG(SIODATA32_LO)] = data; + sio->p->memory.io[GBA_REG(SIODATA32_HI)] = data >> 16; + if (GBASIONormalIsIrq(sio->siocnt)) { + GBARaiseIRQ(sio->p, GBA_IRQ_SIO, cyclesLate); + } +} + int GBASIOJOYSendCommand(struct GBASIODriver* sio, enum GBASIOJOYCommand command, uint8_t* data) { switch (command) { case JOY_RESET: diff --git a/src/gba/sio/gbp.c b/src/gba/sio/gbp.c index e1f00827443..37944d596cd 100644 --- a/src/gba/sio/gbp.c +++ b/src/gba/sio/gbp.c @@ -143,7 +143,6 @@ static int _gbpSioConnectedDevices(struct GBASIODriver* driver) { void _gbpSioProcessEvents(struct mTiming* timing, void* user, uint32_t cyclesLate) { UNUSED(timing); - UNUSED(cyclesLate); struct GBASIOPlayer* gbp = user; uint32_t tx = 0; int txPosition = gbp->txPosition; @@ -155,11 +154,5 @@ void _gbpSioProcessEvents(struct mTiming* timing, void* user, uint32_t cyclesLat } tx = _gbpTxData[txPosition]; ++gbp->txPosition; - gbp->p->memory.io[GBA_REG(SIODATA32_LO)] = tx; - gbp->p->memory.io[GBA_REG(SIODATA32_HI)] = tx >> 16; - if (GBASIONormalIsIrq(gbp->d.p->siocnt)) { - GBARaiseIRQ(gbp->p, GBA_IRQ_SIO, cyclesLate); - } - gbp->d.p->siocnt = GBASIONormalClearStart(gbp->d.p->siocnt); - gbp->p->memory.io[GBA_REG(SIOCNT)] = gbp->d.p->siocnt & ~0x0080; + GBASIONormal32FinishTransfer(gbp->d.p, tx, cyclesLate); } diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 08c586ae501..67b35923468 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -283,31 +283,19 @@ static void _finishTransfer(struct GBASIOLockstepNode* node) { GBASIOMultiplayerFinishTransfer(sio, node->p->multiRecv, 0); break; case GBA_SIO_NORMAL_8: - // TODO - sio->siocnt = GBASIONormalClearStart(sio->siocnt); if (node->id) { sio->siocnt = GBASIONormalSetSi(sio->siocnt, GBASIONormalGetIdleSo(node->p->players[node->id - 1]->d.p->siocnt)); - node->d.p->p->memory.io[GBA_REG(SIODATA8)] = node->p->normalRecv[node->id - 1] & 0xFF; + GBASIONormal8FinishTransfer(sio, node->p->normalRecv[node->id - 1], 0); } else { - node->d.p->p->memory.io[GBA_REG(SIODATA8)] = 0xFFFF; - } - if (GBASIONormalIsIrq(sio->siocnt)) { - GBARaiseIRQ(sio->p, GBA_IRQ_SIO, 0); + GBASIONormal8FinishTransfer(sio, 0xFF, 0); } break; case GBA_SIO_NORMAL_32: - // TODO - sio->siocnt = GBASIONormalClearStart(sio->siocnt); if (node->id) { sio->siocnt = GBASIONormalSetSi(sio->siocnt, GBASIONormalGetIdleSo(node->p->players[node->id - 1]->d.p->siocnt)); - node->d.p->p->memory.io[GBA_REG(SIODATA32_LO)] = node->p->normalRecv[node->id - 1]; - node->d.p->p->memory.io[GBA_REG(SIODATA32_HI)] = node->p->normalRecv[node->id - 1] >> 16; + GBASIONormal32FinishTransfer(sio, node->p->normalRecv[node->id - 1], 0); } else { - node->d.p->p->memory.io[GBA_REG(SIODATA32_LO)] = 0xFFFF; - node->d.p->p->memory.io[GBA_REG(SIODATA32_HI)] = 0xFFFF; - } - if (GBASIONormalIsIrq(sio->siocnt)) { - GBARaiseIRQ(sio->p, GBA_IRQ_SIO, 0); + GBASIONormal32FinishTransfer(sio, 0xFFFFFFFF, 0); } break; default: From 9998de48803887633ff052fe12ef11a46c5ef3ff Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 21 May 2024 23:52:55 -0700 Subject: [PATCH 212/338] GBA SIO: Move more write logging out of drivers --- src/gba/sio.c | 27 ++++++++++++++++++++++----- 1 file changed, 22 insertions(+), 5 deletions(-) diff --git a/src/gba/sio.c b/src/gba/sio.c index 56dc55a9f03..e0b0a6d1d65 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -256,6 +256,11 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { } uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t value) { + int id = 0; + if (sio->activeDriver && sio->activeDriver->deviceId) { + id = sio->activeDriver->deviceId(sio->activeDriver); + } + switch (sio->mode) { case GBA_SIO_JOYBUS: switch (address) { @@ -283,10 +288,10 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu case GBA_SIO_NORMAL_8: switch (address) { case GBA_REG_SIODATA8: - mLOG(GBA_SIO, DEBUG, "NORMAL8 write: SIODATA8 <- %02X", value); + mLOG(GBA_SIO, DEBUG, "NORMAL8 %i write: SIODATA8 <- %02X", id, value); break; default: - mLOG(GBA_SIO, DEBUG, "NORMAL8 write: Unknown reg %03X <- %04X", address, value); + mLOG(GBA_SIO, DEBUG, "NORMAL8 %i write: Unknown reg %03X <- %04X", id, address, value); break; case GBA_REG_RCNT: break; @@ -295,13 +300,25 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu case GBA_SIO_NORMAL_32: switch (address) { case GBA_REG_SIODATA32_LO: - mLOG(GBA_SIO, DEBUG, "NORMAL32 write: SIODATA32_LO <- %04X", value); + mLOG(GBA_SIO, DEBUG, "NORMAL32 %i write: SIODATA32_LO <- %04X", id, value); break; case GBA_REG_SIODATA32_HI: - mLOG(GBA_SIO, DEBUG, "NORMAL32 write: SIODATA32_HI <- %04X", value); + mLOG(GBA_SIO, DEBUG, "NORMAL32 %i write: SIODATA32_HI <- %04X", id, value); + break; + default: + mLOG(GBA_SIO, DEBUG, "NORMAL32 %i write: Unknown reg %03X <- %04X", id, address, value); + break; + case GBA_REG_RCNT: + break; + } + break; + case GBA_SIO_MULTI: + switch (address) { + case GBA_REG_SIOMLT_SEND: + mLOG(GBA_SIO, DEBUG, "MULTI %i write: SIOMLT_SEND <- %04X", id, value); break; default: - mLOG(GBA_SIO, DEBUG, "NORMAL32 write: Unknown reg %03X <- %04X", address, value); + mLOG(GBA_SIO, DEBUG, "MULTI %i write: Unknown reg %03X <- %04X", id, address, value); break; case GBA_REG_RCNT: break; From 5da4b1fc4d61888564894d5b7f6662428b4647e5 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 22 May 2024 01:40:01 -0700 Subject: [PATCH 213/338] GBA SIO: Replace writeRegister with writeSIOCNT --- include/mgba/gba/interface.h | 2 +- src/gba/extra/battlechip.c | 24 ++----- src/gba/sio.c | 11 +-- src/gba/sio/dolphin.c | 2 +- src/gba/sio/gbp.c | 39 +++++----- src/gba/sio/lockstep.c | 134 ++++++++++++++++------------------- 6 files changed, 90 insertions(+), 122 deletions(-) diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index c2a4fb5d2bb..b698f403057 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -117,7 +117,7 @@ struct GBASIODriver { bool (*handlesMode)(struct GBASIODriver* driver, enum GBASIOMode mode); int (*connectedDevices)(struct GBASIODriver* driver); int (*deviceId)(struct GBASIODriver* driver); - uint16_t (*writeRegister)(struct GBASIODriver* driver, uint32_t address, uint16_t value); + uint16_t (*writeSIOCNT)(struct GBASIODriver* driver, uint16_t value); }; enum GBASIOBattleChipGateFlavor { diff --git a/src/gba/extra/battlechip.c b/src/gba/extra/battlechip.c index 040ec80b8c0..b71b4e33e6b 100644 --- a/src/gba/extra/battlechip.c +++ b/src/gba/extra/battlechip.c @@ -34,7 +34,7 @@ enum { }; static bool GBASIOBattlechipGateLoad(struct GBASIODriver* driver); -static uint16_t GBASIOBattlechipGateWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value); +static uint16_t GBASIOBattlechipGateWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); static bool GBASIOBattlechipGateHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); static int GBASIOBattlechipGateConnectedDevices(struct GBASIODriver* driver); @@ -46,7 +46,7 @@ void GBASIOBattlechipGateCreate(struct GBASIOBattlechipGate* gate) { gate->d.deinit = NULL; gate->d.load = GBASIOBattlechipGateLoad; gate->d.unload = NULL; - gate->d.writeRegister = GBASIOBattlechipGateWriteRegister; + gate->d.writeSIOCNT = GBASIOBattlechipGateWriteSIOCNT; gate->d.setMode = NULL; gate->d.handlesMode = GBASIOBattlechipGateHandlesMode; gate->d.connectedDevices = GBASIOBattlechipGateConnectedDevices; @@ -68,22 +68,12 @@ bool GBASIOBattlechipGateLoad(struct GBASIODriver* driver) { return true; } -uint16_t GBASIOBattlechipGateWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value) { +uint16_t GBASIOBattlechipGateWriteSIOCNT(struct GBASIODriver* driver, uint16_t value) { struct GBASIOBattlechipGate* gate = (struct GBASIOBattlechipGate*) driver; - switch (address) { - case GBA_REG_SIOCNT: - value &= ~0xC; - value |= 0x8; - if (value & 0x80) { - _battlechipTransfer(gate); - } - break; - case GBA_REG_SIOMLT_SEND: - break; - case GBA_REG_RCNT: - break; - default: - break; + value &= ~0xC; + value |= 0x8; + if (value & 0x80) { + _battlechipTransfer(gate); } return value; } diff --git a/src/gba/sio.c b/src/gba/sio.c index e0b0a6d1d65..68b8fcb48a4 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -193,9 +193,6 @@ void GBASIOWriteRCNT(struct GBASIO* sio, uint16_t value) { sio->rcnt &= 0xF; sio->rcnt |= value & ~0xF; _switchMode(sio); - if (sio->activeDriver && sio->activeDriver->writeRegister) { - sio->activeDriver->writeRegister(sio->activeDriver, GBA_REG_RCNT, value); - } } void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { @@ -213,7 +210,7 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { id = sio->activeDriver->deviceId(sio->activeDriver); } connected = sio->activeDriver->connectedDevices(sio->activeDriver); - handled = !!sio->activeDriver->writeRegister; + handled = !!sio->activeDriver->writeSIOCNT; } } @@ -229,7 +226,7 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { break; } if (handled) { - value = sio->activeDriver->writeRegister(sio->activeDriver, GBA_REG_SIOCNT, value); + value = sio->activeDriver->writeSIOCNT(sio->activeDriver, value); } else { // Dummy drivers switch (sio->mode) { @@ -328,10 +325,6 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu // TODO break; } - - if (sio->activeDriver && sio->activeDriver->writeRegister && sio->activeDriver->handlesMode(sio->activeDriver, sio->mode)) { - sio->activeDriver->writeRegister(sio->activeDriver, address, value); - } return value; } diff --git a/src/gba/sio/dolphin.c b/src/gba/sio/dolphin.c index badbd05f7f0..039f9b52835 100644 --- a/src/gba/sio/dolphin.c +++ b/src/gba/sio/dolphin.c @@ -36,7 +36,7 @@ void GBASIODolphinCreate(struct GBASIODolphin* dol) { dol->d.init = GBASIODolphinInit; dol->d.load = GBASIODolphinLoad; dol->d.unload = GBASIODolphinUnload; - dol->d.writeRegister = NULL; + dol->d.writeSIOCNT = NULL; dol->d.setMode = NULL; dol->d.handlesMode = GBASIODolphinHandlesMode; dol->d.connectedDevices = GBASIODolphinConnectedDevices; diff --git a/src/gba/sio/gbp.c b/src/gba/sio/gbp.c index 37944d596cd..7aeef1b0b79 100644 --- a/src/gba/sio/gbp.c +++ b/src/gba/sio/gbp.c @@ -13,7 +13,7 @@ #include static uint16_t _gbpRead(struct mKeyCallback*); -static uint16_t _gbpSioWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value); +static uint16_t _gbpSioWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); static bool _gbpSioHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); static int _gbpSioConnectedDevices(struct GBASIODriver* driver); static void _gbpSioProcessEvents(struct mTiming* timing, void* user, uint32_t cyclesLate); @@ -49,7 +49,7 @@ void GBASIOPlayerInit(struct GBASIOPlayer* gbp) { gbp->d.deinit = NULL; gbp->d.load = NULL; gbp->d.unload = NULL; - gbp->d.writeRegister = _gbpSioWriteRegister; + gbp->d.writeSIOCNT = _gbpSioWriteSIOCNT; gbp->d.setMode = NULL; gbp->d.handlesMode = _gbpSioHandlesMode; gbp->d.connectedDevices = _gbpSioConnectedDevices; @@ -106,28 +106,27 @@ uint16_t _gbpRead(struct mKeyCallback* callback) { return 0; } -uint16_t _gbpSioWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value) { +uint16_t _gbpSioWriteSIOCNT(struct GBASIODriver* driver, uint16_t value) { struct GBASIOPlayer* gbp = (struct GBASIOPlayer*) driver; - if (address == GBA_REG_SIOCNT) { - if (value & 0x0080) { - uint32_t rx = gbp->p->memory.io[GBA_REG(SIODATA32_LO)] | (gbp->p->memory.io[GBA_REG(SIODATA32_HI)] << 16); - if (gbp->txPosition < 12 && gbp->txPosition > 0) { - // TODO: Check expected - } else if (gbp->txPosition >= 12) { - // 0x00 = Stop - // 0x11 = Hard Stop - // 0x22 = Start - if (gbp->p->rumble) { - int32_t currentTime = mTimingCurrentTime(&gbp->p->timing); - gbp->p->rumble->setRumble(gbp->p->rumble, (rx & 0x33) == 0x22, currentTime - gbp->p->lastRumble); - gbp->p->lastRumble = currentTime; - } + if (value & 0x0080) { + uint32_t rx = gbp->p->memory.io[GBA_REG(SIODATA32_LO)] | (gbp->p->memory.io[GBA_REG(SIODATA32_HI)] << 16); + if (gbp->txPosition < 12 && gbp->txPosition > 0) { + // TODO: Check expected + } else if (gbp->txPosition >= 12) { + uint32_t mask = 0x33; + // 0x00 = Stop + // 0x11 = Hard Stop + // 0x22 = Start + if (gbp->p->rumble) { + int32_t currentTime = mTimingCurrentTime(&gbp->p->timing); + gbp->p->rumble->setRumble(gbp->p->rumble, (rx & 0x33) == 0x22, currentTime - gbp->p->lastRumble); + gbp->p->lastRumble = currentTime; } - mTimingDeschedule(&gbp->p->timing, &gbp->event); - mTimingSchedule(&gbp->p->timing, &gbp->event, 2048); } - value &= 0x78FB; + mTimingDeschedule(&gbp->p->timing, &gbp->event); + mTimingSchedule(&gbp->p->timing, &gbp->event, 2048); } + value &= 0x78FB; return value; } diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 67b35923468..526d83575d8 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -19,8 +19,8 @@ static void GBASIOLockstepNodeSetMode(struct GBASIODriver* driver, enum GBASIOMo static bool GBASIOLockstepNodeHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); static int GBASIOLockstepNodeConnectedDevices(struct GBASIODriver* driver); static int GBASIOLockstepNodeDeviceId(struct GBASIODriver* driver); -static uint16_t GBASIOLockstepNodeMultiWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value); -static uint16_t GBASIOLockstepNodeNormalWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value); +static uint16_t GBASIOLockstepNodeMultiWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); +static uint16_t GBASIOLockstepNodeNormalWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); static void _GBASIOLockstepNodeProcessEvents(struct mTiming* timing, void* driver, uint32_t cyclesLate); static void _finishTransfer(struct GBASIOLockstepNode* node); @@ -46,7 +46,7 @@ void GBASIOLockstepNodeCreate(struct GBASIOLockstepNode* node) { node->d.handlesMode = GBASIOLockstepNodeHandlesMode; node->d.connectedDevices = GBASIOLockstepNodeConnectedDevices; node->d.deviceId = GBASIOLockstepNodeDeviceId; - node->d.writeRegister = NULL; + node->d.writeSIOCNT = NULL; } bool GBASIOLockstepAttachNode(struct GBASIOLockstep* lockstep, struct GBASIOLockstepNode* node) { @@ -112,7 +112,7 @@ bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver) { switch (node->mode) { case GBA_SIO_MULTI: - node->d.writeRegister = GBASIOLockstepNodeMultiWriteRegister; + node->d.writeSIOCNT = GBASIOLockstepNodeMultiWriteSIOCNT; ATOMIC_ADD(node->p->attachedMulti, 1); node->d.p->siocnt = GBASIOMultiplayerSetReady(node->d.p->siocnt, node->p->attachedMulti == node->p->d.attached); if (node->id) { @@ -134,7 +134,7 @@ bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver) { } else { node->d.p->siocnt = GBASIONormalClearSi(node->d.p->siocnt); } - node->d.writeRegister = GBASIOLockstepNodeNormalWriteRegister; + node->d.writeSIOCNT = GBASIOLockstepNodeNormalWriteSIOCNT; break; default: break; @@ -231,41 +231,35 @@ static int GBASIOLockstepNodeDeviceId(struct GBASIODriver* driver) { return node->id; } -static uint16_t GBASIOLockstepNodeMultiWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value) { +static uint16_t GBASIOLockstepNodeMultiWriteSIOCNT(struct GBASIODriver* driver, uint16_t value) { struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; mLockstepLock(&node->p->d); - if (address == GBA_REG_SIOCNT) { - mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIOCNT <- %04X", node->id, value); + mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIOCNT <- %04X", node->id, value); - enum mLockstepPhase transferActive; - int attached; - ATOMIC_LOAD(transferActive, node->p->d.transferActive); - ATOMIC_LOAD(attached, node->p->d.attached); + enum mLockstepPhase transferActive; + int attached; + ATOMIC_LOAD(transferActive, node->p->d.transferActive); + ATOMIC_LOAD(attached, node->p->d.attached); - driver->p->siocnt = GBASIOMultiplayerSetSlave(driver->p->siocnt, node->id || attached < 2); + driver->p->siocnt = GBASIOMultiplayerSetSlave(driver->p->siocnt, node->id || attached < 2); - if (value & 0x0080 && transferActive == TRANSFER_IDLE) { - if (!node->id && attached > 1 && GBASIOMultiplayerIsReady(node->d.p->siocnt)) { - mLOG(GBA_SIO, DEBUG, "Lockstep %i: Transfer initiated", node->id); - ATOMIC_STORE(node->p->d.transferActive, TRANSFER_STARTING); - ATOMIC_STORE(node->p->d.transferCycles, GBASIOTransferCycles(node->d.p)); + if (value & 0x0080 && transferActive == TRANSFER_IDLE) { + if (!node->id && attached > 1 && GBASIOMultiplayerIsReady(node->d.p->siocnt)) { + mLOG(GBA_SIO, DEBUG, "Lockstep %i: Transfer initiated", node->id); + ATOMIC_STORE(node->p->d.transferActive, TRANSFER_STARTING); + ATOMIC_STORE(node->p->d.transferCycles, GBASIOTransferCycles(node->d.p)); - if (mTimingIsScheduled(&driver->p->p->timing, &node->event)) { - node->eventDiff -= node->event.when - mTimingCurrentTime(&driver->p->p->timing); - mTimingDeschedule(&driver->p->p->timing, &node->event); - } - mTimingSchedule(&driver->p->p->timing, &node->event, 0); + if (mTimingIsScheduled(&driver->p->p->timing, &node->event)) { + node->eventDiff -= node->event.when - mTimingCurrentTime(&driver->p->p->timing); + mTimingDeschedule(&driver->p->p->timing, &node->event); } + mTimingSchedule(&driver->p->p->timing, &node->event, 0); } - value &= 0xFF83; - value |= driver->p->siocnt & 0x00FC; - } else if (address == GBA_REG_SIOMLT_SEND) { - mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIOMLT_SEND <- %04X", node->id, value); - } else { - mLOG(GBA_SIO, STUB, "Lockstep %i: Unknown reg %03X <- %04X", node->id, address, value); } + value &= 0xFF83; + value |= driver->p->siocnt & 0x00FC; mLockstepUnlock(&node->p->d); @@ -525,62 +519,54 @@ static void _GBASIOLockstepNodeProcessEvents(struct mTiming* timing, void* user, mLockstepUnlock(&node->p->d); } -static uint16_t GBASIOLockstepNodeNormalWriteRegister(struct GBASIODriver* driver, uint32_t address, uint16_t value) { +static uint16_t GBASIOLockstepNodeNormalWriteSIOCNT(struct GBASIODriver* driver, uint16_t value) { struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; mLockstepLock(&node->p->d); - if (address == GBA_REG_SIOCNT) { - mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIOCNT <- %04X", node->id, value); - int attached; - ATOMIC_LOAD(attached, node->p->attachedNormal); - value &= 0xFF8B; - if (node->id > 0) { - value = GBASIONormalSetSi(value, GBASIONormalGetIdleSo(node->p->players[node->id - 1]->d.p->siocnt)); - } else { - value = GBASIONormalClearSi(value); - } + mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIOCNT <- %04X", node->id, value); + int attached; + ATOMIC_LOAD(attached, node->p->attachedNormal); + value &= 0xFF8B; + if (node->id > 0) { + value = GBASIONormalSetSi(value, GBASIONormalGetIdleSo(node->p->players[node->id - 1]->d.p->siocnt)); + } else { + value = GBASIONormalClearSi(value); + } - enum mLockstepPhase transferActive; - ATOMIC_LOAD(transferActive, node->p->d.transferActive); - if (node->id < 3 && attached > node->id + 1 && transferActive == TRANSFER_IDLE) { - int try; - for (try = 0; try < 3; ++try) { - GBASIONormal nextSiocnct; - ATOMIC_LOAD(nextSiocnct, node->p->players[node->id + 1]->d.p->siocnt); - if (ATOMIC_CMPXCHG(node->p->players[node->id + 1]->d.p->siocnt, nextSiocnct, GBASIONormalSetSi(nextSiocnct, GBASIONormalGetIdleSo(value)))) { - break; - } + enum mLockstepPhase transferActive; + ATOMIC_LOAD(transferActive, node->p->d.transferActive); + if (node->id < 3 && attached > node->id + 1 && transferActive == TRANSFER_IDLE) { + int try; + for (try = 0; try < 3; ++try) { + GBASIONormal nextSiocnct; + ATOMIC_LOAD(nextSiocnct, node->p->players[node->id + 1]->d.p->siocnt); + if (ATOMIC_CMPXCHG(node->p->players[node->id + 1]->d.p->siocnt, nextSiocnct, GBASIONormalSetSi(nextSiocnct, GBASIONormalGetIdleSo(value)))) { + break; } } - if ((value & 0x0081) == 0x0081) { - if (!node->id) { - // Frequency - int32_t cycles = GBASIOTransferCycles(node->d.p); - - if (transferActive == TRANSFER_IDLE) { - mLOG(GBA_SIO, DEBUG, "Lockstep %i: Transfer initiated", node->id); - ATOMIC_STORE(node->p->d.transferActive, TRANSFER_STARTING); - ATOMIC_STORE(node->p->d.transferCycles, cycles); - - if (mTimingIsScheduled(&driver->p->p->timing, &node->event)) { - node->eventDiff -= node->event.when - mTimingCurrentTime(&driver->p->p->timing); - mTimingDeschedule(&driver->p->p->timing, &node->event); - } - mTimingSchedule(&driver->p->p->timing, &node->event, 0); - } else { - value &= ~0x0080; + } + if ((value & 0x0081) == 0x0081) { + if (!node->id) { + // Frequency + int32_t cycles = GBASIOTransferCycles(node->d.p); + + if (transferActive == TRANSFER_IDLE) { + mLOG(GBA_SIO, DEBUG, "Lockstep %i: Transfer initiated", node->id); + ATOMIC_STORE(node->p->d.transferActive, TRANSFER_STARTING); + ATOMIC_STORE(node->p->d.transferCycles, cycles); + + if (mTimingIsScheduled(&driver->p->p->timing, &node->event)) { + node->eventDiff -= node->event.when - mTimingCurrentTime(&driver->p->p->timing); + mTimingDeschedule(&driver->p->p->timing, &node->event); } + mTimingSchedule(&driver->p->p->timing, &node->event, 0); } else { - // TODO + value &= ~0x0080; } + } else { + // TODO } - } else if (address == GBA_REG_SIODATA32_LO) { - mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIODATA32_LO <- %04X", node->id, value); - } else if (address == GBA_REG_SIODATA32_HI) { - mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIODATA32_HI <- %04X", node->id, value); - } else if (address == GBA_REG_SIODATA8) { - mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIODATA8 <- %02X", node->id, value); } mLockstepUnlock(&node->p->d); From aad552ff47deb92b929f6146fd6d795125c869af Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 22 May 2024 22:42:58 -0700 Subject: [PATCH 214/338] GBA SIO: Add writeRCNT callback, mostly for GPIO mode --- include/mgba/gba/interface.h | 1 + src/gba/extra/battlechip.c | 1 + src/gba/sio.c | 12 ++++-------- src/gba/sio/dolphin.c | 1 + src/gba/sio/gbp.c | 1 + src/gba/sio/lockstep.c | 1 + 6 files changed, 9 insertions(+), 8 deletions(-) diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index b698f403057..f83f9e7179b 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -118,6 +118,7 @@ struct GBASIODriver { int (*connectedDevices)(struct GBASIODriver* driver); int (*deviceId)(struct GBASIODriver* driver); uint16_t (*writeSIOCNT)(struct GBASIODriver* driver, uint16_t value); + uint16_t (*writeRCNT)(struct GBASIODriver* driver, uint16_t value); }; enum GBASIOBattleChipGateFlavor { diff --git a/src/gba/extra/battlechip.c b/src/gba/extra/battlechip.c index b71b4e33e6b..4070626d82e 100644 --- a/src/gba/extra/battlechip.c +++ b/src/gba/extra/battlechip.c @@ -51,6 +51,7 @@ void GBASIOBattlechipGateCreate(struct GBASIOBattlechipGate* gate) { gate->d.handlesMode = GBASIOBattlechipGateHandlesMode; gate->d.connectedDevices = GBASIOBattlechipGateConnectedDevices; gate->d.deviceId = NULL; + gate->d.writeRCNT = NULL; gate->event.context = gate; gate->event.callback = _battlechipTransferEvent; diff --git a/src/gba/sio.c b/src/gba/sio.c index 68b8fcb48a4..14edd7b7a66 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -193,6 +193,10 @@ void GBASIOWriteRCNT(struct GBASIO* sio, uint16_t value) { sio->rcnt &= 0xF; sio->rcnt |= value & ~0xF; _switchMode(sio); + if (sio->activeDriver && sio->activeDriver->writeRCNT) { + sio->rcnt &= 0xC000; + sio->rcnt |= sio->activeDriver->writeRCNT(sio->activeDriver, value) & 0x01FF; + } } void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { @@ -278,8 +282,6 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu default: mLOG(GBA_SIO, DEBUG, "JOY write: Unknown reg %03X <- %04X", address, value); break; - case GBA_REG_RCNT: - break; } break; case GBA_SIO_NORMAL_8: @@ -290,8 +292,6 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu default: mLOG(GBA_SIO, DEBUG, "NORMAL8 %i write: Unknown reg %03X <- %04X", id, address, value); break; - case GBA_REG_RCNT: - break; } break; case GBA_SIO_NORMAL_32: @@ -305,8 +305,6 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu default: mLOG(GBA_SIO, DEBUG, "NORMAL32 %i write: Unknown reg %03X <- %04X", id, address, value); break; - case GBA_REG_RCNT: - break; } break; case GBA_SIO_MULTI: @@ -317,8 +315,6 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu default: mLOG(GBA_SIO, DEBUG, "MULTI %i write: Unknown reg %03X <- %04X", id, address, value); break; - case GBA_REG_RCNT: - break; } break; default: diff --git a/src/gba/sio/dolphin.c b/src/gba/sio/dolphin.c index 039f9b52835..f7aad747b91 100644 --- a/src/gba/sio/dolphin.c +++ b/src/gba/sio/dolphin.c @@ -41,6 +41,7 @@ void GBASIODolphinCreate(struct GBASIODolphin* dol) { dol->d.handlesMode = GBASIODolphinHandlesMode; dol->d.connectedDevices = GBASIODolphinConnectedDevices; dol->d.deviceId = NULL; + dol->d.writeSIOCNT = NULL; dol->event.context = dol; dol->event.name = "GB SIO Lockstep"; dol->event.callback = GBASIODolphinProcessEvents; diff --git a/src/gba/sio/gbp.c b/src/gba/sio/gbp.c index 7aeef1b0b79..f7b3747a1e0 100644 --- a/src/gba/sio/gbp.c +++ b/src/gba/sio/gbp.c @@ -54,6 +54,7 @@ void GBASIOPlayerInit(struct GBASIOPlayer* gbp) { gbp->d.handlesMode = _gbpSioHandlesMode; gbp->d.connectedDevices = _gbpSioConnectedDevices; gbp->d.deviceId = NULL; + gbp->d.writeRCNT = NULL; gbp->event.context = gbp; gbp->event.name = "GBA SIO Game Boy Player"; gbp->event.callback = _gbpSioProcessEvents; diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 526d83575d8..30092c3ecb3 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -47,6 +47,7 @@ void GBASIOLockstepNodeCreate(struct GBASIOLockstepNode* node) { node->d.connectedDevices = GBASIOLockstepNodeConnectedDevices; node->d.deviceId = GBASIOLockstepNodeDeviceId; node->d.writeSIOCNT = NULL; + node->d.writeRCNT = NULL; } bool GBASIOLockstepAttachNode(struct GBASIOLockstep* lockstep, struct GBASIOLockstepNode* node) { From aeb547e3dc621a6ba4f14cbcb3b04941049e54c6 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 22 May 2024 23:04:44 -0700 Subject: [PATCH 215/338] GBA SIO: Finish up GBASIOWriteRegister logging --- src/gba/sio.c | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/src/gba/sio.c b/src/gba/sio.c index 14edd7b7a66..ec29a62a576 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -280,7 +280,7 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu mLOG(GBA_SIO, DEBUG, "JOY write: TRANS_HI <- %04X", value); break; default: - mLOG(GBA_SIO, DEBUG, "JOY write: Unknown reg %03X <- %04X", address, value); + mLOG(GBA_SIO, GAME_ERROR, "JOY write: Unknown reg %03X <- %04X", address, value); break; } break; @@ -290,7 +290,7 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu mLOG(GBA_SIO, DEBUG, "NORMAL8 %i write: SIODATA8 <- %02X", id, value); break; default: - mLOG(GBA_SIO, DEBUG, "NORMAL8 %i write: Unknown reg %03X <- %04X", id, address, value); + mLOG(GBA_SIO, GAME_ERROR, "NORMAL8 %i write: Unknown reg %03X <- %04X", id, address, value); break; } break; @@ -303,7 +303,7 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu mLOG(GBA_SIO, DEBUG, "NORMAL32 %i write: SIODATA32_HI <- %04X", id, value); break; default: - mLOG(GBA_SIO, DEBUG, "NORMAL32 %i write: Unknown reg %03X <- %04X", id, address, value); + mLOG(GBA_SIO, GAME_ERROR, "NORMAL32 %i write: Unknown reg %03X <- %04X", id, address, value); break; } break; @@ -313,12 +313,22 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu mLOG(GBA_SIO, DEBUG, "MULTI %i write: SIOMLT_SEND <- %04X", id, value); break; default: - mLOG(GBA_SIO, DEBUG, "MULTI %i write: Unknown reg %03X <- %04X", id, address, value); + mLOG(GBA_SIO, GAME_ERROR, "MULTI %i write: Unknown reg %03X <- %04X", id, address, value); break; } break; - default: - // TODO + case GBA_SIO_UART: + switch (address) { + case GBA_REG_SIODATA8: + mLOG(GBA_SIO, DEBUG, "UART write: SIODATA8 <- %02X", value); + break; + default: + mLOG(GBA_SIO, GAME_ERROR, "UART write: Unknown reg %03X <- %04X", address, value); + break; + } + break; + case GBA_SIO_GPIO: + mLOG(GBA_SIO, GAME_ERROR, "GPIO %i write: Unknown reg %03X <- %04X", id, address, value); break; } return value; From b572e8b09fbe6ac6052da30d730601d89425b17b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 26 Sep 2024 02:52:25 -0700 Subject: [PATCH 216/338] GBA SIO: Fix SIO register writing per mode --- src/gba/io.c | 1 + src/gba/sio.c | 48 ++++++++++++++++++++++++++++++++++++++++-------- 2 files changed, 41 insertions(+), 8 deletions(-) diff --git a/src/gba/io.c b/src/gba/io.c index ea9d8d8b063..d29fb8a4bfb 100644 --- a/src/gba/io.c +++ b/src/gba/io.c @@ -483,6 +483,7 @@ void GBAIOWrite(struct GBA* gba, uint32_t address, uint16_t value) { // SIO case GBA_REG_SIOCNT: + value &= 0x7FFF; GBASIOWriteSIOCNT(&gba->sio, value); break; case GBA_REG_RCNT: diff --git a/src/gba/sio.c b/src/gba/sio.c index ec29a62a576..62ce0adb7cd 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -262,9 +262,13 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu id = sio->activeDriver->deviceId(sio->activeDriver); } + bool handled = true; switch (sio->mode) { case GBA_SIO_JOYBUS: switch (address) { + case GBA_REG_SIODATA8: + mLOG(GBA_SIO, DEBUG, "JOY write: SIODATA8 (?) <- %04X", value); + break; case GBA_REG_JOYCNT: mLOG(GBA_SIO, DEBUG, "JOY write: CNT <- %04X", value); value = (value & 0x0040) | (sio->p->memory.io[GBA_REG(JOYCNT)] & ~(value & 0x7) & ~0x0040); @@ -280,17 +284,23 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu mLOG(GBA_SIO, DEBUG, "JOY write: TRANS_HI <- %04X", value); break; default: - mLOG(GBA_SIO, GAME_ERROR, "JOY write: Unknown reg %03X <- %04X", address, value); + mLOG(GBA_SIO, GAME_ERROR, "JOY write: Unhandled %s <- %04X", GBAIORegisterNames[address >> 1], value); + handled = false; break; } break; case GBA_SIO_NORMAL_8: switch (address) { case GBA_REG_SIODATA8: - mLOG(GBA_SIO, DEBUG, "NORMAL8 %i write: SIODATA8 <- %02X", id, value); + mLOG(GBA_SIO, DEBUG, "NORMAL8 %i write: SIODATA8 <- %04X", id, value); + break; + case GBA_REG_JOYCNT: + mLOG(GBA_SIO, DEBUG, "NORMAL8 %i write: JOYCNT (?) <- %04X", id, value); + value = (value & 0x0040) | (sio->p->memory.io[GBA_REG(JOYCNT)] & ~(value & 0x7) & ~0x0040); break; default: - mLOG(GBA_SIO, GAME_ERROR, "NORMAL8 %i write: Unknown reg %03X <- %04X", id, address, value); + mLOG(GBA_SIO, GAME_ERROR, "NORMAL8 %i write: Unhandled %s <- %04X", id, GBAIORegisterNames[address >> 1], value); + handled = false; break; } break; @@ -302,8 +312,16 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu case GBA_REG_SIODATA32_HI: mLOG(GBA_SIO, DEBUG, "NORMAL32 %i write: SIODATA32_HI <- %04X", id, value); break; + case GBA_REG_SIODATA8: + mLOG(GBA_SIO, DEBUG, "NORMAL32 %i write: SIODATA8 (?) <- %04X", id, value); + break; + case GBA_REG_JOYCNT: + mLOG(GBA_SIO, DEBUG, "NORMAL32 %i write: JOYCNT (?) <- %04X", id, value); + value = (value & 0x0040) | (sio->p->memory.io[GBA_REG(JOYCNT)] & ~(value & 0x7) & ~0x0040); + break; default: - mLOG(GBA_SIO, GAME_ERROR, "NORMAL32 %i write: Unknown reg %03X <- %04X", id, address, value); + mLOG(GBA_SIO, GAME_ERROR, "NORMAL32 %i write: Unhandled %s <- %04X", id, GBAIORegisterNames[address >> 1], value); + handled = false; break; } break; @@ -312,25 +330,39 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu case GBA_REG_SIOMLT_SEND: mLOG(GBA_SIO, DEBUG, "MULTI %i write: SIOMLT_SEND <- %04X", id, value); break; + case GBA_REG_JOYCNT: + mLOG(GBA_SIO, DEBUG, "MULTI %i write: JOYCNT (?) <- %04X", id, value); + value = (value & 0x0040) | (sio->p->memory.io[GBA_REG(JOYCNT)] & ~(value & 0x7) & ~0x0040); + break; default: - mLOG(GBA_SIO, GAME_ERROR, "MULTI %i write: Unknown reg %03X <- %04X", id, address, value); + mLOG(GBA_SIO, GAME_ERROR, "MULTI %i write: Unhandled %s <- %04X", id, GBAIORegisterNames[address >> 1], value); + handled = false; break; } break; case GBA_SIO_UART: switch (address) { case GBA_REG_SIODATA8: - mLOG(GBA_SIO, DEBUG, "UART write: SIODATA8 <- %02X", value); + mLOG(GBA_SIO, DEBUG, "UART write: SIODATA8 <- %04X", value); + break; + case GBA_REG_JOYCNT: + mLOG(GBA_SIO, DEBUG, "UART write: JOYCNT (?) <- %04X", value); + value = (value & 0x0040) | (sio->p->memory.io[GBA_REG(JOYCNT)] & ~(value & 0x7) & ~0x0040); break; default: - mLOG(GBA_SIO, GAME_ERROR, "UART write: Unknown reg %03X <- %04X", address, value); + mLOG(GBA_SIO, GAME_ERROR, "UART write: Unhandled %s <- %04X", GBAIORegisterNames[address >> 1], value); + handled = false; break; } break; case GBA_SIO_GPIO: - mLOG(GBA_SIO, GAME_ERROR, "GPIO %i write: Unknown reg %03X <- %04X", id, address, value); + mLOG(GBA_SIO, STUB, "GPIO write: Unhandled %s <- %04X", GBAIORegisterNames[address >> 1], value); + handled = false; break; } + if (!handled) { + value = sio->p->memory.io[address >> 1]; + } return value; } From ab655db3f8b6a72d167fbd60e4963dd0c6805666 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 24 May 2024 01:32:55 -0700 Subject: [PATCH 217/338] GBA SIO: Fix NORMAL timing out --- include/mgba/internal/gba/sio.h | 1 + src/gba/sio.c | 42 ++++++++++++++++++++++++++++----- 2 files changed, 37 insertions(+), 6 deletions(-) diff --git a/include/mgba/internal/gba/sio.h b/include/mgba/internal/gba/sio.h index 43acaa7b8c7..804f0f52a33 100644 --- a/include/mgba/internal/gba/sio.h +++ b/include/mgba/internal/gba/sio.h @@ -70,6 +70,7 @@ struct GBASIO { uint16_t siocnt; struct GBASIOPlayer gbp; + struct mTimingEvent completeEvent; }; void GBASIOInit(struct GBASIO* sio); diff --git a/src/gba/sio.c b/src/gba/sio.c index 62ce0adb7cd..710cd9d4533 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -18,6 +18,8 @@ static const int GBASIOCyclesPerTransfer[4][MAX_GBAS] = { { 3140, 5755, 8376, 10486 } }; +static void _sioFinish(struct mTiming* timing, void* user, uint32_t cyclesLate); + static struct GBASIODriver* _lookupDriver(struct GBASIO* sio, enum GBASIOMode mode) { switch (mode) { case GBA_SIO_NORMAL_8: @@ -90,10 +92,15 @@ static void _switchMode(struct GBASIO* sio) { } void GBASIOInit(struct GBASIO* sio) { - sio->drivers.normal = 0; - sio->drivers.multiplayer = 0; - sio->drivers.joybus = 0; - sio->activeDriver = 0; + sio->drivers.normal = NULL; + sio->drivers.multiplayer = NULL; + sio->drivers.joybus = NULL; + sio->activeDriver = NULL; + + sio->completeEvent.context = sio; + sio->completeEvent.name = "GBA SIO Complete"; + sio->completeEvent.callback = _sioFinish; + sio->completeEvent.priority = 0x80; sio->gbp.p = sio->p; GBASIOPlayerInit(&sio->gbp); @@ -239,10 +246,12 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { value = GBASIONormalFillSi(value); if ((value & 0x0081) == 0x0081) { if (GBASIONormalIsIrq(value)) { + mTimingDeschedule(&sio->p->timing, &sio->completeEvent); + mTimingSchedule(&sio->p->timing, &sio->completeEvent, GBASIOTransferCycles(sio)); + } else { // TODO: Test this on hardware to see if this is correct - GBARaiseIRQ(sio->p, GBA_IRQ_SIO, 0); + value = GBASIONormalClearStart(value); } - value = GBASIONormalClearStart(value); } break; case GBA_SIO_MULTI: @@ -425,6 +434,27 @@ void GBASIONormal32FinishTransfer(struct GBASIO* sio, uint32_t data, uint32_t cy } } +static void _sioFinish(struct mTiming* timing, void* user, uint32_t cyclesLate) { + UNUSED(timing); + struct GBASIO* sio = user; + uint16_t data[4] = {0, 0, 0, 0}; + switch (sio->mode) { + case GBA_SIO_MULTI: + GBASIOMultiplayerFinishTransfer(sio, data, cyclesLate); + break; + case GBA_SIO_NORMAL_8: + GBASIONormal8FinishTransfer(sio, 0, cyclesLate); + break; + case GBA_SIO_NORMAL_32: + GBASIONormal32FinishTransfer(sio, 0, cyclesLate); + break; + default: + // TODO + mLOG(GBA_SIO, STUB, "No dummy finish implemented for mode %s", _modeName(sio->mode)); + break; + } +} + int GBASIOJOYSendCommand(struct GBASIODriver* sio, enum GBASIOJOYCommand command, uint8_t* data) { switch (command) { case JOY_RESET: From 914d8798116c4f713c19ad050394d195417c047d Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 24 May 2024 03:01:44 -0700 Subject: [PATCH 218/338] GBA SIO: Allow seamless mode switching if driver supports it --- src/gba/sio.c | 22 +++++++++++++++------- src/gba/sio/lockstep.c | 10 +--------- 2 files changed, 16 insertions(+), 16 deletions(-) diff --git a/src/gba/sio.c b/src/gba/sio.c index 710cd9d4533..54fff7ea199 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -60,16 +60,24 @@ static void _switchMode(struct GBASIO* sio) { newMode = (enum GBASIOMode) (mode & 0xC); } if (newMode != sio->mode) { - if (sio->activeDriver && sio->activeDriver->unload) { - sio->activeDriver->unload(sio->activeDriver); - } + struct GBASIODriver* driver = _lookupDriver(sio, newMode); if (sio->mode != (enum GBASIOMode) -1) { mLOG(GBA_SIO, DEBUG, "Switching mode from %s to %s", _modeName(sio->mode), _modeName(newMode)); } - sio->mode = newMode; - sio->activeDriver = _lookupDriver(sio, sio->mode); - if (sio->activeDriver && sio->activeDriver->load) { - sio->activeDriver->load(sio->activeDriver); + if (driver != sio->activeDriver || (driver && !driver->setMode)) { + if (sio->activeDriver && sio->activeDriver->unload) { + sio->activeDriver->unload(sio->activeDriver); + } + sio->mode = newMode; + sio->activeDriver = driver; + if (sio->activeDriver && sio->activeDriver->load) { + sio->activeDriver->load(sio->activeDriver); + } + } else { + sio->mode = newMode; + if (sio->activeDriver && sio->activeDriver->setMode) { + sio->activeDriver->setMode(sio->activeDriver, newMode); + } } int id = 0; diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 30092c3ecb3..f7b82f08934 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -15,7 +15,6 @@ static bool GBASIOLockstepNodeInit(struct GBASIODriver* driver); static void GBASIOLockstepNodeDeinit(struct GBASIODriver* driver); static bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver); static bool GBASIOLockstepNodeUnload(struct GBASIODriver* driver); -static void GBASIOLockstepNodeSetMode(struct GBASIODriver* driver, enum GBASIOMode mode); static bool GBASIOLockstepNodeHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); static int GBASIOLockstepNodeConnectedDevices(struct GBASIODriver* driver); static int GBASIOLockstepNodeDeviceId(struct GBASIODriver* driver); @@ -42,7 +41,7 @@ void GBASIOLockstepNodeCreate(struct GBASIOLockstepNode* node) { node->d.deinit = GBASIOLockstepNodeDeinit; node->d.load = GBASIOLockstepNodeLoad; node->d.unload = GBASIOLockstepNodeUnload; - node->d.setMode = GBASIOLockstepNodeSetMode; + node->d.setMode = NULL; node->d.handlesMode = GBASIOLockstepNodeHandlesMode; node->d.connectedDevices = GBASIOLockstepNodeConnectedDevices; node->d.deviceId = GBASIOLockstepNodeDeviceId; @@ -190,13 +189,6 @@ bool GBASIOLockstepNodeUnload(struct GBASIODriver* driver) { return true; } -static void GBASIOLockstepNodeSetMode(struct GBASIODriver* driver, enum GBASIOMode mode) { - struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; - mLockstepLock(&node->p->d); - node->mode = mode; - mLockstepUnlock(&node->p->d); -} - static bool GBASIOLockstepNodeHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { UNUSED(driver); switch (mode) { From 0425dadee9bdb1eebaae80f523037fd62c39e004 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 26 May 2024 00:46:00 -0700 Subject: [PATCH 219/338] GBA SIO: Add RCNT bitfield --- include/mgba/internal/gba/sio.h | 9 +++++++++ src/gba/sio.c | 16 ++++++++++------ 2 files changed, 19 insertions(+), 6 deletions(-) diff --git a/include/mgba/internal/gba/sio.h b/include/mgba/internal/gba/sio.h index 804f0f52a33..bb7b2a78c74 100644 --- a/include/mgba/internal/gba/sio.h +++ b/include/mgba/internal/gba/sio.h @@ -52,6 +52,15 @@ DECL_BITS(GBASIOMultiplayer, Id, 4, 2); DECL_BIT(GBASIOMultiplayer, Error, 6); DECL_BIT(GBASIOMultiplayer, Busy, 7); DECL_BIT(GBASIOMultiplayer, Irq, 14); +DECL_BITFIELD(GBASIORegisterRCNT, uint16_t); +DECL_BIT(GBASIORegisterRCNT, Sc, 0); +DECL_BIT(GBASIORegisterRCNT, Sd, 1); +DECL_BIT(GBASIORegisterRCNT, Si, 2); +DECL_BIT(GBASIORegisterRCNT, So, 3); +DECL_BIT(GBASIORegisterRCNT, ScDirection, 4); +DECL_BIT(GBASIORegisterRCNT, SdDirection, 5); +DECL_BIT(GBASIORegisterRCNT, SiDirection, 6); +DECL_BIT(GBASIORegisterRCNT, SoDirection, 7); struct GBASIODriverSet { struct GBASIODriver* normal; diff --git a/src/gba/sio.c b/src/gba/sio.c index 54fff7ea199..b10d2c257f3 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -86,11 +86,7 @@ static void _switchMode(struct GBASIO* sio) { if (sio->activeDriver && sio->activeDriver->deviceId) { id = sio->activeDriver->deviceId(sio->activeDriver); } - if (id) { - sio->rcnt |= 4; - } else { - sio->rcnt &= ~4; - } + sio->rcnt = GBASIORegisterRCNTSetSi(sio->rcnt, !!id); break; default: // TODO @@ -417,9 +413,17 @@ void GBASIOMultiplayerFinishTransfer(struct GBASIO* sio, uint16_t data[4], uint3 sio->p->memory.io[GBA_REG(SIOMULTI1)] = data[1]; sio->p->memory.io[GBA_REG(SIOMULTI2)] = data[2]; sio->p->memory.io[GBA_REG(SIOMULTI3)] = data[3]; - sio->rcnt |= 1; + sio->siocnt = GBASIOMultiplayerClearBusy(sio->siocnt); sio->siocnt = GBASIOMultiplayerSetId(sio->siocnt, id); + + // This SC level is actually a transient pulse, and probably a hardware glitch. + // Based on analog sampling it seems to just be a spike when the other lines deassert. + // It rapidly falls down to GND but it's high enough that it's read out as a 1 for + // several microseconds, likely around 300-500 cycles. I have not measured if and when + // it returns to 0 afterwards. + sio->rcnt = GBASIORegisterRCNTFillSc(sio->rcnt); + if (GBASIOMultiplayerIsIrq(sio->siocnt)) { GBARaiseIRQ(sio->p, GBA_IRQ_SIO, cyclesLate); } From 435c4aa2436addc27e7d0f8439a3aa0281b820bb Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 15 Sep 2024 23:26:58 -0700 Subject: [PATCH 220/338] GBA SIO: Improve RCNT emulation --- src/gba/sio.c | 40 ++++++++++++++++++++++++++++++++-------- 1 file changed, 32 insertions(+), 8 deletions(-) diff --git a/src/gba/sio.c b/src/gba/sio.c index b10d2c257f3..acc45e60739 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -201,12 +201,23 @@ void GBASIOSetDriver(struct GBASIO* sio, struct GBASIODriver* driver, enum GBASI } void GBASIOWriteRCNT(struct GBASIO* sio, uint16_t value) { - sio->rcnt &= 0xF; - sio->rcnt |= value & ~0xF; + sio->rcnt &= 0x1FF; + sio->rcnt |= value & 0xC000; _switchMode(sio); if (sio->activeDriver && sio->activeDriver->writeRCNT) { + switch (sio->mode) { + case GBA_SIO_GPIO: + sio->rcnt = (sio->activeDriver->writeRCNT(sio->activeDriver, value) & 0x01FF) | (sio->rcnt & 0xC000); + break; + default: + sio->rcnt = (sio->activeDriver->writeRCNT(sio->activeDriver, value) & 0x01F0) | (sio->rcnt & 0xC00F); + } + } else if (sio->mode == GBA_SIO_GPIO) { sio->rcnt &= 0xC000; - sio->rcnt |= sio->activeDriver->writeRCNT(sio->activeDriver, value) & 0x01FF; + sio->rcnt |= value & 0x1FF; + } else { + sio->rcnt &= 0xC00F; + sio->rcnt |= value & 0x1F0; } } @@ -235,6 +246,24 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { value = GBASIOMultiplayerSetSlave(value, id || !connected); value = GBASIOMultiplayerSetId(value, id); value |= sio->siocnt & 0x00FC; + + // SC appears to float in multi mode when not doing a transfer. While + // it does spike at the end of a transfer, it appears to die down after + // around 20-30 microseconds. However, the docs on akkit.org + // (http://www.akkit.org/info/gba_comms.html) say this is high until + // a transfer starts and low while active. Further, the Mario Bros. + // multiplayer expects SC to be high in multi mode. This needs better + // investigation than I managed, apparently. + sio->rcnt = GBASIORegisterRCNTFillSc(sio->rcnt); + + break; + case GBA_SIO_NORMAL_8: + case GBA_SIO_NORMAL_32: + // This line is pulled up by the clock owner while the clock is idle. + // If there is no clock owner it's just hi-Z. + if (GBASIONormalGetSc(value)) { + sio->rcnt = GBASIORegisterRCNTFillSc(sio->rcnt); + } break; default: // TODO @@ -417,11 +446,6 @@ void GBASIOMultiplayerFinishTransfer(struct GBASIO* sio, uint16_t data[4], uint3 sio->siocnt = GBASIOMultiplayerClearBusy(sio->siocnt); sio->siocnt = GBASIOMultiplayerSetId(sio->siocnt, id); - // This SC level is actually a transient pulse, and probably a hardware glitch. - // Based on analog sampling it seems to just be a spike when the other lines deassert. - // It rapidly falls down to GND but it's high enough that it's read out as a 1 for - // several microseconds, likely around 300-500 cycles. I have not measured if and when - // it returns to 0 afterwards. sio->rcnt = GBASIORegisterRCNTFillSc(sio->rcnt); if (GBASIOMultiplayerIsIrq(sio->siocnt)) { From 621eb4d4257ce2fc1894812bc6278e6404dc094b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 27 May 2024 23:11:22 -0700 Subject: [PATCH 221/338] GBA SIO: Move starting/end timing logic out of drivers --- include/mgba/gba/interface.h | 5 ++- include/mgba/internal/gba/serialize.h | 4 +- include/mgba/internal/gba/sio/gbp.h | 1 - src/gba/cart/gpio.c | 14 +++---- src/gba/extra/battlechip.c | 45 +++++--------------- src/gba/sio.c | 60 +++++++++++++++++++++------ src/gba/sio/dolphin.c | 5 +-- src/gba/sio/gbp.c | 59 +++++++++++--------------- src/gba/sio/lockstep.c | 14 ++++--- 9 files changed, 104 insertions(+), 103 deletions(-) diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index f83f9e7179b..3d52e77431b 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -119,6 +119,10 @@ struct GBASIODriver { int (*deviceId)(struct GBASIODriver* driver); uint16_t (*writeSIOCNT)(struct GBASIODriver* driver, uint16_t value); uint16_t (*writeRCNT)(struct GBASIODriver* driver, uint16_t value); + bool (*start)(struct GBASIODriver* driver); + void (*finishMultiplayer)(struct GBASIODriver* driver, uint16_t data[4]); + uint8_t (*finishNormal8)(struct GBASIODriver* driver); + uint32_t (*finishNormal32)(struct GBASIODriver* driver); }; enum GBASIOBattleChipGateFlavor { @@ -130,7 +134,6 @@ enum GBASIOBattleChipGateFlavor { struct GBASIOBattlechipGate { struct GBASIODriver d; - struct mTimingEvent event; uint16_t chipId; uint16_t data[2]; int state; diff --git a/include/mgba/internal/gba/serialize.h b/include/mgba/internal/gba/serialize.h index 9bd21821a38..c824e85aafb 100644 --- a/include/mgba/internal/gba/serialize.h +++ b/include/mgba/internal/gba/serialize.h @@ -191,7 +191,7 @@ mLOG_DECLARE_CATEGORY(GBA_STATE); * | bits 2 - 3: GB Player inputs posted * | bits 4 - 8: GB Player transmit position * | bits 9 - 23: Reserved - * 0x002C4 - 0x002C7: Game Boy Player next event + * 0x002C4 - 0x002C7: SIO next event * 0x002C8 - 0x002CB: Current DMA transfer word * 0x002CC - 0x002CF: Last DMA transfer PC * 0x002D0 - 0x002DF: Matrix memory command buffer @@ -370,7 +370,7 @@ struct GBASerializedState { uint8_t lightSample; GBASerializedHWFlags2 flags2; GBASerializedHWFlags3 flags3; - uint32_t gbpNextEvent; + uint32_t sioNextEvent; } hw; uint32_t dmaTransferRegister; diff --git a/include/mgba/internal/gba/sio/gbp.h b/include/mgba/internal/gba/sio/gbp.h index 6713cdcaf77..fe32cd8c15b 100644 --- a/include/mgba/internal/gba/sio/gbp.h +++ b/include/mgba/internal/gba/sio/gbp.h @@ -21,7 +21,6 @@ struct GBASIOPlayer { struct GBA* p; unsigned inputsPosted; int txPosition; - struct mTimingEvent event; struct GBASIOPlayerKeyCallback callback; bool oldOpposingDirections; struct mKeyCallback* oldCallback; diff --git a/src/gba/cart/gpio.c b/src/gba/cart/gpio.c index fde4e3714b0..a04a5f6b36d 100644 --- a/src/gba/cart/gpio.c +++ b/src/gba/cart/gpio.c @@ -486,10 +486,10 @@ void GBAHardwareSerialize(const struct GBACartridgeHardware* hw, struct GBASeria flags2 = GBASerializedHWFlags2SetTiltState(flags2, hw->tiltState); flags2 = GBASerializedHWFlags1SetLightCounter(flags2, hw->lightCounter); - // GBP stuff is only here for legacy reasons + // GBP/SIO stuff is only here for legacy reasons flags2 = GBASerializedHWFlags2SetGbpInputsPosted(flags2, hw->p->sio.gbp.inputsPosted); flags2 = GBASerializedHWFlags2SetGbpTxPosition(flags2, hw->p->sio.gbp.txPosition); - STORE_32(hw->p->sio.gbp.event.when - mTimingCurrentTime(&hw->p->timing), 0, &state->hw.gbpNextEvent); + STORE_32(hw->p->sio.completeEvent.when - mTimingCurrentTime(&hw->p->timing), 0, &state->hw.sioNextEvent); state->hw.flags2 = flags2; } @@ -520,16 +520,16 @@ void GBAHardwareDeserialize(struct GBACartridgeHardware* hw, const struct GBASer hw->lightSample = state->hw.lightSample; hw->lightEdge = GBASerializedHWFlags1GetLightEdge(flags1); - // GBP stuff is only here for legacy reasons + // GBP/SIO stuff is only here for legacy reasons hw->p->sio.gbp.inputsPosted = GBASerializedHWFlags2GetGbpInputsPosted(state->hw.flags2); hw->p->sio.gbp.txPosition = GBASerializedHWFlags2GetGbpTxPosition(state->hw.flags2); uint32_t when; - LOAD_32(when, 0, &state->hw.gbpNextEvent); + LOAD_32(when, 0, &state->hw.sioNextEvent); if (hw->devices & HW_GB_PLAYER) { GBASIOSetDriver(&hw->p->sio, &hw->p->sio.gbp.d, GBA_SIO_NORMAL_32); - if (hw->p->memory.io[GBA_REG(SIOCNT)] & 0x0080) { - mTimingSchedule(&hw->p->timing, &hw->p->sio.gbp.event, when); - } + } + if ((hw->p->memory.io[GBA_REG(SIOCNT)] & 0x0080) && when < 0x20000) { + mTimingSchedule(&hw->p->timing, &hw->p->sio.completeEvent, when); } } diff --git a/src/gba/extra/battlechip.c b/src/gba/extra/battlechip.c index 4070626d82e..a6eda3bdfdd 100644 --- a/src/gba/extra/battlechip.c +++ b/src/gba/extra/battlechip.c @@ -37,25 +37,15 @@ static bool GBASIOBattlechipGateLoad(struct GBASIODriver* driver); static uint16_t GBASIOBattlechipGateWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); static bool GBASIOBattlechipGateHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); static int GBASIOBattlechipGateConnectedDevices(struct GBASIODriver* driver); - -static void _battlechipTransfer(struct GBASIOBattlechipGate* gate); -static void _battlechipTransferEvent(struct mTiming* timing, void* user, uint32_t cyclesLate); +static void GBASIOBattlechipGateFinishMultiplayer(struct GBASIODriver* driver, uint16_t data[4]); void GBASIOBattlechipGateCreate(struct GBASIOBattlechipGate* gate) { - gate->d.init = NULL; - gate->d.deinit = NULL; + memset(&gate->d, 0, sizeof(gate->d)); gate->d.load = GBASIOBattlechipGateLoad; - gate->d.unload = NULL; gate->d.writeSIOCNT = GBASIOBattlechipGateWriteSIOCNT; - gate->d.setMode = NULL; gate->d.handlesMode = GBASIOBattlechipGateHandlesMode; gate->d.connectedDevices = GBASIOBattlechipGateConnectedDevices; - gate->d.deviceId = NULL; - gate->d.writeRCNT = NULL; - - gate->event.context = gate; - gate->event.callback = _battlechipTransferEvent; - gate->event.priority = 0x80; + gate->d.finishMultiplayer = GBASIOBattlechipGateFinishMultiplayer; gate->chipId = 0; gate->flavor = GBA_FLAVOR_BATTLECHIP_GATE; @@ -70,12 +60,9 @@ bool GBASIOBattlechipGateLoad(struct GBASIODriver* driver) { } uint16_t GBASIOBattlechipGateWriteSIOCNT(struct GBASIODriver* driver, uint16_t value) { - struct GBASIOBattlechipGate* gate = (struct GBASIOBattlechipGate*) driver; + UNUSED(driver); value &= ~0xC; value |= 0x8; - if (value & 0x80) { - _battlechipTransfer(gate); - } return value; } @@ -95,20 +82,8 @@ static int GBASIOBattlechipGateConnectedDevices(struct GBASIODriver* driver) { return 1; } -void _battlechipTransfer(struct GBASIOBattlechipGate* gate) { - int32_t cycles = GBASIOTransferCycles(gate->d.p); - mTimingDeschedule(&gate->d.p->p->timing, &gate->event); - mTimingSchedule(&gate->d.p->p->timing, &gate->event, cycles); -} - -void _battlechipTransferEvent(struct mTiming* timing, void* user, uint32_t cyclesLate) { - UNUSED(timing); - struct GBASIOBattlechipGate* gate = user; - - if (gate->d.p->mode == GBA_SIO_NORMAL_32) { - GBASIONormal32FinishTransfer(gate->d.p, 0, cyclesLate); - return; - } +static void GBASIOBattlechipGateFinishMultiplayer(struct GBASIODriver* driver, uint16_t data[4]) { + struct GBASIOBattlechipGate* gate = (struct GBASIOBattlechipGate*) driver; uint16_t cmd = gate->d.p->p->memory.io[GBA_REG(SIOMLT_SEND)]; uint16_t reply = 0xFFFF; @@ -189,8 +164,8 @@ void _battlechipTransferEvent(struct mTiming* timing, void* user, uint32_t cycle mLOG(GBA_BATTLECHIP, DEBUG, "Gate: %04X (%i)", reply, gate->state); ++gate->state; - uint16_t data[4] = { - cmd, reply, 0xFFFF, 0xFFFF - }; - GBASIOMultiplayerFinishTransfer(gate->d.p, data, cyclesLate); + data[0] = cmd; + data[1] = reply; + data[2] = 0xFFFF; + data[3] = 0xFFFF; } diff --git a/src/gba/sio.c b/src/gba/sio.c index acc45e60739..971eb950242 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -221,6 +221,17 @@ void GBASIOWriteRCNT(struct GBASIO* sio, uint16_t value) { } } +static void _startTransfer(struct GBASIO* sio) { + if (sio->activeDriver && sio->activeDriver->start) { + if (!sio->activeDriver->start(sio->activeDriver)) { + // Transfer completion is handled internally to the driver + return; + } + } + mTimingDeschedule(&sio->p->timing, &sio->completeEvent); + mTimingSchedule(&sio->p->timing, &sio->completeEvent, GBASIOTransferCycles(sio)); +} + void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { if ((value ^ sio->siocnt) & 0x3000) { sio->siocnt = value & 0x3000; @@ -256,6 +267,18 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { // investigation than I managed, apparently. sio->rcnt = GBASIORegisterRCNTFillSc(sio->rcnt); + if (GBASIOMultiplayerIsBusy(value) && !GBASIOMultiplayerIsBusy(sio->siocnt)) { + if (!id) { + sio->p->memory.io[GBA_REG(SIOMULTI0)] = 0xFFFF; + sio->p->memory.io[GBA_REG(SIOMULTI1)] = 0xFFFF; + sio->p->memory.io[GBA_REG(SIOMULTI2)] = 0xFFFF; + sio->p->memory.io[GBA_REG(SIOMULTI3)] = 0xFFFF; + sio->rcnt = GBASIORegisterRCNTClearSc(sio->rcnt); + _startTransfer(sio); + } else { + // TODO + } + } break; case GBA_SIO_NORMAL_8: case GBA_SIO_NORMAL_32: @@ -264,6 +287,13 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { if (GBASIONormalGetSc(value)) { sio->rcnt = GBASIORegisterRCNTFillSc(sio->rcnt); } + if (GBASIONormalIsStart(value) && !GBASIONormalIsStart(sio->siocnt)) { + if (GBASIONormalIsSc(value)) { + _startTransfer(sio); + } else { + // TODO + } + } break; default: // TODO @@ -277,15 +307,6 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { case GBA_SIO_NORMAL_8: case GBA_SIO_NORMAL_32: value = GBASIONormalFillSi(value); - if ((value & 0x0081) == 0x0081) { - if (GBASIONormalIsIrq(value)) { - mTimingDeschedule(&sio->p->timing, &sio->completeEvent); - mTimingSchedule(&sio->p->timing, &sio->completeEvent, GBASIOTransferCycles(sio)); - } else { - // TODO: Test this on hardware to see if this is correct - value = GBASIONormalClearStart(value); - } - } break; case GBA_SIO_MULTI: value = GBASIOMultiplayerFillReady(value); @@ -473,16 +494,29 @@ void GBASIONormal32FinishTransfer(struct GBASIO* sio, uint32_t data, uint32_t cy static void _sioFinish(struct mTiming* timing, void* user, uint32_t cyclesLate) { UNUSED(timing); struct GBASIO* sio = user; - uint16_t data[4] = {0, 0, 0, 0}; + union { + uint16_t multi[4]; + uint8_t normal8; + uint32_t normal32; + } data = {0}; switch (sio->mode) { case GBA_SIO_MULTI: - GBASIOMultiplayerFinishTransfer(sio, data, cyclesLate); + if (sio->activeDriver && sio->activeDriver->finishMultiplayer) { + sio->activeDriver->finishMultiplayer(sio->activeDriver, data.multi); + } + GBASIOMultiplayerFinishTransfer(sio, data.multi, cyclesLate); break; case GBA_SIO_NORMAL_8: - GBASIONormal8FinishTransfer(sio, 0, cyclesLate); + if (sio->activeDriver && sio->activeDriver->finishNormal8) { + data.normal8 = sio->activeDriver->finishNormal8(sio->activeDriver); + } + GBASIONormal8FinishTransfer(sio, data.normal8, cyclesLate); break; case GBA_SIO_NORMAL_32: - GBASIONormal32FinishTransfer(sio, 0, cyclesLate); + if (sio->activeDriver && sio->activeDriver->finishNormal32) { + data.normal32 = sio->activeDriver->finishNormal32(sio->activeDriver); + } + GBASIONormal32FinishTransfer(sio, data.normal32, cyclesLate); break; default: // TODO diff --git a/src/gba/sio/dolphin.c b/src/gba/sio/dolphin.c index f7aad747b91..e36dfb8a53e 100644 --- a/src/gba/sio/dolphin.c +++ b/src/gba/sio/dolphin.c @@ -33,15 +33,12 @@ static int32_t _processCommand(struct GBASIODolphin* dol, uint32_t cyclesLate); static void _flush(struct GBASIODolphin* dol); void GBASIODolphinCreate(struct GBASIODolphin* dol) { + memset(&dol->d, 0, sizeof(dol->d)); dol->d.init = GBASIODolphinInit; dol->d.load = GBASIODolphinLoad; dol->d.unload = GBASIODolphinUnload; - dol->d.writeSIOCNT = NULL; - dol->d.setMode = NULL; dol->d.handlesMode = GBASIODolphinHandlesMode; dol->d.connectedDevices = GBASIODolphinConnectedDevices; - dol->d.deviceId = NULL; - dol->d.writeSIOCNT = NULL; dol->event.context = dol; dol->event.name = "GB SIO Lockstep"; dol->event.callback = GBASIODolphinProcessEvents; diff --git a/src/gba/sio/gbp.c b/src/gba/sio/gbp.c index f7b3747a1e0..3335905a1f8 100644 --- a/src/gba/sio/gbp.c +++ b/src/gba/sio/gbp.c @@ -16,7 +16,8 @@ static uint16_t _gbpRead(struct mKeyCallback*); static uint16_t _gbpSioWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); static bool _gbpSioHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); static int _gbpSioConnectedDevices(struct GBASIODriver* driver); -static void _gbpSioProcessEvents(struct mTiming* timing, void* user, uint32_t cyclesLate); +static bool _gbpSioStart(struct GBASIODriver* driver); +static uint32_t _gbpSioFinishNormal32(struct GBASIODriver* driver); static const uint8_t _logoPalette[] = { 0xDF, 0xFF, 0x0C, 0x64, 0x0C, 0xE4, 0x2D, 0xE4, 0x4E, 0x64, 0x4E, 0xE4, 0x6E, 0xE4, 0xAF, 0x68, @@ -45,20 +46,12 @@ void GBASIOPlayerInit(struct GBASIOPlayer* gbp) { gbp->callback.d.readKeys = _gbpRead; gbp->callback.d.requireOpposingDirections = true; gbp->callback.p = gbp; - gbp->d.init = NULL; - gbp->d.deinit = NULL; - gbp->d.load = NULL; - gbp->d.unload = NULL; + memset(&gbp->d, 0, sizeof(gbp->d)); gbp->d.writeSIOCNT = _gbpSioWriteSIOCNT; - gbp->d.setMode = NULL; gbp->d.handlesMode = _gbpSioHandlesMode; gbp->d.connectedDevices = _gbpSioConnectedDevices; - gbp->d.deviceId = NULL; - gbp->d.writeRCNT = NULL; - gbp->event.context = gbp; - gbp->event.name = "GBA SIO Game Boy Player"; - gbp->event.callback = _gbpSioProcessEvents; - gbp->event.priority = 0x80; + gbp->d.start = _gbpSioStart; + gbp->d.finishNormal32 = _gbpSioFinishNormal32; } void GBASIOPlayerReset(struct GBASIOPlayer* gbp) { @@ -108,27 +101,26 @@ uint16_t _gbpRead(struct mKeyCallback* callback) { } uint16_t _gbpSioWriteSIOCNT(struct GBASIODriver* driver, uint16_t value) { + UNUSED(driver); + return value & 0x78FB; +} + +bool _gbpSioStart(struct GBASIODriver* driver) { struct GBASIOPlayer* gbp = (struct GBASIOPlayer*) driver; - if (value & 0x0080) { - uint32_t rx = gbp->p->memory.io[GBA_REG(SIODATA32_LO)] | (gbp->p->memory.io[GBA_REG(SIODATA32_HI)] << 16); - if (gbp->txPosition < 12 && gbp->txPosition > 0) { - // TODO: Check expected - } else if (gbp->txPosition >= 12) { - uint32_t mask = 0x33; - // 0x00 = Stop - // 0x11 = Hard Stop - // 0x22 = Start - if (gbp->p->rumble) { - int32_t currentTime = mTimingCurrentTime(&gbp->p->timing); - gbp->p->rumble->setRumble(gbp->p->rumble, (rx & 0x33) == 0x22, currentTime - gbp->p->lastRumble); - gbp->p->lastRumble = currentTime; - } + uint32_t rx = gbp->p->memory.io[GBA_REG(SIODATA32_LO)] | (gbp->p->memory.io[GBA_REG(SIODATA32_HI)] << 16); + if (gbp->txPosition < 12 && gbp->txPosition > 0) { + // TODO: Check expected + } else if (gbp->txPosition >= 12) { + // 0x00 = Stop + // 0x11 = Hard Stop + // 0x22 = Start + if (gbp->p->rumble) { + int32_t currentTime = mTimingCurrentTime(&gbp->p->timing); + gbp->p->rumble->setRumble(gbp->p->rumble, (rx & 0x33) == 0x22, currentTime - gbp->p->lastRumble); + gbp->p->lastRumble = currentTime; } - mTimingDeschedule(&gbp->p->timing, &gbp->event); - mTimingSchedule(&gbp->p->timing, &gbp->event, 2048); } - value &= 0x78FB; - return value; + return true; } static bool _gbpSioHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { @@ -141,9 +133,8 @@ static int _gbpSioConnectedDevices(struct GBASIODriver* driver) { return 1; } -void _gbpSioProcessEvents(struct mTiming* timing, void* user, uint32_t cyclesLate) { - UNUSED(timing); - struct GBASIOPlayer* gbp = user; +uint32_t _gbpSioFinishNormal32(struct GBASIODriver* driver) { + struct GBASIOPlayer* gbp = (struct GBASIOPlayer*) driver; uint32_t tx = 0; int txPosition = gbp->txPosition; if (txPosition > 16) { @@ -154,5 +145,5 @@ void _gbpSioProcessEvents(struct mTiming* timing, void* user, uint32_t cyclesLat } tx = _gbpTxData[txPosition]; ++gbp->txPosition; - GBASIONormal32FinishTransfer(gbp->d.p, tx, cyclesLate); + return tx; } diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index f7b82f08934..ed74ed6d4fc 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -18,6 +18,7 @@ static bool GBASIOLockstepNodeUnload(struct GBASIODriver* driver); static bool GBASIOLockstepNodeHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); static int GBASIOLockstepNodeConnectedDevices(struct GBASIODriver* driver); static int GBASIOLockstepNodeDeviceId(struct GBASIODriver* driver); +static bool GBASIOLockstepNodeStart(struct GBASIODriver* driver); static uint16_t GBASIOLockstepNodeMultiWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); static uint16_t GBASIOLockstepNodeNormalWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); static void _GBASIOLockstepNodeProcessEvents(struct mTiming* timing, void* driver, uint32_t cyclesLate); @@ -37,16 +38,16 @@ void GBASIOLockstepInit(struct GBASIOLockstep* lockstep) { } void GBASIOLockstepNodeCreate(struct GBASIOLockstepNode* node) { + memset(&node->d, 0, sizeof(node->d)); node->d.init = GBASIOLockstepNodeInit; node->d.deinit = GBASIOLockstepNodeDeinit; node->d.load = GBASIOLockstepNodeLoad; node->d.unload = GBASIOLockstepNodeUnload; - node->d.setMode = NULL; node->d.handlesMode = GBASIOLockstepNodeHandlesMode; node->d.connectedDevices = GBASIOLockstepNodeConnectedDevices; node->d.deviceId = GBASIOLockstepNodeDeviceId; + node->d.start = GBASIOLockstepNodeStart; node->d.writeSIOCNT = NULL; - node->d.writeRCNT = NULL; } bool GBASIOLockstepAttachNode(struct GBASIOLockstep* lockstep, struct GBASIOLockstepNode* node) { @@ -224,6 +225,11 @@ static int GBASIOLockstepNodeDeviceId(struct GBASIODriver* driver) { return node->id; } +static bool GBASIOLockstepNodeStart(struct GBASIODriver* driver) { + UNUSED(driver); + return false; +} + static uint16_t GBASIOLockstepNodeMultiWriteSIOCNT(struct GBASIODriver* driver, uint16_t value) { struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; @@ -319,10 +325,6 @@ static int32_t _masterUpdate(struct GBASIOLockstepNode* node) { switch (node->mode) { case GBA_SIO_MULTI: node->p->multiRecv[0] = node->d.p->p->memory.io[GBA_REG(SIOMLT_SEND)]; - node->d.p->p->memory.io[GBA_REG(SIOMULTI0)] = 0xFFFF; - node->d.p->p->memory.io[GBA_REG(SIOMULTI1)] = 0xFFFF; - node->d.p->p->memory.io[GBA_REG(SIOMULTI2)] = 0xFFFF; - node->d.p->p->memory.io[GBA_REG(SIOMULTI3)] = 0xFFFF; node->p->multiRecv[1] = 0xFFFF; node->p->multiRecv[2] = 0xFFFF; node->p->multiRecv[3] = 0xFFFF; From 0b9cf1270cd1779d489ad276527aab973adebeee Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 5 Sep 2024 03:33:35 -0700 Subject: [PATCH 222/338] GBA SIO: Modify GBASIOTransferCycles to not require SIO struct --- include/mgba/internal/gba/sio.h | 2 +- src/gba/sio.c | 25 ++++++++++++------------- src/gba/sio/lockstep.c | 6 +++--- 3 files changed, 16 insertions(+), 17 deletions(-) diff --git a/include/mgba/internal/gba/sio.h b/include/mgba/internal/gba/sio.h index bb7b2a78c74..ca271abc4cd 100644 --- a/include/mgba/internal/gba/sio.h +++ b/include/mgba/internal/gba/sio.h @@ -93,7 +93,7 @@ void GBASIOWriteRCNT(struct GBASIO* sio, uint16_t value); void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value); uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t value); -int32_t GBASIOTransferCycles(struct GBASIO* sio); +int32_t GBASIOTransferCycles(enum GBASIOMode mode, uint16_t siocnt, int connected); void GBASIOMultiplayerFinishTransfer(struct GBASIO* sio, uint16_t data[4], uint32_t cyclesLate); void GBASIONormal8FinishTransfer(struct GBASIO* sio, uint8_t data, uint32_t cyclesLate); diff --git a/src/gba/sio.c b/src/gba/sio.c index 971eb950242..4b635db18dd 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -228,8 +228,12 @@ static void _startTransfer(struct GBASIO* sio) { return; } } + int connected = 0; + if (sio->activeDriver && sio->activeDriver->connectedDevices) { + connected = sio->activeDriver->connectedDevices(sio->activeDriver); + } mTimingDeschedule(&sio->p->timing, &sio->completeEvent); - mTimingSchedule(&sio->p->timing, &sio->completeEvent, GBASIOTransferCycles(sio)); + mTimingSchedule(&sio->p->timing, &sio->completeEvent, GBASIOTransferCycles(sio->mode, sio->siocnt, connected)); } void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { @@ -429,26 +433,21 @@ uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t valu return value; } -int32_t GBASIOTransferCycles(struct GBASIO* sio) { - int connected = 0; - if (sio->activeDriver) { - connected = sio->activeDriver->connectedDevices(sio->activeDriver); - } - +int32_t GBASIOTransferCycles(enum GBASIOMode mode, uint16_t siocnt, int connected) { if (connected < 0 || connected >= MAX_GBAS) { - mLOG(GBA_SIO, ERROR, "SIO driver returned invalid device count %i", connected); + mLOG(GBA_SIO, ERROR, "Invalid device count %i", connected); return 0; } - switch (sio->mode) { + switch (mode) { case GBA_SIO_MULTI: - return GBASIOCyclesPerTransfer[GBASIOMultiplayerGetBaud(sio->siocnt)][connected]; + return GBASIOCyclesPerTransfer[GBASIOMultiplayerGetBaud(siocnt)][connected]; case GBA_SIO_NORMAL_8: - return 8 * GBA_ARM7TDMI_FREQUENCY / ((GBASIONormalIsInternalSc(sio->siocnt) ? 2048 : 256) * 1024); + return 8 * GBA_ARM7TDMI_FREQUENCY / ((GBASIONormalIsInternalSc(siocnt) ? 2048 : 256) * 1024); case GBA_SIO_NORMAL_32: - return 32 * GBA_ARM7TDMI_FREQUENCY / ((GBASIONormalIsInternalSc(sio->siocnt) ? 2048 : 256) * 1024); + return 32 * GBA_ARM7TDMI_FREQUENCY / ((GBASIONormalIsInternalSc(siocnt) ? 2048 : 256) * 1024); default: - mLOG(GBA_SIO, STUB, "No cycle count implemented for mode %s", _modeName(sio->mode)); + mLOG(GBA_SIO, STUB, "No cycle count implemented for mode %s", _modeName(mode)); break; } return 0; diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index ed74ed6d4fc..2008638bd63 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -248,7 +248,7 @@ static uint16_t GBASIOLockstepNodeMultiWriteSIOCNT(struct GBASIODriver* driver, if (!node->id && attached > 1 && GBASIOMultiplayerIsReady(node->d.p->siocnt)) { mLOG(GBA_SIO, DEBUG, "Lockstep %i: Transfer initiated", node->id); ATOMIC_STORE(node->p->d.transferActive, TRANSFER_STARTING); - ATOMIC_STORE(node->p->d.transferCycles, GBASIOTransferCycles(node->d.p)); + ATOMIC_STORE(node->p->d.transferCycles, GBASIOTransferCycles(node->d.p->mode, node->d.p->siocnt, attached)); if (mTimingIsScheduled(&driver->p->p->timing, &node->event)) { node->eventDiff -= node->event.when - mTimingCurrentTime(&driver->p->p->timing); @@ -479,7 +479,7 @@ static void _GBASIOLockstepNodeProcessEvents(struct mTiming* timing, void* user, if (node->p->d.attached < 2) { switch (node->mode) { case GBA_SIO_MULTI: - cycles = GBASIOTransferCycles(node->d.p); + cycles = GBASIOTransferCycles(node->d.p->mode, node->d.p->siocnt, node->p->d.attached); break; case GBA_SIO_NORMAL_8: case GBA_SIO_NORMAL_32: @@ -544,7 +544,7 @@ static uint16_t GBASIOLockstepNodeNormalWriteSIOCNT(struct GBASIODriver* driver, if ((value & 0x0081) == 0x0081) { if (!node->id) { // Frequency - int32_t cycles = GBASIOTransferCycles(node->d.p); + int32_t cycles = GBASIOTransferCycles(node->d.p->mode, node->d.p->siocnt, attached); if (transferActive == TRANSFER_IDLE) { mLOG(GBA_SIO, DEBUG, "Lockstep %i: Transfer initiated", node->id); From 3180d432e5b1352b5605b5eb9f46aaee439137d1 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 21 Aug 2024 23:59:56 -0700 Subject: [PATCH 223/338] Core: Add new mLockstepUser API for upcoming lockstep rewrite --- include/mgba/core/lockstep.h | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/include/mgba/core/lockstep.h b/include/mgba/core/lockstep.h index ac6cb3f84e3..8936d263e66 100644 --- a/include/mgba/core/lockstep.h +++ b/include/mgba/core/lockstep.h @@ -1,4 +1,4 @@ -/* Copyright (c) 2013-2016 Jeffrey Pfau +/* Copyright (c) 2013-2024 Jeffrey Pfau * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this @@ -53,6 +53,14 @@ static inline void mLockstepUnlock(struct mLockstep* lockstep) { } } +struct mLockstepUser { + void (*sleep)(struct mLockstepUser*); + void (*wake)(struct mLockstepUser*); + + int (*requestedId)(struct mLockstepUser*); + void (*playerIdChanged)(struct mLockstepUser*, int id); +}; + CXX_GUARD_END #endif From 36c1a8cfbc759eae52958dd5e927a6ab4dd8a5ed Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 22 Aug 2024 22:23:27 -0700 Subject: [PATCH 224/338] Core: Implement mLockstepUser for mCoreThread --- include/mgba/core/lockstep.h | 11 +++++++++++ src/core/lockstep.c | 25 +++++++++++++++++++++++-- 2 files changed, 34 insertions(+), 2 deletions(-) diff --git a/include/mgba/core/lockstep.h b/include/mgba/core/lockstep.h index 8936d263e66..b83d1765784 100644 --- a/include/mgba/core/lockstep.h +++ b/include/mgba/core/lockstep.h @@ -61,6 +61,17 @@ struct mLockstepUser { void (*playerIdChanged)(struct mLockstepUser*, int id); }; +#ifndef DISABLE_THREADING +struct mCoreThread; +struct mLockstepThreadUser { + struct mLockstepUser d; + + struct mCoreThread* thread; +}; + +void mLockstepThreadUserInit(struct mLockstepThreadUser* lockstep, struct mCoreThread* thread); +#endif + CXX_GUARD_END #endif diff --git a/src/core/lockstep.c b/src/core/lockstep.c index 587cff2b59b..c058a80fc62 100644 --- a/src/core/lockstep.c +++ b/src/core/lockstep.c @@ -1,10 +1,14 @@ -/* Copyright (c) 2013-2016 Jeffrey Pfau +/* Copyright (c) 2013-2024 Jeffrey Pfau * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include +#ifndef DISABLE_THREADING +#include +#endif + void mLockstepInit(struct mLockstep* lockstep) { lockstep->attached = 0; lockstep->transferActive = 0; @@ -19,4 +23,21 @@ void mLockstepDeinit(struct mLockstep* lockstep) { UNUSED(lockstep); } -// TODO: Migrate nodes +#ifndef DISABLE_THREADING +static void mLockstepThreadUserSleep(struct mLockstepUser* user) { + struct mLockstepThreadUser* lockstep = (struct mLockstepThreadUser*) user; + mCoreThreadWaitFromThread(lockstep->thread); +} + +static void mLockstepThreadUserWake(struct mLockstepUser* user) { + struct mLockstepThreadUser* lockstep = (struct mLockstepThreadUser*) user; + mCoreThreadStopWaiting(lockstep->thread); +} + +void mLockstepThreadUserInit(struct mLockstepThreadUser* lockstep, struct mCoreThread* thread) { + memset(lockstep, 0, sizeof(*lockstep)); + lockstep->d.sleep = mLockstepThreadUserSleep; + lockstep->d.wake = mLockstepThreadUserWake; + lockstep->thread = thread; +} +#endif From 0955b9446624d63743b74dd1cb18cb71500e1ebc Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 22 Aug 2024 00:00:10 -0700 Subject: [PATCH 225/338] GBA SIO: Bring up new lockstep driver --- include/mgba/internal/gba/sio/lockstep.h | 77 ++- src/gba/sio/lockstep.c | 769 ++++++++++++++++++++++- 2 files changed, 844 insertions(+), 2 deletions(-) diff --git a/include/mgba/internal/gba/sio/lockstep.h b/include/mgba/internal/gba/sio/lockstep.h index 13c181039a5..313285a44d9 100644 --- a/include/mgba/internal/gba/sio/lockstep.h +++ b/include/mgba/internal/gba/sio/lockstep.h @@ -1,4 +1,4 @@ -/* Copyright (c) 2013-2015 Jeffrey Pfau +/* Copyright (c) 2013-2024 Jeffrey Pfau * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this @@ -13,6 +13,9 @@ CXX_GUARD_START #include #include #include +#include +#include +#include struct GBASIOLockstep { struct mLockstep d; @@ -48,6 +51,78 @@ void GBASIOLockstepNodeCreate(struct GBASIOLockstepNode*); bool GBASIOLockstepAttachNode(struct GBASIOLockstep*, struct GBASIOLockstepNode*); void GBASIOLockstepDetachNode(struct GBASIOLockstep*, struct GBASIOLockstepNode*); +#define MAX_LOCKSTEP_EVENTS 8 + +enum GBASIOLockstepEventType { + SIO_EV_ATTACH, + SIO_EV_DETACH, + SIO_EV_HARD_SYNC, + SIO_EV_MODE_SET, + SIO_EV_TRANSFER_START, +}; + +struct GBASIOLockstepCoordinator { + struct Table players; + Mutex mutex; + + unsigned nextId; + + unsigned attachedPlayers[MAX_GBAS]; + int nAttached; + uint32_t waiting; + + bool transferActive; + enum GBASIOMode transferMode; + + int32_t cycle; + + uint16_t multiData[4]; + uint32_t normalData[4]; +}; + +struct GBASIOLockstepEvent { + enum GBASIOLockstepEventType type; + int32_t timestamp; + struct GBASIOLockstepEvent* next; + int playerId; + union { + enum GBASIOMode mode; + int32_t finishCycle; + }; +}; + +struct GBASIOLockstepPlayer { + struct GBASIOLockstepDriver* driver; + int playerId; + enum GBASIOMode mode; + enum GBASIOMode otherModes[MAX_GBAS]; + bool asleep; + int32_t cycleOffset; + struct GBASIOLockstepEvent* queue; + bool dataReceived; + + struct GBASIOLockstepEvent buffer[MAX_LOCKSTEP_EVENTS]; + struct GBASIOLockstepEvent* freeList; +}; + +struct GBASIOLockstepDriver { + struct GBASIODriver d; + struct GBASIOLockstepCoordinator* coordinator; + struct mTimingEvent event; + unsigned lockstepId; + + struct mLockstepUser* user; +}; + +void GBASIOLockstepCoordinatorInit(struct GBASIOLockstepCoordinator*); +void GBASIOLockstepCoordinatorDeinit(struct GBASIOLockstepCoordinator*); + +void GBASIOLockstepCoordinatorAttach(struct GBASIOLockstepCoordinator*, struct GBASIOLockstepDriver*); +void GBASIOLockstepCoordinatorDetach(struct GBASIOLockstepCoordinator*, struct GBASIOLockstepDriver*); +size_t GBASIOLockstepCoordinatorAttached(struct GBASIOLockstepCoordinator*); + +void GBASIOLockstepDriverCreate(struct GBASIOLockstepDriver*, struct mLockstepUser*); + CXX_GUARD_END #endif diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 2008638bd63..18603e05457 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -1,4 +1,4 @@ -/* Copyright (c) 2013-2015 Jeffrey Pfau +/* Copyright (c) 2013-2024 Jeffrey Pfau * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this @@ -10,6 +10,7 @@ #define LOCKSTEP_INCREMENT 2000 #define LOCKSTEP_TRANSFER 512 +#define QUEUE_SIZE 16 static bool GBASIOLockstepNodeInit(struct GBASIODriver* driver); static void GBASIOLockstepNodeDeinit(struct GBASIODriver* driver); @@ -568,3 +569,769 @@ static uint16_t GBASIOLockstepNodeNormalWriteSIOCNT(struct GBASIODriver* driver, return value; } + +#define TARGET(P) (1 << (P)) +#define TARGET_ALL 0xF +#define TARGET_PRIMARY 0x1 +#define TARGET_SECONDARY ((TARGET_ALL) & ~(TARGET_PRIMARY)) + +static bool GBASIOLockstepDriverInit(struct GBASIODriver* driver); +static void GBASIOLockstepDriverDeinit(struct GBASIODriver* driver); +static void GBASIOLockstepDriverReset(struct GBASIODriver* driver); +static bool GBASIOLockstepDriverLoad(struct GBASIODriver* driver); +static bool GBASIOLockstepDriverUnload(struct GBASIODriver* driver); +static void GBASIOLockstepDriverSetMode(struct GBASIODriver* driver, enum GBASIOMode mode); +static bool GBASIOLockstepDriverHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); +static int GBASIOLockstepDriverConnectedDevices(struct GBASIODriver* driver); +static int GBASIOLockstepDriverDeviceId(struct GBASIODriver* driver); +static uint16_t GBASIOLockstepDriverWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); +static uint16_t GBASIOLockstepDriverWriteRCNT(struct GBASIODriver* driver, uint16_t value); +static bool GBASIOLockstepDriverStart(struct GBASIODriver* driver); +static void GBASIOLockstepDriverFinishMultiplayer(struct GBASIODriver* driver, uint16_t data[4]); +static uint8_t GBASIOLockstepDriverFinishNormal8(struct GBASIODriver* driver); +static uint32_t GBASIOLockstepDriverFinishNormal32(struct GBASIODriver* driver); + +static void GBASIOLockstepCoordinatorWaitOnPlayers(struct GBASIOLockstepCoordinator*, struct GBASIOLockstepPlayer*); +static void GBASIOLockstepCoordinatorAckPlayer(struct GBASIOLockstepCoordinator*, struct GBASIOLockstepPlayer*); +static void GBASIOLockstepCoordinatorWakePlayers(struct GBASIOLockstepCoordinator*); + +static int32_t GBASIOLockstepTime(struct GBASIOLockstepPlayer*); +static void GBASIOLockstepPlayerWake(struct GBASIOLockstepPlayer*); +static void GBASIOLockstepPlayerSleep(struct GBASIOLockstepPlayer*); + +static void _advanceCycle(struct GBASIOLockstepCoordinator*, struct GBASIOLockstepPlayer*); +static void _removePlayer(struct GBASIOLockstepCoordinator*, struct GBASIOLockstepPlayer*); +static void _reconfigPlayers(struct GBASIOLockstepCoordinator*); +static int32_t _untilNextSync(struct GBASIOLockstepCoordinator*, struct GBASIOLockstepPlayer*); +static void _enqueueEvent(struct GBASIOLockstepCoordinator*, const struct GBASIOLockstepEvent*, uint32_t target); +static void _setData(struct GBASIOLockstepCoordinator*, uint32_t id, struct GBASIO* sio); +static void _setReady(struct GBASIOLockstepCoordinator*, struct GBASIOLockstepPlayer* activePlayer, int playerId, enum GBASIOMode mode); +static void _hardSync(struct GBASIOLockstepCoordinator*, struct GBASIOLockstepPlayer*); + +static void _lockstepEvent(struct mTiming*, void* context, uint32_t cyclesLate); + +void GBASIOLockstepDriverCreate(struct GBASIOLockstepDriver* driver, struct mLockstepUser* user) { + memset(driver, 0, sizeof(*driver)); + driver->d.init = GBASIOLockstepDriverInit; + driver->d.deinit = GBASIOLockstepDriverDeinit; + driver->d.reset = GBASIOLockstepDriverReset; + driver->d.load = GBASIOLockstepDriverLoad; + driver->d.unload = GBASIOLockstepDriverUnload; + driver->d.setMode = GBASIOLockstepDriverSetMode; + driver->d.handlesMode = GBASIOLockstepDriverHandlesMode; + driver->d.deviceId = GBASIOLockstepDriverDeviceId; + driver->d.connectedDevices = GBASIOLockstepDriverConnectedDevices; + driver->d.writeSIOCNT = GBASIOLockstepDriverWriteSIOCNT; + driver->d.writeRCNT = GBASIOLockstepDriverWriteRCNT; + driver->d.start = GBASIOLockstepDriverStart; + driver->d.finishMultiplayer = GBASIOLockstepDriverFinishMultiplayer; + driver->d.finishNormal8 = GBASIOLockstepDriverFinishNormal8; + driver->d.finishNormal32 = GBASIOLockstepDriverFinishNormal32; + driver->event.context = driver; + driver->event.callback = _lockstepEvent; + driver->event.name = "GBA SIO Lockstep"; + driver->event.priority = 0x80; + driver->user = user; +} + +static bool GBASIOLockstepDriverInit(struct GBASIODriver* driver) { + GBASIOLockstepDriverReset(driver); + return true; +} + +static void GBASIOLockstepDriverDeinit(struct GBASIODriver* driver) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + MutexLock(&coordinator->mutex); + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + if (player) { + _removePlayer(coordinator, player); + } + MutexUnlock(&coordinator->mutex); + mTimingDeschedule(&lockstep->d.p->p->timing, &lockstep->event); + lockstep->lockstepId = 0; +} + +static void GBASIOLockstepDriverReset(struct GBASIODriver* driver) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + if (!lockstep->lockstepId) { + struct GBASIOLockstepPlayer* player = calloc(1, sizeof(*player)); + unsigned id; + player->driver = lockstep; + player->mode = driver->p->mode; + player->playerId = -1; + + int i; + for (i = 0; i < MAX_LOCKSTEP_EVENTS - 1; ++i) { + player->buffer[i].next = &player->buffer[i + 1]; + } + player->freeList = &player->buffer[0]; + + MutexLock(&coordinator->mutex); + while (true) { + if (coordinator->nextId == UINT_MAX) { + coordinator->nextId = 0; + } + ++coordinator->nextId; + id = coordinator->nextId; + if (!TableLookup(&coordinator->players, id)) { + TableInsert(&coordinator->players, id, player); + lockstep->lockstepId = id; + break; + } + } + _reconfigPlayers(coordinator); + if (player->playerId != 0) { + player->cycleOffset = mTimingCurrentTime(&driver->p->p->timing) - coordinator->cycle + LOCKSTEP_INCREMENT; + struct GBASIOLockstepEvent event = { + .type = SIO_EV_ATTACH, + .playerId = player->playerId, + .timestamp = GBASIOLockstepTime(player), + }; + _enqueueEvent(coordinator, &event, TARGET_ALL & ~TARGET(player->playerId)); + } + MutexUnlock(&coordinator->mutex); + } + + if (mTimingIsScheduled(&lockstep->d.p->p->timing, &lockstep->event)) { + return; + } + + int32_t nextEvent; + MutexLock(&coordinator->mutex); + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + _setReady(coordinator, player, player->playerId, player->mode); + if (TableSize(&coordinator->players) == 1) { + coordinator->cycle = mTimingCurrentTime(&lockstep->d.p->p->timing); + nextEvent = LOCKSTEP_INCREMENT; + } else { + _setReady(coordinator, player, 0, coordinator->transferMode); + nextEvent = _untilNextSync(lockstep->coordinator, player); + } + MutexUnlock(&coordinator->mutex); + mTimingSchedule(&lockstep->d.p->p->timing, &lockstep->event, nextEvent); +} + +static bool GBASIOLockstepDriverLoad(struct GBASIODriver* driver) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + if (lockstep->lockstepId) { + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + MutexLock(&coordinator->mutex); + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + _setReady(coordinator, player, 0, coordinator->transferMode); + MutexUnlock(&coordinator->mutex); + GBASIOLockstepDriverSetMode(driver, driver->p->mode); + } + return true; +} + +static bool GBASIOLockstepDriverUnload(struct GBASIODriver* driver) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + if (lockstep->lockstepId) { + GBASIOLockstepDriverSetMode(driver, -1); + } + return true; +} + +static void GBASIOLockstepDriverSetMode(struct GBASIODriver* driver, enum GBASIOMode mode) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + MutexLock(&coordinator->mutex); + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + if (mode != player->mode) { + player->mode = mode; + struct GBASIOLockstepEvent event = { + .type = SIO_EV_MODE_SET, + .playerId = player->playerId, + .timestamp = GBASIOLockstepTime(player), + .mode = mode, + }; + if (player->playerId == 0) { + mASSERT(!coordinator->transferActive); // TODO + coordinator->transferMode = mode; + GBASIOLockstepCoordinatorWaitOnPlayers(coordinator, player); + } + _setReady(coordinator, player, player->playerId, mode); + _enqueueEvent(coordinator, &event, TARGET_ALL & ~TARGET(player->playerId)); + } + MutexUnlock(&coordinator->mutex); +} + +static bool GBASIOLockstepDriverHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { + UNUSED(driver); + UNUSED(mode); + return true; +} + +static int GBASIOLockstepDriverConnectedDevices(struct GBASIODriver* driver) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + if (!lockstep->lockstepId) { + return 0; + } + MutexLock(&coordinator->mutex); + int attached = coordinator->nAttached - 1; + MutexUnlock(&coordinator->mutex); + return attached; +} + +static int GBASIOLockstepDriverDeviceId(struct GBASIODriver* driver) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + int playerId = 0; + MutexLock(&coordinator->mutex); + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + if (player && player->playerId >= 0) { + playerId = player->playerId; + } + MutexUnlock(&coordinator->mutex); + return playerId; +} + +static uint16_t GBASIOLockstepDriverWriteSIOCNT(struct GBASIODriver* driver, uint16_t value) { + UNUSED(driver); + mLOG(GBA_SIO, DEBUG, "Lockstep: SIOCNT <- %04X", value); + return value; +} + +static uint16_t GBASIOLockstepDriverWriteRCNT(struct GBASIODriver* driver, uint16_t value) { + UNUSED(driver); + mLOG(GBA_SIO, DEBUG, "Lockstep: RCNT <- %04X", value); + return value; +} + +static bool GBASIOLockstepDriverStart(struct GBASIODriver* driver) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + bool ret = false; + MutexLock(&coordinator->mutex); + if (coordinator->transferActive) { + mLOG(GBA_SIO, ERROR, "Transfer restarted unexpectedly"); + goto out; + } + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + if (player->playerId != 0) { + mLOG(GBA_SIO, DEBUG, "Secondary player attempted to start transfer"); + goto out; + } + mLOG(GBA_SIO, DEBUG, "Transfer starting at %08X", coordinator->cycle); + memset(coordinator->multiData, 0xFF, sizeof(coordinator->multiData)); + _setData(coordinator, 0, player->driver->d.p); + + int32_t timestamp = GBASIOLockstepTime(player); + struct GBASIOLockstepEvent event = { + .type = SIO_EV_TRANSFER_START, + .timestamp = timestamp, + .finishCycle = timestamp + GBASIOTransferCycles(player->mode, player->driver->d.p->siocnt, coordinator->nAttached - 1), + }; + _enqueueEvent(coordinator, &event, TARGET_SECONDARY); + GBASIOLockstepCoordinatorWaitOnPlayers(coordinator, player); + coordinator->transferActive = true; + ret = true; +out: + MutexUnlock(&coordinator->mutex); + return ret; +} + +static void GBASIOLockstepDriverFinishMultiplayer(struct GBASIODriver* driver, uint16_t data[4]) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + MutexLock(&coordinator->mutex); + if (coordinator->transferMode == GBA_SIO_MULTI) { + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + if (!player->dataReceived) { + mLOG(GBA_SIO, WARN, "MULTI did not receive data. Are we running behind?"); + memset(data, 0xFF, sizeof(uint16_t) * 4); + } else { + mLOG(GBA_SIO, INFO, "MULTI transfer finished: %04X %04X %04X %04X", + coordinator->multiData[0], + coordinator->multiData[1], + coordinator->multiData[2], + coordinator->multiData[3]); + memcpy(data, coordinator->multiData, sizeof(uint16_t) * 4); + } + player->dataReceived = false; + if (player->playerId == 0) { + _hardSync(coordinator, player); + } + } + MutexUnlock(&coordinator->mutex); +} + +static uint8_t GBASIOLockstepDriverFinishNormal8(struct GBASIODriver* driver) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + uint8_t data = 0xFF; + MutexLock(&coordinator->mutex); + if (coordinator->transferMode == GBA_SIO_NORMAL_8) { + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + if (player->playerId > 0) { + if (!player->dataReceived) { + mLOG(GBA_SIO, WARN, "NORMAL did not receive data. Are we running behind?"); + } else { + data = coordinator->normalData[player->playerId - 1]; + mLOG(GBA_SIO, INFO, "NORMAL8 transfer finished: %02X", data); + } + } + player->dataReceived = false; + if (player->playerId == 0) { + _hardSync(coordinator, player); + } + } + MutexUnlock(&coordinator->mutex); + return data; +} + +static uint32_t GBASIOLockstepDriverFinishNormal32(struct GBASIODriver* driver) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + uint32_t data = 0xFFFFFFFF; + MutexLock(&coordinator->mutex); + if (coordinator->transferMode == GBA_SIO_NORMAL_32) { + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + if (player->playerId > 0) { + if (!player->dataReceived) { + mLOG(GBA_SIO, WARN, "Did not receive data. Are we running behind?"); + } else { + data = coordinator->normalData[player->playerId - 1]; + mLOG(GBA_SIO, INFO, "NORMAL32 transfer finished: %08X", data); + } + } + player->dataReceived = false; + if (player->playerId == 0) { + _hardSync(coordinator, player); + } + } + MutexUnlock(&coordinator->mutex); + return data; +} + +void GBASIOLockstepCoordinatorInit(struct GBASIOLockstepCoordinator* coordinator) { + memset(coordinator, 0, sizeof(*coordinator)); + MutexInit(&coordinator->mutex); + TableInit(&coordinator->players, 8, free); +} + +void GBASIOLockstepCoordinatorDeinit(struct GBASIOLockstepCoordinator* coordinator) { + MutexDeinit(&coordinator->mutex); + TableDeinit(&coordinator->players); +} + +void GBASIOLockstepCoordinatorAttach(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepDriver* driver) { + if (driver->coordinator && driver->coordinator != coordinator) { + // TODO + abort(); + } + driver->coordinator = coordinator; +} + +void GBASIOLockstepCoordinatorDetach(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepDriver* driver) { + if (driver->coordinator != coordinator) { + // TODO + abort(); + return; + } + MutexLock(&coordinator->mutex); + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, driver->lockstepId); + if (player) { + _removePlayer(coordinator, player); + } + MutexUnlock(&coordinator->mutex); + driver->coordinator = NULL; +} + +int32_t _untilNextSync(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepPlayer* player) { + int32_t cycle = coordinator->cycle - GBASIOLockstepTime(player); + if (player->playerId == 0) { + cycle += LOCKSTEP_INCREMENT; + } + return cycle; +} + +void _advanceCycle(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepPlayer* player) { + int32_t newCycle = GBASIOLockstepTime(player); + mASSERT(newCycle - coordinator->cycle >= 0); + //mLOG(GBA_SIO, DEBUG, "Advancing from cycle %08X to %08X (%i cycles)", coordinator->cycle, newCycle, newCycle - coordinator->cycle); + coordinator->cycle = newCycle; +} + +void _removePlayer(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepPlayer* player) { + struct GBASIOLockstepEvent event = { + .type = SIO_EV_DETACH, + .playerId = player->playerId, + .timestamp = GBASIOLockstepTime(player), + }; + _enqueueEvent(coordinator, &event, TARGET_ALL & ~TARGET(player->playerId)); + GBASIOLockstepCoordinatorWakePlayers(coordinator); + if (player->playerId != 0) { + GBASIOLockstepCoordinatorAckPlayer(coordinator, player); + } + TableRemove(&coordinator->players, player->driver->lockstepId); + _reconfigPlayers(coordinator); +} + +void _reconfigPlayers(struct GBASIOLockstepCoordinator* coordinator) { + size_t players = TableSize(&coordinator->players); + memset(coordinator->attachedPlayers, 0, sizeof(coordinator->attachedPlayers)); + if (players == 0) { + mLOG(GBA_SIO, WARN, "Reconfiguring player IDs with no players attached somehow?"); + } else if (players == 1) { + struct TableIterator iter; + mASSERT(TableIteratorStart(&coordinator->players, &iter)); + unsigned p0 = TableIteratorGetKey(&coordinator->players, &iter); + coordinator->attachedPlayers[0] = p0; + + struct GBASIOLockstepPlayer* player = TableIteratorGetValue(&coordinator->players, &iter); + coordinator->cycle = mTimingCurrentTime(&player->driver->d.p->p->timing); + + if (player->playerId != 0) { + player->playerId = 0; + if (player->driver->user->playerIdChanged) { + player->driver->user->playerIdChanged(player->driver->user, player->playerId); + } + } + + if (!coordinator->transferActive) { + coordinator->transferMode = player->mode; + } + } else { + struct UIntList playerPreferences[MAX_GBAS]; + + int i; + for (i = 0; i < MAX_GBAS; ++i) { + UIntListInit(&playerPreferences[i], 4); + } + + // Collect the first four players' requested player IDs so we can sort through them later + int seen = 0; + struct TableIterator iter; + mASSERT(TableIteratorStart(&coordinator->players, &iter)); + do { + unsigned pid = TableIteratorGetKey(&coordinator->players, &iter); + struct GBASIOLockstepPlayer* player = TableIteratorGetValue(&coordinator->players, &iter); + int requested = MAX_GBAS - 1; + if (player->driver->user->requestedId) { + requested = player->driver->user->requestedId(player->driver->user); + } + if (requested < 0) { + continue; + } + if (requested >= MAX_GBAS) { + requested = MAX_GBAS - 1; + } + + *UIntListAppend(&playerPreferences[requested]) = pid; + ++seen; + } while (TableIteratorNext(&coordinator->players, &iter) && seen < MAX_GBAS); + + // Now sort each requested player ID to figure out who gets which ID + seen = 0; + for (i = 0; i < MAX_GBAS; ++i) { + int j; + for (j = 0; j <= i; ++j) { + while (UIntListSize(&playerPreferences[j]) && seen < MAX_GBAS) { + unsigned pid = *UIntListGetPointer(&playerPreferences[j], 0); + UIntListShift(&playerPreferences[j], 0, 1); + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, pid); + if (!player) { + mLOG(GBA_SIO, ERROR, "Player list appears to have changed unexpectedly. PID %u missing.", pid); + continue; + } + coordinator->attachedPlayers[seen] = pid; + if (player->playerId != seen) { + player->playerId = seen; + if (player->driver->user->playerIdChanged) { + player->driver->user->playerIdChanged(player->driver->user, player->playerId); + } + } + ++seen; + } + } + } + + for (i = 0; i < MAX_GBAS; ++i) { + UIntListDeinit(&playerPreferences[i]); + } + } + + int nAttached = 0; + size_t i; + for (i = 0; i < MAX_GBAS; ++i) { + unsigned pid = coordinator->attachedPlayers[i]; + if (!pid) { + continue; + } + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, pid); + if (!player) { + coordinator->attachedPlayers[i] = 0; + } else { + ++nAttached; + } + } + coordinator->nAttached = nAttached; +} + +static void _setData(struct GBASIOLockstepCoordinator* coordinator, uint32_t id, struct GBASIO* sio) { + switch (coordinator->transferMode) { + case GBA_SIO_MULTI: + coordinator->multiData[id] = sio->p->memory.io[GBA_REG(SIOMLT_SEND)]; + break; + case GBA_SIO_NORMAL_8: + coordinator->normalData[id] = sio->p->memory.io[GBA_REG(SIODATA8)]; + break; + case GBA_SIO_NORMAL_32: + coordinator->normalData[id] = sio->p->memory.io[GBA_REG(SIODATA32_LO)]; + coordinator->normalData[id] |= sio->p->memory.io[GBA_REG(SIODATA32_HI)] << 16; + break; + case GBA_SIO_UART: + case GBA_SIO_GPIO: + case GBA_SIO_JOYBUS: + mLOG(GBA_SIO, ERROR, "Unsupported mode %i in lockstep", coordinator->transferMode); + // TODO: Should we handle this or just abort? + abort(); + break; + } +} + +void _setReady(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepPlayer* activePlayer, int playerId, enum GBASIOMode mode) { + activePlayer->otherModes[playerId] = mode; + bool ready = true; + int i; + for (i = 0; ready && i < coordinator->nAttached; ++i) { + ready = activePlayer->otherModes[i] == activePlayer->mode; + } + if (activePlayer->mode == GBA_SIO_MULTI) { + struct GBASIO* sio = activePlayer->driver->d.p; + sio->siocnt = GBASIOMultiplayerSetReady(sio->siocnt, ready); + sio->rcnt = GBASIORegisterRCNTSetSd(sio->rcnt, ready); + } +} + +void _hardSync(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepPlayer* player) { + mASSERT_DEBUG(player->playerId == 0); + struct GBASIOLockstepEvent event = { + .type = SIO_EV_HARD_SYNC, + .playerId = 0, + .timestamp = GBASIOLockstepTime(player), + }; + _enqueueEvent(coordinator, &event, TARGET_SECONDARY); + GBASIOLockstepCoordinatorWaitOnPlayers(coordinator, player); +} + +void _enqueueEvent(struct GBASIOLockstepCoordinator* coordinator, const struct GBASIOLockstepEvent* event, uint32_t target) { + mLOG(GBA_SIO, DEBUG, "Enqueuing event of type %X from %i for target %X at timestamp %X", + event->type, event->playerId, target, event->timestamp); + + int i; + for (i = 0; i < coordinator->nAttached; ++i) { + if (!(target & TARGET(i))) { + continue; + } + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, coordinator->attachedPlayers[i]); + mASSERT_LOG(GBA_SIO, player->freeList, "No free events"); + struct GBASIOLockstepEvent* newEvent = player->freeList; + player->freeList = newEvent->next; + + memcpy(newEvent, event, sizeof(*event)); + struct GBASIOLockstepEvent** previous = &player->queue; + struct GBASIOLockstepEvent* next = player->queue; + while (next) { + int32_t until = newEvent->timestamp - next->timestamp; + if (until < 0) { + break; + } + previous = &next->next; + next = next->next; + } + newEvent->next = next; + *previous = newEvent; + } +} + +void _lockstepEvent(struct mTiming* timing, void* context, uint32_t cyclesLate) { + struct GBASIOLockstepDriver* lockstep = context; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + MutexLock(&coordinator->mutex); + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + struct GBASIO* sio = player->driver->d.p; + mASSERT(player->playerId >= 0 && player->playerId < 4); + + bool wasDetach = false; + if (player->queue && player->queue->type == SIO_EV_DETACH) { + mLOG(GBA_SIO, DEBUG, "Player %i detached at timestamp %X, picking up the pieces", + player->queue->playerId, player->queue->timestamp); + wasDetach = true; + } + if (player->playerId == 0) { + // We are the clock owner; advance the shared clock + _advanceCycle(coordinator, player); + if (!coordinator->transferActive) { + GBASIOLockstepCoordinatorWakePlayers(coordinator); + } + } + + int32_t nextEvent = _untilNextSync(coordinator, player); + //mASSERT_DEBUG(nextEvent + cyclesLate > 0); + while (true) { + struct GBASIOLockstepEvent* event = player->queue; + if (!event) { + break; + } + if (event->timestamp > GBASIOLockstepTime(player)) { + break; + } + player->queue = event->next; + struct GBASIOLockstepEvent reply = { + .playerId = player->playerId, + .timestamp = GBASIOLockstepTime(player), + }; + mLOG(GBA_SIO, DEBUG, "Got event of type %X from %i at timestamp %X", + event->type, event->playerId, event->timestamp); + switch (event->type) { + case SIO_EV_ATTACH: + _setReady(coordinator, player, event->playerId, -1); + if (player->playerId == 0) { + struct GBASIO* sio = player->driver->d.p; + sio->siocnt = GBASIOMultiplayerClearSlave(sio->siocnt); + } + reply.mode = player->mode; + reply.type = SIO_EV_MODE_SET; + _enqueueEvent(coordinator, &reply, TARGET(event->playerId)); + break; + case SIO_EV_HARD_SYNC: + GBASIOLockstepCoordinatorAckPlayer(coordinator, player); + break; + case SIO_EV_TRANSFER_START: + _setData(coordinator, player->playerId, sio); + nextEvent = event->finishCycle - GBASIOLockstepTime(player) - cyclesLate; + player->driver->d.p->siocnt |= 0x80; + mTimingDeschedule(&sio->p->timing, &sio->completeEvent); + mTimingSchedule(&sio->p->timing, &sio->completeEvent, nextEvent); + GBASIOLockstepCoordinatorAckPlayer(coordinator, player); + break; + case SIO_EV_MODE_SET: + _setReady(coordinator, player, event->playerId, event->mode); + if (event->playerId == 0) { + GBASIOLockstepCoordinatorAckPlayer(coordinator, player); + } + break; + case SIO_EV_DETACH: + _setReady(coordinator, player, event->playerId, -1); + _setReady(coordinator, player, player->playerId, player->mode); + reply.mode = player->mode; + reply.type = SIO_EV_MODE_SET; + _enqueueEvent(coordinator, &reply, ~TARGET(event->playerId)); + if (player->mode == GBA_SIO_MULTI) { + sio->siocnt = GBASIOMultiplayerSetId(sio->siocnt, player->playerId); + sio->siocnt = GBASIOMultiplayerSetSlave(sio->siocnt, player->playerId || coordinator->nAttached < 2); + } + wasDetach = true; + break; + } + event->next = player->freeList; + player->freeList = event; + } + if (player->queue && player->queue->timestamp - GBASIOLockstepTime(player) < nextEvent) { + nextEvent = player->queue->timestamp - GBASIOLockstepTime(player); + } + + if (player->playerId != 0 && nextEvent <= LOCKSTEP_INCREMENT) { + if (!player->queue || wasDetach) { + GBASIOLockstepPlayerSleep(player); + // XXX: Is there a better way to gain sync lock at the beginning? + if (nextEvent < 4) { + nextEvent = 4; + } + } + } + MutexUnlock(&coordinator->mutex); + + mASSERT_DEBUG(nextEvent > 0); + mTimingSchedule(timing, &lockstep->event, nextEvent); +} + +int32_t GBASIOLockstepTime(struct GBASIOLockstepPlayer* player) { + return mTimingCurrentTime(&player->driver->d.p->p->timing) - player->cycleOffset; +} + +void GBASIOLockstepCoordinatorWaitOnPlayers(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepPlayer* player) { + mASSERT(!coordinator->waiting); + mASSERT(!player->asleep); + mASSERT(player->playerId == 0); + if (coordinator->nAttached < 2) { + return; + } + + _advanceCycle(coordinator, player); + mLOG(GBA_SIO, DEBUG, "Primary waiting for players to ack"); + coordinator->waiting = ((1 << coordinator->nAttached) - 1) & ~TARGET(player->playerId); + GBASIOLockstepPlayerSleep(player); + GBASIOLockstepCoordinatorWakePlayers(coordinator); +} + +void GBASIOLockstepCoordinatorWakePlayers(struct GBASIOLockstepCoordinator* coordinator) { + //mLOG(GBA_SIO, DEBUG, "Waking all secondary players"); + int i; + for (i = 1; i < coordinator->nAttached; ++i) { + if (!coordinator->attachedPlayers[i]) { + continue; + } + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, coordinator->attachedPlayers[i]); + GBASIOLockstepPlayerWake(player); + } +} + +void GBASIOLockstepPlayerWake(struct GBASIOLockstepPlayer* player) { + if (!player->asleep) { + return; + } + player->asleep = false; + player->driver->user->wake(player->driver->user); +} + +void GBASIOLockstepCoordinatorAckPlayer(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepPlayer* player) { + if (player->playerId == 0) { + return; + } + mLOG(GBA_SIO, DEBUG, "Player %i acking primary", player->playerId); + coordinator->waiting &= ~TARGET(player->playerId); + if (!coordinator->waiting) { + mLOG(GBA_SIO, DEBUG, "All players acked, waking primary"); + if (coordinator->transferActive) { + int i; + for (i = 0; i < coordinator->nAttached; ++i) { + if (!coordinator->attachedPlayers[i]) { + continue; + } + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, coordinator->attachedPlayers[i]); + player->dataReceived = true; + } + + coordinator->transferActive = false; + } + + struct GBASIOLockstepPlayer* runner = TableLookup(&coordinator->players, coordinator->attachedPlayers[0]); + GBASIOLockstepPlayerWake(runner); + } + GBASIOLockstepPlayerSleep(player); +} + +void GBASIOLockstepPlayerSleep(struct GBASIOLockstepPlayer* player) { + if (player->asleep) { + return; + } + //mLOG(GBA_SIO, DEBUG, "Player %i going to sleep with %i cycles until sync", player->playerId, _untilNextSync(coordinator, player)); + player->asleep = true; + player->driver->user->sleep(player->driver->user); + player->driver->d.p->p->cpu->nextEvent = 0; + player->driver->d.p->p->earlyExit = true; +} + +size_t GBASIOLockstepCoordinatorAttached(struct GBASIOLockstepCoordinator* coordinator) { + size_t count; + MutexLock(&coordinator->mutex); + count = TableSize(&coordinator->players); + MutexUnlock(&coordinator->mutex); + return count; +} From cd8933415cfcc25452ecfcb95292faa8ea9c74b3 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 25 Aug 2024 02:48:50 -0700 Subject: [PATCH 226/338] Qt: Switch to new GBA lockstep driver --- src/platform/qt/MultiplayerController.cpp | 120 ++++++++++++++-------- src/platform/qt/MultiplayerController.h | 15 ++- 2 files changed, 87 insertions(+), 48 deletions(-) diff --git a/src/platform/qt/MultiplayerController.cpp b/src/platform/qt/MultiplayerController.cpp index 149df238606..c142fe126d6 100644 --- a/src/platform/qt/MultiplayerController.cpp +++ b/src/platform/qt/MultiplayerController.cpp @@ -7,6 +7,7 @@ #include "CoreController.h" #include "LogController.h" +#include "utils.h" #ifdef M_CORE_GBA #include @@ -27,8 +28,14 @@ MultiplayerController::Player::Player(CoreController* coreController) int MultiplayerController::Player::id() const { switch (controller->platform()) { #ifdef M_CORE_GBA - case mPLATFORM_GBA: - return node.gba->id; + case mPLATFORM_GBA: { + int id = node.gba->d.deviceId(&node.gba->d); + if (id >= 0) { + return id; + } else { + return preferredId; + } + } #endif #ifdef M_CORE_GB case mPLATFORM_GB: @@ -89,25 +96,7 @@ MultiplayerController::MultiplayerController() { switch (player->controller->platform()) { #ifdef M_CORE_GBA case mPLATFORM_GBA: - if (!id) { - for (int i = 1; i < controller->m_players.count(); ++i) { - player = controller->player(i); - if (player->node.gba->d.p->mode > GBA_SIO_MULTI) { - player->controller->setSync(true); - continue; - } - player->controller->setSync(false); - player->cyclesPosted += cycles; - if (player->awake < 1) { - player->node.gba->nextEvent += player->cyclesPosted; - } - mCoreThreadStopWaiting(player->controller->thread()); - player->awake = 1; - } - } else { - player->controller->setSync(true); - player->cyclesPosted += cycles; - } + abort(); break; #endif #ifdef M_CORE_GB @@ -169,7 +158,6 @@ MultiplayerController::MultiplayerController() { switch (player->controller->platform()) { #ifdef M_CORE_GBA case mPLATFORM_GBA: - player->cyclesPosted += reinterpret_cast(lockstep)->players[0]->eventDiff; break; #endif #ifdef M_CORE_GB @@ -184,7 +172,6 @@ MultiplayerController::MultiplayerController() { switch (player->controller->platform()) { #ifdef M_CORE_GBA case mPLATFORM_GBA: - player->node.gba->nextEvent += player->cyclesPosted; break; #endif #ifdef M_CORE_GB @@ -214,11 +201,11 @@ bool MultiplayerController::attachGame(CoreController* controller) { interrupters.append(p.controller); } - if (m_lockstep.attached == 0) { + if (attached() == 0) { switch (controller->platform()) { #ifdef M_CORE_GBA case mPLATFORM_GBA: - GBASIOLockstepInit(&m_gbaLockstep); + GBASIOLockstepCoordinatorInit(&m_gbaCoordinator); break; #endif #ifdef M_CORE_GB @@ -240,28 +227,53 @@ bool MultiplayerController::attachGame(CoreController* controller) { } Player player{controller}; + for (int i = 0; i < MAX_GBAS; ++i) { + if (m_claimedIds & (1 << i)) { + continue; + } + player.preferredId = i; + m_claimedIds |= 1 << i; + break; + } switch (controller->platform()) { #ifdef M_CORE_GBA case mPLATFORM_GBA: { - if (m_lockstep.attached >= MAX_GBAS) { + if (attached() >= MAX_GBAS) { return false; } GBA* gba = static_cast(thread->core->board); - GBASIOLockstepNode* node = new GBASIOLockstepNode; - GBASIOLockstepNodeCreate(node); - GBASIOLockstepAttachNode(&m_gbaLockstep, node); + GBASIOLockstepDriver* node = new GBASIOLockstepDriver; + LockstepUser* user = new LockstepUser; + mLockstepThreadUserInit(user, thread); + user->controller = this; + user->pid = m_nextPid; + user->d.requestedId = [](mLockstepUser* ctx) { + mLockstepThreadUser* tctx = reinterpret_cast(ctx); + LockstepUser* user = static_cast(tctx); + MultiplayerController* controller = user->controller; + const auto iter = controller->m_pids.find(user->pid); + if (iter == controller->m_pids.end()) { + return -1; + } + const Player& p = iter.value(); + return p.preferredId; + }; + + GBASIOLockstepDriverCreate(node, &user->d); + GBASIOLockstepCoordinatorAttach(&m_gbaCoordinator, node); player.node.gba = node; GBASIOSetDriver(&gba->sio, &node->d, GBA_SIO_MULTI); + GBASIOSetDriver(&gba->sio, &node->d, GBA_SIO_NORMAL_8); GBASIOSetDriver(&gba->sio, &node->d, GBA_SIO_NORMAL_32); break; } #endif #ifdef M_CORE_GB case mPLATFORM_GB: { - if (m_lockstep.attached >= 2) { + if (attached() >= 2) { return false; } @@ -281,7 +293,7 @@ bool MultiplayerController::attachGame(CoreController* controller) { } QPair path(controller->path(), controller->baseDirectory()); - int claimed = m_claimed[path]; + int claimed = m_claimedSaves[path]; int saveId = 0; mCoreConfigGetIntValue(&controller->thread()->core->config, "savePlayerId", &saveId); @@ -304,7 +316,7 @@ bool MultiplayerController::attachGame(CoreController* controller) { } else { player.saveId = 1; } - m_claimed[path] |= 1 << (player.saveId - 1); + m_claimedSaves[path] |= 1 << (player.saveId - 1); m_pids.insert(m_nextPid, player); ++m_nextPid; @@ -328,8 +340,7 @@ void MultiplayerController::detachGame(CoreController* controller) { for (int i = 0; i < m_players.count(); ++i) { Player* p = player(i); if (!p) { - LOG(QT, ERROR) << tr("Trying to detach a multiplayer player that's not attached"); - return; + continue; } CoreController* playerController = p->controller; if (playerController == controller) { @@ -337,15 +348,21 @@ void MultiplayerController::detachGame(CoreController* controller) { } interrupters.append(playerController); } + if (pid < 0) { + LOG(QT, WARN) << tr("Trying to detach a multiplayer player that's not attached"); + return; + } switch (controller->platform()) { #ifdef M_CORE_GBA case mPLATFORM_GBA: { GBA* gba = static_cast(thread->core->board); - GBASIOLockstepNode* node = reinterpret_cast(gba->sio.drivers.multiplayer); + GBASIOLockstepDriver* node = reinterpret_cast(gba->sio.drivers.multiplayer); GBASIOSetDriver(&gba->sio, nullptr, GBA_SIO_MULTI); + GBASIOSetDriver(&gba->sio, nullptr, GBA_SIO_NORMAL_8); GBASIOSetDriver(&gba->sio, nullptr, GBA_SIO_NORMAL_32); if (node) { - GBASIOLockstepDetachNode(&m_gbaLockstep, node); + GBASIOLockstepCoordinatorDetach(&m_gbaCoordinator, node); + delete node->user; delete node; } break; @@ -371,14 +388,20 @@ void MultiplayerController::detachGame(CoreController* controller) { QPair path(controller->path(), controller->baseDirectory()); Player& p = m_pids.find(pid).value(); if (!p.saveId) { - LOG(QT, ERROR) << "Clearing invalid save ID"; + LOG(QT, WARN) << "Clearing invalid save ID"; } else { - m_claimed[path] &= ~(1 << (p.saveId - 1)); - if (!m_claimed[path]) { - m_claimed.remove(path); + m_claimedSaves[path] &= ~(1 << (p.saveId - 1)); + if (!m_claimedSaves[path]) { + m_claimedSaves.remove(path); } } + if (p.preferredId < 0) { + LOG(QT, WARN) << "Clearing invalid preferred ID"; + } else { + m_claimedIds &= ~(1 << p.preferredId); + } + m_pids.remove(pid); if (m_pids.size() == 0) { m_platform = mPLATFORM_NONE; @@ -417,8 +440,17 @@ int MultiplayerController::saveId(CoreController* controller) const { } int MultiplayerController::attached() { - int num; - num = m_lockstep.attached; + int num = 0; + switch (m_platform) { + case mPLATFORM_GB: + num = m_lockstep.attached; + break; + case mPLATFORM_GBA: + num = saturateCast(GBASIOLockstepCoordinatorAttached(&m_gbaCoordinator)); + break; + default: + break; + } return num; } @@ -456,8 +488,8 @@ void MultiplayerController::fixOrder() { for (int pid : m_pids.keys()) { Player& p = m_pids.find(pid).value(); GBA* gba = static_cast(p.controller->thread()->core->board); - GBASIOLockstepNode* node = reinterpret_cast(gba->sio.drivers.multiplayer); - m_players[node->id] = pid; + GBASIOLockstepDriver* node = reinterpret_cast(gba->sio.drivers.multiplayer); + m_players[node->d.deviceId(&node->d)] = pid; } break; #endif diff --git a/src/platform/qt/MultiplayerController.h b/src/platform/qt/MultiplayerController.h index b5582319f9d..9eaf20b16bb 100644 --- a/src/platform/qt/MultiplayerController.h +++ b/src/platform/qt/MultiplayerController.h @@ -49,7 +49,7 @@ Q_OBJECT private: union Node { GBSIOLockstepNode* gb; - GBASIOLockstepNode* gba; + GBASIOLockstepDriver* gba; }; struct Player { Player(CoreController* controller); @@ -63,6 +63,11 @@ Q_OBJECT int32_t cyclesPosted = 0; unsigned waitMask = 0; int saveId = 1; + int preferredId = 0; + }; + struct LockstepUser : mLockstepThreadUser { + MultiplayerController* controller; + int pid; }; Player* player(int id); @@ -74,17 +79,19 @@ Q_OBJECT #ifdef M_CORE_GB GBSIOLockstep m_gbLockstep; #endif + }; + #ifdef M_CORE_GBA - GBASIOLockstep m_gbaLockstep; + GBASIOLockstepCoordinator m_gbaCoordinator; #endif - }; mPlatform m_platform = mPLATFORM_NONE; int m_nextPid = 0; + int m_claimedIds = 0; QHash m_pids; QList m_players; QMutex m_lock; - QHash, int> m_claimed; + QHash, int> m_claimedSaves; }; } From 26e20ca8461f76eefacc2a3906b74ec53dc39741 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 30 Aug 2024 23:26:29 -0700 Subject: [PATCH 227/338] GBA SIO: Remove old lockstep driver --- include/mgba/internal/gba/sio/lockstep.h | 34 -- src/gba/sio/lockstep.c | 561 ----------------------- 2 files changed, 595 deletions(-) diff --git a/include/mgba/internal/gba/sio/lockstep.h b/include/mgba/internal/gba/sio/lockstep.h index 313285a44d9..7baed069364 100644 --- a/include/mgba/internal/gba/sio/lockstep.h +++ b/include/mgba/internal/gba/sio/lockstep.h @@ -17,40 +17,6 @@ CXX_GUARD_START #include #include -struct GBASIOLockstep { - struct mLockstep d; - struct GBASIOLockstepNode* players[MAX_GBAS]; - int attachedMulti; - int attachedNormal; - - uint16_t multiRecv[MAX_GBAS]; - uint32_t normalRecv[MAX_GBAS]; -}; - -struct GBASIOLockstepNode { - struct GBASIODriver d; - struct GBASIOLockstep* p; - struct mTimingEvent event; - - volatile int32_t nextEvent; - int32_t eventDiff; - bool normalSO; - int id; - enum GBASIOMode mode; - bool transferFinished; -#ifndef NDEBUG - int transferId; - enum mLockstepPhase phase; -#endif -}; - -void GBASIOLockstepInit(struct GBASIOLockstep*); - -void GBASIOLockstepNodeCreate(struct GBASIOLockstepNode*); - -bool GBASIOLockstepAttachNode(struct GBASIOLockstep*, struct GBASIOLockstepNode*); -void GBASIOLockstepDetachNode(struct GBASIOLockstep*, struct GBASIOLockstepNode*); - #define MAX_LOCKSTEP_EVENTS 8 enum GBASIOLockstepEventType { diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 18603e05457..1493ca9f6a3 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -9,567 +9,6 @@ #include #define LOCKSTEP_INCREMENT 2000 -#define LOCKSTEP_TRANSFER 512 -#define QUEUE_SIZE 16 - -static bool GBASIOLockstepNodeInit(struct GBASIODriver* driver); -static void GBASIOLockstepNodeDeinit(struct GBASIODriver* driver); -static bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver); -static bool GBASIOLockstepNodeUnload(struct GBASIODriver* driver); -static bool GBASIOLockstepNodeHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); -static int GBASIOLockstepNodeConnectedDevices(struct GBASIODriver* driver); -static int GBASIOLockstepNodeDeviceId(struct GBASIODriver* driver); -static bool GBASIOLockstepNodeStart(struct GBASIODriver* driver); -static uint16_t GBASIOLockstepNodeMultiWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); -static uint16_t GBASIOLockstepNodeNormalWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); -static void _GBASIOLockstepNodeProcessEvents(struct mTiming* timing, void* driver, uint32_t cyclesLate); -static void _finishTransfer(struct GBASIOLockstepNode* node); - -void GBASIOLockstepInit(struct GBASIOLockstep* lockstep) { - lockstep->players[0] = 0; - lockstep->players[1] = 0; - lockstep->players[2] = 0; - lockstep->players[3] = 0; - lockstep->multiRecv[0] = 0xFFFF; - lockstep->multiRecv[1] = 0xFFFF; - lockstep->multiRecv[2] = 0xFFFF; - lockstep->multiRecv[3] = 0xFFFF; - lockstep->attachedMulti = 0; - lockstep->attachedNormal = 0; -} - -void GBASIOLockstepNodeCreate(struct GBASIOLockstepNode* node) { - memset(&node->d, 0, sizeof(node->d)); - node->d.init = GBASIOLockstepNodeInit; - node->d.deinit = GBASIOLockstepNodeDeinit; - node->d.load = GBASIOLockstepNodeLoad; - node->d.unload = GBASIOLockstepNodeUnload; - node->d.handlesMode = GBASIOLockstepNodeHandlesMode; - node->d.connectedDevices = GBASIOLockstepNodeConnectedDevices; - node->d.deviceId = GBASIOLockstepNodeDeviceId; - node->d.start = GBASIOLockstepNodeStart; - node->d.writeSIOCNT = NULL; -} - -bool GBASIOLockstepAttachNode(struct GBASIOLockstep* lockstep, struct GBASIOLockstepNode* node) { - if (lockstep->d.attached == MAX_GBAS) { - return false; - } - mLockstepLock(&lockstep->d); - lockstep->players[lockstep->d.attached] = node; - node->p = lockstep; - node->id = lockstep->d.attached; - node->normalSO = true; - node->transferFinished = true; - ++lockstep->d.attached; - mLockstepUnlock(&lockstep->d); - return true; -} - -void GBASIOLockstepDetachNode(struct GBASIOLockstep* lockstep, struct GBASIOLockstepNode* node) { - if (lockstep->d.attached == 0) { - return; - } - mLockstepLock(&lockstep->d); - int i; - for (i = 0; i < lockstep->d.attached; ++i) { - if (lockstep->players[i] != node) { - continue; - } - for (++i; i < lockstep->d.attached; ++i) { - lockstep->players[i - 1] = lockstep->players[i]; - lockstep->players[i - 1]->id = i - 1; - } - --lockstep->d.attached; - lockstep->players[lockstep->d.attached] = NULL; - break; - } - mLockstepUnlock(&lockstep->d); -} - -bool GBASIOLockstepNodeInit(struct GBASIODriver* driver) { - struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; - node->d.p->siocnt = GBASIOMultiplayerSetSlave(node->d.p->siocnt, node->id > 0); - mLOG(GBA_SIO, DEBUG, "Lockstep %i: Node init", node->id); - node->event.context = node; - node->event.name = "GBA SIO Lockstep"; - node->event.callback = _GBASIOLockstepNodeProcessEvents; - node->event.priority = 0x80; - return true; -} - -void GBASIOLockstepNodeDeinit(struct GBASIODriver* driver) { - UNUSED(driver); -} - -bool GBASIOLockstepNodeLoad(struct GBASIODriver* driver) { - struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; - node->nextEvent = 0; - node->eventDiff = 0; - mTimingSchedule(&driver->p->p->timing, &node->event, 0); - - mLockstepLock(&node->p->d); - - node->mode = driver->p->mode; - - switch (node->mode) { - case GBA_SIO_MULTI: - node->d.writeSIOCNT = GBASIOLockstepNodeMultiWriteSIOCNT; - ATOMIC_ADD(node->p->attachedMulti, 1); - node->d.p->siocnt = GBASIOMultiplayerSetReady(node->d.p->siocnt, node->p->attachedMulti == node->p->d.attached); - if (node->id) { - node->d.p->rcnt |= 4; - int try; - for (try = 0; try < 3; ++try) { - uint16_t masterSiocnt; - ATOMIC_LOAD(masterSiocnt, node->p->players[0]->d.p->siocnt); - if (ATOMIC_CMPXCHG(node->p->players[0]->d.p->siocnt, masterSiocnt, GBASIOMultiplayerClearSlave(masterSiocnt))) { - break; - } - } - } - break; - case GBA_SIO_NORMAL_8: - case GBA_SIO_NORMAL_32: - if (ATOMIC_ADD(node->p->attachedNormal, 1) > node->id + 1 && node->id > 0) { - node->d.p->siocnt = GBASIONormalSetSi(node->d.p->siocnt, GBASIONormalGetIdleSo(node->p->players[node->id - 1]->d.p->siocnt)); - } else { - node->d.p->siocnt = GBASIONormalClearSi(node->d.p->siocnt); - } - node->d.writeSIOCNT = GBASIOLockstepNodeNormalWriteSIOCNT; - break; - default: - break; - } -#ifndef NDEBUG - node->phase = node->p->d.transferActive; - node->transferId = node->p->d.transferId; -#endif - - mLockstepUnlock(&node->p->d); - - return true; -} - -bool GBASIOLockstepNodeUnload(struct GBASIODriver* driver) { - struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; - - mLockstepLock(&node->p->d); - - node->mode = driver->p->mode; - switch (node->mode) { - case GBA_SIO_MULTI: - ATOMIC_SUB(node->p->attachedMulti, 1); - break; - case GBA_SIO_NORMAL_8: - case GBA_SIO_NORMAL_32: - ATOMIC_SUB(node->p->attachedNormal, 1); - break; - default: - break; - } - - // Flush ongoing transfer - if (mTimingIsScheduled(&driver->p->p->timing, &node->event)) { - node->eventDiff -= node->event.when - mTimingCurrentTime(&driver->p->p->timing); - mTimingDeschedule(&driver->p->p->timing, &node->event); - } - - node->p->d.unload(&node->p->d, node->id); - - _finishTransfer(node); - - if (!node->id) { - ATOMIC_STORE(node->p->d.transferActive, TRANSFER_IDLE); - } - - // Invalidate SIO mode - node->mode = GBA_SIO_GPIO; - - mLockstepUnlock(&node->p->d); - - return true; -} - -static bool GBASIOLockstepNodeHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { - UNUSED(driver); - switch (mode) { - case GBA_SIO_NORMAL_8: - case GBA_SIO_NORMAL_32: - case GBA_SIO_MULTI: - return true; - default: - return false; - } -} - -static int GBASIOLockstepNodeConnectedDevices(struct GBASIODriver* driver) { - struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; - int attached = 1; - - switch (node->mode) { - case GBA_SIO_NORMAL_8: - case GBA_SIO_NORMAL_32: - ATOMIC_LOAD(attached, node->p->attachedNormal); - break; - case GBA_SIO_MULTI: - ATOMIC_LOAD(attached, node->p->attachedMulti); - break; - default: - break; - } - return attached - 1; -} - -static int GBASIOLockstepNodeDeviceId(struct GBASIODriver* driver) { - struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; - return node->id; -} - -static bool GBASIOLockstepNodeStart(struct GBASIODriver* driver) { - UNUSED(driver); - return false; -} - -static uint16_t GBASIOLockstepNodeMultiWriteSIOCNT(struct GBASIODriver* driver, uint16_t value) { - struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; - - mLockstepLock(&node->p->d); - - mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIOCNT <- %04X", node->id, value); - - enum mLockstepPhase transferActive; - int attached; - ATOMIC_LOAD(transferActive, node->p->d.transferActive); - ATOMIC_LOAD(attached, node->p->d.attached); - - driver->p->siocnt = GBASIOMultiplayerSetSlave(driver->p->siocnt, node->id || attached < 2); - - if (value & 0x0080 && transferActive == TRANSFER_IDLE) { - if (!node->id && attached > 1 && GBASIOMultiplayerIsReady(node->d.p->siocnt)) { - mLOG(GBA_SIO, DEBUG, "Lockstep %i: Transfer initiated", node->id); - ATOMIC_STORE(node->p->d.transferActive, TRANSFER_STARTING); - ATOMIC_STORE(node->p->d.transferCycles, GBASIOTransferCycles(node->d.p->mode, node->d.p->siocnt, attached)); - - if (mTimingIsScheduled(&driver->p->p->timing, &node->event)) { - node->eventDiff -= node->event.when - mTimingCurrentTime(&driver->p->p->timing); - mTimingDeschedule(&driver->p->p->timing, &node->event); - } - mTimingSchedule(&driver->p->p->timing, &node->event, 0); - } - } - value &= 0xFF83; - value |= driver->p->siocnt & 0x00FC; - - mLockstepUnlock(&node->p->d); - - return value; -} - -static void _finishTransfer(struct GBASIOLockstepNode* node) { - if (node->transferFinished) { - return; - } - - struct GBASIO* sio = node->d.p; - switch (node->mode) { - case GBA_SIO_MULTI: - GBASIOMultiplayerFinishTransfer(sio, node->p->multiRecv, 0); - break; - case GBA_SIO_NORMAL_8: - if (node->id) { - sio->siocnt = GBASIONormalSetSi(sio->siocnt, GBASIONormalGetIdleSo(node->p->players[node->id - 1]->d.p->siocnt)); - GBASIONormal8FinishTransfer(sio, node->p->normalRecv[node->id - 1], 0); - } else { - GBASIONormal8FinishTransfer(sio, 0xFF, 0); - } - break; - case GBA_SIO_NORMAL_32: - if (node->id) { - sio->siocnt = GBASIONormalSetSi(sio->siocnt, GBASIONormalGetIdleSo(node->p->players[node->id - 1]->d.p->siocnt)); - GBASIONormal32FinishTransfer(sio, node->p->normalRecv[node->id - 1], 0); - } else { - GBASIONormal32FinishTransfer(sio, 0xFFFFFFFF, 0); - } - break; - default: - break; - } - node->transferFinished = true; -#ifndef NDEBUG - ++node->transferId; -#endif -} - -static int32_t _masterUpdate(struct GBASIOLockstepNode* node) { - bool needsToWait = false; - int i; - - enum mLockstepPhase transferActive; - int attachedMulti, attached; - - ATOMIC_LOAD(transferActive, node->p->d.transferActive); - ATOMIC_LOAD(attachedMulti, node->p->attachedMulti); - ATOMIC_LOAD(attached, node->p->d.attached); - - switch (transferActive) { - case TRANSFER_IDLE: - // If the master hasn't initiated a transfer, it can keep going. - node->nextEvent += LOCKSTEP_INCREMENT; - if (node->mode == GBA_SIO_MULTI) { - node->d.p->siocnt = GBASIOMultiplayerSetReady(node->d.p->siocnt, attachedMulti == attached); - } - break; - case TRANSFER_STARTING: - // Start the transfer, but wait for the other GBAs to catch up - node->transferFinished = false; - switch (node->mode) { - case GBA_SIO_MULTI: - node->p->multiRecv[0] = node->d.p->p->memory.io[GBA_REG(SIOMLT_SEND)]; - node->p->multiRecv[1] = 0xFFFF; - node->p->multiRecv[2] = 0xFFFF; - node->p->multiRecv[3] = 0xFFFF; - break; - case GBA_SIO_NORMAL_8: - node->p->multiRecv[0] = 0xFFFF; - node->p->normalRecv[0] = node->d.p->p->memory.io[GBA_REG(SIODATA8)] & 0xFF; - break; - case GBA_SIO_NORMAL_32: - node->p->multiRecv[0] = 0xFFFF; - mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIODATA32_LO <- %04X", node->id, node->d.p->p->memory.io[GBA_REG(SIODATA32_LO)]); - mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIODATA32_HI <- %04X", node->id, node->d.p->p->memory.io[GBA_REG(SIODATA32_HI)]); - node->p->normalRecv[0] = node->d.p->p->memory.io[GBA_REG(SIODATA32_LO)]; - node->p->normalRecv[0] |= node->d.p->p->memory.io[GBA_REG(SIODATA32_HI)] << 16; - break; - default: - node->p->multiRecv[0] = 0xFFFF; - break; - } - needsToWait = true; - ATOMIC_STORE(node->p->d.transferActive, TRANSFER_STARTED); - node->nextEvent += LOCKSTEP_TRANSFER; - break; - case TRANSFER_STARTED: - // All the other GBAs have caught up and are sleeping, we can all continue now - node->nextEvent += LOCKSTEP_TRANSFER; - ATOMIC_STORE(node->p->d.transferActive, TRANSFER_FINISHING); - break; - case TRANSFER_FINISHING: - // Finish the transfer - // We need to make sure the other GBAs catch up so they don't get behind - node->nextEvent += node->p->d.transferCycles - 1024; // Split the cycles to avoid waiting too long -#ifndef NDEBUG - ATOMIC_ADD(node->p->d.transferId, 1); -#endif - needsToWait = true; - ATOMIC_STORE(node->p->d.transferActive, TRANSFER_FINISHED); - break; - case TRANSFER_FINISHED: - // Everything's settled. We're done. - _finishTransfer(node); - node->nextEvent += LOCKSTEP_INCREMENT; - ATOMIC_STORE(node->p->d.transferActive, TRANSFER_IDLE); - break; - } - int mask = 0; - for (i = 1; i < node->p->d.attached; ++i) { - if (node->p->players[i]->mode == node->mode) { - mask |= 1 << i; - } - } - if (mask) { - if (needsToWait) { - if (!node->p->d.wait(&node->p->d, mask)) { - abort(); - } - } else { - node->p->d.signal(&node->p->d, mask); - } - } - // Tell the other GBAs they can continue up to where we were - node->p->d.addCycles(&node->p->d, 0, node->eventDiff); -#ifndef NDEBUG - node->phase = node->p->d.transferActive; -#endif - - if (needsToWait) { - return 0; - } - return node->nextEvent; -} - -static uint32_t _slaveUpdate(struct GBASIOLockstepNode* node) { - enum mLockstepPhase transferActive; - int attached; - int attachedMode; - - ATOMIC_LOAD(transferActive, node->p->d.transferActive); - ATOMIC_LOAD(attached, node->p->d.attached); - - if (node->mode == GBA_SIO_MULTI) { - ATOMIC_LOAD(attachedMode, node->p->attachedMulti); - node->d.p->siocnt = GBASIOMultiplayerSetReady(node->d.p->siocnt, attachedMode == attached); - } else { - ATOMIC_LOAD(attachedMode, node->p->attachedNormal); - } - bool signal = false; - switch (transferActive) { - case TRANSFER_IDLE: - if (attachedMode != attached) { - node->p->d.addCycles(&node->p->d, node->id, LOCKSTEP_INCREMENT); - } - break; - case TRANSFER_STARTING: - case TRANSFER_FINISHING: - break; - case TRANSFER_STARTED: - if (node->p->d.unusedCycles(&node->p->d, node->id) > node->eventDiff) { - break; - } - node->transferFinished = false; - switch (node->mode) { - case GBA_SIO_MULTI: - node->d.p->rcnt &= ~1; - node->p->multiRecv[node->id] = node->d.p->p->memory.io[GBA_REG(SIOMLT_SEND)]; - node->d.p->p->memory.io[GBA_REG(SIOMULTI0)] = 0xFFFF; - node->d.p->p->memory.io[GBA_REG(SIOMULTI1)] = 0xFFFF; - node->d.p->p->memory.io[GBA_REG(SIOMULTI2)] = 0xFFFF; - node->d.p->p->memory.io[GBA_REG(SIOMULTI3)] = 0xFFFF; - node->d.p->siocnt = GBASIOMultiplayerFillBusy(node->d.p->siocnt); - break; - case GBA_SIO_NORMAL_8: - node->p->multiRecv[node->id] = 0xFFFF; - node->p->normalRecv[node->id] = node->d.p->p->memory.io[GBA_REG(SIODATA8)] & 0xFF; - break; - case GBA_SIO_NORMAL_32: - node->p->multiRecv[node->id] = 0xFFFF; - node->p->normalRecv[node->id] = node->d.p->p->memory.io[GBA_REG(SIODATA32_LO)]; - node->p->normalRecv[node->id] |= node->d.p->p->memory.io[GBA_REG(SIODATA32_HI)] << 16; - break; - default: - node->p->multiRecv[node->id] = 0xFFFF; - break; - } - signal = true; - break; - case TRANSFER_FINISHED: - if (node->p->d.unusedCycles(&node->p->d, node->id) > node->eventDiff) { - break; - } - _finishTransfer(node); - signal = true; - break; - } -#ifndef NDEBUG - node->phase = node->p->d.transferActive; -#endif - if (signal) { - node->p->d.signal(&node->p->d, 1 << node->id); - } - - return 0; -} - -static void _GBASIOLockstepNodeProcessEvents(struct mTiming* timing, void* user, uint32_t cyclesLate) { - struct GBASIOLockstepNode* node = user; - mLockstepLock(&node->p->d); - - int32_t cycles = node->nextEvent; - node->nextEvent -= cyclesLate; - node->eventDiff += cyclesLate; - if (node->p->d.attached < 2) { - switch (node->mode) { - case GBA_SIO_MULTI: - cycles = GBASIOTransferCycles(node->d.p->mode, node->d.p->siocnt, node->p->d.attached); - break; - case GBA_SIO_NORMAL_8: - case GBA_SIO_NORMAL_32: - if (node->nextEvent <= 0) { - cycles = _masterUpdate(node); - node->eventDiff = 0; - } - break; - default: - break; - } - } else if (node->nextEvent <= 0) { - if (!node->id) { - cycles = _masterUpdate(node); - } else { - cycles = _slaveUpdate(node); - cycles += node->p->d.useCycles(&node->p->d, node->id, node->eventDiff); - } - node->eventDiff = 0; - } - if (cycles > 0) { - node->nextEvent = 0; - node->eventDiff += cycles; - mTimingDeschedule(timing, &node->event); - mTimingSchedule(timing, &node->event, cycles); - } else { - node->d.p->p->earlyExit = true; - node->eventDiff += 1; - mTimingSchedule(timing, &node->event, 1); - } - - mLockstepUnlock(&node->p->d); -} - -static uint16_t GBASIOLockstepNodeNormalWriteSIOCNT(struct GBASIODriver* driver, uint16_t value) { - struct GBASIOLockstepNode* node = (struct GBASIOLockstepNode*) driver; - - mLockstepLock(&node->p->d); - - mLOG(GBA_SIO, DEBUG, "Lockstep %i: SIOCNT <- %04X", node->id, value); - int attached; - ATOMIC_LOAD(attached, node->p->attachedNormal); - value &= 0xFF8B; - if (node->id > 0) { - value = GBASIONormalSetSi(value, GBASIONormalGetIdleSo(node->p->players[node->id - 1]->d.p->siocnt)); - } else { - value = GBASIONormalClearSi(value); - } - - enum mLockstepPhase transferActive; - ATOMIC_LOAD(transferActive, node->p->d.transferActive); - if (node->id < 3 && attached > node->id + 1 && transferActive == TRANSFER_IDLE) { - int try; - for (try = 0; try < 3; ++try) { - GBASIONormal nextSiocnct; - ATOMIC_LOAD(nextSiocnct, node->p->players[node->id + 1]->d.p->siocnt); - if (ATOMIC_CMPXCHG(node->p->players[node->id + 1]->d.p->siocnt, nextSiocnct, GBASIONormalSetSi(nextSiocnct, GBASIONormalGetIdleSo(value)))) { - break; - } - } - } - if ((value & 0x0081) == 0x0081) { - if (!node->id) { - // Frequency - int32_t cycles = GBASIOTransferCycles(node->d.p->mode, node->d.p->siocnt, attached); - - if (transferActive == TRANSFER_IDLE) { - mLOG(GBA_SIO, DEBUG, "Lockstep %i: Transfer initiated", node->id); - ATOMIC_STORE(node->p->d.transferActive, TRANSFER_STARTING); - ATOMIC_STORE(node->p->d.transferCycles, cycles); - - if (mTimingIsScheduled(&driver->p->p->timing, &node->event)) { - node->eventDiff -= node->event.when - mTimingCurrentTime(&driver->p->p->timing); - mTimingDeschedule(&driver->p->p->timing, &node->event); - } - mTimingSchedule(&driver->p->p->timing, &node->event, 0); - } else { - value &= ~0x0080; - } - } else { - // TODO - } - } - - mLockstepUnlock(&node->p->d); - - return value; -} - #define TARGET(P) (1 << (P)) #define TARGET_ALL 0xF #define TARGET_PRIMARY 0x1 From 630e3a591a89b24a268be772a209de33d8a07824 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 7 Sep 2024 21:12:19 -0700 Subject: [PATCH 228/338] GBA SIO: Add support for side data in save states --- include/mgba/gba/interface.h | 3 +++ include/mgba/internal/gba/serialize.h | 1 + src/gba/core.c | 37 ++++++++++++++++++++++++++- 3 files changed, 40 insertions(+), 1 deletion(-) diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index 3d52e77431b..cba5866327c 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -113,6 +113,9 @@ struct GBASIODriver { void (*reset)(struct GBASIODriver* driver); bool (*load)(struct GBASIODriver* driver); bool (*unload)(struct GBASIODriver* driver); + uint32_t (*driverId)(const struct GBASIODriver* renderer); + bool (*loadState)(struct GBASIODriver* renderer, const void* state, size_t size); + void (*saveState)(struct GBASIODriver* renderer, void** state, size_t* size); void (*setMode)(struct GBASIODriver* driver, enum GBASIOMode mode); bool (*handlesMode)(struct GBASIODriver* driver, enum GBASIOMode mode); int (*connectedDevices)(struct GBASIODriver* driver); diff --git a/include/mgba/internal/gba/serialize.h b/include/mgba/internal/gba/serialize.h index c824e85aafb..8b1823a173d 100644 --- a/include/mgba/internal/gba/serialize.h +++ b/include/mgba/internal/gba/serialize.h @@ -287,6 +287,7 @@ DECL_BITS(GBASerializedMiscFlags, KeyIRQKeys, 4, 11); enum { GBA_SUBSYSTEM_VIDEO_RENDERER = 0, + GBA_SUBSYSTEM_SIO_DRIVER = 1, GBA_SUBSYSTEM_MAX, }; diff --git a/src/gba/core.c b/src/gba/core.c index a6939406e25..00f5ccf97e7 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -842,7 +842,21 @@ static bool _GBACoreLoadExtraState(struct mCore* core, const struct mStateExtdat if (type == gba->video.renderer->rendererId(gba->video.renderer)) { ok = gba->video.renderer->loadState(gba->video.renderer, (void*) ((uintptr_t) item.data + sizeof(uint32_t)), - item.size - sizeof(type)); + item.size - sizeof(type)) && ok; + } + } else if (item.data) { + ok = false; + } + } + if (gba->sio.activeDriver && gba->sio.activeDriver->driverId && gba->sio.activeDriver->loadState && + mStateExtdataGet(extdata, EXTDATA_SUBSYSTEM_START + GBA_SUBSYSTEM_SIO_DRIVER, &item)) { + if ((uint32_t) item.size > sizeof(uint32_t)) { + uint32_t type; + LOAD_32(type, 0, item.data); + if (type == gba->sio.activeDriver->driverId(gba->sio.activeDriver)) { + ok = gba->sio.activeDriver->loadState(gba->sio.activeDriver, + (void*) ((uintptr_t) item.data + sizeof(uint32_t)), + item.size - sizeof(type)) && ok; } } else if (item.data) { ok = false; @@ -868,6 +882,27 @@ static bool _GBACoreSaveExtraState(struct mCore* core, struct mStateExtdata* ext } if (buffer) { free(buffer); + buffer = NULL; + } + size = 0; + + if (gba->sio.activeDriver && gba->sio.activeDriver->driverId && gba->sio.activeDriver->saveState) { + gba->sio.activeDriver->saveState(gba->sio.activeDriver, &buffer, &size); + if (size > 0 && buffer) { + struct mStateExtdataItem item; + item.size = size + sizeof(uint32_t); + item.data = malloc(item.size); + item.clean = free; + uint32_t type = gba->sio.activeDriver->driverId(gba->sio.activeDriver); + STORE_32(type, 0, item.data); + memcpy((void*) ((uintptr_t) item.data + sizeof(uint32_t)), buffer, size); + mStateExtdataPut(extdata, EXTDATA_SUBSYSTEM_START + GBA_SUBSYSTEM_SIO_DRIVER, &item); + } + if (buffer) { + free(buffer); + buffer = NULL; + } + size = 0; } return true; From f2bbf8e66c0dfcd1166939a5701a278f104199ec Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 8 Sep 2024 04:17:41 -0700 Subject: [PATCH 229/338] GBA SIO: Support save states in lockstep driver --- src/gba/sio/lockstep.c | 271 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 271 insertions(+) diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 1493ca9f6a3..074b7d0e842 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -8,17 +8,82 @@ #include #include +#define DRIVER_ID 0x6B636F4C +#define DRIVER_STATE_VERSION 1 #define LOCKSTEP_INCREMENT 2000 #define TARGET(P) (1 << (P)) #define TARGET_ALL 0xF #define TARGET_PRIMARY 0x1 #define TARGET_SECONDARY ((TARGET_ALL) & ~(TARGET_PRIMARY)) +DECL_BITFIELD(GBASIOLockstepSerializedFlags, uint32_t); +DECL_BITS(GBASIOLockstepSerializedFlags, DriverMode, 0, 3); +DECL_BITS(GBASIOLockstepSerializedFlags, NumEvents, 3, 4); +DECL_BIT(GBASIOLockstepSerializedFlags, Asleep, 7); +DECL_BIT(GBASIOLockstepSerializedFlags, DataReceived, 8); +DECL_BIT(GBASIOLockstepSerializedFlags, EventScheduled, 9); +DECL_BITS(GBASIOLockstepSerializedFlags, Player0Mode, 10, 3); +DECL_BITS(GBASIOLockstepSerializedFlags, Player1Mode, 13, 3); +DECL_BITS(GBASIOLockstepSerializedFlags, Player2Mode, 16, 3); +DECL_BITS(GBASIOLockstepSerializedFlags, Player3Mode, 19, 3); +DECL_BITS(GBASIOLockstepSerializedFlags, TransferMode, 28, 3); +DECL_BIT(GBASIOLockstepSerializedFlags, TransferActive, 31); + +DECL_BITFIELD(GBASIOLockstepSerializedEventFlags, uint32_t); +DECL_BITS(GBASIOLockstepSerializedEventFlags, Type, 0, 3); + +struct GBASIOLockstepSerializedEvent { + int32_t timestamp; + int32_t playerId; + GBASIOLockstepSerializedEventFlags flags; + int32_t reserved[5]; + union { + int32_t mode; + int32_t finishCycle; + int32_t padding[4]; + }; +}; +static_assert(sizeof(struct GBASIOLockstepSerializedEvent) == 0x30, "GBA lockstep event savestate struct sized wrong"); + +struct GBASIOLockstepSerializedState { + uint32_t version; + GBASIOLockstepSerializedFlags flags; + uint32_t reserved[2]; + + struct { + int32_t nextEvent; + uint32_t reservedDriver[7]; + } driver; + + struct { + int32_t playerId; + int32_t cycleOffset; + uint32_t reservedPlayer[2]; + struct GBASIOLockstepSerializedEvent events[MAX_LOCKSTEP_EVENTS]; + } player; + + // playerId 0 only + struct { + int32_t cycle; + uint32_t waiting; + uint32_t reservedCoordinator[4]; + uint16_t multiData[4]; + uint32_t normalData[4]; + } coordinator; +}; +static_assert(offsetof(struct GBASIOLockstepSerializedState, driver) == 0x10, "GBA lockstep savestate driver offset wrong"); +static_assert(offsetof(struct GBASIOLockstepSerializedState, player) == 0x30, "GBA lockstep savestate player offset wrong"); +static_assert(offsetof(struct GBASIOLockstepSerializedState, coordinator) == 0x1C0, "GBA lockstep savestate coordinator offset wrong"); +static_assert(sizeof(struct GBASIOLockstepSerializedState) == 0x1F0, "GBA lockstep savestate struct sized wrong"); + static bool GBASIOLockstepDriverInit(struct GBASIODriver* driver); static void GBASIOLockstepDriverDeinit(struct GBASIODriver* driver); static void GBASIOLockstepDriverReset(struct GBASIODriver* driver); static bool GBASIOLockstepDriverLoad(struct GBASIODriver* driver); static bool GBASIOLockstepDriverUnload(struct GBASIODriver* driver); +static uint32_t GBASIOLockstepDriverId(const struct GBASIODriver* driver); +static bool GBASIOLockstepDriverLoadState(struct GBASIODriver* driver, const void* state, size_t size); +static void GBASIOLockstepDriverSaveState(struct GBASIODriver* driver, void** state, size_t* size); static void GBASIOLockstepDriverSetMode(struct GBASIODriver* driver, enum GBASIOMode mode); static bool GBASIOLockstepDriverHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); static int GBASIOLockstepDriverConnectedDevices(struct GBASIODriver* driver); @@ -56,6 +121,9 @@ void GBASIOLockstepDriverCreate(struct GBASIOLockstepDriver* driver, struct mLoc driver->d.reset = GBASIOLockstepDriverReset; driver->d.load = GBASIOLockstepDriverLoad; driver->d.unload = GBASIOLockstepDriverUnload; + driver->d.driverId = GBASIOLockstepDriverId; + driver->d.loadState = GBASIOLockstepDriverLoadState; + driver->d.saveState = GBASIOLockstepDriverSaveState; driver->d.setMode = GBASIOLockstepDriverSetMode; driver->d.handlesMode = GBASIOLockstepDriverHandlesMode; driver->d.deviceId = GBASIOLockstepDriverDeviceId; @@ -173,6 +241,209 @@ static bool GBASIOLockstepDriverUnload(struct GBASIODriver* driver) { return true; } +static uint32_t GBASIOLockstepDriverId(const struct GBASIODriver* driver) { + UNUSED(driver); + return DRIVER_ID; +} + +static unsigned _modeEnumToInt(enum GBASIOMode mode) { + switch ((int) mode) { + case -1: + default: + return 0; + case GBA_SIO_MULTI: + return 1; + case GBA_SIO_NORMAL_8: + return 2; + case GBA_SIO_NORMAL_32: + return 3; + case GBA_SIO_GPIO: + return 4; + case GBA_SIO_UART: + return 5; + case GBA_SIO_JOYBUS: + return 6; + } +} + +static enum GBASIOMode _modeIntToEnum(unsigned mode) { + const enum GBASIOMode modes[8] = { + -1, GBA_SIO_MULTI, GBA_SIO_NORMAL_8, GBA_SIO_NORMAL_32, GBA_SIO_GPIO, GBA_SIO_UART, GBA_SIO_JOYBUS, -1 + }; + return modes[mode & 7]; +} + +static bool GBASIOLockstepDriverLoadState(struct GBASIODriver* driver, const void* data, size_t size) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + if (size != sizeof(struct GBASIOLockstepSerializedState)) { + mLOG(GBA_SIO, WARN, "Incorrect state size: expected %" PRIz "X, got %" PRIz "X", sizeof(struct GBASIOLockstepSerializedState), size); + return false; + } + const struct GBASIOLockstepSerializedState* state = data; + bool error = false; + uint32_t ucheck; + int32_t check; + LOAD_32LE(ucheck, 0, &state->version); + if (ucheck > DRIVER_STATE_VERSION) { + mLOG(GBA_SIO, WARN, "Invalid or too new save state: expected %u, got %u", DRIVER_STATE_VERSION, ucheck); + return false; + } + + MutexLock(&coordinator->mutex); + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + LOAD_32LE(check, 0, &state->player.playerId); + if (check != player->playerId) { + mLOG(GBA_SIO, WARN, "State is for different player: expected %d, got %d", player->playerId, check); + error = true; + goto out; + } + + GBASIOLockstepSerializedFlags flags = 0; + LOAD_32LE(flags, 0, &state->flags); + LOAD_32LE(player->cycleOffset, 0, &state->player.cycleOffset); + player->dataReceived = GBASIOLockstepSerializedFlagsGetDataReceived(flags); + player->mode = _modeIntToEnum(GBASIOLockstepSerializedFlagsGetDriverMode(flags)); + + player->otherModes[0] = _modeIntToEnum(GBASIOLockstepSerializedFlagsGetPlayer0Mode(flags)); + player->otherModes[1] = _modeIntToEnum(GBASIOLockstepSerializedFlagsGetPlayer1Mode(flags)); + player->otherModes[2] = _modeIntToEnum(GBASIOLockstepSerializedFlagsGetPlayer2Mode(flags)); + player->otherModes[3] = _modeIntToEnum(GBASIOLockstepSerializedFlagsGetPlayer3Mode(flags)); + + if (GBASIOLockstepSerializedFlagsGetEventScheduled(flags)) { + int32_t when; + LOAD_32LE(when, 0, &state->driver.nextEvent); + mTimingSchedule(&driver->p->p->timing, &lockstep->event, when); + } + + if (GBASIOLockstepSerializedFlagsGetAsleep(flags)) { + if (!player->asleep && player->driver->user->sleep) { + player->driver->user->sleep(player->driver->user); + } + player->asleep = true; + } else { + if (player->asleep && player->driver->user->wake) { + player->driver->user->wake(player->driver->user); + } + player->asleep = false; + } + + unsigned i; + for (i = 0; i < MAX_LOCKSTEP_EVENTS - 1; ++i) { + player->buffer[i].next = &player->buffer[i + 1]; + } + player->freeList = &player->buffer[0]; + player->queue = NULL; + + struct GBASIOLockstepEvent** lastEvent = &player->queue; + for (i = 0; i < GBASIOLockstepSerializedFlagsGetNumEvents(flags) && i < MAX_LOCKSTEP_EVENTS; ++i) { + struct GBASIOLockstepEvent* event = player->freeList; + const struct GBASIOLockstepSerializedEvent* stateEvent = &state->player.events[i]; + player->freeList = player->freeList->next; + *lastEvent = event; + lastEvent = &event->next; + + GBASIOLockstepSerializedEventFlags flags; + LOAD_32LE(flags, 0, &stateEvent->flags); + LOAD_32LE(event->timestamp, 0, &stateEvent->timestamp); + LOAD_32LE(event->playerId, 0, &stateEvent->playerId); + event->type = GBASIOLockstepSerializedEventFlagsGetType(flags); + switch (event->type) { + case SIO_EV_ATTACH: + case SIO_EV_DETACH: + case SIO_EV_HARD_SYNC: + break; + case SIO_EV_MODE_SET: + LOAD_32LE(event->mode, 0, &stateEvent->mode); + break; + case SIO_EV_TRANSFER_START: + LOAD_32LE(event->finishCycle, 0, &stateEvent->finishCycle); + break; + } + } + + if (player->playerId == 0) { + LOAD_32LE(coordinator->cycle, 0, &state->coordinator.cycle); + LOAD_32LE(coordinator->waiting, 0, &state->coordinator.waiting); + for (i = 0; i < 4; ++i) { + LOAD_16LE(coordinator->multiData[i], 0, &state->coordinator.multiData[i]); + LOAD_32LE(coordinator->normalData[i], 0, &state->coordinator.normalData[i]); + } + coordinator->transferMode = _modeIntToEnum(GBASIOLockstepSerializedFlagsGetTransferMode(flags)); + coordinator->transferActive = GBASIOLockstepSerializedFlagsGetTransferActive(flags); + } +out: + MutexUnlock(&coordinator->mutex); + if (!error) { + mTimingInterrupt(&driver->p->p->timing); + } + return !error; +} + +static void GBASIOLockstepDriverSaveState(struct GBASIODriver* driver, void** stateOut, size_t* size) { + struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; + struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + struct GBASIOLockstepSerializedState* state = calloc(1, sizeof(*state)); + + STORE_32LE(DRIVER_STATE_VERSION, 0, &state->version); + + STORE_32LE(lockstep->event.when - mTimingCurrentTime(&driver->p->p->timing), 0, &state->driver.nextEvent); + + MutexLock(&coordinator->mutex); + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); + GBASIOLockstepSerializedFlags flags = 0; + STORE_32LE(player->playerId, 0, &state->player.playerId); + STORE_32LE(player->cycleOffset, 0, &state->player.cycleOffset); + flags = GBASIOLockstepSerializedFlagsSetAsleep(flags, player->asleep); + flags = GBASIOLockstepSerializedFlagsSetDataReceived(flags, player->dataReceived); + flags = GBASIOLockstepSerializedFlagsSetDriverMode(flags, _modeEnumToInt(player->mode)); + flags = GBASIOLockstepSerializedFlagsSetEventScheduled(flags, mTimingIsScheduled(&driver->p->p->timing, &lockstep->event)); + + flags = GBASIOLockstepSerializedFlagsSetPlayer0Mode(flags, _modeEnumToInt(player->otherModes[0])); + flags = GBASIOLockstepSerializedFlagsSetPlayer1Mode(flags, _modeEnumToInt(player->otherModes[1])); + flags = GBASIOLockstepSerializedFlagsSetPlayer2Mode(flags, _modeEnumToInt(player->otherModes[2])); + flags = GBASIOLockstepSerializedFlagsSetPlayer3Mode(flags, _modeEnumToInt(player->otherModes[3])); + + struct GBASIOLockstepEvent* event = player->queue; + size_t i; + for (i = 0; i < MAX_LOCKSTEP_EVENTS && event; ++i, event = event->next) { + struct GBASIOLockstepSerializedEvent* stateEvent = &state->player.events[i]; + GBASIOLockstepSerializedEventFlags flags = GBASIOLockstepSerializedEventFlagsSetType(0, event->type); + STORE_32LE(event->timestamp, 0, &stateEvent->timestamp); + STORE_32LE(event->playerId, 0, &stateEvent->playerId); + switch (event->type) { + case SIO_EV_ATTACH: + case SIO_EV_DETACH: + case SIO_EV_HARD_SYNC: + break; + case SIO_EV_MODE_SET: + STORE_32LE(event->mode, 0, &stateEvent->mode); + break; + case SIO_EV_TRANSFER_START: + STORE_32LE(event->finishCycle, 0, &stateEvent->finishCycle); + break; + } + STORE_32LE(flags, 0, &stateEvent->flags); + } + flags = GBASIOLockstepSerializedFlagsSetNumEvents(flags, i); + + if (player->playerId == 0) { + STORE_32LE(coordinator->cycle, 0, &state->coordinator.cycle); + STORE_32LE(coordinator->waiting, 0, &state->coordinator.waiting); + for (i = 0; i < 4; ++i) { + STORE_16LE(coordinator->multiData[i], 0, &state->coordinator.multiData[i]); + STORE_32LE(coordinator->normalData[i], 0, &state->coordinator.normalData[i]); + } + flags = GBASIOLockstepSerializedFlagsSetTransferMode(flags, _modeEnumToInt(coordinator->transferMode)); + flags = GBASIOLockstepSerializedFlagsSetTransferActive(flags, coordinator->transferActive); + } + MutexUnlock(&lockstep->coordinator->mutex); + + STORE_32LE(flags, 0, &state->flags); + *stateOut = state; + *size = sizeof(*state); +} + static void GBASIOLockstepDriverSetMode(struct GBASIODriver* driver, enum GBASIOMode mode) { struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; From 0823797671d678206f4bf1cf042a15e1299782d4 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 10 Sep 2024 03:19:02 -0700 Subject: [PATCH 230/338] GBA SIO: Remove driver sets and driver load/unload concepts --- include/mgba/gba/interface.h | 2 - include/mgba/internal/gba/sio.h | 12 +- src/gba/cart/gpio.c | 2 +- src/gba/core.c | 19 ++- src/gba/extra/battlechip.c | 6 +- src/gba/gba.c | 4 +- src/gba/sio.c | 157 ++++++---------------- src/gba/sio/dolphin.c | 21 ++- src/gba/sio/gbp.c | 6 +- src/gba/sio/lockstep.c | 25 ---- src/platform/qt/CoreController.cpp | 5 +- src/platform/qt/MultiplayerController.cpp | 17 +-- 12 files changed, 77 insertions(+), 199 deletions(-) diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index cba5866327c..9b8f6e001e1 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -111,8 +111,6 @@ struct GBASIODriver { bool (*init)(struct GBASIODriver* driver); void (*deinit)(struct GBASIODriver* driver); void (*reset)(struct GBASIODriver* driver); - bool (*load)(struct GBASIODriver* driver); - bool (*unload)(struct GBASIODriver* driver); uint32_t (*driverId)(const struct GBASIODriver* renderer); bool (*loadState)(struct GBASIODriver* renderer, const void* state, size_t size); void (*saveState)(struct GBASIODriver* renderer, void** state, size_t* size); diff --git a/include/mgba/internal/gba/sio.h b/include/mgba/internal/gba/sio.h index ca271abc4cd..14a2136b86b 100644 --- a/include/mgba/internal/gba/sio.h +++ b/include/mgba/internal/gba/sio.h @@ -62,18 +62,11 @@ DECL_BIT(GBASIORegisterRCNT, SdDirection, 5); DECL_BIT(GBASIORegisterRCNT, SiDirection, 6); DECL_BIT(GBASIORegisterRCNT, SoDirection, 7); -struct GBASIODriverSet { - struct GBASIODriver* normal; - struct GBASIODriver* multiplayer; - struct GBASIODriver* joybus; -}; - struct GBASIO { struct GBA* p; enum GBASIOMode mode; - struct GBASIODriverSet drivers; - struct GBASIODriver* activeDriver; + struct GBASIODriver* driver; uint16_t rcnt; uint16_t siocnt; @@ -86,8 +79,7 @@ void GBASIOInit(struct GBASIO* sio); void GBASIODeinit(struct GBASIO* sio); void GBASIOReset(struct GBASIO* sio); -void GBASIOSetDriverSet(struct GBASIO* sio, struct GBASIODriverSet* drivers); -void GBASIOSetDriver(struct GBASIO* sio, struct GBASIODriver* driver, enum GBASIOMode mode); +void GBASIOSetDriver(struct GBASIO* sio, struct GBASIODriver* driver); void GBASIOWriteRCNT(struct GBASIO* sio, uint16_t value); void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value); diff --git a/src/gba/cart/gpio.c b/src/gba/cart/gpio.c index a04a5f6b36d..3386ac3c633 100644 --- a/src/gba/cart/gpio.c +++ b/src/gba/cart/gpio.c @@ -527,7 +527,7 @@ void GBAHardwareDeserialize(struct GBACartridgeHardware* hw, const struct GBASer uint32_t when; LOAD_32(when, 0, &state->hw.sioNextEvent); if (hw->devices & HW_GB_PLAYER) { - GBASIOSetDriver(&hw->p->sio, &hw->p->sio.gbp.d, GBA_SIO_NORMAL_32); + GBASIOSetDriver(&hw->p->sio, &hw->p->sio.gbp.d); } if ((hw->p->memory.io[GBA_REG(SIOCNT)] & 0x0080) && when < 0x20000) { mTimingSchedule(&hw->p->timing, &hw->p->sio.completeEvent, when); diff --git a/src/gba/core.c b/src/gba/core.c index 00f5ccf97e7..898745e9ebc 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -848,15 +848,15 @@ static bool _GBACoreLoadExtraState(struct mCore* core, const struct mStateExtdat ok = false; } } - if (gba->sio.activeDriver && gba->sio.activeDriver->driverId && gba->sio.activeDriver->loadState && + if (gba->sio.driver && gba->sio.driver->driverId && gba->sio.driver->loadState && mStateExtdataGet(extdata, EXTDATA_SUBSYSTEM_START + GBA_SUBSYSTEM_SIO_DRIVER, &item)) { if ((uint32_t) item.size > sizeof(uint32_t)) { uint32_t type; LOAD_32(type, 0, item.data); - if (type == gba->sio.activeDriver->driverId(gba->sio.activeDriver)) { - ok = gba->sio.activeDriver->loadState(gba->sio.activeDriver, - (void*) ((uintptr_t) item.data + sizeof(uint32_t)), - item.size - sizeof(type)) && ok; + if (type == gba->sio.driver->driverId(gba->sio.driver)) { + ok = gba->sio.driver->loadState(gba->sio.driver, + (void*) ((uintptr_t) item.data + sizeof(uint32_t)), + item.size - sizeof(type)) && ok; } } else if (item.data) { ok = false; @@ -886,14 +886,14 @@ static bool _GBACoreSaveExtraState(struct mCore* core, struct mStateExtdata* ext } size = 0; - if (gba->sio.activeDriver && gba->sio.activeDriver->driverId && gba->sio.activeDriver->saveState) { - gba->sio.activeDriver->saveState(gba->sio.activeDriver, &buffer, &size); + if (gba->sio.driver && gba->sio.driver->driverId && gba->sio.driver->saveState) { + gba->sio.driver->saveState(gba->sio.driver, &buffer, &size); if (size > 0 && buffer) { struct mStateExtdataItem item; item.size = size + sizeof(uint32_t); item.data = malloc(item.size); item.clean = free; - uint32_t type = gba->sio.activeDriver->driverId(gba->sio.activeDriver); + uint32_t type = gba->sio.driver->driverId(gba->sio.driver); STORE_32(type, 0, item.data); memcpy((void*) ((uintptr_t) item.data + sizeof(uint32_t)), buffer, size); mStateExtdataPut(extdata, EXTDATA_SUBSYSTEM_START + GBA_SUBSYSTEM_SIO_DRIVER, &item); @@ -963,8 +963,7 @@ static void _GBACoreSetPeripheral(struct mCore* core, int type, void* periph) { gba->luminanceSource = periph; break; case mPERIPH_GBA_BATTLECHIP_GATE: - GBASIOSetDriver(&gba->sio, periph, GBA_SIO_MULTI); - GBASIOSetDriver(&gba->sio, periph, GBA_SIO_NORMAL_32); + GBASIOSetDriver(&gba->sio, periph); break; default: return; diff --git a/src/gba/extra/battlechip.c b/src/gba/extra/battlechip.c index a6eda3bdfdd..d7bf35cceaf 100644 --- a/src/gba/extra/battlechip.c +++ b/src/gba/extra/battlechip.c @@ -33,7 +33,7 @@ enum { BATTLECHIP_CONTINUE = 0xFFFF, }; -static bool GBASIOBattlechipGateLoad(struct GBASIODriver* driver); +static bool GBASIOBattlechipGateInit(struct GBASIODriver* driver); static uint16_t GBASIOBattlechipGateWriteSIOCNT(struct GBASIODriver* driver, uint16_t value); static bool GBASIOBattlechipGateHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); static int GBASIOBattlechipGateConnectedDevices(struct GBASIODriver* driver); @@ -41,7 +41,7 @@ static void GBASIOBattlechipGateFinishMultiplayer(struct GBASIODriver* driver, u void GBASIOBattlechipGateCreate(struct GBASIOBattlechipGate* gate) { memset(&gate->d, 0, sizeof(gate->d)); - gate->d.load = GBASIOBattlechipGateLoad; + gate->d.init = GBASIOBattlechipGateInit; gate->d.writeSIOCNT = GBASIOBattlechipGateWriteSIOCNT; gate->d.handlesMode = GBASIOBattlechipGateHandlesMode; gate->d.connectedDevices = GBASIOBattlechipGateConnectedDevices; @@ -51,7 +51,7 @@ void GBASIOBattlechipGateCreate(struct GBASIOBattlechipGate* gate) { gate->flavor = GBA_FLAVOR_BATTLECHIP_GATE; } -bool GBASIOBattlechipGateLoad(struct GBASIODriver* driver) { +bool GBASIOBattlechipGateInit(struct GBASIODriver* driver) { struct GBASIOBattlechipGate* gate = (struct GBASIOBattlechipGate*) driver; gate->state = BATTLECHIP_STATE_SYNC; gate->data[0] = 0x00FE; diff --git a/src/gba/gba.c b/src/gba/gba.c index aab2cd3ec2f..187d83373cf 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -263,8 +263,8 @@ void GBAReset(struct ARMCore* cpu) { // GB Player SIO control should not be engaged before detection, even if we already know it's GBP gba->memory.hw.devices &= ~HW_GB_PLAYER; - if (gba->sio.drivers.normal == &gba->sio.gbp.d) { - GBASIOSetDriver(&gba->sio, NULL, GBA_SIO_NORMAL_32); + if (gba->sio.driver == &gba->sio.gbp.d) { + GBASIOSetDriver(&gba->sio, NULL); } bool isELF = false; diff --git a/src/gba/sio.c b/src/gba/sio.c index 4b635db18dd..60c7c2286d0 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -20,20 +20,6 @@ static const int GBASIOCyclesPerTransfer[4][MAX_GBAS] = { static void _sioFinish(struct mTiming* timing, void* user, uint32_t cyclesLate); -static struct GBASIODriver* _lookupDriver(struct GBASIO* sio, enum GBASIOMode mode) { - switch (mode) { - case GBA_SIO_NORMAL_8: - case GBA_SIO_NORMAL_32: - return sio->drivers.normal; - case GBA_SIO_MULTI: - return sio->drivers.multiplayer; - case GBA_SIO_JOYBUS: - return sio->drivers.joybus; - default: - return 0; - } -} - static const char* _modeName(enum GBASIOMode mode) { switch (mode) { case GBA_SIO_NORMAL_8: @@ -60,31 +46,19 @@ static void _switchMode(struct GBASIO* sio) { newMode = (enum GBASIOMode) (mode & 0xC); } if (newMode != sio->mode) { - struct GBASIODriver* driver = _lookupDriver(sio, newMode); if (sio->mode != (enum GBASIOMode) -1) { mLOG(GBA_SIO, DEBUG, "Switching mode from %s to %s", _modeName(sio->mode), _modeName(newMode)); } - if (driver != sio->activeDriver || (driver && !driver->setMode)) { - if (sio->activeDriver && sio->activeDriver->unload) { - sio->activeDriver->unload(sio->activeDriver); - } - sio->mode = newMode; - sio->activeDriver = driver; - if (sio->activeDriver && sio->activeDriver->load) { - sio->activeDriver->load(sio->activeDriver); - } - } else { - sio->mode = newMode; - if (sio->activeDriver && sio->activeDriver->setMode) { - sio->activeDriver->setMode(sio->activeDriver, newMode); - } + sio->mode = newMode; + if (sio->driver && sio->driver->setMode) { + sio->driver->setMode(sio->driver, newMode); } int id = 0; switch (newMode) { case GBA_SIO_MULTI: - if (sio->activeDriver && sio->activeDriver->deviceId) { - id = sio->activeDriver->deviceId(sio->activeDriver); + if (sio->driver && sio->driver->deviceId) { + id = sio->driver->deviceId(sio->driver); } sio->rcnt = GBASIORegisterRCNTSetSi(sio->rcnt, !!id); break; @@ -96,10 +70,7 @@ static void _switchMode(struct GBASIO* sio) { } void GBASIOInit(struct GBASIO* sio) { - sio->drivers.normal = NULL; - sio->drivers.multiplayer = NULL; - sio->drivers.joybus = NULL; - sio->activeDriver = NULL; + sio->driver = NULL; sio->completeEvent.context = sio; sio->completeEvent.name = "GBA SIO Complete"; @@ -113,73 +84,28 @@ void GBASIOInit(struct GBASIO* sio) { } void GBASIODeinit(struct GBASIO* sio) { - if (sio->activeDriver && sio->activeDriver->unload) { - sio->activeDriver->unload(sio->activeDriver); - } - if (sio->drivers.multiplayer && sio->drivers.multiplayer->deinit) { - sio->drivers.multiplayer->deinit(sio->drivers.multiplayer); - } - if (sio->drivers.joybus && sio->drivers.joybus->deinit) { - sio->drivers.joybus->deinit(sio->drivers.joybus); - } - if (sio->drivers.normal && sio->drivers.normal->deinit) { - sio->drivers.normal->deinit(sio->drivers.normal); + if (sio->driver && sio->driver->deinit) { + sio->driver->deinit(sio->driver); } } void GBASIOReset(struct GBASIO* sio) { - if (sio->activeDriver && sio->activeDriver->unload) { - sio->activeDriver->unload(sio->activeDriver); - } - if (sio->drivers.multiplayer && sio->drivers.multiplayer->reset) { - sio->drivers.multiplayer->reset(sio->drivers.multiplayer); - } - if (sio->drivers.joybus && sio->drivers.joybus->reset) { - sio->drivers.joybus->reset(sio->drivers.joybus); - } - if (sio->drivers.normal && sio->drivers.normal->reset) { - sio->drivers.normal->reset(sio->drivers.normal); + if (sio->driver && sio->driver->reset) { + sio->driver->reset(sio->driver); } sio->rcnt = RCNT_INITIAL; sio->siocnt = 0; sio->mode = -1; - sio->activeDriver = NULL; _switchMode(sio); GBASIOPlayerReset(&sio->gbp); } -void GBASIOSetDriverSet(struct GBASIO* sio, struct GBASIODriverSet* drivers) { - GBASIOSetDriver(sio, drivers->normal, GBA_SIO_NORMAL_8); - GBASIOSetDriver(sio, drivers->multiplayer, GBA_SIO_MULTI); - GBASIOSetDriver(sio, drivers->joybus, GBA_SIO_JOYBUS); -} - -void GBASIOSetDriver(struct GBASIO* sio, struct GBASIODriver* driver, enum GBASIOMode mode) { - struct GBASIODriver** driverLoc; - switch (mode) { - case GBA_SIO_NORMAL_8: - case GBA_SIO_NORMAL_32: - driverLoc = &sio->drivers.normal; - break; - case GBA_SIO_MULTI: - driverLoc = &sio->drivers.multiplayer; - break; - case GBA_SIO_JOYBUS: - driverLoc = &sio->drivers.joybus; - break; - default: - mLOG(GBA_SIO, ERROR, "Setting an unsupported SIO driver: %x", mode); - return; - } - if (*driverLoc) { - if ((*driverLoc)->unload) { - (*driverLoc)->unload(*driverLoc); - } - if ((*driverLoc)->deinit) { - (*driverLoc)->deinit(*driverLoc); - } +void GBASIOSetDriver(struct GBASIO* sio, struct GBASIODriver* driver) { + if (sio->driver && sio->driver->deinit) { + sio->driver->deinit(sio->driver); } + sio->driver = driver; if (driver) { driver->p = sio; @@ -191,26 +117,19 @@ void GBASIOSetDriver(struct GBASIO* sio, struct GBASIODriver* driver, enum GBASI } } } - if (sio->activeDriver == *driverLoc) { - sio->activeDriver = driver; - if (driver && driver->load) { - driver->load(driver); - } - } - *driverLoc = driver; } void GBASIOWriteRCNT(struct GBASIO* sio, uint16_t value) { sio->rcnt &= 0x1FF; sio->rcnt |= value & 0xC000; _switchMode(sio); - if (sio->activeDriver && sio->activeDriver->writeRCNT) { + if (sio->driver && sio->driver->writeRCNT) { switch (sio->mode) { case GBA_SIO_GPIO: - sio->rcnt = (sio->activeDriver->writeRCNT(sio->activeDriver, value) & 0x01FF) | (sio->rcnt & 0xC000); + sio->rcnt = (sio->driver->writeRCNT(sio->driver, value) & 0x01FF) | (sio->rcnt & 0xC000); break; default: - sio->rcnt = (sio->activeDriver->writeRCNT(sio->activeDriver, value) & 0x01F0) | (sio->rcnt & 0xC00F); + sio->rcnt = (sio->driver->writeRCNT(sio->driver, value) & 0x01F0) | (sio->rcnt & 0xC00F); } } else if (sio->mode == GBA_SIO_GPIO) { sio->rcnt &= 0xC000; @@ -222,15 +141,15 @@ void GBASIOWriteRCNT(struct GBASIO* sio, uint16_t value) { } static void _startTransfer(struct GBASIO* sio) { - if (sio->activeDriver && sio->activeDriver->start) { - if (!sio->activeDriver->start(sio->activeDriver)) { + if (sio->driver && sio->driver->start) { + if (!sio->driver->start(sio->driver)) { // Transfer completion is handled internally to the driver return; } } int connected = 0; - if (sio->activeDriver && sio->activeDriver->connectedDevices) { - connected = sio->activeDriver->connectedDevices(sio->activeDriver); + if (sio->driver && sio->driver->connectedDevices) { + connected = sio->driver->connectedDevices(sio->driver); } mTimingDeschedule(&sio->p->timing, &sio->completeEvent); mTimingSchedule(&sio->p->timing, &sio->completeEvent, GBASIOTransferCycles(sio->mode, sio->siocnt, connected)); @@ -244,14 +163,14 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { int id = 0; int connected = 0; bool handled = false; - if (sio->activeDriver) { - handled = sio->activeDriver->handlesMode(sio->activeDriver, sio->mode); + if (sio->driver) { + handled = sio->driver->handlesMode(sio->driver, sio->mode); if (handled) { - if (sio->activeDriver->deviceId) { - id = sio->activeDriver->deviceId(sio->activeDriver); + if (sio->driver->deviceId) { + id = sio->driver->deviceId(sio->driver); } - connected = sio->activeDriver->connectedDevices(sio->activeDriver); - handled = !!sio->activeDriver->writeSIOCNT; + connected = sio->driver->connectedDevices(sio->driver); + handled = !!sio->driver->writeSIOCNT; } } @@ -304,7 +223,7 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { break; } if (handled) { - value = sio->activeDriver->writeSIOCNT(sio->activeDriver, value); + value = sio->driver->writeSIOCNT(sio->driver, value); } else { // Dummy drivers switch (sio->mode) { @@ -325,8 +244,8 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { uint16_t GBASIOWriteRegister(struct GBASIO* sio, uint32_t address, uint16_t value) { int id = 0; - if (sio->activeDriver && sio->activeDriver->deviceId) { - id = sio->activeDriver->deviceId(sio->activeDriver); + if (sio->driver && sio->driver->deviceId) { + id = sio->driver->deviceId(sio->driver); } bool handled = true; @@ -455,8 +374,8 @@ int32_t GBASIOTransferCycles(enum GBASIOMode mode, uint16_t siocnt, int connecte void GBASIOMultiplayerFinishTransfer(struct GBASIO* sio, uint16_t data[4], uint32_t cyclesLate) { int id = 0; - if (sio->activeDriver && sio->activeDriver->deviceId) { - id = sio->activeDriver->deviceId(sio->activeDriver); + if (sio->driver && sio->driver->deviceId) { + id = sio->driver->deviceId(sio->driver); } sio->p->memory.io[GBA_REG(SIOMULTI0)] = data[0]; sio->p->memory.io[GBA_REG(SIOMULTI1)] = data[1]; @@ -500,20 +419,20 @@ static void _sioFinish(struct mTiming* timing, void* user, uint32_t cyclesLate) } data = {0}; switch (sio->mode) { case GBA_SIO_MULTI: - if (sio->activeDriver && sio->activeDriver->finishMultiplayer) { - sio->activeDriver->finishMultiplayer(sio->activeDriver, data.multi); + if (sio->driver && sio->driver->finishMultiplayer) { + sio->driver->finishMultiplayer(sio->driver, data.multi); } GBASIOMultiplayerFinishTransfer(sio, data.multi, cyclesLate); break; case GBA_SIO_NORMAL_8: - if (sio->activeDriver && sio->activeDriver->finishNormal8) { - data.normal8 = sio->activeDriver->finishNormal8(sio->activeDriver); + if (sio->driver && sio->driver->finishNormal8) { + data.normal8 = sio->driver->finishNormal8(sio->driver); } GBASIONormal8FinishTransfer(sio, data.normal8, cyclesLate); break; case GBA_SIO_NORMAL_32: - if (sio->activeDriver && sio->activeDriver->finishNormal32) { - data.normal32 = sio->activeDriver->finishNormal32(sio->activeDriver); + if (sio->driver && sio->driver->finishNormal32) { + data.normal32 = sio->driver->finishNormal32(sio->driver); } GBASIONormal32FinishTransfer(sio, data.normal32, cyclesLate); break; diff --git a/src/gba/sio/dolphin.c b/src/gba/sio/dolphin.c index e36dfb8a53e..0bb783e76a1 100644 --- a/src/gba/sio/dolphin.c +++ b/src/gba/sio/dolphin.c @@ -23,8 +23,8 @@ enum { }; static bool GBASIODolphinInit(struct GBASIODriver* driver); -static bool GBASIODolphinLoad(struct GBASIODriver* driver); -static bool GBASIODolphinUnload(struct GBASIODriver* driver); +static void GBASIODolphinReset(struct GBASIODriver* driver); +static void GBASIODolphinSetMode(struct GBASIODriver* driver, enum GBASIOMode mode); static bool GBASIODolphinHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode); static int GBASIODolphinConnectedDevices(struct GBASIODriver* driver); static void GBASIODolphinProcessEvents(struct mTiming* timing, void* context, uint32_t cyclesLate); @@ -35,8 +35,8 @@ static void _flush(struct GBASIODolphin* dol); void GBASIODolphinCreate(struct GBASIODolphin* dol) { memset(&dol->d, 0, sizeof(dol->d)); dol->d.init = GBASIODolphinInit; - dol->d.load = GBASIODolphinLoad; - dol->d.unload = GBASIODolphinUnload; + dol->d.reset = GBASIODolphinReset; + dol->d.setMode = GBASIODolphinSetMode; dol->d.handlesMode = GBASIODolphinHandlesMode; dol->d.connectedDevices = GBASIODolphinConnectedDevices; dol->event.context = dol; @@ -98,26 +98,23 @@ bool GBASIODolphinConnect(struct GBASIODolphin* dol, const struct Address* addre static bool GBASIODolphinInit(struct GBASIODriver* driver) { struct GBASIODolphin* dol = (struct GBASIODolphin*) driver; - dol->active = false; dol->clockSlice = 0; dol->state = WAIT_FOR_FIRST_CLOCK; - _flush(dol); + GBASIODolphinReset(driver); return true; } -static bool GBASIODolphinLoad(struct GBASIODriver* driver) { +static void GBASIODolphinReset(struct GBASIODriver* driver) { struct GBASIODolphin* dol = (struct GBASIODolphin*) driver; - dol->active = true; + dol->active = false; _flush(dol); mTimingDeschedule(&dol->d.p->p->timing, &dol->event); mTimingSchedule(&dol->d.p->p->timing, &dol->event, 0); - return true; } -static bool GBASIODolphinUnload(struct GBASIODriver* driver) { +static void GBASIODolphinSetMode(struct GBASIODriver* driver, enum GBASIOMode mode) { struct GBASIODolphin* dol = (struct GBASIODolphin*) driver; - dol->active = false; - return true; + dol->active = mode == GBA_SIO_JOYBUS; } static bool GBASIODolphinHandlesMode(struct GBASIODriver* driver, enum GBASIOMode mode) { diff --git a/src/gba/sio/gbp.c b/src/gba/sio/gbp.c index 3335905a1f8..8edd92388a9 100644 --- a/src/gba/sio/gbp.c +++ b/src/gba/sio/gbp.c @@ -55,8 +55,8 @@ void GBASIOPlayerInit(struct GBASIOPlayer* gbp) { } void GBASIOPlayerReset(struct GBASIOPlayer* gbp) { - if (gbp->p->sio.drivers.normal == &gbp->d) { - GBASIOSetDriver(&gbp->p->sio, NULL, GBA_SIO_NORMAL_32); + if (gbp->p->sio.driver == &gbp->d) { + GBASIOSetDriver(&gbp->p->sio, NULL); } } @@ -88,7 +88,7 @@ void GBASIOPlayerUpdate(struct GBA* gba) { gba->sio.gbp.oldCallback = gba->keyCallback; gba->keyCallback = &gba->sio.gbp.callback.d; // TODO: Check if the SIO driver is actually used first - GBASIOSetDriver(&gba->sio, &gba->sio.gbp.d, GBA_SIO_NORMAL_32); + GBASIOSetDriver(&gba->sio, &gba->sio.gbp.d); } } diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 074b7d0e842..f71f9b3239b 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -79,8 +79,6 @@ static_assert(sizeof(struct GBASIOLockstepSerializedState) == 0x1F0, "GBA lockst static bool GBASIOLockstepDriverInit(struct GBASIODriver* driver); static void GBASIOLockstepDriverDeinit(struct GBASIODriver* driver); static void GBASIOLockstepDriverReset(struct GBASIODriver* driver); -static bool GBASIOLockstepDriverLoad(struct GBASIODriver* driver); -static bool GBASIOLockstepDriverUnload(struct GBASIODriver* driver); static uint32_t GBASIOLockstepDriverId(const struct GBASIODriver* driver); static bool GBASIOLockstepDriverLoadState(struct GBASIODriver* driver, const void* state, size_t size); static void GBASIOLockstepDriverSaveState(struct GBASIODriver* driver, void** state, size_t* size); @@ -119,8 +117,6 @@ void GBASIOLockstepDriverCreate(struct GBASIOLockstepDriver* driver, struct mLoc driver->d.init = GBASIOLockstepDriverInit; driver->d.deinit = GBASIOLockstepDriverDeinit; driver->d.reset = GBASIOLockstepDriverReset; - driver->d.load = GBASIOLockstepDriverLoad; - driver->d.unload = GBASIOLockstepDriverUnload; driver->d.driverId = GBASIOLockstepDriverId; driver->d.loadState = GBASIOLockstepDriverLoadState; driver->d.saveState = GBASIOLockstepDriverSaveState; @@ -220,27 +216,6 @@ static void GBASIOLockstepDriverReset(struct GBASIODriver* driver) { mTimingSchedule(&lockstep->d.p->p->timing, &lockstep->event, nextEvent); } -static bool GBASIOLockstepDriverLoad(struct GBASIODriver* driver) { - struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; - if (lockstep->lockstepId) { - struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; - MutexLock(&coordinator->mutex); - struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); - _setReady(coordinator, player, 0, coordinator->transferMode); - MutexUnlock(&coordinator->mutex); - GBASIOLockstepDriverSetMode(driver, driver->p->mode); - } - return true; -} - -static bool GBASIOLockstepDriverUnload(struct GBASIODriver* driver) { - struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; - if (lockstep->lockstepId) { - GBASIOLockstepDriverSetMode(driver, -1); - } - return true; -} - static uint32_t GBASIOLockstepDriverId(const struct GBASIODriver* driver) { UNUSED(driver); return DRIVER_ID; diff --git a/src/platform/qt/CoreController.cpp b/src/platform/qt/CoreController.cpp index 08b96bd81a7..032bdbc4f4d 100644 --- a/src/platform/qt/CoreController.cpp +++ b/src/platform/qt/CoreController.cpp @@ -424,7 +424,7 @@ bool CoreController::attachDolphin(const Address& address) { } if (GBASIODolphinConnect(&m_dolphin, &address, 0, 0)) { GBA* gba = static_cast(m_threadContext.core->board); - GBASIOSetDriver(&gba->sio, &m_dolphin.d, GBA_SIO_JOYBUS); + GBASIOSetDriver(&gba->sio, &m_dolphin.d); return true; } return false; @@ -433,7 +433,8 @@ bool CoreController::attachDolphin(const Address& address) { void CoreController::detachDolphin() { if (platform() == mPLATFORM_GBA) { GBA* gba = static_cast(m_threadContext.core->board); - GBASIOSetDriver(&gba->sio, nullptr, GBA_SIO_JOYBUS); + // TODO: Reattach to multiplayer controller + GBASIOSetDriver(&gba->sio, nullptr); } GBASIODolphinDestroy(&m_dolphin); } diff --git a/src/platform/qt/MultiplayerController.cpp b/src/platform/qt/MultiplayerController.cpp index c142fe126d6..616a252b5a8 100644 --- a/src/platform/qt/MultiplayerController.cpp +++ b/src/platform/qt/MultiplayerController.cpp @@ -265,9 +265,7 @@ bool MultiplayerController::attachGame(CoreController* controller) { GBASIOLockstepCoordinatorAttach(&m_gbaCoordinator, node); player.node.gba = node; - GBASIOSetDriver(&gba->sio, &node->d, GBA_SIO_MULTI); - GBASIOSetDriver(&gba->sio, &node->d, GBA_SIO_NORMAL_8); - GBASIOSetDriver(&gba->sio, &node->d, GBA_SIO_NORMAL_32); + GBASIOSetDriver(&gba->sio, &node->d); break; } #endif @@ -356,10 +354,8 @@ void MultiplayerController::detachGame(CoreController* controller) { #ifdef M_CORE_GBA case mPLATFORM_GBA: { GBA* gba = static_cast(thread->core->board); - GBASIOLockstepDriver* node = reinterpret_cast(gba->sio.drivers.multiplayer); - GBASIOSetDriver(&gba->sio, nullptr, GBA_SIO_MULTI); - GBASIOSetDriver(&gba->sio, nullptr, GBA_SIO_NORMAL_8); - GBASIOSetDriver(&gba->sio, nullptr, GBA_SIO_NORMAL_32); + GBASIOLockstepDriver* node = reinterpret_cast(gba->sio.driver); + GBASIOSetDriver(&gba->sio, nullptr); if (node) { GBASIOLockstepCoordinatorDetach(&m_gbaCoordinator, node); delete node->user; @@ -485,12 +481,13 @@ void MultiplayerController::fixOrder() { switch (m_platform) { #ifdef M_CORE_GBA case mPLATFORM_GBA: - for (int pid : m_pids.keys()) { + // TODO: fix + /*for (int pid : m_pids.keys()) { Player& p = m_pids.find(pid).value(); GBA* gba = static_cast(p.controller->thread()->core->board); - GBASIOLockstepDriver* node = reinterpret_cast(gba->sio.drivers.multiplayer); + GBASIOLockstepDriver* node = reinterpret_cast(gba->sio.driver); m_players[node->d.deviceId(&node->d)] = pid; - } + }*/ break; #endif #ifdef M_CORE_GB From 7fa572e3ff39164c64a453646a0a74d43f21720c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 11 Sep 2024 02:02:38 -0700 Subject: [PATCH 231/338] GBA SIO: Split lockstep interval for linked and unlinked times --- src/gba/sio/lockstep.c | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index f71f9b3239b..7d6f921d9ef 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -10,7 +10,8 @@ #define DRIVER_ID 0x6B636F4C #define DRIVER_STATE_VERSION 1 -#define LOCKSTEP_INCREMENT 2000 +#define LOCKSTEP_INTERVAL 2048 +#define UNLOCKED_INTERVAL 4096 #define TARGET(P) (1 << (P)) #define TARGET_ALL 0xF #define TARGET_PRIMARY 0x1 @@ -186,7 +187,7 @@ static void GBASIOLockstepDriverReset(struct GBASIODriver* driver) { } _reconfigPlayers(coordinator); if (player->playerId != 0) { - player->cycleOffset = mTimingCurrentTime(&driver->p->p->timing) - coordinator->cycle + LOCKSTEP_INCREMENT; + player->cycleOffset = mTimingCurrentTime(&driver->p->p->timing) - coordinator->cycle + LOCKSTEP_INTERVAL; struct GBASIOLockstepEvent event = { .type = SIO_EV_ATTACH, .playerId = player->playerId, @@ -207,7 +208,7 @@ static void GBASIOLockstepDriverReset(struct GBASIODriver* driver) { _setReady(coordinator, player, player->playerId, player->mode); if (TableSize(&coordinator->players) == 1) { coordinator->cycle = mTimingCurrentTime(&lockstep->d.p->p->timing); - nextEvent = LOCKSTEP_INCREMENT; + nextEvent = LOCKSTEP_INTERVAL; } else { _setReady(coordinator, player, 0, coordinator->transferMode); nextEvent = _untilNextSync(lockstep->coordinator, player); @@ -629,7 +630,11 @@ void GBASIOLockstepCoordinatorDetach(struct GBASIOLockstepCoordinator* coordinat int32_t _untilNextSync(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepPlayer* player) { int32_t cycle = coordinator->cycle - GBASIOLockstepTime(player); if (player->playerId == 0) { - cycle += LOCKSTEP_INCREMENT; + if (coordinator->nAttached < 2) { + cycle += UNLOCKED_INTERVAL; + } else { + cycle += LOCKSTEP_INTERVAL; + } } return cycle; } @@ -921,7 +926,7 @@ void _lockstepEvent(struct mTiming* timing, void* context, uint32_t cyclesLate) nextEvent = player->queue->timestamp - GBASIOLockstepTime(player); } - if (player->playerId != 0 && nextEvent <= LOCKSTEP_INCREMENT) { + if (player->playerId != 0 && nextEvent <= LOCKSTEP_INTERVAL) { if (!player->queue || wasDetach) { GBASIOLockstepPlayerSleep(player); // XXX: Is there a better way to gain sync lock at the beginning? From 5db42e83c97d705a0a1d564148458bf29082c4bc Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 12 Sep 2024 02:13:38 -0700 Subject: [PATCH 232/338] Qt: Delay attaching SIO driver until a second player is connected --- src/platform/qt/MultiplayerController.cpp | 39 ++++++++++++++++------- src/platform/qt/MultiplayerController.h | 1 + 2 files changed, 29 insertions(+), 11 deletions(-) diff --git a/src/platform/qt/MultiplayerController.cpp b/src/platform/qt/MultiplayerController.cpp index 616a252b5a8..0d12359bb06 100644 --- a/src/platform/qt/MultiplayerController.cpp +++ b/src/platform/qt/MultiplayerController.cpp @@ -201,7 +201,8 @@ bool MultiplayerController::attachGame(CoreController* controller) { interrupters.append(p.controller); } - if (attached() == 0) { + bool doDelayedAttach = false; + if (m_platform == mPLATFORM_NONE) { switch (controller->platform()) { #ifdef M_CORE_GBA case mPLATFORM_GBA: @@ -242,8 +243,6 @@ bool MultiplayerController::attachGame(CoreController* controller) { return false; } - GBA* gba = static_cast(thread->core->board); - GBASIOLockstepDriver* node = new GBASIOLockstepDriver; LockstepUser* user = new LockstepUser; mLockstepThreadUserInit(user, thread); @@ -262,10 +261,11 @@ bool MultiplayerController::attachGame(CoreController* controller) { }; GBASIOLockstepDriverCreate(node, &user->d); - GBASIOLockstepCoordinatorAttach(&m_gbaCoordinator, node); player.node.gba = node; - GBASIOSetDriver(&gba->sio, &node->d); + if (m_pids.size()) { + doDelayedAttach = true; + } break; } #endif @@ -281,6 +281,7 @@ bool MultiplayerController::attachGame(CoreController* controller) { GBSIOLockstepNodeCreate(node); GBSIOLockstepAttachNode(&m_gbLockstep, node); player.node.gb = node; + player.attached = true; GBSIOSetDriver(&gb->sio, &node->d); break; @@ -320,6 +321,19 @@ bool MultiplayerController::attachGame(CoreController* controller) { ++m_nextPid; fixOrder(); + if (doDelayedAttach) { + for (auto pid: m_players) { + Player& player = m_pids.find(pid).value(); + if (player.attached) { + continue; + } + GBA* gba = static_cast(player.controller->thread()->core->board); + GBASIOLockstepCoordinatorAttach(&m_gbaCoordinator, player.node.gba); + GBASIOSetDriver(&gba->sio, &player.node.gba->d); + player.attached = true; + } + } + emit gameAttached(); return true; } @@ -354,13 +368,16 @@ void MultiplayerController::detachGame(CoreController* controller) { #ifdef M_CORE_GBA case mPLATFORM_GBA: { GBA* gba = static_cast(thread->core->board); - GBASIOLockstepDriver* node = reinterpret_cast(gba->sio.driver); - GBASIOSetDriver(&gba->sio, nullptr); - if (node) { - GBASIOLockstepCoordinatorDetach(&m_gbaCoordinator, node); - delete node->user; - delete node; + Player& p = m_pids.find(pid).value(); + GBASIODriver* node = gba->sio.driver; + if (node == &p.node.gba->d) { + GBASIOSetDriver(&gba->sio, nullptr); + } + if (p.attached) { + GBASIOLockstepCoordinatorDetach(&m_gbaCoordinator, p.node.gba); } + delete p.node.gba->user; + delete p.node.gba; break; } #endif diff --git a/src/platform/qt/MultiplayerController.h b/src/platform/qt/MultiplayerController.h index 9eaf20b16bb..666cb390ba2 100644 --- a/src/platform/qt/MultiplayerController.h +++ b/src/platform/qt/MultiplayerController.h @@ -64,6 +64,7 @@ Q_OBJECT unsigned waitMask = 0; int saveId = 1; int preferredId = 0; + bool attached = false; }; struct LockstepUser : mLockstepThreadUser { MultiplayerController* controller; From 1d584edb77db9693e050d0b00dda2b06d9582c1c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 12 Sep 2024 02:44:26 -0700 Subject: [PATCH 233/338] GBA: Expose setting the link port device as a peripheral --- include/mgba/gba/interface.h | 2 +- src/gba/core.c | 2 +- src/platform/qt/CoreController.cpp | 11 +++++------ src/platform/qt/MultiplayerController.cpp | 6 +++--- 4 files changed, 10 insertions(+), 11 deletions(-) diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index 9b8f6e001e1..cbbb4d23a2f 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -81,7 +81,7 @@ extern MGBA_EXPORT const int GBA_LUX_LEVELS[10]; enum { mPERIPH_GBA_LUMINANCE = 0x1000, - mPERIPH_GBA_BATTLECHIP_GATE, + mPERIPH_GBA_LINK_PORT, }; struct GBACartridgeOverride { diff --git a/src/gba/core.c b/src/gba/core.c index 898745e9ebc..67550bd7a5d 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -962,7 +962,7 @@ static void _GBACoreSetPeripheral(struct mCore* core, int type, void* periph) { case mPERIPH_GBA_LUMINANCE: gba->luminanceSource = periph; break; - case mPERIPH_GBA_BATTLECHIP_GATE: + case mPERIPH_GBA_LINK_PORT: GBASIOSetDriver(&gba->sio, periph); break; default: diff --git a/src/platform/qt/CoreController.cpp b/src/platform/qt/CoreController.cpp index 032bdbc4f4d..807a866851b 100644 --- a/src/platform/qt/CoreController.cpp +++ b/src/platform/qt/CoreController.cpp @@ -423,8 +423,8 @@ bool CoreController::attachDolphin(const Address& address) { return false; } if (GBASIODolphinConnect(&m_dolphin, &address, 0, 0)) { - GBA* gba = static_cast(m_threadContext.core->board); - GBASIOSetDriver(&gba->sio, &m_dolphin.d); + clearMultiplayerController(); + m_threadContext.core->setPeripheral(m_threadContext.core, mPERIPH_GBA_LINK_PORT, &m_dolphin.d); return true; } return false; @@ -432,9 +432,8 @@ bool CoreController::attachDolphin(const Address& address) { void CoreController::detachDolphin() { if (platform() == mPLATFORM_GBA) { - GBA* gba = static_cast(m_threadContext.core->board); // TODO: Reattach to multiplayer controller - GBASIOSetDriver(&gba->sio, nullptr); + m_threadContext.core->setPeripheral(m_threadContext.core, mPERIPH_GBA_LINK_PORT, NULL); } GBASIODolphinDestroy(&m_dolphin); } @@ -1095,7 +1094,7 @@ void CoreController::attachBattleChipGate() { Interrupter interrupter(this); clearMultiplayerController(); GBASIOBattlechipGateCreate(&m_battlechip); - m_threadContext.core->setPeripheral(m_threadContext.core, mPERIPH_GBA_BATTLECHIP_GATE, &m_battlechip); + m_threadContext.core->setPeripheral(m_threadContext.core, mPERIPH_GBA_LINK_PORT, &m_battlechip); } void CoreController::detachBattleChipGate() { @@ -1103,7 +1102,7 @@ void CoreController::detachBattleChipGate() { return; } Interrupter interrupter(this); - m_threadContext.core->setPeripheral(m_threadContext.core, mPERIPH_GBA_BATTLECHIP_GATE, nullptr); + m_threadContext.core->setPeripheral(m_threadContext.core, mPERIPH_GBA_LINK_PORT, nullptr); } void CoreController::setBattleChipId(uint16_t id) { diff --git a/src/platform/qt/MultiplayerController.cpp b/src/platform/qt/MultiplayerController.cpp index 0d12359bb06..5839b0f8437 100644 --- a/src/platform/qt/MultiplayerController.cpp +++ b/src/platform/qt/MultiplayerController.cpp @@ -327,9 +327,9 @@ bool MultiplayerController::attachGame(CoreController* controller) { if (player.attached) { continue; } - GBA* gba = static_cast(player.controller->thread()->core->board); + struct mCore* core = player.controller->thread()->core; GBASIOLockstepCoordinatorAttach(&m_gbaCoordinator, player.node.gba); - GBASIOSetDriver(&gba->sio, &player.node.gba->d); + core->setPeripheral(core, mPERIPH_GBA_LINK_PORT, &player.node.gba->d); player.attached = true; } } @@ -371,7 +371,7 @@ void MultiplayerController::detachGame(CoreController* controller) { Player& p = m_pids.find(pid).value(); GBASIODriver* node = gba->sio.driver; if (node == &p.node.gba->d) { - GBASIOSetDriver(&gba->sio, nullptr); + thread->core->setPeripheral(thread->core, mPERIPH_GBA_LINK_PORT, NULL); } if (p.attached) { GBASIOLockstepCoordinatorDetach(&m_gbaCoordinator, p.node.gba); From 39d90e5e443cd41c68b4562b66d08fc40ff1fe57 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 13 Sep 2024 01:13:48 -0700 Subject: [PATCH 234/338] GBA SIO: Only set up GBP driver if no other driver is loaded --- src/gba/sio/gbp.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/gba/sio/gbp.c b/src/gba/sio/gbp.c index 8edd92388a9..977e67de43f 100644 --- a/src/gba/sio/gbp.c +++ b/src/gba/sio/gbp.c @@ -87,8 +87,9 @@ void GBASIOPlayerUpdate(struct GBA* gba) { gba->sio.gbp.inputsPosted = 0; gba->sio.gbp.oldCallback = gba->keyCallback; gba->keyCallback = &gba->sio.gbp.callback.d; - // TODO: Check if the SIO driver is actually used first - GBASIOSetDriver(&gba->sio, &gba->sio.gbp.d); + if (!gba->sio.driver) { + GBASIOSetDriver(&gba->sio, &gba->sio.gbp.d); + } } } From 79ed790a4e397451d810824f86c50e322fb1ec08 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 15 Sep 2024 04:43:18 -0700 Subject: [PATCH 235/338] GBA IO: Fix SIOCNT/RCNT serialization --- src/gba/io.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/gba/io.c b/src/gba/io.c index d29fb8a4bfb..8a4ea7fc2a8 100644 --- a/src/gba/io.c +++ b/src/gba/io.c @@ -214,8 +214,8 @@ static const int _isRSpecialRegister[GBA_REG(INTERNAL_MAX)] = { /* 10 */ 1, 1, 1, 1, 1, 1, 1, 1, /* 11 */ 0, 0, 0, 0, 0, 0, 0, 0, /* SIO */ - /* 12 */ 1, 1, 1, 1, 1, 0, 0, 0, - /* 13 */ 1, 1, 1, 0, 0, 0, 0, 0, + /* 12 */ 1, 1, 1, 1, 0, 0, 0, 0, + /* 13 */ 1, 1, 0, 0, 0, 0, 0, 0, /* 14 */ 1, 0, 0, 0, 0, 0, 0, 0, /* 15 */ 1, 1, 1, 1, 1, 0, 0, 0, /* 16 */ 0, 0, 0, 0, 0, 0, 0, 0, From 2c1fcf96915523fa527fb97df672c1b70f43962b Mon Sep 17 00:00:00 2001 From: CasualPokePlayer <50538166+CasualPokePlayer@users.noreply.github.com> Date: Sat, 28 Sep 2024 08:55:21 -0700 Subject: [PATCH 236/338] Fix savestates not writing back GPIO variables to gpioBase Resolves #3294 Also see https://github.com/TASEmulators/BizHawk/issues/4060 (this is fixed with this patch). --- src/gba/cart/gpio.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/gba/cart/gpio.c b/src/gba/cart/gpio.c index fde4e3714b0..15f08284901 100644 --- a/src/gba/cart/gpio.c +++ b/src/gba/cart/gpio.c @@ -465,6 +465,18 @@ void GBAHardwareSerialize(const struct GBACartridgeHardware* hw, struct GBASeria STORE_16(hw->direction, 0, &state->hw.pinDirection); state->hw.devices = hw->devices; + if (hw->gpioBase) { + if (hw->readWrite) { + STORE_16(hw->pinState, 0, hw->gpioBase); + STORE_16(hw->direction, 2, hw->gpioBase); + STORE_16(hw->readWrite, 4, hw->gpioBase); + } else { + hw->gpioBase[0] = 0; + hw->gpioBase[1] = 0; + hw->gpioBase[2] = 0; + } + } + STORE_32(hw->rtc.bytesRemaining, 0, &state->hw.rtcBytesRemaining); STORE_32(hw->rtc.transferStep, 0, &state->hw.rtcTransferStep); STORE_32(hw->rtc.bitsRead, 0, &state->hw.rtcBitsRead); From a26971cdc7fe564a572a06e7320e115cc959895d Mon Sep 17 00:00:00 2001 From: CasualPokePlayer <50538166+CasualPokePlayer@users.noreply.github.com> Date: Sat, 28 Sep 2024 16:39:19 -0700 Subject: [PATCH 237/338] This should be in Deserialize not Serialize --- src/gba/cart/gpio.c | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/src/gba/cart/gpio.c b/src/gba/cart/gpio.c index 15f08284901..562a42b63b6 100644 --- a/src/gba/cart/gpio.c +++ b/src/gba/cart/gpio.c @@ -465,18 +465,6 @@ void GBAHardwareSerialize(const struct GBACartridgeHardware* hw, struct GBASeria STORE_16(hw->direction, 0, &state->hw.pinDirection); state->hw.devices = hw->devices; - if (hw->gpioBase) { - if (hw->readWrite) { - STORE_16(hw->pinState, 0, hw->gpioBase); - STORE_16(hw->direction, 2, hw->gpioBase); - STORE_16(hw->readWrite, 4, hw->gpioBase); - } else { - hw->gpioBase[0] = 0; - hw->gpioBase[1] = 0; - hw->gpioBase[2] = 0; - } - } - STORE_32(hw->rtc.bytesRemaining, 0, &state->hw.rtcBytesRemaining); STORE_32(hw->rtc.transferStep, 0, &state->hw.rtcTransferStep); STORE_32(hw->rtc.bitsRead, 0, &state->hw.rtcBitsRead); @@ -514,6 +502,18 @@ void GBAHardwareDeserialize(struct GBACartridgeHardware* hw, const struct GBASer LOAD_16(hw->direction, 0, &state->hw.pinDirection); hw->devices = state->hw.devices; + if (hw->gpioBase) { + if (hw->readWrite) { + STORE_16(hw->pinState, 0, hw->gpioBase); + STORE_16(hw->direction, 2, hw->gpioBase); + STORE_16(hw->readWrite, 4, hw->gpioBase); + } else { + hw->gpioBase[0] = 0; + hw->gpioBase[1] = 0; + hw->gpioBase[2] = 0; + } + } + LOAD_32(hw->rtc.bytesRemaining, 0, &state->hw.rtcBytesRemaining); LOAD_32(hw->rtc.transferStep, 0, &state->hw.rtcTransferStep); LOAD_32(hw->rtc.bitsRead, 0, &state->hw.rtcBitsRead); From 4008ccea3d1fcdfee476fcdc0a3511f3206a9a21 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 29 Sep 2024 01:00:32 -0700 Subject: [PATCH 238/338] CHANGES: Update --- CHANGES | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGES b/CHANGES index 9a1694d6938..b30f3c95f68 100644 --- a/CHANGES +++ b/CHANGES @@ -18,6 +18,7 @@ Emulation fixes: - GBA I/O: Fix HALTCNT access behavior (fixes mgba.io/i/2309) - GBA I/O: Fix audio register 8-bit write behavior (fixes mgba.io/i/3086) - GBA Serialize: Fix some minor save state edge cases + - GBA Serialize: Properly restore GPIO register state (fixes mgba.io/i/3294) - GBA SIO: Fix MULTI mode SIOCNT bit 7 writes on secondary GBAs (fixes mgba.io/i/3110) - GBA Video: Disable BG target 1 blending when OBJ blending (fixes mgba.io/i/2722) - GBA Video: Improve emulation of window start/end conditions (fixes mgba.io/i/1945) From 7089a5572b21e9ba82448538b40cd31e9a538f19 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 17 Sep 2024 00:35:31 -0700 Subject: [PATCH 239/338] GBA SIO: Add periodic hard sync so the runner doesn't get too ahead --- include/mgba/internal/gba/sio/lockstep.h | 1 + src/gba/sio/lockstep.c | 26 +++++++++++++++++++----- 2 files changed, 22 insertions(+), 5 deletions(-) diff --git a/include/mgba/internal/gba/sio/lockstep.h b/include/mgba/internal/gba/sio/lockstep.h index 7baed069364..0053e6b94b7 100644 --- a/include/mgba/internal/gba/sio/lockstep.h +++ b/include/mgba/internal/gba/sio/lockstep.h @@ -41,6 +41,7 @@ struct GBASIOLockstepCoordinator { enum GBASIOMode transferMode; int32_t cycle; + int32_t nextHardSync; uint16_t multiData[4]; uint32_t normalData[4]; diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index 7d6f921d9ef..d1375c8a0e3 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -12,6 +12,7 @@ #define DRIVER_STATE_VERSION 1 #define LOCKSTEP_INTERVAL 2048 #define UNLOCKED_INTERVAL 4096 +#define HARD_SYNC_INTERVAL 0x80000 #define TARGET(P) (1 << (P)) #define TARGET_ALL 0xF #define TARGET_PRIMARY 0x1 @@ -67,7 +68,8 @@ struct GBASIOLockstepSerializedState { struct { int32_t cycle; uint32_t waiting; - uint32_t reservedCoordinator[4]; + int32_t nextHardSync; + uint32_t reservedCoordinator[3]; uint16_t multiData[4]; uint32_t normalData[4]; } coordinator; @@ -159,9 +161,10 @@ static void GBASIOLockstepDriverDeinit(struct GBASIODriver* driver) { static void GBASIOLockstepDriverReset(struct GBASIODriver* driver) { struct GBASIOLockstepDriver* lockstep = (struct GBASIOLockstepDriver*) driver; struct GBASIOLockstepCoordinator* coordinator = lockstep->coordinator; + struct GBASIOLockstepPlayer* player; if (!lockstep->lockstepId) { - struct GBASIOLockstepPlayer* player = calloc(1, sizeof(*player)); unsigned id; + player = calloc(1, sizeof(*player)); player->driver = lockstep; player->mode = driver->p->mode; player->playerId = -1; @@ -195,16 +198,19 @@ static void GBASIOLockstepDriverReset(struct GBASIODriver* driver) { }; _enqueueEvent(coordinator, &event, TARGET_ALL & ~TARGET(player->playerId)); } - MutexUnlock(&coordinator->mutex); + } else { + player = TableLookup(&coordinator->players, lockstep->lockstepId); + if (player->playerId != 0) { + player->cycleOffset = mTimingCurrentTime(&driver->p->p->timing) - coordinator->cycle + LOCKSTEP_INTERVAL; + } } if (mTimingIsScheduled(&lockstep->d.p->p->timing, &lockstep->event)) { + MutexUnlock(&coordinator->mutex); return; } int32_t nextEvent; - MutexLock(&coordinator->mutex); - struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, lockstep->lockstepId); _setReady(coordinator, player, player->playerId, player->mode); if (TableSize(&coordinator->players) == 1) { coordinator->cycle = mTimingCurrentTime(&lockstep->d.p->p->timing); @@ -341,6 +347,7 @@ static bool GBASIOLockstepDriverLoadState(struct GBASIODriver* driver, const voi if (player->playerId == 0) { LOAD_32LE(coordinator->cycle, 0, &state->coordinator.cycle); LOAD_32LE(coordinator->waiting, 0, &state->coordinator.waiting); + LOAD_32LE(coordinator->nextHardSync, 0, &state->coordinator.nextHardSync); for (i = 0; i < 4; ++i) { LOAD_16LE(coordinator->multiData[i], 0, &state->coordinator.multiData[i]); LOAD_32LE(coordinator->normalData[i], 0, &state->coordinator.normalData[i]); @@ -406,6 +413,7 @@ static void GBASIOLockstepDriverSaveState(struct GBASIODriver* driver, void** st if (player->playerId == 0) { STORE_32LE(coordinator->cycle, 0, &state->coordinator.cycle); STORE_32LE(coordinator->waiting, 0, &state->coordinator.waiting); + STORE_32LE(coordinator->nextHardSync, 0, &state->coordinator.nextHardSync); for (i = 0; i < 4; ++i) { STORE_16LE(coordinator->multiData[i], 0, &state->coordinator.multiData[i]); STORE_32LE(coordinator->normalData[i], 0, &state->coordinator.normalData[i]); @@ -643,6 +651,7 @@ void _advanceCycle(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOL int32_t newCycle = GBASIOLockstepTime(player); mASSERT(newCycle - coordinator->cycle >= 0); //mLOG(GBA_SIO, DEBUG, "Advancing from cycle %08X to %08X (%i cycles)", coordinator->cycle, newCycle, newCycle - coordinator->cycle); + coordinator->nextHardSync -= newCycle - coordinator->cycle; coordinator->cycle = newCycle; } @@ -674,6 +683,7 @@ void _reconfigPlayers(struct GBASIOLockstepCoordinator* coordinator) { struct GBASIOLockstepPlayer* player = TableIteratorGetValue(&coordinator->players, &iter); coordinator->cycle = mTimingCurrentTime(&player->driver->d.p->p->timing); + coordinator->nextHardSync = HARD_SYNC_INTERVAL; if (player->playerId != 0) { player->playerId = 0; @@ -859,6 +869,12 @@ void _lockstepEvent(struct mTiming* timing, void* context, uint32_t cyclesLate) if (!coordinator->transferActive) { GBASIOLockstepCoordinatorWakePlayers(coordinator); } + if (coordinator->nextHardSync < 0) { + if (!coordinator->waiting) { + _hardSync(coordinator, player); + } + coordinator->nextHardSync += HARD_SYNC_INTERVAL; + } } int32_t nextEvent = _untilNextSync(coordinator, player); From 3f7cfb3e32775919c803c105c08b23a3dd33093f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 24 Sep 2024 01:47:16 -0700 Subject: [PATCH 240/338] GBA SIO: Attempt to clean up resyncing on disconnects --- src/gba/sio/lockstep.c | 46 +++++++++++++++++++++++++++++++++--------- 1 file changed, 36 insertions(+), 10 deletions(-) diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index d1375c8a0e3..e73dcbb0927 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -115,6 +115,23 @@ static void _hardSync(struct GBASIOLockstepCoordinator*, struct GBASIOLockstepPl static void _lockstepEvent(struct mTiming*, void* context, uint32_t cyclesLate); +static void _verifyAwake(struct GBASIOLockstepCoordinator* coordinator) { +#ifdef NDEBUG + UNUSED(coordinator); +#else + int i; + int asleep = 0; + for (i = 0; i < coordinator->nAttached; ++i) { + if (!coordinator->attachedPlayers[i]) { + continue; + } + struct GBASIOLockstepPlayer* player = TableLookup(&coordinator->players, coordinator->attachedPlayers[i]); + asleep += player->asleep; + } + mASSERT_DEBUG(!asleep || asleep < coordinator->nAttached); +#endif +} + void GBASIOLockstepDriverCreate(struct GBASIOLockstepDriver* driver, struct mLockstepUser* user) { memset(driver, 0, sizeof(*driver)); driver->d.init = GBASIOLockstepDriverInit; @@ -189,8 +206,8 @@ static void GBASIOLockstepDriverReset(struct GBASIODriver* driver) { } } _reconfigPlayers(coordinator); + player->cycleOffset = mTimingCurrentTime(&driver->p->p->timing) - coordinator->cycle; if (player->playerId != 0) { - player->cycleOffset = mTimingCurrentTime(&driver->p->p->timing) - coordinator->cycle + LOCKSTEP_INTERVAL; struct GBASIOLockstepEvent event = { .type = SIO_EV_ATTACH, .playerId = player->playerId, @@ -200,9 +217,7 @@ static void GBASIOLockstepDriverReset(struct GBASIODriver* driver) { } } else { player = TableLookup(&coordinator->players, lockstep->lockstepId); - if (player->playerId != 0) { - player->cycleOffset = mTimingCurrentTime(&driver->p->p->timing) - coordinator->cycle + LOCKSTEP_INTERVAL; - } + player->cycleOffset = mTimingCurrentTime(&driver->p->p->timing) - coordinator->cycle; } if (mTimingIsScheduled(&lockstep->d.p->p->timing, &lockstep->event)) { @@ -662,12 +677,18 @@ void _removePlayer(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOL .timestamp = GBASIOLockstepTime(player), }; _enqueueEvent(coordinator, &event, TARGET_ALL & ~TARGET(player->playerId)); - GBASIOLockstepCoordinatorWakePlayers(coordinator); - if (player->playerId != 0) { - GBASIOLockstepCoordinatorAckPlayer(coordinator, player); - } + + coordinator->waiting = 0; + coordinator->transferActive = false; + TableRemove(&coordinator->players, player->driver->lockstepId); _reconfigPlayers(coordinator); + + struct GBASIOLockstepPlayer* runner = TableLookup(&coordinator->players, coordinator->attachedPlayers[0]); + if (runner) { + GBASIOLockstepPlayerWake(runner); + } + _verifyAwake(coordinator); } void _reconfigPlayers(struct GBASIOLockstepCoordinator* coordinator) { @@ -863,8 +884,10 @@ void _lockstepEvent(struct mTiming* timing, void* context, uint32_t cyclesLate) player->queue->playerId, player->queue->timestamp); wasDetach = true; } - if (player->playerId == 0) { - // We are the clock owner; advance the shared clock + if (player->playerId == 0 && GBASIOLockstepTime(player) - coordinator->cycle >= 0) { + // We are the clock owner; advance the shared clock. However, if we just became + // the clock owner (by the previous one disconnecting) we might be slightly + // behind the shared clock. We should wait a bit if needed in that case. _advanceCycle(coordinator, player); if (!coordinator->transferActive) { GBASIOLockstepCoordinatorWakePlayers(coordinator); @@ -949,6 +972,7 @@ void _lockstepEvent(struct mTiming* timing, void* context, uint32_t cyclesLate) if (nextEvent < 4) { nextEvent = 4; } + _verifyAwake(coordinator); } } MutexUnlock(&coordinator->mutex); @@ -974,6 +998,8 @@ void GBASIOLockstepCoordinatorWaitOnPlayers(struct GBASIOLockstepCoordinator* co coordinator->waiting = ((1 << coordinator->nAttached) - 1) & ~TARGET(player->playerId); GBASIOLockstepPlayerSleep(player); GBASIOLockstepCoordinatorWakePlayers(coordinator); + + _verifyAwake(coordinator); } void GBASIOLockstepCoordinatorWakePlayers(struct GBASIOLockstepCoordinator* coordinator) { From f0d65b73e81a39208e6305127185a0792b844460 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 17 Sep 2024 00:18:58 -0700 Subject: [PATCH 241/338] GBA SIO: Late cleanup --- src/gba/sio/lockstep.c | 12 +++--------- 1 file changed, 3 insertions(+), 9 deletions(-) diff --git a/src/gba/sio/lockstep.c b/src/gba/sio/lockstep.c index e73dcbb0927..a429a31e24c 100644 --- a/src/gba/sio/lockstep.c +++ b/src/gba/sio/lockstep.c @@ -10,7 +10,7 @@ #define DRIVER_ID 0x6B636F4C #define DRIVER_STATE_VERSION 1 -#define LOCKSTEP_INTERVAL 2048 +#define LOCKSTEP_INTERVAL 4096 #define UNLOCKED_INTERVAL 4096 #define HARD_SYNC_INTERVAL 0x80000 #define TARGET(P) (1 << (P)) @@ -457,7 +457,7 @@ static void GBASIOLockstepDriverSetMode(struct GBASIODriver* driver, enum GBASIO .mode = mode, }; if (player->playerId == 0) { - mASSERT(!coordinator->transferActive); // TODO + mASSERT_DEBUG(!coordinator->transferActive); // TODO coordinator->transferMode = mode; GBASIOLockstepCoordinatorWaitOnPlayers(coordinator, player); } @@ -664,8 +664,7 @@ int32_t _untilNextSync(struct GBASIOLockstepCoordinator* coordinator, struct GBA void _advanceCycle(struct GBASIOLockstepCoordinator* coordinator, struct GBASIOLockstepPlayer* player) { int32_t newCycle = GBASIOLockstepTime(player); - mASSERT(newCycle - coordinator->cycle >= 0); - //mLOG(GBA_SIO, DEBUG, "Advancing from cycle %08X to %08X (%i cycles)", coordinator->cycle, newCycle, newCycle - coordinator->cycle); + mASSERT_DEBUG(newCycle - coordinator->cycle >= 0); coordinator->nextHardSync -= newCycle - coordinator->cycle; coordinator->cycle = newCycle; } @@ -810,7 +809,6 @@ static void _setData(struct GBASIOLockstepCoordinator* coordinator, uint32_t id, case GBA_SIO_JOYBUS: mLOG(GBA_SIO, ERROR, "Unsupported mode %i in lockstep", coordinator->transferMode); // TODO: Should we handle this or just abort? - abort(); break; } } @@ -901,7 +899,6 @@ void _lockstepEvent(struct mTiming* timing, void* context, uint32_t cyclesLate) } int32_t nextEvent = _untilNextSync(coordinator, player); - //mASSERT_DEBUG(nextEvent + cyclesLate > 0); while (true) { struct GBASIOLockstepEvent* event = player->queue; if (!event) { @@ -1003,7 +1000,6 @@ void GBASIOLockstepCoordinatorWaitOnPlayers(struct GBASIOLockstepCoordinator* co } void GBASIOLockstepCoordinatorWakePlayers(struct GBASIOLockstepCoordinator* coordinator) { - //mLOG(GBA_SIO, DEBUG, "Waking all secondary players"); int i; for (i = 1; i < coordinator->nAttached; ++i) { if (!coordinator->attachedPlayers[i]) { @@ -1026,7 +1022,6 @@ void GBASIOLockstepCoordinatorAckPlayer(struct GBASIOLockstepCoordinator* coordi if (player->playerId == 0) { return; } - mLOG(GBA_SIO, DEBUG, "Player %i acking primary", player->playerId); coordinator->waiting &= ~TARGET(player->playerId); if (!coordinator->waiting) { mLOG(GBA_SIO, DEBUG, "All players acked, waking primary"); @@ -1053,7 +1048,6 @@ void GBASIOLockstepPlayerSleep(struct GBASIOLockstepPlayer* player) { if (player->asleep) { return; } - //mLOG(GBA_SIO, DEBUG, "Player %i going to sleep with %i cycles until sync", player->playerId, _untilNextSync(coordinator, player)); player->asleep = true; player->driver->user->sleep(player->driver->user); player->driver->d.p->p->cpu->nextEvent = 0; From ed0a63d1b812611fa3832e5af1722037a9916e3d Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 29 Sep 2024 20:09:48 -0700 Subject: [PATCH 242/338] Python: Attempt to fix build --- src/platform/python/_builder.h | 1 - src/platform/python/_builder.py | 1 - 2 files changed, 2 deletions(-) diff --git a/src/platform/python/_builder.h b/src/platform/python/_builder.h index 0b51eb19d96..ad12c107e11 100644 --- a/src/platform/python/_builder.h +++ b/src/platform/python/_builder.h @@ -46,7 +46,6 @@ void free(void*); #define PYEXPORT extern "Python+C" #include "platform/python/core.h" #include "platform/python/log.h" -#include "platform/python/sio.h" #include "platform/python/vfs-py.h" #undef PYEXPORT diff --git a/src/platform/python/_builder.py b/src/platform/python/_builder.py index 1defca53791..e144b6a51f3 100644 --- a/src/platform/python/_builder.py +++ b/src/platform/python/_builder.py @@ -45,7 +45,6 @@ #define PYEXPORT #include "platform/python/core.h" #include "platform/python/log.h" -#include "platform/python/sio.h" #include "platform/python/vfs-py.h" #undef PYEXPORT """, include_dirs=[incdir, srcdir], From 36f321f84889bc69b48541e0519401c091eeaeca Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 29 Sep 2024 20:27:00 -0700 Subject: [PATCH 243/338] Python: Actually fix build --- src/platform/python/_builder.h | 3 +-- src/platform/python/_builder.py | 2 +- 2 files changed, 2 insertions(+), 3 deletions(-) diff --git a/src/platform/python/_builder.h b/src/platform/python/_builder.h index ad12c107e11..c39fcf1435c 100644 --- a/src/platform/python/_builder.h +++ b/src/platform/python/_builder.h @@ -22,8 +22,7 @@ #define CXX_GUARD_END #define PYCPARSE -#define va_list void* - +typedef ... va_list; typedef int... time_t; typedef int... off_t; typedef ...* png_structp; diff --git a/src/platform/python/_builder.py b/src/platform/python/_builder.py index e144b6a51f3..f18a3c95e39 100644 --- a/src/platform/python/_builder.py +++ b/src/platform/python/_builder.py @@ -52,7 +52,7 @@ libraries=["mgba"], library_dirs=[bindir], runtime_library_dirs=[libdir], - sources=[os.path.join(pydir, path) for path in ["vfs-py.c", "core.c", "log.c", "sio.c"]]) + sources=[os.path.join(pydir, path) for path in ["vfs-py.c", "core.c", "log.c"]]) preprocessed = subprocess.check_output(cpp + ["-fno-inline", "-P"] + cppflags + [os.path.join(pydir, "_builder.h")], universal_newlines=True) From 8941f742927226c822ab0879347558aea6aa9b6e Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 29 Sep 2024 20:13:11 -0700 Subject: [PATCH 244/338] Qt: Add missing tr()s --- src/platform/qt/MultiplayerController.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/platform/qt/MultiplayerController.cpp b/src/platform/qt/MultiplayerController.cpp index 5839b0f8437..3b2146f7afe 100644 --- a/src/platform/qt/MultiplayerController.cpp +++ b/src/platform/qt/MultiplayerController.cpp @@ -401,7 +401,7 @@ void MultiplayerController::detachGame(CoreController* controller) { QPair path(controller->path(), controller->baseDirectory()); Player& p = m_pids.find(pid).value(); if (!p.saveId) { - LOG(QT, WARN) << "Clearing invalid save ID"; + LOG(QT, WARN) << tr("Clearing invalid save ID"); } else { m_claimedSaves[path] &= ~(1 << (p.saveId - 1)); if (!m_claimedSaves[path]) { @@ -410,7 +410,7 @@ void MultiplayerController::detachGame(CoreController* controller) { } if (p.preferredId < 0) { - LOG(QT, WARN) << "Clearing invalid preferred ID"; + LOG(QT, WARN) << tr("Clearing invalid preferred ID"); } else { m_claimedIds &= ~(1 << p.preferredId); } From bfc52cd2f0156d82add7d634e107b68552cac538 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 30 Sep 2024 17:24:04 -0700 Subject: [PATCH 245/338] All: Fix whitespace errors --- include/mgba-util/geometry.h | 12 +++++----- include/mgba/feature/proxy-backend.h | 2 +- include/mgba/internal/defines.h | 24 +++++++++---------- src/arm/isa-thumb.c | 2 +- src/core/cheats.c | 2 +- src/core/thread.c | 2 +- src/feature/ffmpeg/ffmpeg-decoder.c | 2 +- src/feature/ffmpeg/ffmpeg-encoder.c | 2 +- src/feature/gui/gui-config.c | 2 +- src/feature/updater.c | 2 +- src/feature/video-logger.c | 6 ++--- src/gb/core.c | 2 +- src/gb/extra/proxy.c | 2 +- src/gb/gb.c | 4 ++-- src/gb/mbc.c | 2 +- src/gb/mbc/tama5.c | 2 +- src/gb/mbc/unlicensed.c | 10 ++++---- src/gb/video.c | 2 +- src/gba/extra/proxy.c | 2 +- src/gba/serialize.c | 2 +- src/platform/3ds/ctr-gpu.c | 2 +- src/platform/example/client-server/server.c | 2 +- src/platform/opengl/gl.c | 4 ++-- src/platform/opengl/gles2.c | 4 ++-- src/platform/psp2/psp2-common.h | 2 +- src/platform/qt/BattleChipView.cpp | 2 +- src/platform/qt/ConfigController.h | 2 +- src/platform/qt/DebuggerConsoleController.cpp | 2 +- src/platform/qt/Display.h | 2 +- src/platform/qt/DisplayGL.cpp | 2 +- src/platform/qt/ForwarderController.cpp | 4 ++-- src/platform/qt/ForwarderView.cpp | 6 ++--- src/platform/qt/MemorySearch.cpp | 2 +- src/platform/qt/SaveConverter.cpp | 16 ++++++------- src/platform/qt/TilePainter.cpp | 2 +- src/platform/qt/TileView.cpp | 4 ++-- src/platform/qt/Window.cpp | 6 ++--- src/platform/qt/library/LibraryTree.cpp | 2 +- .../qt/scripting/ScriptingTextBuffer.cpp | 2 +- src/script/engines/lua.c | 2 +- src/script/types.c | 2 +- src/tools/font-sdf.c | 2 +- src/util/audio-resampler.c | 2 +- src/util/crc32.c | 2 +- src/util/hash.c | 6 ++--- src/util/sfo.c | 2 +- 46 files changed, 86 insertions(+), 86 deletions(-) diff --git a/include/mgba-util/geometry.h b/include/mgba-util/geometry.h index aa7d65e943d..5164b0b8d43 100644 --- a/include/mgba-util/geometry.h +++ b/include/mgba-util/geometry.h @@ -11,15 +11,15 @@ CXX_GUARD_START struct mSize { - int width; - int height; + int width; + int height; }; struct mRectangle { - int x; - int y; - int width; - int height; + int x; + int y; + int width; + int height; }; void mRectangleUnion(struct mRectangle* dst, const struct mRectangle* add); diff --git a/include/mgba/feature/proxy-backend.h b/include/mgba/feature/proxy-backend.h index ffd38eb47c3..0851b3a68a5 100644 --- a/include/mgba/feature/proxy-backend.h +++ b/include/mgba/feature/proxy-backend.h @@ -57,7 +57,7 @@ struct mVideoBackendCommand { struct mVideoProxyBackend { struct VideoBackend d; struct VideoBackend* backend; - + struct RingFIFO in; struct RingFIFO out; diff --git a/include/mgba/internal/defines.h b/include/mgba/internal/defines.h index 8af6037369c..67b8ec8fd2f 100644 --- a/include/mgba/internal/defines.h +++ b/include/mgba/internal/defines.h @@ -9,23 +9,23 @@ #define mSAVEDATA_CLEANUP_THRESHOLD 15 enum { - mSAVEDATA_DIRT_NONE = 0, + mSAVEDATA_DIRT_NONE = 0, mSAVEDATA_DIRT_NEW = 1, mSAVEDATA_DIRT_SEEN = 2, }; static inline bool mSavedataClean(int* dirty, uint32_t* dirtAge, uint32_t frameCount) { - if (*dirty & mSAVEDATA_DIRT_NEW) { - *dirtAge = frameCount; - *dirty &= ~mSAVEDATA_DIRT_NEW; - if (!(*dirty & mSAVEDATA_DIRT_SEEN)) { - *dirty |= mSAVEDATA_DIRT_SEEN; - } - } else if ((*dirty & mSAVEDATA_DIRT_SEEN) && frameCount - *dirtAge > mSAVEDATA_CLEANUP_THRESHOLD) { - *dirty = 0; - return true; - } - return false; + if (*dirty & mSAVEDATA_DIRT_NEW) { + *dirtAge = frameCount; + *dirty &= ~mSAVEDATA_DIRT_NEW; + if (!(*dirty & mSAVEDATA_DIRT_SEEN)) { + *dirty |= mSAVEDATA_DIRT_SEEN; + } + } else if ((*dirty & mSAVEDATA_DIRT_SEEN) && frameCount - *dirtAge > mSAVEDATA_CLEANUP_THRESHOLD) { + *dirty = 0; + return true; + } + return false; } #endif diff --git a/src/arm/isa-thumb.c b/src/arm/isa-thumb.c index 0bc8fcb12a9..30fcfde9d61 100644 --- a/src/arm/isa-thumb.c +++ b/src/arm/isa-thumb.c @@ -88,7 +88,7 @@ DEFINE_IMMEDIATE_5_INSTRUCTION_THUMB(LSR1, } THUMB_NEUTRAL_S( , , cpu->gprs[rd]);) -DEFINE_IMMEDIATE_5_INSTRUCTION_THUMB(ASR1, +DEFINE_IMMEDIATE_5_INSTRUCTION_THUMB(ASR1, if (!immediate) { cpu->cpsr.c = ARM_SIGN(cpu->gprs[rm]); if (cpu->cpsr.c) { diff --git a/src/core/cheats.c b/src/core/cheats.c index 53f71e907c9..1ffe91adf91 100644 --- a/src/core/cheats.c +++ b/src/core/cheats.c @@ -37,7 +37,7 @@ static uint32_t _patchMakeKey(struct mCheatPatch* patch) { patchKey >>= 2; break; default: - break; + break; } // TODO: More than one segment if (patch->segment > 0) { diff --git a/src/core/thread.c b/src/core/thread.c index 2462407cc1f..2b16a03c7ba 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -656,7 +656,7 @@ void mCoreThreadContinue(struct mCoreThread* threadContext) { if (threadContext->impl->requested) { threadContext->impl->state = mTHREAD_REQUEST; } else { - threadContext->impl->state = mTHREAD_RUNNING; + threadContext->impl->state = mTHREAD_RUNNING; } ConditionWake(&threadContext->impl->stateOnThreadCond); } diff --git a/src/feature/ffmpeg/ffmpeg-decoder.c b/src/feature/ffmpeg/ffmpeg-decoder.c index 09539ca61c2..189fb312f00 100644 --- a/src/feature/ffmpeg/ffmpeg-decoder.c +++ b/src/feature/ffmpeg/ffmpeg-decoder.c @@ -71,7 +71,7 @@ bool FFmpegDecoderOpen(struct FFmpegDecoder* decoder, const char* infile) { codec = avcodec_find_decoder(context->codec_id); if (!codec) { FFmpegDecoderClose(decoder); - return false; + return false; } if (avcodec_open2(context, codec, NULL) < 0) { FFmpegDecoderClose(decoder); diff --git a/src/feature/ffmpeg/ffmpeg-encoder.c b/src/feature/ffmpeg/ffmpeg-encoder.c index 5ee54a5e87d..6202e0fcdce 100644 --- a/src/feature/ffmpeg/ffmpeg-encoder.c +++ b/src/feature/ffmpeg/ffmpeg-encoder.c @@ -893,7 +893,7 @@ void FFmpegEncoderSetInputFrameRate(struct FFmpegEncoder* encoder, int numerator void FFmpegEncoderSetInputSampleRate(struct FFmpegEncoder* encoder, int sampleRate) { encoder->isampleRate = sampleRate; - if (encoder->resampleContext) { + if (encoder->resampleContext) { av_freep(&encoder->audioBuffer); #ifdef USE_LIBAVRESAMPLE avresample_close(encoder->resampleContext); diff --git a/src/feature/gui/gui-config.c b/src/feature/gui/gui-config.c index e110ef76857..6214abc159c 100644 --- a/src/feature/gui/gui-config.c +++ b/src/feature/gui/gui-config.c @@ -295,7 +295,7 @@ void mGUIShowConfig(struct mGUIRunner* runner, struct GUIMenuItem* extra, size_t test.v.s = mCoreConfigGetValue(&runner->config, item->data.v.s); if (test.v.s && strcmp(test.v.s, v->v.s) == 0) { item->state = j; - break; + break; } break; case GUI_VARIANT_POINTER: diff --git a/src/feature/updater.c b/src/feature/updater.c index e50ed0fa275..ea9cea3c16a 100644 --- a/src/feature/updater.c +++ b/src/feature/updater.c @@ -46,7 +46,7 @@ static void _updateList(const char* key, const char* value, void* user) { if (strncmp("medusa.", key, 7) == 0) { dotLoc = strchr(&key[7], '.'); } else { - dotLoc = strchr(key, '.'); + dotLoc = strchr(key, '.'); } if (!dotLoc) { return; diff --git a/src/feature/video-logger.c b/src/feature/video-logger.c index 4044a492839..ac5ef177718 100644 --- a/src/feature/video-logger.c +++ b/src/feature/video-logger.c @@ -339,17 +339,17 @@ bool mVideoLoggerRendererRunInjected(struct mVideoLogger* logger) { channel->injecting = true; bool res = mVideoLoggerRendererRun(logger, false); channel->injecting = false; - return res; + return res; } void mVideoLoggerInjectionPoint(struct mVideoLogger* logger, enum mVideoLoggerInjectionPoint injectionPoint) { struct mVideoLogChannel* channel = logger->dataContext; - channel->injectionPoint = injectionPoint; + channel->injectionPoint = injectionPoint; } void mVideoLoggerIgnoreAfterInjection(struct mVideoLogger* logger, uint32_t mask) { struct mVideoLogChannel* channel = logger->dataContext; - channel->ignorePackets = mask; + channel->ignorePackets = mask; } static bool _writeData(struct mVideoLogger* logger, const void* data, size_t length) { diff --git a/src/gb/core.c b/src/gb/core.c index 2bfea28ef95..e67fe423290 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -152,7 +152,7 @@ static bool _GBCoreInit(struct mCore* core) { #ifdef ENABLE_VFS mDirectorySetInit(&core->dirs); #endif - + return true; } diff --git a/src/gb/extra/proxy.c b/src/gb/extra/proxy.c index ba36c0090cf..c0c386f4c05 100644 --- a/src/gb/extra/proxy.c +++ b/src/gb/extra/proxy.c @@ -267,7 +267,7 @@ void GBVideoProxyRendererDrawRange(struct GBVideoRenderer* renderer, int startX, _copyExtraState(proxyRenderer); proxyRenderer->backend->drawRange(proxyRenderer->backend, startX, endX, y); } - mVideoLoggerRendererDrawRange(proxyRenderer->logger, startX, endX, y); + mVideoLoggerRendererDrawRange(proxyRenderer->logger, startX, endX, y); } void GBVideoProxyRendererFinishScanline(struct GBVideoRenderer* renderer, int y) { diff --git a/src/gb/gb.c b/src/gb/gb.c index 67dea55b8a2..fa0d6482f3b 100644 --- a/src/gb/gb.c +++ b/src/gb/gb.c @@ -152,7 +152,7 @@ bool GBLoadGBX(struct GBXMetadata* metadata, struct VFile* vf) { if (memcmp(footer, "MBC1", 4) == 0) { metadata->mapperVars.u8[0] = 5; } else if (memcmp(footer, "MB1M", 4) == 0) { - metadata->mapperVars.u8[0] = 4; + metadata->mapperVars.u8[0] = 4; } return true; } @@ -894,7 +894,7 @@ int GBValidModels(const uint8_t* bank0) { } else if (cart->cgb == 0xC0) { models = GB_MODEL_CGB; } else { - models = GB_MODEL_MGB; + models = GB_MODEL_MGB; } if (cart->sgb == 0x03 && cart->oldLicensee == 0x33) { models |= GB_MODEL_SGB; diff --git a/src/gb/mbc.c b/src/gb/mbc.c index c9ebed54638..397b5008814 100644 --- a/src/gb/mbc.c +++ b/src/gb/mbc.c @@ -163,7 +163,7 @@ static bool _isMulticart(const uint8_t* mem) { success = GBIsROM(vf); vf->close(vf); } - + return success; } diff --git a/src/gb/mbc/tama5.c b/src/gb/mbc/tama5.c index 505a35ed89d..c4f0a1517d0 100644 --- a/src/gb/mbc/tama5.c +++ b/src/gb/mbc/tama5.c @@ -131,7 +131,7 @@ static void _latchTAMA6Rtc(struct mRTCSource* rtc, struct GBTAMA5State* tama5, t timerRegs[GBTAMA6_RTC_PA0_HOUR_10] = (diff % 24) / 10; } else { timerRegs[GBTAMA6_RTC_PA0_HOUR_1] = (diff % 12) % 10; - timerRegs[GBTAMA6_RTC_PA0_HOUR_10] = (diff % 12) / 10 + (diff / 12) * 2; + timerRegs[GBTAMA6_RTC_PA0_HOUR_10] = (diff % 12) / 10 + (diff / 12) * 2; } t /= 24; t += diff / 24; diff --git a/src/gb/mbc/unlicensed.c b/src/gb/mbc/unlicensed.c index 950ddf074dd..844c0d0cd57 100644 --- a/src/gb/mbc/unlicensed.c +++ b/src/gb/mbc/unlicensed.c @@ -349,7 +349,7 @@ void _GBHitek(struct GB* gb, uint16_t address, uint8_t value) { break; case 0x300: // See hhugboy src/memory/mbc/MbcUnlHitek.cpp for commentary on this return - return; + return; } _GBMBC5(gb, address, value); } @@ -396,10 +396,10 @@ uint8_t _GBGGB81Read(struct GBMemory* memory, uint16_t address) { } void _GBLiCheng(struct GB* gb, uint16_t address, uint8_t value) { - if (address > 0x2100 && address < 0x3000) { - return; - } - _GBMBC5(gb, address, value); + if (address > 0x2100 && address < 0x3000) { + return; + } + _GBMBC5(gb, address, value); } void _GBSachen(struct GB* gb, uint16_t address, uint8_t value) { diff --git a/src/gb/video.c b/src/gb/video.c index 38be72a5ab7..d52e43deed5 100644 --- a/src/gb/video.c +++ b/src/gb/video.c @@ -755,7 +755,7 @@ void GBVideoWriteLCDC(struct GBVideo* video, GBRegisterLCDC value) { video->ly = 0; video->p->memory.io[GB_REG_LY] = 0; video->renderer->writePalette(video->renderer, 0, video->dmgPalette[0]); - + mTimingDeschedule(&video->p->timing, &video->modeEvent); mTimingDeschedule(&video->p->timing, &video->frameEvent); mTimingSchedule(&video->p->timing, &video->frameEvent, GB_VIDEO_TOTAL_LENGTH << 1); diff --git a/src/gba/extra/proxy.c b/src/gba/extra/proxy.c index ee611247b31..e33c7b568aa 100644 --- a/src/gba/extra/proxy.c +++ b/src/gba/extra/proxy.c @@ -324,7 +324,7 @@ void GBAVideoProxyRendererSaveState(struct GBAVideoRenderer* renderer, void** st proxyRenderer->logger->stateSize = 0; } else { proxyRenderer->backend->saveState(proxyRenderer->backend, state, size); - } + } } void GBAVideoProxyRendererWriteVRAM(struct GBAVideoRenderer* renderer, uint32_t address) { diff --git a/src/gba/serialize.c b/src/gba/serialize.c index 1669eca3d4c..5eabaedea8a 100644 --- a/src/gba/serialize.c +++ b/src/gba/serialize.c @@ -195,7 +195,7 @@ bool GBADeserialize(struct GBA* gba, const struct GBASerializedState* state) { if (GBASerializedMiscFlagsIsIrqPending(miscFlags)) { int32_t when; LOAD_32(when, 0, &state->nextIrq); - mTimingSchedule(&gba->timing, &gba->irqEvent, when); + mTimingSchedule(&gba->timing, &gba->irqEvent, when); } gba->cpuBlocked = GBASerializedMiscFlagsGetBlocked(miscFlags); gba->keysLast = GBASerializedMiscFlagsGetKeyIRQKeys(miscFlags); diff --git a/src/platform/3ds/ctr-gpu.c b/src/platform/3ds/ctr-gpu.c index 4a95c46405c..d153f84a0b3 100644 --- a/src/platform/3ds/ctr-gpu.c +++ b/src/platform/3ds/ctr-gpu.c @@ -160,7 +160,7 @@ void ctrActivateTexture(const C3D_Tex* texture) { .m = { // Rows are in the order w z y x, because ctrulib 0.0f, 0.0f, 0.0f, 1.0f / activeTexture->width, - 0.0f, 0.0f, 1.0f / activeTexture->height, 0.0f + 0.0f, 0.0f, 1.0f / activeTexture->height, 0.0f } }; C3D_FVUnifMtx2x4(GPU_GEOMETRY_SHADER, GSH_FVEC_textureMtx, &textureMtx); diff --git a/src/platform/example/client-server/server.c b/src/platform/example/client-server/server.c index 0dcec9b150a..71472a05c2e 100644 --- a/src/platform/example/client-server/server.c +++ b/src/platform/example/client-server/server.c @@ -53,7 +53,7 @@ int main(int argc, char** argv) { SocketClose(sock); SocketSubsystemDeinit(); didFail = true; - goto cleanup; + goto cleanup; } // Run the server diff --git a/src/platform/opengl/gl.c b/src/platform/opengl/gl.c index b0cef1f0d92..de8354c1c52 100644 --- a/src/platform/opengl/gl.c +++ b/src/platform/opengl/gl.c @@ -253,7 +253,7 @@ static void mGLContextImageSize(struct VideoBackend* v, enum VideoLayer layer, i *height = context->layerDims[layer].height; } else { *width = context->imageSizes[layer].width; - *height = context->imageSizes[layer].height; + *height = context->imageSizes[layer].height; } } @@ -266,7 +266,7 @@ void mGLContextPostFrame(struct VideoBackend* v, enum VideoLayer layer, const vo context->activeTex ^= 1; glBindTexture(GL_TEXTURE_2D, context->tex[context->activeTex]); } else { - glBindTexture(GL_TEXTURE_2D, context->layers[layer]); + glBindTexture(GL_TEXTURE_2D, context->layers[layer]); } int width = context->imageSizes[layer].width; diff --git a/src/platform/opengl/gles2.c b/src/platform/opengl/gles2.c index fa6716be92f..e5ee9876791 100644 --- a/src/platform/opengl/gles2.c +++ b/src/platform/opengl/gles2.c @@ -529,7 +529,7 @@ static void mGLES2ContextImageSize(struct VideoBackend* v, enum VideoLayer layer *height = context->layerDims[layer].height; } else { *width = context->imageSizes[layer].width; - *height = context->imageSizes[layer].height; + *height = context->imageSizes[layer].height; } } @@ -617,7 +617,7 @@ void mGLES2ShaderInit(struct mGLES2Shader* shader, const char* vs, const char* f if (shader->width > 0 && shader->height > 0) { glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, shader->width, shader->height, 0, GL_RGB, GL_UNSIGNED_BYTE, 0); } else { - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 512, 512, 0, GL_RGB, GL_UNSIGNED_BYTE, 0); + glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 512, 512, 0, GL_RGB, GL_UNSIGNED_BYTE, 0); } glFramebufferTexture2D(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_2D, shader->tex, 0); diff --git a/src/platform/psp2/psp2-common.h b/src/platform/psp2/psp2-common.h index 7f34d1d100c..dcb67b70063 100644 --- a/src/platform/psp2/psp2-common.h +++ b/src/platform/psp2/psp2-common.h @@ -5,7 +5,7 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #ifndef PSP2_COMMON_H #define PSP2_COMMON_H - + #include #define PSP2_HORIZONTAL_PIXELS 960 diff --git a/src/platform/qt/BattleChipView.cpp b/src/platform/qt/BattleChipView.cpp index f7d6eb4c7dd..46b24e92766 100644 --- a/src/platform/qt/BattleChipView.cpp +++ b/src/platform/qt/BattleChipView.cpp @@ -216,7 +216,7 @@ void BattleChipView::loadDeck() { error->show(); return; } - + QList newDeck; QStringList deck = ini.value("deck").toString().split(','); for (const auto& item : deck) { diff --git a/src/platform/qt/ConfigController.h b/src/platform/qt/ConfigController.h index 4c71c39439c..4325a46ba1a 100644 --- a/src/platform/qt/ConfigController.h +++ b/src/platform/qt/ConfigController.h @@ -130,7 +130,7 @@ public slots: mGraphicsOpts m_graphicsOpts{}; std::array m_subparsers; bool m_parsed = false; - + QHash m_argvOptions; QHash m_optionSet; std::unique_ptr m_settings; diff --git a/src/platform/qt/DebuggerConsoleController.cpp b/src/platform/qt/DebuggerConsoleController.cpp index dffd71bcf63..716c3163972 100644 --- a/src/platform/qt/DebuggerConsoleController.cpp +++ b/src/platform/qt/DebuggerConsoleController.cpp @@ -162,7 +162,7 @@ void DebuggerConsoleController::historyLoad() { if (line.endsWith("\r\n")) { line.chop(2); } else if (line.endsWith("\n")) { - line.chop(1); + line.chop(1); } history.append(QString::fromUtf8(line)); } diff --git a/src/platform/qt/Display.h b/src/platform/qt/Display.h index bb16b268e4f..3cc2fc61f99 100644 --- a/src/platform/qt/Display.h +++ b/src/platform/qt/Display.h @@ -62,7 +62,7 @@ Q_OBJECT virtual void setVideoProxy(std::shared_ptr proxy) { m_videoProxy = std::move(proxy); } std::shared_ptr videoProxy() { return m_videoProxy; } virtual VideoBackend* videoBackend(); - + signals: void drawingStarted(); void showCursor(); diff --git a/src/platform/qt/DisplayGL.cpp b/src/platform/qt/DisplayGL.cpp index 5b60eb46e79..ad496994358 100644 --- a/src/platform/qt/DisplayGL.cpp +++ b/src/platform/qt/DisplayGL.cpp @@ -314,7 +314,7 @@ bool DisplayGL::highestCompatible(QSurfaceFormat& format) { if (QOpenGLContext::openGLModuleType() == QOpenGLContext::LibGL) { format.setVersion(1, 4); } else { - format.setVersion(1, 1); + format.setVersion(1, 1); } format.setOption(QSurfaceFormat::DeprecatedFunctions); if (DisplayGL::supportsFormat(format)) { diff --git a/src/platform/qt/ForwarderController.cpp b/src/platform/qt/ForwarderController.cpp index 0934f1c69b2..abf2d27d028 100644 --- a/src/platform/qt/ForwarderController.cpp +++ b/src/platform/qt/ForwarderController.cpp @@ -160,7 +160,7 @@ void ForwarderController::gotManifest(QNetworkReply* reply) { mUpdaterGetUpdateForChannel(&context, platform.toUtf8().constData(), m_channel.toUtf8().constData(), &update); downloadBuild({bucket + update.path}); - mUpdaterDeinit(&context); + mUpdaterDeinit(&context); } void ForwarderController::downloadBuild(const QUrl& url) { @@ -174,7 +174,7 @@ void ForwarderController::downloadBuild(const QUrl& url) { .arg(extension)); if (!m_sourceFile.open(QIODevice::WriteOnly | QIODevice::Truncate)) { emit buildFailed(); - return; + return; } QNetworkReply* reply = GBAApp::app()->httpGet(url); diff --git a/src/platform/qt/ForwarderView.cpp b/src/platform/qt/ForwarderView.cpp index 922ef7c1691..7261c09415b 100644 --- a/src/platform/qt/ForwarderView.cpp +++ b/src/platform/qt/ForwarderView.cpp @@ -97,7 +97,7 @@ void ForwarderView::build() { if (m_ui.baseType->currentIndex() == 2) { m_controller.setBaseFilename(m_ui.baseFilename->text()); } else { - m_controller.clearBaseFilename(); + m_controller.clearBaseFilename(); } m_controller.startBuild(m_ui.outputFilename->text()); m_ui.buttonBox->button(QDialogButtonBox::Ok)->setEnabled(false); @@ -235,14 +235,14 @@ void ForwarderView::updateProgress() { if (m_needsForwarderKit) { m_ui.progressBar->setValue(450 + m_downloadProgress * 50); } else { - m_ui.progressBar->setValue(m_downloadProgress * 100); + m_ui.progressBar->setValue(m_downloadProgress * 100); } break; case ForwarderController::BASE: if (m_needsForwarderKit) { m_ui.progressBar->setValue(500 + m_downloadProgress * 500); } else { - m_ui.progressBar->setValue(100 + m_downloadProgress * 900); + m_ui.progressBar->setValue(100 + m_downloadProgress * 900); } break; } diff --git a/src/platform/qt/MemorySearch.cpp b/src/platform/qt/MemorySearch.cpp index 34f87fe14bf..7a844688723 100644 --- a/src/platform/qt/MemorySearch.cpp +++ b/src/platform/qt/MemorySearch.cpp @@ -21,7 +21,7 @@ MemorySearch::MemorySearch(std::shared_ptr controller, QWidget* mCoreMemorySearchResultsInit(&m_results, 0); connect(m_ui.search, &QPushButton::clicked, this, &MemorySearch::search); - connect(m_ui.value, &QLineEdit::returnPressed, this, &MemorySearch::search); + connect(m_ui.value, &QLineEdit::returnPressed, this, &MemorySearch::search); connect(m_ui.searchWithin, &QPushButton::clicked, this, &MemorySearch::searchWithin); connect(m_ui.refresh, &QPushButton::clicked, this, &MemorySearch::refresh); connect(m_ui.numHex, &QPushButton::clicked, this, &MemorySearch::refresh); diff --git a/src/platform/qt/SaveConverter.cpp b/src/platform/qt/SaveConverter.cpp index 974f31af0fd..205a7563d71 100644 --- a/src/platform/qt/SaveConverter.cpp +++ b/src/platform/qt/SaveConverter.cpp @@ -86,18 +86,18 @@ void SaveConverter::refreshInputTypes() { m_validSaves.clear(); m_ui.inputType->clear(); if (m_ui.inputFile->text().isEmpty()) { - m_ui.inputType->addItem(tr("No file selected")); + m_ui.inputType->addItem(tr("No file selected")); m_ui.inputType->setEnabled(false); return; } std::shared_ptr vf = std::make_shared(m_ui.inputFile->text(), QIODevice::ReadOnly); if (!vf->isOpen()) { - m_ui.inputType->addItem(tr("Could not open file")); + m_ui.inputType->addItem(tr("Could not open file")); m_ui.inputType->setEnabled(false); return; } - + detectFromSavestate(*vf); detectFromSize(vf); detectFromHeaders(vf); @@ -108,7 +108,7 @@ void SaveConverter::refreshInputTypes() { if (m_validSaves.count()) { m_ui.inputType->setEnabled(true); } else { - m_ui.inputType->addItem(tr("No valid formats found")); + m_ui.inputType->addItem(tr("No valid formats found")); m_ui.inputType->setEnabled(false); } } @@ -127,7 +127,7 @@ void SaveConverter::refreshOutputTypes() { if (m_validOutputs.count()) { m_ui.outputType->setEnabled(true); } else { - m_ui.outputType->addItem(tr("No valid conversions found")); + m_ui.outputType->addItem(tr("No valid conversions found")); m_ui.outputType->setEnabled(false); } checkCanConvert(); @@ -494,21 +494,21 @@ SaveConverter::AnnotatedSave::operator QString() const { if (size & 0xFF) { typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "%1 SRAM + RTC"); } else { - typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "%1 SRAM"); + typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "%1 SRAM"); } break; case GB_MBC2: if (size == 0x100) { typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "packed MBC2"); } else { - typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "unpacked MBC2"); + typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "unpacked MBC2"); } break; case GB_MBC6: if (size == GB_SIZE_MBC6_FLASH) { typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "MBC6 flash"); } else if (size > GB_SIZE_MBC6_FLASH) { - typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "MBC6 combined SRAM + flash"); + typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "MBC6 combined SRAM + flash"); } else { typeFormat = QCoreApplication::translate("QGBA::SaveConverter", "MBC6 SRAM"); } diff --git a/src/platform/qt/TilePainter.cpp b/src/platform/qt/TilePainter.cpp index b8c8075e677..88f7b51b19e 100644 --- a/src/platform/qt/TilePainter.cpp +++ b/src/platform/qt/TilePainter.cpp @@ -81,7 +81,7 @@ void TilePainter::setTileCount(int tiles) { int w = width() / m_size; int h = (tiles + w - 1) * m_size / w; setMinimumSize(m_size, h - (h % m_size)); - } else { + } else { int w = minimumSize().width() / m_size; if (!w) { w = 1; diff --git a/src/platform/qt/TileView.cpp b/src/platform/qt/TileView.cpp index dbfc1553155..6ba409a0a85 100644 --- a/src/platform/qt/TileView.cpp +++ b/src/platform/qt/TileView.cpp @@ -132,7 +132,7 @@ void TileView::updateTilesGBA(bool force) { if (m_ui.tilesBg->isChecked()) { m_ui.tiles->setTileCount(1024); } else if (m_ui.tilesObj->isChecked()) { - m_ui.tiles->setTileCount(512); + m_ui.tiles->setTileCount(512); } else { m_ui.tiles->setTileCount(1536); } @@ -165,7 +165,7 @@ void TileView::updateTilesGBA(bool force) { if (m_ui.tilesBg->isChecked()) { m_ui.tiles->setTileCount(2048); } else if (m_ui.tilesObj->isChecked()) { - m_ui.tiles->setTileCount(1024); + m_ui.tiles->setTileCount(1024); } else { m_ui.tiles->setTileCount(3072); } diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index 0e3d73b00ce..77c7695fb19 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -127,7 +127,7 @@ Window::Window(CoreManager* manager, ConfigController* config, int playerId, QWi if (value.toBool()) { attachWidget(m_libraryView); } else { - attachWidget(m_screenWidget); + attachWidget(m_screenWidget); } } }, this); @@ -136,8 +136,8 @@ Window::Window(CoreManager* manager, ConfigController* config, int playerId, QWi ConfigOption* showFilenameInLibrary = m_config->addOption("showFilenameInLibrary"); showFilenameInLibrary->connect([this](const QVariant& value) { m_libraryView->setShowFilename(value.toBool()); - }, this); - m_config->updateOption("showFilenameInLibrary"); + }, this); + m_config->updateOption("showFilenameInLibrary"); ConfigOption* libraryStyle = m_config->addOption("libraryStyle"); libraryStyle->connect([this](const QVariant& value) { m_libraryView->setViewStyle(static_cast(value.toInt())); diff --git a/src/platform/qt/library/LibraryTree.cpp b/src/platform/qt/library/LibraryTree.cpp index 37d07e3e7bf..c9029e96395 100644 --- a/src/platform/qt/library/LibraryTree.cpp +++ b/src/platform/qt/library/LibraryTree.cpp @@ -181,7 +181,7 @@ void LibraryTree::rebuildTree() { QHash pathNodes; if (m_currentStyle == LibraryStyle::STYLE_TREE) { - for (const QString& folder : m_pathNodes.keys()) { + for (const QString& folder : m_pathNodes.keys()) { QTreeWidgetItem* i = new LibraryTreeItem; pathNodes.insert(folder, i); i->setText(0, folder.section("/", -1)); diff --git a/src/platform/qt/scripting/ScriptingTextBuffer.cpp b/src/platform/qt/scripting/ScriptingTextBuffer.cpp index fe85eda0e1a..9a5de818d92 100644 --- a/src/platform/qt/scripting/ScriptingTextBuffer.cpp +++ b/src/platform/qt/scripting/ScriptingTextBuffer.cpp @@ -107,7 +107,7 @@ void ScriptingTextBuffer::moveCursor(const QPoint& pos) { m_shim.cursor.insertBlock(); } } else { - m_shim.cursor.movePosition(QTextCursor::Down, QTextCursor::MoveAnchor, y); + m_shim.cursor.movePosition(QTextCursor::Down, QTextCursor::MoveAnchor, y); } int x = pos.x(); diff --git a/src/script/engines/lua.c b/src/script/engines/lua.c index f6bdabea2aa..732d54e9976 100644 --- a/src/script/engines/lua.c +++ b/src/script/engines/lua.c @@ -1143,7 +1143,7 @@ bool _luaInvoke(struct mScriptEngineContextLua* luaContext, struct mScriptFrame* if (ret == LUA_ERRRUN) { luaContext->lastError = strdup(lua_tostring(luaContext->lua, -1)); lua_pop(luaContext->lua, 1); - + _luaError(luaContext); } mScriptContextDeactivate(luaContext->d.context); diff --git a/src/script/types.c b/src/script/types.c index be58a43bff9..00422d20cb8 100644 --- a/src/script/types.c +++ b/src/script/types.c @@ -1443,7 +1443,7 @@ static struct mScriptClassMember* _findSetter(const struct mScriptTypeClass* cls if (m) { return m; } - + switch (type->base) { case mSCRIPT_TYPE_SINT: if (type->size < 2) { diff --git a/src/tools/font-sdf.c b/src/tools/font-sdf.c index e28c34eafaf..0ddcdc645b5 100644 --- a/src/tools/font-sdf.c +++ b/src/tools/font-sdf.c @@ -24,7 +24,7 @@ void createSdf(const struct mImage* src, struct mImage* dst, int x, int y, int w if (mImageGetPixel(src, i, j) & 0xFFFFFF) { mImageSetPixelRaw(dst, i, j, 0xFF); } else { - mImageSetPixelRaw(dst, i, j, 1); + mImageSetPixelRaw(dst, i, j, 1); } } } diff --git a/src/util/audio-resampler.c b/src/util/audio-resampler.c index 3b1848190ae..554f4744b9d 100644 --- a/src/util/audio-resampler.c +++ b/src/util/audio-resampler.c @@ -60,7 +60,7 @@ void mAudioResamplerSetSource(struct mAudioResampler* resampler, struct mAudioBu void mAudioResamplerSetDestination(struct mAudioResampler* resampler, struct mAudioBuffer* destination, double rate) { resampler->destination = destination; - resampler->destRate = rate; + resampler->destRate = rate; } size_t mAudioResamplerProcess(struct mAudioResampler* resampler) { diff --git a/src/util/crc32.c b/src/util/crc32.c index 24f61111107..7c1fcda55d3 100644 --- a/src/util/crc32.c +++ b/src/util/crc32.c @@ -103,7 +103,7 @@ uint32_t doCrc32(const void* buf, size_t size) { #ifndef HAVE_CRC32 uint32_t crc32(uint32_t crc, const void* buf, size_t size) { const uint8_t* p = buf; - + crc = ~crc; for (size_t i = 0; i < size; ++i) { crc = crc32Table[(crc ^ p[i]) & 0xFF] ^ (crc >> 8); diff --git a/src/util/hash.c b/src/util/hash.c index ed070e86c5d..1ac0b56e28a 100644 --- a/src/util/hash.c +++ b/src/util/hash.c @@ -69,9 +69,9 @@ uint32_t hash32(const void* key, size_t len, uint32_t seed) { k1 *= c1; k1 = ROTL32(k1, 15); k1 *= c2; - + h1 ^= k1; - h1 = ROTL32(h1, 13); + h1 = ROTL32(h1, 13); h1 = h1 * 5 + 0xe6546b64; } @@ -105,4 +105,4 @@ uint32_t hash32(const void* key, size_t len, uint32_t seed) { h1 = fmix32(h1); return h1; -} +} diff --git a/src/util/sfo.c b/src/util/sfo.c index 97c4e385346..47d5f27026d 100644 --- a/src/util/sfo.c +++ b/src/util/sfo.c @@ -91,7 +91,7 @@ bool SfoAddStrValue(struct Table* sfo, const char* name, const char* value) { HashTableInsert(sfo, name, entry); } entry->type = PSF_TYPE_STR; - entry->data.str = value; + entry->data.str = value; return true; } From c71cd4a81b8ad0d09084d28d56d1ebaadcb7d468 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 1 Oct 2024 02:02:18 -0700 Subject: [PATCH 246/338] Qt: Improve --script help --- src/platform/qt/ConfigController.cpp | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/platform/qt/ConfigController.cpp b/src/platform/qt/ConfigController.cpp index ccec60432f2..819b2479d0b 100644 --- a/src/platform/qt/ConfigController.cpp +++ b/src/platform/qt/ConfigController.cpp @@ -154,11 +154,12 @@ ConfigController::ConfigController(QObject* parent) mSubParserGraphicsInit(&m_subparsers[0], &m_graphicsOpts); m_subparsers[1].usage = "Frontend options:\n" - " --ecard FILE Scan an e-Reader card in the first loaded game\n" - " Can be passed multiple times for multiple cards\n" - " --mb FILE Boot a multiboot image with FILE inserted into the ROM slot" + " --ecard FILE Scan an e-Reader card in the first loaded game\n" + " Can be passed multiple times for multiple cards\n" + " --mb FILE Boot a multiboot image with FILE inserted into the ROM slot" #ifdef ENABLE_SCRIPTING - "\n --script FILE Script file to load on start" + "\n --script FILE Script file to load on start\n" + " Can be passed multiple times\n" #endif ; From 541ed9606cc3a53879f81f473f88a8d5b96fe451 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 4 Oct 2024 17:13:43 -0700 Subject: [PATCH 247/338] Core: Check for null when autoloading/saving cheats --- src/core/cheats.c | 3 +++ src/core/core.c | 6 ++++-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/core/cheats.c b/src/core/cheats.c index 1ffe91adf91..2fc97c3ac52 100644 --- a/src/core/cheats.c +++ b/src/core/cheats.c @@ -627,6 +627,9 @@ void mCheatAutosave(struct mCheatDevice* device) { if (!device->autosave) { return; } + if (!device->p->dirs.cheats) { + return; + } struct VFile* vf = mDirectorySetOpenSuffix(&device->p->dirs, device->p->dirs.cheats, ".cheats", O_WRONLY | O_CREAT | O_TRUNC); if (!vf) { return; diff --git a/src/core/core.c b/src/core/core.c index 20f9fdefc95..789656ea4dc 100644 --- a/src/core/core.c +++ b/src/core/core.c @@ -245,14 +245,16 @@ bool mCoreAutoloadPatch(struct mCore* core) { } bool mCoreAutoloadCheats(struct mCore* core) { - bool success = true; + bool success = !!core->dirs.cheats; int cheatAuto; - if (!mCoreConfigGetIntValue(&core->config, "cheatAutoload", &cheatAuto) || cheatAuto) { + if (success && (!mCoreConfigGetIntValue(&core->config, "cheatAutoload", &cheatAuto) || cheatAuto)) { struct VFile* vf = mDirectorySetOpenSuffix(&core->dirs, core->dirs.cheats, ".cheats", O_RDONLY); if (vf) { struct mCheatDevice* device = core->cheatDevice(core); success = mCheatParseFile(device, vf); vf->close(vf); + } else { + success = false; } } if (!mCoreConfigGetIntValue(&core->config, "cheatAutosave", &cheatAuto) || cheatAuto) { From 5fb7c5e3ee85343c2e9c397a3644fe568b6373f6 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 4 Oct 2024 17:17:47 -0700 Subject: [PATCH 248/338] Core: Add sanity check for mDirectorySetOpenSuffix --- src/core/directories.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/core/directories.c b/src/core/directories.c index c4551b6c729..e0748f82977 100644 --- a/src/core/directories.c +++ b/src/core/directories.c @@ -110,6 +110,9 @@ struct VFile* mDirectorySetOpenPath(struct mDirectorySet* dirs, const char* path } struct VFile* mDirectorySetOpenSuffix(struct mDirectorySet* dirs, struct VDir* dir, const char* suffix, int mode) { + if (!dir) { + return NULL; + } char name[PATH_MAX + 1] = ""; snprintf(name, sizeof(name) - 1, "%s%s", dirs->baseName, suffix); return dir->openFile(dir, name, mode); From 7950279a09ce7f41a56a584a8fd1b6231f8074b2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 4 Oct 2024 22:20:21 -0700 Subject: [PATCH 249/338] Core: Split out semantics of rumble integrator init/reset (fixes #3309) --- include/mgba/core/interface.h | 1 + src/core/interface.c | 16 ++++++++++------ src/platform/libretro/libretro.c | 2 +- src/platform/switch/main.c | 6 ++---- 4 files changed, 14 insertions(+), 11 deletions(-) diff --git a/include/mgba/core/interface.h b/include/mgba/core/interface.h index 5973877535b..033047caca8 100644 --- a/include/mgba/core/interface.h +++ b/include/mgba/core/interface.h @@ -133,6 +133,7 @@ struct mRumbleIntegrator { }; void mRumbleIntegratorInit(struct mRumbleIntegrator*); +void mRumbleIntegratorReset(struct mRumbleIntegrator*); struct mCoreChannelInfo { size_t id; diff --git a/src/core/interface.c b/src/core/interface.c index 10d3433ab2d..5771d80e1c7 100644 --- a/src/core/interface.c +++ b/src/core/interface.c @@ -110,14 +110,14 @@ void mRTCGenericSourceInit(struct mRTCGenericSource* rtc, struct mCore* core) { rtc->d.deserialize = _rtcGenericDeserialize; } -static void mRumbleIntegratorReset(struct mRumble* rumble, bool enable) { +static void _mRumbleIntegratorReset(struct mRumble* rumble, bool enable) { struct mRumbleIntegrator* integrator = (struct mRumbleIntegrator*) rumble; integrator->state = enable; integrator->timeOn = 0; integrator->totalTime = 0; } -static void mRumbleIntegratorSetRumble(struct mRumble* rumble, bool enable, uint32_t sinceLast) { +static void _mRumbleIntegratorSetRumble(struct mRumble* rumble, bool enable, uint32_t sinceLast) { struct mRumbleIntegrator* integrator = (struct mRumbleIntegrator*) rumble; if (integrator->state) { @@ -127,7 +127,7 @@ static void mRumbleIntegratorSetRumble(struct mRumble* rumble, bool enable, uint integrator->state = enable; } -static void mRumbleIntegratorIntegrate(struct mRumble* rumble, uint32_t period) { +static void _mRumbleIntegratorIntegrate(struct mRumble* rumble, uint32_t period) { if (!period) { return; } @@ -144,7 +144,11 @@ static void mRumbleIntegratorIntegrate(struct mRumble* rumble, uint32_t period) void mRumbleIntegratorInit(struct mRumbleIntegrator* integrator) { memset(integrator, 0, sizeof(*integrator)); - integrator->d.reset = mRumbleIntegratorReset; - integrator->d.setRumble = mRumbleIntegratorSetRumble; - integrator->d.integrate = mRumbleIntegratorIntegrate; + integrator->d.reset = _mRumbleIntegratorReset; + integrator->d.setRumble = _mRumbleIntegratorSetRumble; + integrator->d.integrate = _mRumbleIntegratorIntegrate; +} + +void mRumbleIntegratorReset(struct mRumbleIntegrator* integrator) { + _mRumbleIntegratorReset(&integrator->d, false); } diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index 232c4e6ebb3..d2a871546e5 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -834,7 +834,7 @@ static void _setupMaps(struct mCore* core) { void retro_reset(void) { core->reset(core); - mRumbleIntegratorInit(&rumble); + mRumbleIntegratorReset(&rumble); _setupMaps(core); } diff --git a/src/platform/switch/main.c b/src/platform/switch/main.c index 1f61cc27915..6cd7bc3b813 100644 --- a/src/platform/switch/main.c +++ b/src/platform/switch/main.c @@ -296,7 +296,7 @@ static void _setup(struct mGUIRunner* runner) { } _updateRenderer(runner, fakeBool); - mRumbleIntegratorInit(&rumble.d); + mRumbleIntegratorReset(&rumble.d); runner->core->setPeripheral(runner->core, mPERIPH_RUMBLE, &rumble.d.d); runner->core->setPeripheral(runner->core, mPERIPH_ROTATION, &rotation); runner->core->setAVStream(runner->core, &stream); @@ -363,13 +363,10 @@ static void _gameLoaded(struct mGUIRunner* runner) { runner->core->reloadConfigOption(runner->core, "videoScale", &runner->config); } } - - mRumbleIntegratorInit(&rumble.d); } static void _gameUnloaded(struct mGUIRunner* runner) { UNUSED(runner); - mRumbleIntegratorInit(&rumble.d); HidVibrationValue values[4]; memcpy(&values[0], &vibrationStop, sizeof(rumble.value)); memcpy(&values[1], &vibrationStop, sizeof(rumble.value)); @@ -812,6 +809,7 @@ static void hidSetup(void) { padConfigureInput(1, HidNpadStyleSet_NpadStandard); padInitializeDefault(&pad); + mRumbleIntegratorInit(&rumble.d); rumble.d.setRumble = _setRumble; rumble.value.freq_low = 120.0; rumble.value.freq_high = 180.0; From 0e52f7054fae93794706611b71a9190d726052b0 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 6 Oct 2024 03:20:49 -0700 Subject: [PATCH 250/338] Res: Add demo input display script --- res/scripts/input-display.lua | 122 ++++++++++++++++++++++++++++++++++ 1 file changed, 122 insertions(+) create mode 100644 res/scripts/input-display.lua diff --git a/res/scripts/input-display.lua b/res/scripts/input-display.lua new file mode 100644 index 00000000000..e3db0340cc9 --- /dev/null +++ b/res/scripts/input-display.lua @@ -0,0 +1,122 @@ +input_display = { + anchor = "top", + offset = { + x = 0, + y = 0, + } +} + +local state = { + drawButton = { + [0] = function(state) -- A + state.painter:drawCircle(27, 6, 4) + end, + [1] = function(state) -- B + state.painter:drawCircle(23, 8, 4) + end, + [2] = function(state) -- Select + state.painter:drawCircle(13, 11, 3) + end, + [3] = function(state) -- Start + state.painter:drawCircle(18, 11, 3) + end, + [4] = function(state) -- Right + state.painter:drawRectangle(9, 7, 4, 3) + end, + [5] = function(state) -- Left + state.painter:drawRectangle(2, 7, 4, 3) + end, + [6] = function(state) -- Up + state.painter:drawRectangle(6, 3, 3, 4) + end, + [7] = function(state) -- Down + state.painter:drawRectangle(6, 10, 3, 4) + end, + [8] = function(state) -- R + state.painter:drawRectangle(28, 0, 4, 3) + end, + [9] = function(state) -- L + state.painter:drawRectangle(0, 0, 4, 3) + end + }, + maxKey = { + [C.PLATFORM.GBA] = 9, + [C.PLATFORM.GB] = 7, + } +} +state.overlay = canvas:newLayer(32, 16) +state.painter = image.newPainter(state.overlay.image) +state.painter:setBlend(false) +state.painter:setFill(true) + +function state.update() + local keys = util.expandBitmask(emu:getKeys()) + local maxKey = state.maxKey[emu:platform()] + + for key = 0, maxKey do + if emu:getKey(key) ~= 0 then + state.painter:setFillColor(0x80FFFFFF) + else + state.painter:setFillColor(0x40404040) + end + state.drawButton[key](state) + end + state.overlay:update() +end + +function state.reset() + local endX = canvas:screenWidth() - 32 + local endY = canvas:screenHeight() - 16 + + local anchors = { + topLeft = { + x = 0, + y = 0 + }, + top = { + x = endX / 2, + y = 0 + }, + topRight = { + x = endX, + y = 0 + }, + left = { + x = 0, + y = endY / 2 + }, + center = { + x = endX / 2, + y = endY / 2 + }, + right = { + x = endX, + y = endY / 2 + }, + bottomLeft = { + x = 0, + y = endY + }, + bottom = { + x = endX / 2, + y = endY + }, + bottomRight = { + x = endX, + y = endY + }, + } + + local pos = anchors[input_display.anchor]; + pos.x = pos.x + input_display.offset.x; + pos.y = pos.y + input_display.offset.y; + + state.overlay:setPosition(pos.x, pos.y); + state.painter:setFillColor(0x40808080) + state.painter:drawRectangle(0, 0, 32, 16) + state.overlay:update() +end + +state.reset() +callbacks:add("frame", state.update) +callbacks:add("start", state.reset) From 58510ca2506679b31618d80dd75fc6f00c043959 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 8 Oct 2024 03:12:51 -0700 Subject: [PATCH 251/338] Util: Add MD5 implementation and consistency tests --- include/mgba-util/md5.h | 34 ++++++ src/util/CMakeLists.txt | 2 + src/util/md5.c | 228 ++++++++++++++++++++++++++++++++++++++++ src/util/test/hash.c | 130 +++++++++++++++++++++++ 4 files changed, 394 insertions(+) create mode 100644 include/mgba-util/md5.h create mode 100644 src/util/md5.c create mode 100644 src/util/test/hash.c diff --git a/include/mgba-util/md5.h b/include/mgba-util/md5.h new file mode 100644 index 00000000000..9a2c58145e3 --- /dev/null +++ b/include/mgba-util/md5.h @@ -0,0 +1,34 @@ +/* Copyright (c) 2013-2014 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + * + * Based on https://github.com/Zunawe/md5-c + * Originally released under the Unlicense */ +#ifndef MD5_H +#define MD5_H + +#include + +CXX_GUARD_START + +struct MD5Context { + size_t size; // Size of input in bytes + uint32_t buffer[4]; // Current accumulation of hash + uint8_t input[0x40]; // Input to be used in the next step + uint8_t digest[0x10]; // Result of algorithm +}; + +void md5Init(struct MD5Context* ctx); +void md5Update(struct MD5Context* ctx, const void* input, size_t len); +void md5Finalize(struct MD5Context* ctx); + +void md5Buffer(const void* input, size_t len, uint8_t* result); + +struct VFile; +bool md5File(struct VFile* vf, uint8_t* result); + +CXX_GUARD_END + +#endif diff --git a/src/util/CMakeLists.txt b/src/util/CMakeLists.txt index 66cd6ca4761..2f4ba2dcda6 100644 --- a/src/util/CMakeLists.txt +++ b/src/util/CMakeLists.txt @@ -6,6 +6,7 @@ set(BASE_SOURCE_FILES formatting.c gbk-table.c hash.c + md5.c string.c table.c vector.c @@ -41,6 +42,7 @@ set(TEST_FILES test/circle-buffer.c test/color.c test/geometry.c + test/hash.c test/image.c test/sfo.c test/string-parser.c diff --git a/src/util/md5.c b/src/util/md5.c new file mode 100644 index 00000000000..08e06fb1d15 --- /dev/null +++ b/src/util/md5.c @@ -0,0 +1,228 @@ +/* Copyright (c) 2013-2014 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + * + * Based on https://github.com/Zunawe/md5-c + * Originally released under the Unlicense + * + * Derived from the RSA Data Security, Inc. MD5 Message-Digest Algorithm + */ +#include + +#include + +/* + * Constants defined by the MD5 algorithm + */ +#define A 0x67452301 +#define B 0xEFCDAB89 +#define C 0x98BADCFE +#define D 0x10325476 + +static const uint32_t S[] = { 7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22, + 5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20, + 4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23, + 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21 }; + +static const uint32_t K[] = { 0xD76AA478, 0xE8C7B756, 0x242070DB, 0xC1BDCEEE, + 0xF57C0FAF, 0x4787C62A, 0xA8304613, 0xFD469501, + 0x698098D8, 0x8B44F7AF, 0xFFFF5BB1, 0x895CD7BE, + 0x6B901122, 0xFD987193, 0xA679438E, 0x49B40821, + 0xF61E2562, 0xC040B340, 0x265E5A51, 0xE9B6C7AA, + 0xD62F105D, 0x02441453, 0xD8A1E681, 0xE7D3FBC8, + 0x21E1CDE6, 0xC33707D6, 0xF4D50D87, 0x455A14ED, + 0xA9E3E905, 0xFCEFA3F8, 0x676F02D9, 0x8D2A4C8A, + 0xFFFA3942, 0x8771F681, 0x6D9D6122, 0xFDE5380C, + 0xA4BEEA44, 0x4BDECFA9, 0xF6BB4B60, 0xBEBFBC70, + 0x289B7EC6, 0xEAA127FA, 0xD4EF3085, 0x04881D05, + 0xD9D4D039, 0xE6DB99E5, 0x1FA27CF8, 0xC4AC5665, + 0xF4292244, 0x432AFF97, 0xAB9423A7, 0xFC93A039, + 0x655B59C3, 0x8F0CCC92, 0xFFEFF47D, 0x85845DD1, + 0x6FA87E4F, 0xFE2CE6E0, 0xA3014314, 0x4E0811A1, + 0xF7537E82, 0xBD3AF235, 0x2AD7D2BB, 0xEB86D391 }; + +/* + * Padding used to make the size (in bits) of the input congruent to 448 mod 512 + */ +static const uint8_t PADDING[] = { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; + +/* + * Bit-manipulation functions defined by the MD5 algorithm + */ +#define F(X, Y, Z) (((X) & (Y)) | (~(X) & (Z))) +#define G(X, Y, Z) (((X) & (Z)) | ((Y) & ~(Z))) +#define H(X, Y, Z) ((X) ^ (Y) ^ (Z)) +#define I(X, Y, Z) ((Y) ^ ((X) | ~(Z))) + +/* + * Rotates a 32-bit word left by n bits + */ +static uint32_t rotateLeft(uint32_t x, uint32_t n) { + return (x << n) | (x >> (32 - n)); +} + +/* + * Step on 512 bits of input with the main MD5 algorithm. + */ +static void md5Step(uint32_t* buffer, const uint32_t* input) { + uint32_t AA = buffer[0]; + uint32_t BB = buffer[1]; + uint32_t CC = buffer[2]; + uint32_t DD = buffer[3]; + + uint32_t E; + + unsigned j; + + for (unsigned i = 0; i < 64; ++i) { + switch (i / 16) { + case 0: + E = F(BB, CC, DD); + j = i; + break; + case 1: + E = G(BB, CC, DD); + j = ((i * 5) + 1) & 0xF; + break; + case 2: + E = H(BB, CC, DD); + j = ((i * 3) + 5) & 0xF; + break; + default: + E = I(BB, CC, DD); + j = (i * 7) & 0xF; + break; + } + + uint32_t temp = DD; + DD = CC; + CC = BB; + BB += rotateLeft(AA + E + K[i] + input[j], S[i]); + AA = temp; + } + + buffer[0] += AA; + buffer[1] += BB; + buffer[2] += CC; + buffer[3] += DD; +} + +/* + * Initialize a context + */ +void md5Init(struct MD5Context* ctx) { + memset(ctx, 0, sizeof(*ctx)); + + ctx->buffer[0] = A; + ctx->buffer[1] = B; + ctx->buffer[2] = C; + ctx->buffer[3] = D; +} + +/* + * Add some amount of input to the context + * + * If the input fills out a block of 512 bits, apply the algorithm (md5Step) + * and save the result in the buffer. Also updates the overall size. + */ +void md5Update(struct MD5Context* ctx, const void* input, size_t len) { + uint32_t buffer[16]; + unsigned offset = ctx->size & 0x3F; + const uint8_t* inputBuffer = input; + ctx->size += len; + + // Copy each byte in input_buffer into the next space in our context input + unsigned i; + for (i = 0; i < len; ++i) { + ctx->input[offset] = inputBuffer[i]; + + // If we've filled our context input, copy it into our local array input + // then reset the offset to 0 and fill in a new buffer. + // Every time we fill out a chunk, we run it through the algorithm + // to enable some back and forth between cpu and i/o + if (offset < 0x3F) { + ++offset; + continue; + } + + unsigned j; + for (j = 0; j < 16; ++j) { + // Convert to little-endian + // The local variable `input` our 512-bit chunk separated into 32-bit words + // we can use in calculations + LOAD_32LE(buffer[j], j * 4, ctx->input); + } + md5Step(ctx->buffer, buffer); + offset = 0; + } +} + +/* + * Pad the current input to get to 448 bits, append the size in bits to the very end, + * and save the result of the final iteration into digest. + */ +void md5Finalize(struct MD5Context* ctx) { + uint32_t input[16]; + int offset = ctx->size & 0x3F; + unsigned paddingLength = offset < 56 ? 56 - offset : (56 + 64) - offset; + + // Fill in the padding and undo the changes to size that resulted from the update + md5Update(ctx, PADDING, paddingLength); + ctx->size -= paddingLength; + + // Do a final update (internal to this function) + // Last two 32-bit words are the two halves of the size (converted from bytes to bits) + unsigned j; + for (j = 0; j < 14; ++j) { + LOAD_32LE(input[j], j * 4, ctx->input); + } + input[14] = (uint32_t) (ctx->size * 8); + input[15] = (uint32_t) ((ctx->size * 8ULL) >> 32); + + md5Step(ctx->buffer, input); + + // Move the result into digest (convert from little-endian) + unsigned i; + for (i = 0; i < 4; ++i) { + STORE_32LE(ctx->buffer[i], i * 4, ctx->digest); + } +} + +void md5Buffer(const void* input, size_t len, uint8_t* result) { + struct MD5Context ctx; + md5Init(&ctx); + md5Update(&ctx, input, len); + md5Finalize(&ctx); + memcpy(result, ctx.digest, sizeof(ctx.digest)); +} + +bool md5File(struct VFile* vf, uint8_t* result) { + struct MD5Context ctx; + uint8_t buffer[2048]; + md5Init(&ctx); + + ssize_t read; + ssize_t position = vf->seek(vf, 0, SEEK_CUR); + if (vf->seek(vf, 0, SEEK_SET) < 0) { + return false; + } + while ((read = vf->read(vf, buffer, sizeof(buffer))) > 0) { + md5Update(&ctx, buffer, read); + } + vf->seek(vf, position, SEEK_SET); + if (read < 0) { + return false; + } + md5Finalize(&ctx); + memcpy(result, ctx.digest, sizeof(ctx.digest)); + return true; +} diff --git a/src/util/test/hash.c b/src/util/test/hash.c new file mode 100644 index 00000000000..6d014435b73 --- /dev/null +++ b/src/util/test/hash.c @@ -0,0 +1,130 @@ +/* Copyright (c) 2013-2022 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#include "util/test/suite.h" + +#include +#include + +M_TEST_DEFINE(emptyCrc32) { + uint8_t buffer[1] = {0}; + assert_int_equal(doCrc32(buffer, 0), 0); +} + +M_TEST_DEFINE(newlineCrc32) { +uint8_t buffer[1] = { '\n' }; + assert_int_equal(doCrc32(buffer, 1), 0x32D70693); +} + +M_TEST_DEFINE(helloWorldCrc32) { + const char* buffer = "Hello, world!"; + assert_int_equal(doCrc32(buffer, strlen(buffer)), 0xEBE6C6E6); +} + +#ifndef HAVE_CRC32 +M_TEST_DEFINE(stagedCrc32) { + uint8_t buffer[1] = { '\n\n' }; + assert_int_equal(crc32(0, buffer, 1), 0x32D70693); + assert_int_equal(crc32(0, buffer, 2), 0x09304EBD); + assert_int_equal(crc32(0x32D70693, buffer, 1), 0x09304EBD); +} +#endif + +M_TEST_DEFINE(emptyMd5) { + uint8_t buffer[1] = {0}; + uint8_t digest[0x10] = {0}; + md5Buffer(buffer, 0, digest); + assert_memory_equal(digest, ((uint8_t[]) { + 0xD4, 0x1D, 0x8C, 0xD9, 0x8F, 0x00, 0xB2, 0x04, + 0xE9, 0x80, 0x09, 0x98, 0xEC, 0xF8, 0x42, 0x7E + }), 16); +} + +M_TEST_DEFINE(newlineMd5) { + uint8_t buffer[1] = { '\n' }; + uint8_t digest[0x10] = {0}; + md5Buffer(buffer, 1, digest); + assert_memory_equal(digest, ((uint8_t[]) { + 0x68, 0xB3, 0x29, 0xDA, 0x98, 0x93, 0xE3, 0x40, + 0x99, 0xC7, 0xD8, 0xAD, 0x5C, 0xB9, 0xC9, 0x40 + }), 16); +} + +M_TEST_DEFINE(fullBlockMd5) { + uint8_t buffer[56] = { + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + }; + uint8_t digest[0x10] = {0}; + md5Buffer(buffer, 56, digest); + assert_memory_equal(digest, ((uint8_t[]) { + 0xA3, 0x31, 0x42, 0x53, 0x78, 0x54, 0xFE, 0xE2, + 0xAF, 0xD6, 0xCF, 0xF4, 0xC5, 0xA1, 0xDD, 0x39 + }), 16); +} + +M_TEST_DEFINE(overflowBlockMd5) { + uint8_t buffer[57] = { + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x0a, + }; + uint8_t digest[0x10] = {0}; + md5Buffer(buffer, 57, digest); + assert_memory_equal(digest, ((uint8_t[]) { + 0xBA, 0x49, 0x77, 0x29, 0x15, 0x5B, 0x13, 0x5D, + 0xBA, 0x27, 0xF3, 0xD8, 0x53, 0xCF, 0xD2, 0x1A + }), 16); +} + +M_TEST_DEFINE(twoBlockMd5) { + uint8_t buffer[120] = { + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, + }; + uint8_t digest[0x10] = {0}; + md5Buffer(buffer, 120, digest); + assert_memory_equal(digest, ((uint8_t[]) { + 0xB5, 0x68, 0xA7, 0x7E, 0xD4, 0xC2, 0x39, 0xFB, + 0x4B, 0x74, 0xD7, 0x5B, 0xDB, 0xFD, 0x94, 0x93 + }), 16); +} + +M_TEST_SUITE_DEFINE(Hashes, + cmocka_unit_test(emptyCrc32), + cmocka_unit_test(newlineCrc32), + cmocka_unit_test(helloWorldCrc32), +#ifndef HAVE_CRC32 + cmocka_unit_test(stagedCrc32), +#endif + cmocka_unit_test(emptyMd5), + cmocka_unit_test(newlineMd5), + cmocka_unit_test(fullBlockMd5), + cmocka_unit_test(overflowBlockMd5), + cmocka_unit_test(twoBlockMd5), +) From 2ccfde0f33ff372f644d40aa4e8bf6d65fa677f8 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 8 Oct 2024 04:09:26 -0700 Subject: [PATCH 252/338] Core: Add MD5 hashing for ROMs --- CHANGES | 1 + include/mgba/core/core.h | 1 + src/gb/core.c | 10 ++ src/gba/core.c | 14 ++ src/platform/qt/ROMInfo.cpp | 6 + src/platform/qt/ROMInfo.ui | 304 ++++++++++++++++++++---------------- 6 files changed, 200 insertions(+), 136 deletions(-) diff --git a/CHANGES b/CHANGES index f0fe0a47413..9a538caee75 100644 --- a/CHANGES +++ b/CHANGES @@ -41,6 +41,7 @@ Other fixes: Misc: - Core: Handle relative paths for saves, screenshots, etc consistently (fixes mgba.io/i/2826) - Core: Improve rumble emulation by averaging state over entire frame (fixes mgba.io/i/3232) + - Core: Add MD5 hashing for ROMs - GB: Prevent incompatible BIOSes from being used on differing models - GB Serialize: Add missing savestate support for MBC6 and NT (newer) - GBA: Improve detection of valid ELF ROMs diff --git a/include/mgba/core/core.h b/include/mgba/core/core.h index e8c5df7bc8a..94dfb111446 100644 --- a/include/mgba/core/core.h +++ b/include/mgba/core/core.h @@ -30,6 +30,7 @@ enum mPlatform { enum mCoreChecksumType { mCHECKSUM_CRC32, + mCHECKSUM_MD5, }; struct mAudioBuffer; diff --git a/src/gb/core.c b/src/gb/core.c index e67fe423290..b97e1ee255a 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -21,6 +21,7 @@ #include #include #include +#include #include #include #include @@ -529,6 +530,15 @@ static void _GBCoreChecksum(const struct mCore* core, void* data, enum mCoreChec case mCHECKSUM_CRC32: memcpy(data, &gb->romCrc32, sizeof(gb->romCrc32)); break; + case mCHECKSUM_MD5: + if (gb->romVf) { + md5File(gb->romVf, data); + } else if (gb->memory.rom && gb->isPristine) { + md5Buffer(gb->memory.rom, gb->pristineRomSize, data); + } else { + md5Buffer("", 0, data); + } + break; } return; } diff --git a/src/gba/core.c b/src/gba/core.c index 67550bd7a5d..e81e66dac48 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -30,6 +30,7 @@ #ifdef USE_ELF #include #endif +#include #include #include #include @@ -676,6 +677,19 @@ static void _GBACoreChecksum(const struct mCore* core, void* data, enum mCoreChe case mCHECKSUM_CRC32: memcpy(data, &gba->romCrc32, sizeof(gba->romCrc32)); break; + case mCHECKSUM_MD5: + if (gba->romVf) { + md5File(gba->romVf, data); + } else if (gba->mbVf) { + md5File(gba->mbVf, data); + } else if (gba->memory.rom && gba->isPristine) { + md5Buffer(gba->memory.rom, gba->pristineRomSize, data); + } else if (gba->memory.rom) { + md5Buffer(gba->memory.rom, gba->memory.romSize, data); + } else { + md5Buffer("", 0, data); + } + break; } return; } diff --git a/src/platform/qt/ROMInfo.cpp b/src/platform/qt/ROMInfo.cpp index 9f25374398c..25aafeda816 100644 --- a/src/platform/qt/ROMInfo.cpp +++ b/src/platform/qt/ROMInfo.cpp @@ -24,6 +24,7 @@ ROMInfo::ROMInfo(std::shared_ptr controller, QWidget* parent) const NoIntroDB* db = GBAApp::app()->gameDB(); #endif uint32_t crc32 = 0; + uint8_t md5[16]{}; CoreController::Interrupter interrupter(controller); mCore* core = controller->thread()->core; @@ -39,6 +40,7 @@ ROMInfo::ROMInfo(std::shared_ptr controller, QWidget* parent) m_ui.version->setText(QString::number(info.version)); core->checksum(core, &crc32, mCHECKSUM_CRC32); + core->checksum(core, &md5, mCHECKSUM_MD5); m_ui.size->setText(QString::number(core->romSize(core)) + tr(" bytes")); @@ -63,6 +65,10 @@ ROMInfo::ROMInfo(std::shared_ptr controller, QWidget* parent) m_ui.name->setText(tr("(unknown)")); } + m_ui.md5->setText(QString::asprintf("%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x", + md5[0x0], md5[0x1], md5[0x2], md5[0x3], md5[0x4], md5[0x5], md5[0x6], md5[0x7], + md5[0x8], md5[0x9], md5[0xA], md5[0xB], md5[0xC], md5[0xD], md5[0xE], md5[0xF])); + QString savePath = controller->savePath(); if (!savePath.isEmpty()) { m_ui.savefile->setText(savePath); diff --git a/src/platform/qt/ROMInfo.ui b/src/platform/qt/ROMInfo.ui index 655d4810fc2..a4a179ca852 100644 --- a/src/platform/qt/ROMInfo.ui +++ b/src/platform/qt/ROMInfo.ui @@ -6,154 +6,186 @@ 0 0 - 178 - 198 + 180 + 298 ROM Info - + QLayout::SetFixedSize - - QFormLayout::FieldsStayAtSizeHint - - - - Game name: - - - - - - - {NAME} - - - true - - - Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse - + + + File information + + + + + + Game name: + + + + + + + {NAME} + + + true + + + Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse + + + + + + + File size: + + + + + + + {SIZE} + + + Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse + + + + + + + CRC32: + + + + + + + {CRC} + + + Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse + + + + + + + MD5 + + + + + + + {MD5} + + + Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse + + + + + + + Save file: + + + + + + + {SAVEFILE} + + + + - - - Internal name: - - - - - - - {TITLE} - - - Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse - - - - - - - Game ID: - - - - - - - {ID} - - - Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse - - - - - - - Maker Code: - - - - - - - {MAKER} - - - Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse - - - - - - - Revision: - - - - - - - {VERSION} - - - Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse - - - - - - - File size: - - - - - - - {SIZE} - - - Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse - - - - - - - CRC32: - - - - - - - {CRC} - - - Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse - - - - - - - Save file: - - - - - - - {SAVEFILE} - + + + ROM header + + + + + + Internal name: + + + + + + + {TITLE} + + + Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse + + + + + + + Game ID: + + + + + + + {ID} + + + Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse + + + + + + + Maker Code: + + + + + + + {MAKER} + + + Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse + + + + + + + Revision: + + + + + + + {VERSION} + + + Qt::LinksAccessibleByMouse|Qt::TextSelectableByKeyboard|Qt::TextSelectableByMouse + + + + From 7e474db93a62c148299616bb315e6c65afc8f00f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 8 Oct 2024 04:32:43 -0700 Subject: [PATCH 253/338] Qt: Fix some new SIO cleanup issues --- src/platform/qt/MultiplayerController.cpp | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/platform/qt/MultiplayerController.cpp b/src/platform/qt/MultiplayerController.cpp index 3b2146f7afe..e95498fade2 100644 --- a/src/platform/qt/MultiplayerController.cpp +++ b/src/platform/qt/MultiplayerController.cpp @@ -192,6 +192,9 @@ MultiplayerController::MultiplayerController() { MultiplayerController::~MultiplayerController() { mLockstepDeinit(&m_lockstep); + if (m_platform == mPLATFORM_GBA) { + GBASIOLockstepCoordinatorDeinit(&m_gbaCoordinator); + } } bool MultiplayerController::attachGame(CoreController* controller) { @@ -376,7 +379,7 @@ void MultiplayerController::detachGame(CoreController* controller) { if (p.attached) { GBASIOLockstepCoordinatorDetach(&m_gbaCoordinator, p.node.gba); } - delete p.node.gba->user; + delete reinterpret_cast(p.node.gba->user); delete p.node.gba; break; } @@ -417,6 +420,9 @@ void MultiplayerController::detachGame(CoreController* controller) { m_pids.remove(pid); if (m_pids.size() == 0) { + if (m_platform == mPLATFORM_GBA) { + GBASIOLockstepCoordinatorDeinit(&m_gbaCoordinator); + } m_platform = mPLATFORM_NONE; } else { fixOrder(); From eaf45b9ab8d2a5902a80fbea5a9210fcda08a7a9 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 8 Oct 2024 04:34:30 -0700 Subject: [PATCH 254/338] GB, GBA: Clean up some corner cases with ROM fd closing --- src/gb/gb.c | 4 +--- src/gb/memory.c | 2 -- src/gba/core.c | 3 +++ src/gba/gba.c | 6 ++---- src/gba/memory.c | 2 -- 5 files changed, 6 insertions(+), 11 deletions(-) diff --git a/src/gb/gb.c b/src/gb/gb.c index fa0d6482f3b..875cbf86ebf 100644 --- a/src/gb/gb.c +++ b/src/gb/gb.c @@ -483,12 +483,10 @@ void GBApplyPatch(struct GB* gb, struct Patch* patch) { mappedMemoryFree(newRom, GB_SIZE_CART_MAX); return; } - if (gb->romVf) { + if (gb->romVf && gb->isPristine) { #ifndef FIXED_ROM_BUFFER gb->romVf->unmap(gb->romVf, gb->memory.rom, gb->pristineRomSize); #endif - gb->romVf->close(gb->romVf); - gb->romVf = NULL; } gb->isPristine = false; if (gb->memory.romBase == gb->memory.rom) { diff --git a/src/gb/memory.c b/src/gb/memory.c index e4105078410..dccd91e08aa 100644 --- a/src/gb/memory.c +++ b/src/gb/memory.c @@ -1017,8 +1017,6 @@ void _pristineCow(struct GB* gb) { } if (gb->romVf) { gb->romVf->unmap(gb->romVf, gb->memory.rom, gb->memory.romSize); - gb->romVf->close(gb->romVf); - gb->romVf = NULL; } gb->memory.rom = newRom; GBMBCSwitchBank(gb, gb->memory.currentBank); diff --git a/src/gba/core.c b/src/gba/core.c index e81e66dac48..1d3fffb9ef0 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -668,6 +668,9 @@ static size_t _GBACoreROMSize(const struct mCore* core) { if (gba->romVf) { return gba->romVf->size(gba->romVf); } + if (gba->mbVf) { + return gba->mbVf->size(gba->mbVf); + } return gba->pristineRomSize; } diff --git a/src/gba/gba.c b/src/gba/gba.c index 187d83373cf..6b833838e47 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -557,16 +557,14 @@ void GBAApplyPatch(struct GBA* gba, struct Patch* patch) { mappedMemoryFree(newRom, GBA_SIZE_ROM0); return; } - if (gba->romVf) { + if (gba->memory.rom) { #ifndef FIXED_ROM_BUFFER if (!gba->isPristine) { - mappedMemoryFree(gba->memory.rom, GBA_SIZE_ROM0); + mappedMemoryFree(gba->memory.rom, gba->memory.romSize); } else { gba->romVf->unmap(gba->romVf, gba->memory.rom, gba->pristineRomSize); } #endif - gba->romVf->close(gba->romVf); - gba->romVf = NULL; } gba->isPristine = false; gba->memory.rom = newRom; diff --git a/src/gba/memory.c b/src/gba/memory.c index 09d3e7a7425..3243fc5a104 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -1894,8 +1894,6 @@ void _pristineCow(struct GBA* gba) { } if (gba->romVf) { gba->romVf->unmap(gba->romVf, gba->memory.rom, gba->memory.romSize); - gba->romVf->close(gba->romVf); - gba->romVf = NULL; } gba->memory.rom = newRom; gba->memory.hw.gpioBase = &((uint16_t*) gba->memory.rom)[GPIO_REG_DATA >> 1]; From 4ef98c7ddfcec1348a21da6f4a23c5f022f0209b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 8 Oct 2024 04:39:53 -0700 Subject: [PATCH 255/338] Core: Fix patch autoloading leaking the file handle --- CHANGES | 1 + src/core/core.c | 19 ++++++++++++++++--- 2 files changed, 17 insertions(+), 3 deletions(-) diff --git a/CHANGES b/CHANGES index 9a538caee75..a3d67111cb7 100644 --- a/CHANGES +++ b/CHANGES @@ -24,6 +24,7 @@ Emulation fixes: - GBA Video: Improve emulation of window start/end conditions (fixes mgba.io/i/1945) Other fixes: - Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963) + - Core: Fix patch autoloading leaking the file handle - Debugger: Fix writing to specific segment in command-line debugger - GB: Fix uninitialized save data when loading undersized temporary saves - GB, GBA Core: Fix memory leak if reloading debug symbols diff --git a/src/core/core.c b/src/core/core.c index 789656ea4dc..ba7ef914c25 100644 --- a/src/core/core.c +++ b/src/core/core.c @@ -239,9 +239,22 @@ bool mCoreAutoloadPatch(struct mCore* core) { if (!core->dirs.patch) { return false; } - return core->loadPatch(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".ups", O_RDONLY)) || - core->loadPatch(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".ips", O_RDONLY)) || - core->loadPatch(core, mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".bps", O_RDONLY)); + struct VFile* vf = NULL; + if (!vf) { + vf = mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".bps", O_RDONLY); + } + if (!vf) { + vf = mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".ups", O_RDONLY); + } + if (!vf) { + vf = mDirectorySetOpenSuffix(&core->dirs, core->dirs.patch, ".ips", O_RDONLY); + } + if (!vf) { + return false; + } + bool result = core->loadPatch(core, vf); + vf->close(vf); + return result; } bool mCoreAutoloadCheats(struct mCore* core) { From 67c3c40989cd5d8e0c6de335ba56c02abc7829d8 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 9 Oct 2024 00:26:10 -0700 Subject: [PATCH 256/338] Util: Shut Coverity up about a false positive --- src/util/md5.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/util/md5.c b/src/util/md5.c index 08e06fb1d15..9eaa4903bc3 100644 --- a/src/util/md5.c +++ b/src/util/md5.c @@ -87,7 +87,7 @@ static void md5Step(uint32_t* buffer, const uint32_t* input) { switch (i / 16) { case 0: E = F(BB, CC, DD); - j = i; + j = i & 0xF; break; case 1: E = G(BB, CC, DD); From afff68cfc0731c441ececa83bf43c3d8bebe5c5a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 11 Oct 2024 21:52:48 -0700 Subject: [PATCH 257/338] Qt: Show a dummy shader settings tab if shaders aren't supported --- CHANGES | 1 + src/platform/qt/SettingsView.cpp | 36 +++++++++++++++++++------------- src/platform/qt/SettingsView.h | 4 ++-- src/platform/qt/Window.cpp | 8 ++++++- src/platform/qt/Window.h | 1 + 5 files changed, 33 insertions(+), 17 deletions(-) diff --git a/CHANGES b/CHANGES index a3d67111cb7..d6fd60848c6 100644 --- a/CHANGES +++ b/CHANGES @@ -58,6 +58,7 @@ Misc: - Qt: Pass logging context through to video proxy thread (fixes mgba.io/i/3095) - Qt: Show maker code and game version in ROM info - Qt: Make window corners square on Windows 11 (fixes mgba.io/i/3285) + - Qt: Show a dummy shader settings tab if shaders aren't supported - Res: Port NSO-gba-colors shader (closes mgba.io/i/2834) - Scripting: Add `callbacks:oneshot` for single-call callbacks - Switch: Add bilinear filtering option (closes mgba.io/i/3111) diff --git a/src/platform/qt/SettingsView.cpp b/src/platform/qt/SettingsView.cpp index 66c125466af..c86dcf06eef 100644 --- a/src/platform/qt/SettingsView.cpp +++ b/src/platform/qt/SettingsView.cpp @@ -397,29 +397,38 @@ SettingsView::SettingsView(ConfigController* controller, InputController* inputC shortcutView->setController(shortcutController); shortcutView->setInputController(inputController); addPage(tr("Shortcuts"), shortcutView, Page::SHORTCUTS); + +#if defined(BUILD_GLES2) || defined(USE_EPOXY) + m_dummyShader = new QLabel(tr("Shaders are not supported when the display driver is not OpenGL.\n\n" + "If it is set to OpenGL and you still see this, your graphics card or drivers may be too old.")); + m_dummyShader->setWordWrap(true); + m_dummyShader->setAlignment(Qt::AlignCenter); + addPage(tr("Shaders"), m_dummyShader, Page::SHADERS); +#endif } SettingsView::~SettingsView() { -#if defined(BUILD_GL) || defined(BUILD_GLES2) - setShaderSelector(nullptr); +#if defined(BUILD_GLES2) || defined(USE_EPOXY) + if (m_shader) { + m_shader->setParent(nullptr); + } #endif } void SettingsView::setShaderSelector(ShaderSelector* shaderSelector) { -#if defined(BUILD_GL) || defined(BUILD_GLES2) - if (m_shader) { - auto items = m_ui.tabs->findItems(tr("Shaders"), Qt::MatchFixedString); - for (const auto& item : items) { - m_ui.tabs->removeItemWidget(item); - } - m_ui.stackedWidget->removeWidget(m_shader); - m_shader->setParent(nullptr); +#if defined(BUILD_GLES2) || defined(USE_EPOXY) + auto items = m_ui.tabs->findItems(tr("Shaders"), Qt::MatchFixedString); + for (QListWidgetItem* item : items) { + delete item; + } + if (!m_shader) { + m_ui.stackedWidget->removeWidget(m_dummyShader); } m_shader = shaderSelector; if (shaderSelector) { - m_ui.stackedWidget->addWidget(m_shader); - m_ui.tabs->addItem(tr("Shaders")); - connect(m_ui.buttonBox, &QDialogButtonBox::accepted, m_shader, &ShaderSelector::saved); + addPage(tr("Shaders"), m_shader, Page::SHADERS); + } else { + addPage(tr("Shaders"), m_dummyShader, Page::SHADERS); } #endif } @@ -579,7 +588,6 @@ void SettingsView::updateConfig() { if (displayDriver != m_controller->getQtOption("displayDriver")) { m_controller->setQtOption("displayDriver", displayDriver); Display::setDriver(static_cast(displayDriver.toInt())); - setShaderSelector(nullptr); emit displayDriverChanged(); } diff --git a/src/platform/qt/SettingsView.h b/src/platform/qt/SettingsView.h index 010b4ef0d8d..85cf35a9981 100644 --- a/src/platform/qt/SettingsView.h +++ b/src/platform/qt/SettingsView.h @@ -51,8 +51,6 @@ Q_OBJECT SettingsView(ConfigController* controller, InputController* inputController, ShortcutController* shortcutController, LogController* logController, QWidget* parent = nullptr); ~SettingsView(); - void setShaderSelector(ShaderSelector* shaderSelector); - signals: void biosLoaded(int platform, const QString&); void audioDriverChanged(); @@ -66,6 +64,7 @@ Q_OBJECT public slots: void selectPage(Page); + void setShaderSelector(ShaderSelector* shaderSelector); private slots: void selectBios(QLineEdit*); @@ -81,6 +80,7 @@ private slots: ConfigController* m_controller; InputController* m_input; ShaderSelector* m_shader = nullptr; + QLabel* m_dummyShader; LogConfigModel m_logModel; QTimer m_checkTimer; diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index 77c7695fb19..ddf34f4f921 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -550,6 +550,7 @@ void Window::openSettingsWindow(SettingsView::Page page) { #ifdef USE_SQLITE3 connect(settingsWindow, &SettingsView::libraryCleared, m_libraryView, &LibraryController::clear); #endif + connect(this, &Window::shaderSelectorAdded, settingsWindow, &SettingsView::setShaderSelector); openView(settingsWindow); settingsWindow->selectPage(page); } @@ -1050,7 +1051,12 @@ void Window::reloadDisplayDriver() { } #if defined(BUILD_GL) || defined(BUILD_GLES2) m_shaderView.reset(); - m_shaderView = std::make_unique(m_display.get(), m_config); + if (m_display->supportsShaders()) { + m_shaderView = std::make_unique(m_display.get(), m_config); + emit shaderSelectorAdded(m_shaderView.get()); + } else { + emit shaderSelectorAdded(nullptr); + } #endif connect(m_display.get(), &QGBA::Display::hideCursor, [this]() { diff --git a/src/platform/qt/Window.h b/src/platform/qt/Window.h index f91e3ff308b..cb467f89d77 100644 --- a/src/platform/qt/Window.h +++ b/src/platform/qt/Window.h @@ -73,6 +73,7 @@ Q_OBJECT void startDrawing(); void shutdown(); void paused(bool); + void shaderSelectorAdded(ShaderSelector*); public slots: void setController(CoreController* controller, const QString& fname); From 4a5a25e90c5ab0909a283df8a9cb10d9807f6e7a Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 18 Oct 2024 02:58:19 -0700 Subject: [PATCH 258/338] GBA DMA: Cache cycle estimation on first DMA --- include/mgba/internal/gba/dma.h | 2 ++ src/gba/audio.c | 1 + src/gba/dma.c | 35 ++++++++++++++++++++++++++++----- src/gba/io.c | 1 + src/gba/memory.c | 4 ++++ 5 files changed, 38 insertions(+), 5 deletions(-) diff --git a/include/mgba/internal/gba/dma.h b/include/mgba/internal/gba/dma.h index 192b3995a7a..58d59094848 100644 --- a/include/mgba/internal/gba/dma.h +++ b/include/mgba/internal/gba/dma.h @@ -48,6 +48,7 @@ struct GBADMA { uint32_t nextDest; int32_t nextCount; uint32_t when; + int32_t cycles; }; struct GBA; @@ -65,6 +66,7 @@ void GBADMARunHblank(struct GBA* gba, int32_t cycles); void GBADMARunVblank(struct GBA* gba, int32_t cycles); void GBADMARunDisplayStart(struct GBA* gba, int32_t cycles); void GBADMAUpdate(struct GBA* gba); +void GBADMARecalculateCycles(struct GBA* gba); CXX_GUARD_END diff --git a/src/gba/audio.c b/src/gba/audio.c index a6ebafbae6b..ac394e99532 100644 --- a/src/gba/audio.c +++ b/src/gba/audio.c @@ -309,6 +309,7 @@ void GBAAudioSampleFIFO(struct GBAAudio* audio, int fifoId, int32_t cycles) { if (GBADMARegisterGetTiming(dma->reg) == GBA_DMA_TIMING_CUSTOM) { dma->when = mTimingCurrentTime(&audio->p->timing) - cycles; dma->nextCount = 4; + GBADMARecalculateCycles(audio->p); GBADMASchedule(audio->p, channel->dmaSource, dma); } } diff --git a/src/gba/dma.c b/src/gba/dma.c index 29034136147..5971b1b03a4 100644 --- a/src/gba/dma.c +++ b/src/gba/dma.c @@ -256,15 +256,21 @@ void GBADMAService(struct GBA* gba, int number, struct GBADMA* info) { if (info->count == info->nextCount) { if (width == 4) { cycles += memory->waitstatesNonseq32[sourceRegion] + memory->waitstatesNonseq32[destRegion]; + info->cycles = memory->waitstatesSeq32[sourceRegion] + memory->waitstatesSeq32[destRegion]; } else { cycles += memory->waitstatesNonseq16[sourceRegion] + memory->waitstatesNonseq16[destRegion]; + info->cycles = memory->waitstatesSeq16[sourceRegion] + memory->waitstatesSeq16[destRegion]; } } else { - if (width == 4) { - cycles += memory->waitstatesSeq32[sourceRegion] + memory->waitstatesSeq32[destRegion]; - } else { - cycles += memory->waitstatesSeq16[sourceRegion] + memory->waitstatesSeq16[destRegion]; + // Crossed region boundary; recalculate cached cycles + if (UNLIKELY(!(source & 0x00FFFFFC) || !(dest & 0x00FFFFFC))) { + if (width == 4) { + info->cycles = memory->waitstatesSeq32[sourceRegion] + memory->waitstatesSeq32[destRegion]; + } else { + info->cycles = memory->waitstatesSeq16[sourceRegion] + memory->waitstatesSeq16[destRegion]; + } } + cycles += info->cycles; } info->when += cycles; @@ -281,7 +287,7 @@ void GBADMAService(struct GBA* gba, int number, struct GBADMA* info) { memory->dmaTransferRegister = cpu->memory.load16(cpu, source, 0); memory->dmaTransferRegister |= memory->dmaTransferRegister << 16; } - if (destRegion == GBA_REGION_ROM2_EX) { + if (UNLIKELY(destRegion == GBA_REGION_ROM2_EX)) { if (memory->savedata.type == GBA_SAVEDATA_AUTODETECT) { mLOG(GBA_MEM, INFO, "Detected EEPROM savegame"); GBASavedataInitEEPROM(&memory->savedata); @@ -327,3 +333,22 @@ void GBADMAService(struct GBA* gba, int number, struct GBADMA* info) { } GBADMAUpdate(gba); } + +void GBADMARecalculateCycles(struct GBA* gba) { + int i; + for (i = 0; i < 4; ++i) { + struct GBADMA* dma = &gba->memory.dma[i]; + if (!GBADMARegisterIsEnable(dma->reg)) { + continue; + } + + uint32_t width = GBADMARegisterGetWidth(dma->reg); + uint32_t sourceRegion = dma->nextSource >> BASE_OFFSET; + uint32_t destRegion = dma->nextDest >> BASE_OFFSET; + if (width) { + dma->cycles = gba->memory.waitstatesSeq32[sourceRegion] + gba->memory.waitstatesSeq32[destRegion]; + } else { + dma->cycles = gba->memory.waitstatesSeq16[sourceRegion] + gba->memory.waitstatesSeq16[destRegion]; + } + } +} diff --git a/src/gba/io.c b/src/gba/io.c index 8a4ea7fc2a8..cb6058f7f6b 100644 --- a/src/gba/io.c +++ b/src/gba/io.c @@ -1079,6 +1079,7 @@ void GBAIODeserialize(struct GBA* gba, const struct GBASerializedState* state) { LOAD_32(gba->dmaPC, 0, &state->dmaBlockPC); LOAD_32(gba->bus, 0, &state->bus); + GBADMARecalculateCycles(gba); GBADMAUpdate(gba); GBAHardwareDeserialize(&gba->memory.hw, state); } diff --git a/src/gba/memory.c b/src/gba/memory.c index 3243fc5a104..c818c75c8fc 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -1734,6 +1734,10 @@ void GBAAdjustWaitstates(struct GBA* gba, uint16_t parameters) { STORE_32(memory->agbPrintFuncBackup, AGB_PRINT_FLUSH_ADDR | base, memory->rom); } } + + if (gba->performingDMA) { + GBADMARecalculateCycles(gba); + } } void GBAAdjustEWRAMWaitstates(struct GBA* gba, uint16_t parameters) { From 1c739e39e71dcbdd776bf0abf0b64761219e755e Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 18 Oct 2024 05:08:14 -0700 Subject: [PATCH 259/338] GBA DMA: Minor branch optimization --- src/gba/dma.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/gba/dma.c b/src/gba/dma.c index 5971b1b03a4..e9044d26a3b 100644 --- a/src/gba/dma.c +++ b/src/gba/dma.c @@ -319,9 +319,11 @@ void GBADMAService(struct GBA* gba, int number, struct GBADMA* info) { int i; for (i = 0; i < 4; ++i) { struct GBADMA* dma = &memory->dma[i]; - int32_t time = dma->when - info->when; - if (time < 0 && GBADMARegisterIsEnable(dma->reg) && dma->nextCount) { - dma->when = info->when; + if (GBADMARegisterIsEnable(dma->reg) && dma->nextCount) { + int32_t time = dma->when - info->when; + if (time < 0) { + dma->when = info->when; + } } } From 279485fc3ed54b0dafbbff448e901be47b25ef2f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 20 Oct 2024 18:04:30 -0700 Subject: [PATCH 260/338] Qt: Fix saving named states breaking when screenshot states disabled (fixes #3320) --- CHANGES | 1 + src/platform/qt/CoreController.cpp | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGES b/CHANGES index d6fd60848c6..e432bee6768 100644 --- a/CHANGES +++ b/CHANGES @@ -38,6 +38,7 @@ Other fixes: - Qt: Fix potential crash when configuring shortcuts - Qt: Fix crash when applying changes to GB I/O registers in I/O view - Qt: Fix LCDC background priority/enable bit being mis-mapped in I/O view + - Qt: Fix saving named states breaking when screenshot states disabled (fixes mgba.io/i/3320) - Updater: Fix updating appimage across filesystems Misc: - Core: Handle relative paths for saves, screenshots, etc consistently (fixes mgba.io/i/2826) diff --git a/src/platform/qt/CoreController.cpp b/src/platform/qt/CoreController.cpp index 807a866851b..2496f80393e 100644 --- a/src/platform/qt/CoreController.cpp +++ b/src/platform/qt/CoreController.cpp @@ -736,7 +736,7 @@ void CoreController::saveState(const QString& path, int flags) { vf->read(vf, controller->m_backupSaveState.data(), controller->m_backupSaveState.size()); vf->close(vf); } - vf = VFileDevice::open(controller->m_statePath, O_WRONLY | O_CREAT | O_TRUNC); + vf = VFileDevice::open(controller->m_statePath, O_RDWR | O_CREAT | O_TRUNC); if (!vf) { return; } From 65b14b4ad984b41dff2e5c9604da3a565dea867e Mon Sep 17 00:00:00 2001 From: oltolm Date: Fri, 25 Oct 2024 19:07:04 +0200 Subject: [PATCH 261/338] fix assignment of modifier keys --- src/platform/qt/KeyEditor.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/platform/qt/KeyEditor.cpp b/src/platform/qt/KeyEditor.cpp index 818b6c703d4..9ad981ce705 100644 --- a/src/platform/qt/KeyEditor.cpp +++ b/src/platform/qt/KeyEditor.cpp @@ -110,7 +110,7 @@ void KeyEditor::keyPressEvent(QKeyEvent* event) { m_key = Qt::Key_unknown; } m_lastKey.start(KEY_TIME); - setValue(ShortcutController::isModifierKey(event->key()) ? event->modifiers() : event->key() | event->modifiers()); + setValue(ShortcutController::isModifierKey(event->key()) ? event->key() : event->key() | event->modifiers()); } event->accept(); } From 47e5cd2432218d27cf778ee4e57c55c387774aab Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 29 Oct 2024 22:40:23 -0700 Subject: [PATCH 262/338] Qt: Fix "QFSFileEngine::open: No file name specified" warning --- src/platform/qt/Window.cpp | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index ddf34f4f921..8dca0207845 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -1086,7 +1086,12 @@ void Window::reloadDisplayDriver() { m_display->setMinimumSize(GBA_VIDEO_HORIZONTAL_PIXELS, GBA_VIDEO_VERTICAL_PIXELS); #endif - m_display->setBackgroundImage(QImage{m_config->getOption("backgroundImage")}); + QString backgroundImage = m_config->getOption("backgroundImage"); + if (backgroundImage.isEmpty()) { + m_display->setBackgroundImage(QImage{}); + } else { + m_display->setBackgroundImage(QImage{backgroundImage}); + } if (!proxy) { proxy = std::make_shared(); @@ -1978,7 +1983,12 @@ void Window::setupOptions() { ConfigOption* backgroundImage = m_config->addOption("backgroundImage"); backgroundImage->connect([this](const QVariant& value) { if (m_display) { - m_display->setBackgroundImage(QImage{value.toString()}); + QString backgroundImage = value.toString(); + if (backgroundImage.isEmpty()) { + m_display->setBackgroundImage(QImage{}); + } else { + m_display->setBackgroundImage(QImage{backgroundImage}); + } } }, this); m_config->updateOption("backgroundImage"); From 377ddf50810a5cd1889e0cdfd86298c577b8a956 Mon Sep 17 00:00:00 2001 From: Jan200101 Date: Wed, 30 Oct 2024 23:48:25 +0100 Subject: [PATCH 263/338] Qt: Recreate Window to release old surface and create a OpenGL one --- src/platform/qt/DisplayGL.cpp | 1 + 1 file changed, 1 insertion(+) diff --git a/src/platform/qt/DisplayGL.cpp b/src/platform/qt/DisplayGL.cpp index ad496994358..e62e9685eaa 100644 --- a/src/platform/qt/DisplayGL.cpp +++ b/src/platform/qt/DisplayGL.cpp @@ -192,6 +192,7 @@ DisplayGL::DisplayGL(const QSurfaceFormat& format, QWidget* parent) setAttribute(Qt::WA_NativeWindow); window()->windowHandle()->setFormat(format); windowHandle()->setSurfaceType(QSurface::OpenGLSurface); + windowHandle()->destroy(); windowHandle()->create(); #ifdef USE_SHARE_WIDGET From 26ea53b024717fb74a6023ac7a59d04a196b24ca Mon Sep 17 00:00:00 2001 From: oltolm Date: Wed, 30 Oct 2024 17:54:32 +0100 Subject: [PATCH 264/338] fix numpad shortcuts --- src/platform/qt/KeyEditor.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/platform/qt/KeyEditor.cpp b/src/platform/qt/KeyEditor.cpp index 9ad981ce705..6ce94fc5523 100644 --- a/src/platform/qt/KeyEditor.cpp +++ b/src/platform/qt/KeyEditor.cpp @@ -110,7 +110,9 @@ void KeyEditor::keyPressEvent(QKeyEvent* event) { m_key = Qt::Key_unknown; } m_lastKey.start(KEY_TIME); - setValue(ShortcutController::isModifierKey(event->key()) ? event->key() : event->key() | event->modifiers()); + setValue(ShortcutController::isModifierKey(event->key()) ? + event->key() : + event->key() | (event->modifiers() & ~Qt::KeypadModifier)); } event->accept(); } From ef5646bbe3aaba0ac72f0ecce319684500852c52 Mon Sep 17 00:00:00 2001 From: Bo He Date: Tue, 15 Oct 2024 23:43:14 +0800 Subject: [PATCH 265/338] associate windows with the owning application --- res/mgba-qt.desktop | 1 + 1 file changed, 1 insertion(+) diff --git a/res/mgba-qt.desktop b/res/mgba-qt.desktop index d5d98ab3751..2dc96901c82 100644 --- a/res/mgba-qt.desktop +++ b/res/mgba-qt.desktop @@ -10,3 +10,4 @@ Comment=Nintendo Game Boy Advance Emulator Categories=Game;Emulator; MimeType=application/x-gameboy-advance-rom;application/x-agb-rom;application/x-gba-rom; Keywords=emulator;Nintendo;advance;gba;Game Boy Advance; +StartupWMClass=mGBA From a114207828b15be742608a1b5160b16e39f150d4 Mon Sep 17 00:00:00 2001 From: yeah-its-gloria <32610623+yeah-its-gloria@users.noreply.github.com> Date: Mon, 4 Nov 2024 01:19:05 +0100 Subject: [PATCH 266/338] Fix various macOS related problems - Disable a duplicate libraries warning that isn't needed - Quit using QApplication::quit instead of QWidget::close to prevent closing inside a dialog from crashing the application - Allow Qt 6 builds to use std::filesystem if the proper macOS SDK version is present - Stop looking for QtMultimedia plugins if Qt 6 is being used for macOS builds --- CMakeLists.txt | 6 ++++++ src/platform/qt/CMakeLists.txt | 21 ++++++++++++++++----- src/platform/qt/Window.cpp | 2 +- 3 files changed, 23 insertions(+), 6 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 78fddfce4ac..7857e9c388e 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -242,6 +242,12 @@ if(APPLE) execute_process(COMMAND xcrun --show-sdk-version OUTPUT_VARIABLE MACOSX_SDK) add_definitions(-D_DARWIN_C_SOURCE) list(APPEND OS_LIB "-framework Foundation") + + # Xcode 15 introduced a warning about duplicate libraries that CMake doesn't disable itself, we do it here globally + if(MACOSX_SDK VERSION_GREATER_EQUAL 10.15) + add_link_options(LINKER:-no_warn_duplicate_libraries) + endif() + if(NOT CMAKE_SYSTEM_VERSION VERSION_LESS "10.0") # Darwin 10.x is Mac OS X 10.6 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mmacosx-version-min=10.6") endif() diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index 51aa22401f3..3cfe83ad0e6 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -59,7 +59,10 @@ if(APPLE) list(APPEND QT_DEFINES USE_SHARE_WIDGET) endif() - if(Qt6Widgets_VERSION) + # Allows building with Qt that was built with std::filesystem support, which requires macOS 15 + if(Qt6Widgets_VERSION AND MACOSX_SDK VERSION_GREATER_EQUAL 10.15) + set(MIN_VER 10.15) + elseif(Qt6Widgets_VERSION) set(MIN_VER 10.14) elseif(Qt5Widgets_VERSION MATCHES "^5.15") set(MIN_VER 10.13) @@ -478,13 +481,21 @@ endif() if(APPLE) if(CMAKE_HOST_SYSTEM_NAME STREQUAL "Darwin") get_target_property(QTCOCOA ${QT}::QCocoaIntegrationPlugin LOCATION) - get_target_property(COREAUDIO ${QT}::CoreAudioPlugin LOCATION) - get_target_property(QTAVFSERVICE ${QT}::AVFServicePlugin LOCATION) + if(${QT_V} LESS 6) + # QtMultimedia plugins were removed with Qt 6, skip checking for them + get_target_property(COREAUDIO ${QT}::CoreAudioPlugin LOCATION) + get_target_property(QTAVFSERVICE ${QT}::AVFServicePlugin LOCATION) + endif() + set(BUNDLE_PATH ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.app) target_sources(${BINARY_NAME}-qt PRIVATE "${PLUGINS}") + set_source_files_properties("${QTCOCOA}" PROPERTIES MACOSX_PACKAGE_LOCATION Contents/PlugIns) - set_source_files_properties("${COREAUDIO}" PROPERTIES MACOSX_PACKAGE_LOCATION Contents/PlugIns) - set_source_files_properties("${QTAVFSERVICE}" PROPERTIES MACOSX_PACKAGE_LOCATION Contents/PlugIns) + if(${QT_V} LESS 6) + set_source_files_properties("${COREAUDIO}" PROPERTIES MACOSX_PACKAGE_LOCATION Contents/PlugIns) + set_source_files_properties("${QTAVFSERVICE}" PROPERTIES MACOSX_PACKAGE_LOCATION Contents/PlugIns) + endif() + install(CODE " include(BundleUtilities) set(BU_CHMOD_BUNDLE_ITEMS ON) diff --git a/src/platform/qt/Window.cpp b/src/platform/qt/Window.cpp index 8dca0207845..bc956fcc4c3 100644 --- a/src/platform/qt/Window.cpp +++ b/src/platform/qt/Window.cpp @@ -1422,7 +1422,7 @@ void Window::setupMenu(QMenuBar* menubar) { #endif m_actions.addAction(tr("About..."), "about", openTView(), "file")->setRole(Action::Role::ABOUT); - m_actions.addAction(tr("E&xit"), "quit", static_cast(this), &QWidget::close, "file", QKeySequence::Quit)->setRole(Action::Role::QUIT); + m_actions.addAction(tr("E&xit"), "quit", &QApplication::quit, "file", QKeySequence::Quit)->setRole(Action::Role::QUIT); m_actions.addMenu(tr("&Emulation"), "emu"); addGameAction(tr("&Reset"), "reset", &CoreController::reset, "emu", QKeySequence("Ctrl+R")); From b27296896904929607da93fb01e9831aa8ee36ff Mon Sep 17 00:00:00 2001 From: Adam Higerd Date: Fri, 11 Oct 2024 19:50:05 -0500 Subject: [PATCH 267/338] Qt: handle newlines in TextBuffer print() --- .../qt/scripting/ScriptingTextBuffer.cpp | 33 +++++++++---------- 1 file changed, 16 insertions(+), 17 deletions(-) diff --git a/src/platform/qt/scripting/ScriptingTextBuffer.cpp b/src/platform/qt/scripting/ScriptingTextBuffer.cpp index 9a5de818d92..da05bd2b990 100644 --- a/src/platform/qt/scripting/ScriptingTextBuffer.cpp +++ b/src/platform/qt/scripting/ScriptingTextBuffer.cpp @@ -51,26 +51,25 @@ void ScriptingTextBuffer::setBufferName(const QString& name) { void ScriptingTextBuffer::print(const QString& text) { QMutexLocker locker(&m_mutex); - QString split(text); - m_shim.cursor.beginEditBlock(); - while (m_shim.cursor.positionInBlock() + split.length() > m_dims.width()) { - int cut = m_dims.width() - m_shim.cursor.positionInBlock(); - if (!m_shim.cursor.atBlockEnd()) { - m_shim.cursor.movePosition(QTextCursor::EndOfBlock, QTextCursor::KeepAnchor); + for (QString split : text.split('\n')) { + while (m_shim.cursor.positionInBlock() + split.length() > m_dims.width()) { + int cut = m_dims.width() - m_shim.cursor.positionInBlock(); + if (!m_shim.cursor.atBlockEnd()) { + m_shim.cursor.movePosition(QTextCursor::EndOfBlock, QTextCursor::KeepAnchor); + } + m_shim.cursor.insertText(split.left(cut)); + if (m_shim.cursor.atEnd()) { + m_shim.cursor.insertBlock(); + } else { + m_shim.cursor.movePosition(QTextCursor::NextBlock, QTextCursor::MoveAnchor, 1); + } + split = split.mid(cut); } - m_shim.cursor.insertText(split.left(cut)); - if (m_shim.cursor.atEnd()) { - m_shim.cursor.insertBlock(); - } else { - m_shim.cursor.movePosition(QTextCursor::NextBlock, QTextCursor::MoveAnchor, 1); + if (!m_shim.cursor.atBlockEnd()) { + m_shim.cursor.movePosition(QTextCursor::NextCharacter, QTextCursor::KeepAnchor, split.length()); } - split = split.mid(cut); - } - if (!m_shim.cursor.atBlockEnd()) { - m_shim.cursor.movePosition(QTextCursor::NextCharacter, QTextCursor::KeepAnchor, split.length()); + m_shim.cursor.insertText(split); } - m_shim.cursor.insertText(split); - m_shim.cursor.endEditBlock(); } void ScriptingTextBuffer::clear() { From 17b03b6f208f5fc8481d5fd693f185a24affcc50 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 3 Nov 2024 18:00:36 -0800 Subject: [PATCH 268/338] GBA Video: Fix potential shader compilation error --- src/gba/renderers/gl.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gba/renderers/gl.c b/src/gba/renderers/gl.c index 24fb092c7dd..dbff67e4ed4 100644 --- a/src/gba/renderers/gl.c +++ b/src/gba/renderers/gl.c @@ -539,7 +539,7 @@ static const char* const _renderWindow = "}\n" "bool test(vec3 circle, vec4 top, vec4 bottom) {\n" - " if (circle.z > 0) {\n" + " if (circle.z > 0.) {\n" " return distance(circle.xy, texCoord.xy) <= circle.z;\n" " }\n" " return crop(interpolate(top, bottom));\n" From 77e747ebf6e2becd669312667999e39e79036ceb Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 3 Nov 2024 19:23:57 -0800 Subject: [PATCH 269/338] mGUI: Fix control remapping not reloading (fixes #3277) --- src/feature/gui/gui-runner.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/feature/gui/gui-runner.c b/src/feature/gui/gui-runner.c index 035522f0232..76e15cdad02 100644 --- a/src/feature/gui/gui-runner.c +++ b/src/feature/gui/gui-runner.c @@ -782,6 +782,9 @@ void mGUILoadInputMaps(struct mGUIRunner* runner) { size_t i; for (i = 0; runner->keySources[i].id; ++i) { mInputMapLoad(&runner->params.keyMap, runner->keySources[i].id, mCoreConfigGetInput(&runner->config)); + if (runner->core) { + mInputMapLoad(&runner->core->inputMap, runner->keySources[i].id, mCoreConfigGetInput(&runner->config)); + } } } From f89184d51fa4fb38c8d82a17de5d6525e6aa915e Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 31 Oct 2024 22:47:51 -0700 Subject: [PATCH 270/338] GBA BIOS: Fix locked BIOS read on boot --- src/gba/hle-bios.c | 4 ++-- src/gba/hle-bios.s | 5 +++-- src/gba/video.c | 2 +- 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/src/gba/hle-bios.c b/src/gba/hle-bios.c index 841caf5430a..8f689fa7a7e 100644 --- a/src/gba/hle-bios.c +++ b/src/gba/hle-bios.c @@ -75,9 +75,9 @@ const uint8_t hleBios[GBA_SIZE_BIOS] = { 0xf0, 0x07, 0xbd, 0xe8, 0x1e, 0xff, 0x2f, 0xe1, 0xb0, 0x01, 0x00, 0x00, 0x04, 0xb0, 0x5b, 0xe2, 0xfd, 0xff, 0xff, 0x8a, 0x1e, 0xff, 0x2f, 0xe1, 0xc2, 0xe3, 0xa0, 0xe3, 0x03, 0x10, 0x5e, 0xe4, 0x00, 0x00, 0x51, 0xe3, - 0x00, 0x10, 0xa0, 0x13, 0x1e, 0xff, 0x2f, 0x11, 0x1c, 0xe0, 0x9f, 0xe5, + 0x00, 0x10, 0xa0, 0x13, 0x05, 0x00, 0x00, 0x1a, 0x1c, 0xe0, 0x9f, 0xe5, 0x00, 0x10, 0x9e, 0xe5, 0x00, 0x00, 0x51, 0xe3, 0x00, 0x10, 0xa0, 0xe3, - 0x1e, 0xff, 0x2f, 0x11, 0xc0, 0xe0, 0x4e, 0xe2, 0x1e, 0xff, 0x2f, 0xe1, + 0x00, 0x00, 0x00, 0x1a, 0xc0, 0xe0, 0x4e, 0xe2, 0x1e, 0xff, 0x2f, 0xe1, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf0, 0x29, 0xe1, 0xc0, 0x00, 0x00, 0x02, 0x4c, 0xd0, 0x9f, 0xe5, 0x00, 0x50, 0x2d, 0xe9, 0x00, 0xc0, 0x4f, 0xe1, 0x00, 0xe0, 0x0f, 0xe1, 0x00, 0x50, 0x2d, 0xe9, 0x02, 0xe3, 0xa0, 0xe3, diff --git a/src/gba/hle-bios.s b/src/gba/hle-bios.s index 07f827b26bb..aa77160c17d 100644 --- a/src/gba/hle-bios.s +++ b/src/gba/hle-bios.s @@ -318,13 +318,14 @@ mov lr, #0x8000003 ldrb r1, [lr], #-3 cmp r1, #0 movne r1, #0 -bxne lr +bne 1f ldr lr, =0x20000C0 ldr r1, [lr] cmp r1, #0 mov r1, #0 -bxne lr +bne 1f sub lr, #0xC0 +1: bx lr .word 0 .word 0xE129F000 diff --git a/src/gba/video.c b/src/gba/video.c index 63e7115c159..749a29be081 100644 --- a/src/gba/video.c +++ b/src/gba/video.c @@ -70,7 +70,7 @@ void GBAVideoReset(struct GBAVideo* video) { } else { // TODO: Verify exact scanline on hardware video->vcount = 0x7E; - nextEvent = 117; + nextEvent = 120; } video->p->memory.io[GBA_REG(VCOUNT)] = video->vcount; From 645d1cf34405a44a8677ecaaaa54a5268c9d1d11 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 1 Nov 2024 02:06:04 -0700 Subject: [PATCH 271/338] GBA Savedata: Improve save write edge cases --- src/gba/memory.c | 12 ++---------- src/gba/savedata.c | 4 +++- 2 files changed, 5 insertions(+), 11 deletions(-) diff --git a/src/gba/memory.c b/src/gba/memory.c index c818c75c8fc..87e31f746ea 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -802,14 +802,7 @@ uint32_t GBALoad8(struct ARMCore* cpu, uint32_t address, int* cycleCounter) { mLOG(GBA_MEM, STUB, "Unimplemented memory Store32: 0x%08X", address); #define STORE_SRAM \ - if (address & 0x3) { \ - mLOG(GBA_MEM, GAME_ERROR, "Unaligned SRAM Store32: 0x%08X", address); \ - } else { \ - GBAStore8(cpu, address, value, cycleCounter); \ - GBAStore8(cpu, address | 1, value, cycleCounter); \ - GBAStore8(cpu, address | 2, value, cycleCounter); \ - GBAStore8(cpu, address | 3, value, cycleCounter); \ - } + GBAStore8(cpu, address, value >> (8 * (address & 3)), cycleCounter); #define STORE_BAD \ mLOG(GBA_MEM, GAME_ERROR, "Bad memory Store32: 0x%08X", address); @@ -989,10 +982,9 @@ void GBAStore16(struct ARMCore* cpu, uint32_t address, int16_t value, int* cycle case GBA_REGION_SRAM_MIRROR: if (address & 1) { mLOG(GBA_MEM, GAME_ERROR, "Unaligned SRAM Store16: 0x%08X", address); - break; + value >>= 8; } GBAStore8(cpu, address, value, cycleCounter); - GBAStore8(cpu, address | 1, value, cycleCounter); break; default: mLOG(GBA_MEM, GAME_ERROR, "Bad memory Store16: 0x%08X", address); diff --git a/src/gba/savedata.c b/src/gba/savedata.c index 11be3e0abfa..ca5d35cbba7 100644 --- a/src/gba/savedata.c +++ b/src/gba/savedata.c @@ -376,7 +376,9 @@ uint8_t GBASavedataReadFlash(struct GBASavedata* savedata, uint16_t address) { } } if (mTimingIsScheduled(savedata->timing, &savedata->dust) && (address >> 12) == savedata->settling) { - return 0x5F; + // This should read /Q7 ("data# polling") and Q6 flipping ("toggle bit") every read, + // but just data# polling is sufficient for games to figure it out + return savedata->currentBank[address] ^ 0x80; } return savedata->currentBank[address]; } From 4d6fb5b3c503d65b170a466e3402f4a88730d8f1 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 8 Nov 2024 00:50:19 -0800 Subject: [PATCH 272/338] Scripting: Combine frame argument and return value stacks These were never used a the same time, and it reduces malloc/free churn --- include/mgba/script/macros.h | 24 ++-- include/mgba/script/types.h | 3 +- src/core/scripting.c | 10 +- src/script/context.c | 4 +- src/script/engines/lua.c | 25 ++-- src/script/test/classes.c | 122 +++++++++---------- src/script/test/lua.c | 10 +- src/script/test/types.c | 230 +++++++++++++++++------------------ src/script/types.c | 30 +++-- src/tools/docgen.c | 6 +- 10 files changed, 234 insertions(+), 230 deletions(-) diff --git a/include/mgba/script/macros.h b/include/mgba/script/macros.h index 70eed0af58b..a1ef0d66917 100644 --- a/include/mgba/script/macros.h +++ b/include/mgba/script/macros.h @@ -76,10 +76,14 @@ CXX_GUARD_START #define _mSCRIPT_FIELD_NAME(V) (V)->type->name #define _mSCRIPT_WRAPPED_FIELD_NAME(V) (V)->value.wrapped->type->name -#define _mSCRIPT_CALL_VOID(FUNCTION, NPARAMS) FUNCTION(_mCAT(mSCRIPT_ARG_NAMES_, NPARAMS)) +#define _mSCRIPT_CALL_VOID(FUNCTION, NPARAMS) \ + FUNCTION(_mCAT(mSCRIPT_ARG_NAMES_, NPARAMS)); \ + mScriptListClear(&frame->stack) + #define _mSCRIPT_CALL(RETURN, FUNCTION, NPARAMS) \ mSCRIPT_TYPE_C_ ## RETURN out = FUNCTION(_mCAT(mSCRIPT_ARG_NAMES_, NPARAMS)); \ - mSCRIPT_PUSH(&frame->returnValues, RETURN, out) + mScriptListClear(&frame->stack); \ + mSCRIPT_PUSH(&frame->stack, RETURN, out) #define mSCRIPT_DECLARE_STRUCT(STRUCT) \ extern const struct mScriptType mSTStruct_ ## STRUCT; \ @@ -249,8 +253,8 @@ CXX_GUARD_START }, #define _mSCRIPT_STRUCT_METHOD_POP(TYPE, S, NPARAMS, ...) \ - _mCALL(_mCAT(mSCRIPT_POP_, _mSUCC_ ## NPARAMS), &frame->arguments, _mCOMMA_ ## NPARAMS(S(TYPE), __VA_ARGS__)); \ - if (mScriptListSize(&frame->arguments)) { \ + _mCALL(_mCAT(mSCRIPT_POP_, _mSUCC_ ## NPARAMS), &frame->stack, _mCOMMA_ ## NPARAMS(S(TYPE), __VA_ARGS__)); \ + if (mScriptListSize(&frame->stack)) { \ return false; \ } @@ -326,11 +330,11 @@ CXX_GUARD_START static const struct mScriptFunctionOverload _mSTStructBindingOverloads_ ## TYPE ## _ ## NAME[mSCRIPT_OVERLOADS_MAX]; \ static bool _mSTStructBinding_ ## TYPE ## _ ## NAME(struct mScriptFrame* frame, void* ctx) { \ UNUSED(ctx); \ - const struct mScriptFunctionOverload* overload = mScriptFunctionFindOverload(_mSTStructBindingOverloads_ ## TYPE ## _ ## NAME, &frame->arguments); \ + const struct mScriptFunctionOverload* overload = mScriptFunctionFindOverload(_mSTStructBindingOverloads_ ## TYPE ## _ ## NAME, &frame->stack); \ if (!overload) { \ return false; \ } \ - if (!mScriptCoerceFrame(&overload->type->details.function.parameters, &frame->arguments, &frame->arguments)) { \ + if (!mScriptCoerceFrame(&overload->type->details.function.parameters, &frame->stack, &frame->stack)) { \ return false; \ } \ return overload->function->call(frame, overload->function->context); \ @@ -552,8 +556,8 @@ CXX_GUARD_START #define _mSCRIPT_BIND_N_FUNCTION(NAME, RETURN, FUNCTION, DEFAULTS, NPARAMS, ...) \ static bool _binding_ ## NAME(struct mScriptFrame* frame, void* ctx) { \ UNUSED(ctx); \ - _mCALL(mSCRIPT_POP_ ## NPARAMS, &frame->arguments, _mEVEN_ ## NPARAMS(__VA_ARGS__)); \ - if (mScriptListSize(&frame->arguments)) { \ + _mCALL(mSCRIPT_POP_ ## NPARAMS, &frame->stack, _mEVEN_ ## NPARAMS(__VA_ARGS__)); \ + if (mScriptListSize(&frame->stack)) { \ return false; \ } \ _mSCRIPT_CALL(RETURN, FUNCTION, NPARAMS); \ @@ -564,8 +568,8 @@ CXX_GUARD_START #define _mSCRIPT_BIND_VOID_FUNCTION(NAME, FUNCTION, DEFAULTS, NPARAMS, ...) \ static bool _binding_ ## NAME(struct mScriptFrame* frame, void* ctx) { \ UNUSED(ctx); \ - _mCALL(mSCRIPT_POP_ ## NPARAMS, &frame->arguments, _mEVEN_ ## NPARAMS(__VA_ARGS__)); \ - if (mScriptListSize(&frame->arguments)) { \ + _mCALL(mSCRIPT_POP_ ## NPARAMS, &frame->stack, _mEVEN_ ## NPARAMS(__VA_ARGS__)); \ + if (mScriptListSize(&frame->stack)) { \ return false; \ } \ _mSCRIPT_CALL_VOID(FUNCTION, NPARAMS); \ diff --git a/include/mgba/script/types.h b/include/mgba/script/types.h index 5b07abe3bc2..684059d32fd 100644 --- a/include/mgba/script/types.h +++ b/include/mgba/script/types.h @@ -325,8 +325,7 @@ struct mScriptString { }; struct mScriptFrame { - struct mScriptList arguments; - struct mScriptList returnValues; + struct mScriptList stack; // TODO: Exception/failure codes }; diff --git a/src/core/scripting.c b/src/core/scripting.c index dc56c178392..9e46b619c8f 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -1205,11 +1205,11 @@ static bool _callRotationCb(struct mScriptCoreAdapter* adapter, const char* cbNa struct mScriptValue* context = mScriptTableLookup(adapter->rotationCbTable, &mSCRIPT_MAKE_CHARP("context")); mScriptFrameInit(&frame); if (context) { - mScriptValueWrap(context, mScriptListAppend(&frame.arguments)); + mScriptValueWrap(context, mScriptListAppend(&frame.stack)); } bool ok = mScriptContextInvoke(adapter->context, cb, &frame); - if (ok && out && mScriptListSize(&frame.returnValues) == 1) { - if (!mScriptCast(mSCRIPT_TYPE_MS_F32, mScriptListGetPointer(&frame.returnValues, 0), out)) { + if (ok && out && mScriptListSize(&frame.stack) == 1) { + if (!mScriptCast(mSCRIPT_TYPE_MS_F32, mScriptListGetPointer(&frame.stack, 0), out)) { ok = false; } } @@ -1278,8 +1278,8 @@ static uint8_t _readLuminance(struct GBALuminanceSource* luminance) { mScriptFrameInit(&frame); bool ok = mScriptContextInvoke(adapter->context, adapter->luminanceCb, &frame); struct mScriptValue out = {0}; - if (ok && mScriptListSize(&frame.returnValues) == 1) { - if (!mScriptCast(mSCRIPT_TYPE_MS_U8, mScriptListGetPointer(&frame.returnValues, 0), &out)) { + if (ok && mScriptListSize(&frame.stack) == 1) { + if (!mScriptCast(mSCRIPT_TYPE_MS_U8, mScriptListGetPointer(&frame.stack, 0), &out)) { ok = false; } } diff --git a/src/script/context.c b/src/script/context.c index d9afd55a1be..0d770dfde22 100644 --- a/src/script/context.c +++ b/src/script/context.c @@ -266,7 +266,7 @@ void mScriptContextTriggerCallback(struct mScriptContext* context, const char* c if (fn) { mScriptFrameInit(&frame); if (args) { - mScriptListCopy(&frame.arguments, args); + mScriptListCopy(&frame.stack, args); } mScriptContextInvoke(context, fn, &frame); mScriptFrameDeinit(&frame); @@ -481,7 +481,7 @@ bool mScriptInvoke(const struct mScriptValue* val, struct mScriptFrame* frame) { return false; } const struct mScriptTypeFunction* signature = &val->type->details.function; - if (!mScriptCoerceFrame(&signature->parameters, &frame->arguments, &frame->arguments)) { + if (!mScriptCoerceFrame(&signature->parameters, &frame->stack, &frame->stack)) { return false; } const struct mScriptFunction* fn = val->value.opaque; diff --git a/src/script/engines/lua.c b/src/script/engines/lua.c index 732d54e9976..f4f4026e9bf 100644 --- a/src/script/engines/lua.c +++ b/src/script/engines/lua.c @@ -912,12 +912,12 @@ void _luaError(struct mScriptEngineContextLua* luaContext) { if (ok) { struct mScriptFrame frame; mScriptFrameInit(&frame); - struct mScriptValue* this = mScriptListAppend(&frame.arguments); + struct mScriptValue* this = mScriptListAppend(&frame.stack); this->type = console->type; this->refs = mSCRIPT_VALUE_UNREF; this->flags = 0; this->value.opaque = console->value.opaque; - mSCRIPT_PUSH(&frame.arguments, CHARP, luaContext->lastError); + mSCRIPT_PUSH(&frame.stack, CHARP, luaContext->lastError); ok = mScriptInvoke(&error, &frame); mScriptFrameDeinit(&frame); } @@ -1115,7 +1115,7 @@ void _autofreeFrame(struct mScriptContext* context, struct mScriptList* frame) { bool _luaInvoke(struct mScriptEngineContextLua* luaContext, struct mScriptFrame* frame) { int nargs = 0; if (frame) { - nargs = mScriptListSize(&frame->arguments); + nargs = mScriptListSize(&frame->stack); } if (luaContext->lastError) { @@ -1127,9 +1127,12 @@ bool _luaInvoke(struct mScriptEngineContextLua* luaContext, struct mScriptFrame* return false; } - if (frame && !_luaPushFrame(luaContext, luaContext->lua, &frame->arguments)) { - mScriptContextDeactivate(luaContext->d.context); - return false; + if (frame) { + if (!_luaPushFrame(luaContext, luaContext->lua, &frame->stack)) { + mScriptContextDeactivate(luaContext->d.context); + return false; + } + mScriptListClear(&frame->stack); } lua_pushliteral(luaContext->lua, "mCtx"); @@ -1151,7 +1154,7 @@ bool _luaInvoke(struct mScriptEngineContextLua* luaContext, struct mScriptFrame* return false; } - if (frame && !_luaPopFrame(luaContext, luaContext->lua, &frame->returnValues)) { + if (frame && !_luaPopFrame(luaContext, luaContext->lua, &frame->stack)) { mScriptContextDrainPool(luaContext->d.context); return false; } @@ -1191,8 +1194,8 @@ int _luaThunk(lua_State* lua) { struct mScriptEngineContextLua* luaContext = _luaGetContext(lua); struct mScriptFrame frame; mScriptFrameInit(&frame); - if (!_luaPopFrame(luaContext, lua, &frame.arguments)) { - _freeFrame(&frame.arguments); + if (!_luaPopFrame(luaContext, lua, &frame.stack)) { + _freeFrame(&frame.stack); mScriptContextDrainPool(luaContext->d.context); mScriptFrameDeinit(&frame); luaL_traceback(lua, lua, "Error calling function (translating arguments into runtime)", 1); @@ -1200,7 +1203,7 @@ int _luaThunk(lua_State* lua) { } struct mScriptValue* fn = lua_touserdata(lua, lua_upvalueindex(1)); - _autofreeFrame(luaContext->d.context, &frame.arguments); + _autofreeFrame(luaContext->d.context, &frame.stack); if (!fn || !mScriptContextInvoke(luaContext->d.context, fn, &frame)) { mScriptContextDrainPool(luaContext->d.context); mScriptFrameDeinit(&frame); @@ -1208,7 +1211,7 @@ int _luaThunk(lua_State* lua) { return lua_error(lua); } - bool ok = _luaPushFrame(luaContext, lua, &frame.returnValues); + bool ok = _luaPushFrame(luaContext, lua, &frame.stack); mScriptContextDrainPool(luaContext->d.context); mScriptFrameDeinit(&frame); if (!ok) { diff --git a/src/script/test/classes.c b/src/script/test/classes.c index e0ce39d47a5..1b688cae43b 100644 --- a/src/script/test/classes.c +++ b/src/script/test/classes.c @@ -519,106 +519,106 @@ M_TEST_DEFINE(testAStatic) { assert_true(mScriptObjectGet(&sval, "i0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 1); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "i1", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 2); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "ic0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(TestA), &s); + mSCRIPT_PUSH(&frame.stack, CS(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 1); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "ic0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 1); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "ic1", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(TestA), &s); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, CS(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 2); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "ic1", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 2); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "v0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "i0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 2); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "ic0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(TestA), &s); + mSCRIPT_PUSH(&frame.stack, CS(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 2); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "v1", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); - mSCRIPT_PUSH(&frame.arguments, S32, 2); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S32, 2); assert_true(mScriptInvoke(&val, &frame)); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "v2", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); - mSCRIPT_PUSH(&frame.arguments, S32, 1); - mSCRIPT_PUSH(&frame.arguments, S32, -2); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, -2); assert_true(mScriptInvoke(&val, &frame)); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "v2", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&val, &frame)); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "i0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 4); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "ic0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(TestA), &s); + mSCRIPT_PUSH(&frame.stack, CS(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 4); mScriptFrameDeinit(&frame); @@ -659,93 +659,93 @@ M_TEST_DEFINE(testADynamic) { assert_true(mScriptObjectGet(&sval, "ifn0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 1); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "ifn1", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 2); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "icfn0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(TestA), &s); + mSCRIPT_PUSH(&frame.stack, CS(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 1); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "icfn0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 1); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "icfn1", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(TestA), &s); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, CS(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 2); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "icfn1", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 2); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "vfn0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "ifn0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 2); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "icfn0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(TestA), &s); + mSCRIPT_PUSH(&frame.stack, CS(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 2); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "vfn1", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); - mSCRIPT_PUSH(&frame.arguments, S32, 2); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S32, 2); assert_true(mScriptInvoke(&val, &frame)); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "ifn0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestA), &s); + mSCRIPT_PUSH(&frame.stack, S(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 4); mScriptFrameDeinit(&frame); assert_true(mScriptObjectGet(&sval, "icfn0", &val)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(TestA), &s); + mSCRIPT_PUSH(&frame.stack, CS(TestA), &s); assert_true(mScriptInvoke(&val, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &rval)); + assert_true(mScriptPopS32(&frame.stack, &rval)); assert_int_equal(rval, 4); mScriptFrameDeinit(&frame); @@ -1228,16 +1228,16 @@ M_TEST_DEFINE(testOverloadsBasic) { assert_true(mScriptObjectGet(&sval, "call", &fn)); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestI), &s); - mSCRIPT_PUSH(&frame.arguments, U32, 1); + mSCRIPT_PUSH(&frame.stack, S(TestI), &s); + mSCRIPT_PUSH(&frame.stack, U32, 1); assert_true(mScriptInvoke(&fn, &frame)); mScriptFrameDeinit(&frame); assert_int_equal(s.num, 1); assert_null(s.str); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(TestI), &s); - mSCRIPT_PUSH(&frame.arguments, CHARP, "called"); + mSCRIPT_PUSH(&frame.stack, S(TestI), &s); + mSCRIPT_PUSH(&frame.stack, CHARP, "called"); assert_true(mScriptInvoke(&fn, &frame)); mScriptFrameDeinit(&frame); assert_int_equal(s.num, 1); diff --git a/src/script/test/lua.c b/src/script/test/lua.c index 49c5521d793..388d7908433 100644 --- a/src/script/test/lua.c +++ b/src/script/test/lua.c @@ -328,10 +328,10 @@ M_TEST_DEFINE(callLuaFunc) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(fn, &frame)); int64_t val; - assert_true(mScriptPopS64(&frame.returnValues, &val)); + assert_true(mScriptPopS64(&frame.stack, &val)); assert_int_equal(val, 2); mScriptFrameDeinit(&frame); @@ -342,10 +342,10 @@ M_TEST_DEFINE(callLuaFunc) { assert_int_equal(fn->type->base, mSCRIPT_TYPE_FUNCTION); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 1); - mSCRIPT_PUSH(&frame.arguments, S32, 2); + mSCRIPT_PUSH(&frame.stack, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 2); assert_true(mScriptInvoke(fn, &frame)); - assert_true(mScriptPopS64(&frame.returnValues, &val)); + assert_true(mScriptPopS64(&frame.stack, &val)); assert_int_equal(val, 3); mScriptFrameDeinit(&frame); diff --git a/src/script/test/types.c b/src/script/test/types.c index 67b6fba9a54..51420eecd38 100644 --- a/src/script/test/types.c +++ b/src/script/test/types.c @@ -111,7 +111,7 @@ M_TEST_DEFINE(voidArgs) { mScriptFrameInit(&frame); assert_true(mScriptInvoke(&boundVoidOne, &frame)); int32_t val; - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 1); mScriptFrameDeinit(&frame); } @@ -119,7 +119,7 @@ M_TEST_DEFINE(voidArgs) { M_TEST_DEFINE(voidFunc) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&boundDiscard, &frame)); mScriptFrameDeinit(&frame); } @@ -127,10 +127,10 @@ M_TEST_DEFINE(voidFunc) { M_TEST_DEFINE(identityFunctionS32) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&boundIdentityInt, &frame)); int32_t val; - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 1); mScriptFrameDeinit(&frame); } @@ -138,10 +138,10 @@ M_TEST_DEFINE(identityFunctionS32) { M_TEST_DEFINE(identityFunctionS64) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S64, 1); + mSCRIPT_PUSH(&frame.stack, S64, 1); assert_true(mScriptInvoke(&boundIdentityInt64, &frame)); int64_t val; - assert_true(mScriptPopS64(&frame.returnValues, &val)); + assert_true(mScriptPopS64(&frame.stack, &val)); assert_int_equal(val, 1); mScriptFrameDeinit(&frame); } @@ -149,10 +149,10 @@ M_TEST_DEFINE(identityFunctionS64) { M_TEST_DEFINE(identityFunctionF32) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, F32, 3.125f); + mSCRIPT_PUSH(&frame.stack, F32, 3.125f); assert_true(mScriptInvoke(&boundIdentityFloat, &frame)); float val; - assert_true(mScriptPopF32(&frame.returnValues, &val)); + assert_true(mScriptPopF32(&frame.stack, &val)); assert_float_equal(val, 3.125f, 0.f); mScriptFrameDeinit(&frame); } @@ -161,10 +161,10 @@ M_TEST_DEFINE(identityFunctionStruct) { struct mScriptFrame frame; struct Test v = {}; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(Test), &v); + mSCRIPT_PUSH(&frame.stack, S(Test), &v); assert_true(mScriptInvoke(&boundIdentityStruct, &frame)); struct Test* val; - assert_true(mScriptPopPointer(&frame.returnValues, (void**) &val)); + assert_true(mScriptPopPointer(&frame.stack, (void**) &val)); assert_ptr_equal(val, &v); mScriptFrameDeinit(&frame); } @@ -172,11 +172,11 @@ M_TEST_DEFINE(identityFunctionStruct) { M_TEST_DEFINE(addS32) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 1); - mSCRIPT_PUSH(&frame.arguments, S32, 2); + mSCRIPT_PUSH(&frame.stack, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 2); assert_true(mScriptInvoke(&boundAddInts, &frame)); int32_t val; - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 3); mScriptFrameDeinit(&frame); } @@ -186,17 +186,17 @@ M_TEST_DEFINE(addS32Defaults) { int32_t val; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 1); - mSCRIPT_PUSH(&frame.arguments, S32, 2); + mSCRIPT_PUSH(&frame.stack, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 2); assert_true(mScriptInvoke(&boundAddIntWithDefaults, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 3); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&boundAddIntWithDefaults, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 1); mScriptFrameDeinit(&frame); @@ -208,11 +208,11 @@ M_TEST_DEFINE(addS32Defaults) { M_TEST_DEFINE(subS32) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 2); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 2); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&boundSubInts, &frame)); int32_t val; - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 1); mScriptFrameDeinit(&frame); } @@ -227,8 +227,8 @@ M_TEST_DEFINE(wrongArgCountLo) { M_TEST_DEFINE(wrongArgCountHi) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 1); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_false(mScriptInvoke(&boundIdentityInt, &frame)); mScriptFrameDeinit(&frame); } @@ -236,7 +236,7 @@ M_TEST_DEFINE(wrongArgCountHi) { M_TEST_DEFINE(wrongArgType) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_false(mScriptInvoke(&boundIdentityStruct, &frame)); mScriptFrameDeinit(&frame); } @@ -252,55 +252,55 @@ M_TEST_DEFINE(wrongPopType) { bool b; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 0); - assert_false(mScriptPopU32(&frame.arguments, &u32)); - assert_false(mScriptPopF32(&frame.arguments, &f32)); - assert_false(mScriptPopBool(&frame.arguments, &b)); + mSCRIPT_PUSH(&frame.stack, S32, 0); + assert_false(mScriptPopU32(&frame.stack, &u32)); + assert_false(mScriptPopF32(&frame.stack, &f32)); + assert_false(mScriptPopBool(&frame.stack, &b)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S64, 0); - assert_false(mScriptPopU64(&frame.arguments, &u64)); - assert_false(mScriptPopF64(&frame.arguments, &f64)); - assert_false(mScriptPopBool(&frame.arguments, &b)); + mSCRIPT_PUSH(&frame.stack, S64, 0); + assert_false(mScriptPopU64(&frame.stack, &u64)); + assert_false(mScriptPopF64(&frame.stack, &f64)); + assert_false(mScriptPopBool(&frame.stack, &b)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, U32, 0); - assert_false(mScriptPopS32(&frame.arguments, &s32)); - assert_false(mScriptPopF32(&frame.arguments, &f32)); - assert_false(mScriptPopBool(&frame.arguments, &b)); + mSCRIPT_PUSH(&frame.stack, U32, 0); + assert_false(mScriptPopS32(&frame.stack, &s32)); + assert_false(mScriptPopF32(&frame.stack, &f32)); + assert_false(mScriptPopBool(&frame.stack, &b)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, U64, 0); - assert_false(mScriptPopS64(&frame.arguments, &s64)); - assert_false(mScriptPopF64(&frame.arguments, &f64)); - assert_false(mScriptPopBool(&frame.arguments, &b)); + mSCRIPT_PUSH(&frame.stack, U64, 0); + assert_false(mScriptPopS64(&frame.stack, &s64)); + assert_false(mScriptPopF64(&frame.stack, &f64)); + assert_false(mScriptPopBool(&frame.stack, &b)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, F32, 0); - assert_false(mScriptPopS32(&frame.arguments, &s32)); - assert_false(mScriptPopU32(&frame.arguments, &u32)); - assert_false(mScriptPopBool(&frame.arguments, &b)); + mSCRIPT_PUSH(&frame.stack, F32, 0); + assert_false(mScriptPopS32(&frame.stack, &s32)); + assert_false(mScriptPopU32(&frame.stack, &u32)); + assert_false(mScriptPopBool(&frame.stack, &b)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, F64, 0); - assert_false(mScriptPopS64(&frame.arguments, &s64)); - assert_false(mScriptPopU64(&frame.arguments, &u64)); - assert_false(mScriptPopBool(&frame.arguments, &b)); + mSCRIPT_PUSH(&frame.stack, F64, 0); + assert_false(mScriptPopS64(&frame.stack, &s64)); + assert_false(mScriptPopU64(&frame.stack, &u64)); + assert_false(mScriptPopBool(&frame.stack, &b)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, BOOL, 0); - assert_false(mScriptPopS32(&frame.arguments, &s32)); - assert_false(mScriptPopU32(&frame.arguments, &u32)); - assert_false(mScriptPopS64(&frame.arguments, &s64)); - assert_false(mScriptPopU64(&frame.arguments, &u64)); - assert_false(mScriptPopF32(&frame.arguments, &f32)); - assert_false(mScriptPopF64(&frame.arguments, &f64)); + mSCRIPT_PUSH(&frame.stack, BOOL, 0); + assert_false(mScriptPopS32(&frame.stack, &s32)); + assert_false(mScriptPopU32(&frame.stack, &u32)); + assert_false(mScriptPopS64(&frame.stack, &s64)); + assert_false(mScriptPopU64(&frame.stack, &u64)); + assert_false(mScriptPopF32(&frame.stack, &f32)); + assert_false(mScriptPopF64(&frame.stack, &f64)); mScriptFrameDeinit(&frame); } @@ -314,33 +314,33 @@ M_TEST_DEFINE(wrongPopSize) { double f64; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 0); - assert_false(mScriptPopS64(&frame.arguments, &s64)); + mSCRIPT_PUSH(&frame.stack, S32, 0); + assert_false(mScriptPopS64(&frame.stack, &s64)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S64, 0); - assert_false(mScriptPopS32(&frame.arguments, &s32)); + mSCRIPT_PUSH(&frame.stack, S64, 0); + assert_false(mScriptPopS32(&frame.stack, &s32)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, U32, 0); - assert_false(mScriptPopU64(&frame.arguments, &u64)); + mSCRIPT_PUSH(&frame.stack, U32, 0); + assert_false(mScriptPopU64(&frame.stack, &u64)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, U64, 0); - assert_false(mScriptPopU32(&frame.arguments, &u32)); + mSCRIPT_PUSH(&frame.stack, U64, 0); + assert_false(mScriptPopU32(&frame.stack, &u32)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, F32, 0); - assert_false(mScriptPopF64(&frame.arguments, &f64)); + mSCRIPT_PUSH(&frame.stack, F32, 0); + assert_false(mScriptPopF64(&frame.stack, &f64)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, F64, 0); - assert_false(mScriptPopF32(&frame.arguments, &f32)); + mSCRIPT_PUSH(&frame.stack, F64, 0); + assert_false(mScriptPopF32(&frame.stack, &f32)); mScriptFrameDeinit(&frame); } @@ -370,63 +370,63 @@ M_TEST_DEFINE(wrongConst) { mScriptClassInit(mSCRIPT_TYPE_MS_CS(Test)->details.cls); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(Test), &a); + mSCRIPT_PUSH(&frame.stack, S(Test), &a); signature.entries[0] = mSCRIPT_TYPE_MS_S(Test); - assert_true(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); + assert_true(mScriptCoerceFrame(&signature, &frame.stack, &frame.stack)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(Test), &a); + mSCRIPT_PUSH(&frame.stack, CS(Test), &a); signature.entries[0] = mSCRIPT_TYPE_MS_CS(Test); - assert_true(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); + assert_true(mScriptCoerceFrame(&signature, &frame.stack, &frame.stack)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(Test), &a); + mSCRIPT_PUSH(&frame.stack, S(Test), &a); signature.entries[0] = mSCRIPT_TYPE_MS_CS(Test); - assert_true(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); + assert_true(mScriptCoerceFrame(&signature, &frame.stack, &frame.stack)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(Test), &a); + mSCRIPT_PUSH(&frame.stack, CS(Test), &a); signature.entries[0] = mSCRIPT_TYPE_MS_S(Test); - assert_false(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); + assert_false(mScriptCoerceFrame(&signature, &frame.stack, &frame.stack)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(Test), &a); - assert_true(mScriptPopSTest(&frame.arguments, &b)); + mSCRIPT_PUSH(&frame.stack, S(Test), &a); + assert_true(mScriptPopSTest(&frame.stack, &b)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(Test), &a); - assert_false(mScriptPopCSTest(&frame.arguments, &cb)); + mSCRIPT_PUSH(&frame.stack, S(Test), &a); + assert_false(mScriptPopCSTest(&frame.stack, &cb)); signature.entries[0] = mSCRIPT_TYPE_MS_CS(Test); - assert_true(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); - assert_true(mScriptPopCSTest(&frame.arguments, &cb)); + assert_true(mScriptCoerceFrame(&signature, &frame.stack, &frame.stack)); + assert_true(mScriptPopCSTest(&frame.stack, &cb)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(Test), &a); - assert_false(mScriptPopSTest(&frame.arguments, &b)); + mSCRIPT_PUSH(&frame.stack, CS(Test), &a); + assert_false(mScriptPopSTest(&frame.stack, &b)); signature.entries[0] = mSCRIPT_TYPE_MS_S(Test); - assert_false(mScriptCoerceFrame(&signature, &frame.arguments, &frame.arguments)); - assert_false(mScriptPopSTest(&frame.arguments, &b)); + assert_false(mScriptCoerceFrame(&signature, &frame.stack, &frame.stack)); + assert_false(mScriptPopSTest(&frame.stack, &b)); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CS(Test), &a); - assert_true(mScriptPopCSTest(&frame.arguments, &cb)); + mSCRIPT_PUSH(&frame.stack, CS(Test), &a); + assert_true(mScriptPopCSTest(&frame.stack, &cb)); mScriptFrameDeinit(&frame); } M_TEST_DEFINE(coerceToFloat) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, 1); + mSCRIPT_PUSH(&frame.stack, S32, 1); assert_true(mScriptInvoke(&boundIdentityFloat, &frame)); float val; - assert_true(mScriptPopF32(&frame.returnValues, &val)); + assert_true(mScriptPopF32(&frame.stack, &val)); assert_float_equal(val, 1.f, 0.f); mScriptFrameDeinit(&frame); } @@ -434,10 +434,10 @@ M_TEST_DEFINE(coerceToFloat) { M_TEST_DEFINE(coerceFromFloat) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, F32, 1.25f); + mSCRIPT_PUSH(&frame.stack, F32, 1.25f); assert_true(mScriptInvoke(&boundIdentityInt, &frame)); int val; - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 1); mScriptFrameDeinit(&frame); } @@ -539,10 +539,10 @@ M_TEST_DEFINE(coerceFromBool) { M_TEST_DEFINE(coerceWiden) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S32, -1); + mSCRIPT_PUSH(&frame.stack, S32, -1); assert_true(mScriptInvoke(&boundIdentityInt64, &frame)); int64_t val; - assert_true(mScriptPopS64(&frame.returnValues, &val)); + assert_true(mScriptPopS64(&frame.stack, &val)); assert_true(val == -1LL); mScriptFrameDeinit(&frame); } @@ -550,10 +550,10 @@ M_TEST_DEFINE(coerceWiden) { M_TEST_DEFINE(coerceNarrow) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S64, -1); + mSCRIPT_PUSH(&frame.stack, S64, -1); assert_true(mScriptInvoke(&boundIdentityInt, &frame)); int32_t val; - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_true(val == -1); mScriptFrameDeinit(&frame); } @@ -1244,10 +1244,10 @@ M_TEST_DEFINE(hashTableString) { M_TEST_DEFINE(stringIsHello) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CHARP, "hello"); + mSCRIPT_PUSH(&frame.stack, CHARP, "hello"); assert_true(mScriptInvoke(&boundIsHello, &frame)); int val; - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 1); mScriptFrameDeinit(&frame); } @@ -1255,10 +1255,10 @@ M_TEST_DEFINE(stringIsHello) { M_TEST_DEFINE(stringIsNotHello) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CHARP, "world"); + mSCRIPT_PUSH(&frame.stack, CHARP, "world"); assert_true(mScriptInvoke(&boundIsHello, &frame)); int val; - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 0); mScriptFrameDeinit(&frame); } @@ -1271,33 +1271,33 @@ M_TEST_DEFINE(invokeList) { mScriptListInit(&list, 0); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, LIST, &list); + mSCRIPT_PUSH(&frame.stack, LIST, &list); assert_true(mScriptInvoke(&boundIsSequential, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 1); mScriptFrameDeinit(&frame); *mScriptListAppend(&list) = mSCRIPT_MAKE_S32(1); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, LIST, &list); + mSCRIPT_PUSH(&frame.stack, LIST, &list); assert_true(mScriptInvoke(&boundIsSequential, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 1); mScriptFrameDeinit(&frame); *mScriptListAppend(&list) = mSCRIPT_MAKE_S32(2); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, LIST, &list); + mSCRIPT_PUSH(&frame.stack, LIST, &list); assert_true(mScriptInvoke(&boundIsSequential, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 1); mScriptFrameDeinit(&frame); *mScriptListAppend(&list) = mSCRIPT_MAKE_S32(4); mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, LIST, &list); + mSCRIPT_PUSH(&frame.stack, LIST, &list); assert_true(mScriptInvoke(&boundIsSequential, &frame)); - assert_true(mScriptPopS32(&frame.returnValues, &val)); + assert_true(mScriptPopS32(&frame.stack, &val)); assert_int_equal(val, 0); mScriptFrameDeinit(&frame); @@ -1309,14 +1309,14 @@ M_TEST_DEFINE(nullString) { bool res; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, CHARP, "hi"); + mSCRIPT_PUSH(&frame.stack, CHARP, "hi"); assert_true(mScriptInvoke(&boundIsNullCharp, &frame)); - assert_true(mScriptPopBool(&frame.returnValues, &res)); + assert_true(mScriptPopBool(&frame.stack, &res)); assert_false(res); - mSCRIPT_PUSH(&frame.arguments, CHARP, NULL); + mSCRIPT_PUSH(&frame.stack, CHARP, NULL); assert_true(mScriptInvoke(&boundIsNullCharp, &frame)); - assert_true(mScriptPopBool(&frame.returnValues, &res)); + assert_true(mScriptPopBool(&frame.stack, &res)); assert_true(res); mScriptFrameDeinit(&frame); @@ -1328,14 +1328,14 @@ M_TEST_DEFINE(nullStruct) { bool res; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, S(Test), &v); + mSCRIPT_PUSH(&frame.stack, S(Test), &v); assert_true(mScriptInvoke(&boundIsNullStruct, &frame)); - assert_true(mScriptPopBool(&frame.returnValues, &res)); + assert_true(mScriptPopBool(&frame.stack, &res)); assert_false(res); - mSCRIPT_PUSH(&frame.arguments, S(Test), NULL); + mSCRIPT_PUSH(&frame.stack, S(Test), NULL); assert_true(mScriptInvoke(&boundIsNullStruct, &frame)); - assert_true(mScriptPopBool(&frame.returnValues, &res)); + assert_true(mScriptPopBool(&frame.stack, &res)); assert_true(res); mScriptFrameDeinit(&frame); diff --git a/src/script/types.c b/src/script/types.c index 00422d20cb8..799c6fb7196 100644 --- a/src/script/types.c +++ b/src/script/types.c @@ -1118,13 +1118,11 @@ bool mScriptTableIteratorLookup(struct mScriptValue* table, struct TableIterator } void mScriptFrameInit(struct mScriptFrame* frame) { - mScriptListInit(&frame->arguments, 4); - mScriptListInit(&frame->returnValues, 1); + mScriptListInit(&frame->stack, 4); } void mScriptFrameDeinit(struct mScriptFrame* frame) { - mScriptListDeinit(&frame->returnValues); - mScriptListDeinit(&frame->arguments); + mScriptListDeinit(&frame->stack); } struct mScriptValue* mScriptLambdaCreate0(struct mScriptValue* fn, struct mScriptList* args) { @@ -1150,15 +1148,15 @@ struct mScriptValue* mScriptLambdaCreate0(struct mScriptValue* fn, struct mScrip } bool _callLambda0(struct mScriptFrame* frame, void* context) { - if (mScriptListSize(&frame->arguments)) { + if (mScriptListSize(&frame->stack)) { return false; } struct mScriptLambda* lambda = context; struct mScriptFrame subframe; mScriptFrameInit(&subframe); - mScriptListCopy(&subframe.arguments, &lambda->arguments); + mScriptListCopy(&subframe.stack, &lambda->arguments); bool ok = mScriptInvoke(lambda->fn, &subframe); - if (mScriptListSize(&subframe.returnValues)) { + if (mScriptListSize(&subframe.stack)) { ok = false; } mScriptFrameDeinit(&subframe); @@ -1399,17 +1397,17 @@ bool mScriptObjectGet(struct mScriptValue* obj, const char* member, struct mScri } struct mScriptFrame frame; mScriptFrameInit(&frame); - struct mScriptValue* this = mScriptListAppend(&frame.arguments); + struct mScriptValue* this = mScriptListAppend(&frame.stack); this->type = obj->type; this->refs = mSCRIPT_VALUE_UNREF; this->flags = 0; this->value.opaque = obj->value.opaque; - mSCRIPT_PUSH(&frame.arguments, CHARP, member); - if (!mScriptInvoke(&getMember, &frame) || mScriptListSize(&frame.returnValues) != 1) { + mSCRIPT_PUSH(&frame.stack, CHARP, member); + if (!mScriptInvoke(&getMember, &frame) || mScriptListSize(&frame.stack) != 1) { mScriptFrameDeinit(&frame); return false; } - memcpy(val, mScriptListGetPointer(&frame.returnValues, 0), sizeof(*val)); + memcpy(val, mScriptListGetPointer(&frame.stack, 0), sizeof(*val)); mScriptFrameDeinit(&frame); return true; } @@ -1547,14 +1545,14 @@ bool mScriptObjectSet(struct mScriptValue* obj, const char* member, struct mScri } struct mScriptFrame frame; mScriptFrameInit(&frame); - struct mScriptValue* this = mScriptListAppend(&frame.arguments); + struct mScriptValue* this = mScriptListAppend(&frame.stack); this->type = obj->type; this->refs = mSCRIPT_VALUE_UNREF; this->flags = 0; this->value.opaque = obj->value.opaque; - mSCRIPT_PUSH(&frame.arguments, CHARP, member); - mScriptValueWrap(val, mScriptListAppend(&frame.arguments)); - if (!mScriptInvoke(&setMember, &frame) || mScriptListSize(&frame.returnValues) != 0) { + mSCRIPT_PUSH(&frame.stack, CHARP, member); + mScriptValueWrap(val, mScriptListAppend(&frame.stack)); + if (!mScriptInvoke(&setMember, &frame) || mScriptListSize(&frame.stack) != 0) { mScriptFrameDeinit(&frame); return false; } @@ -1665,7 +1663,7 @@ void mScriptObjectFree(struct mScriptValue* value) { if (_accessRawMember(value->type->details.cls->free, value->value.opaque, value->type->isConst, &deinitMember)) { struct mScriptFrame frame; mScriptFrameInit(&frame); - mSCRIPT_PUSH(&frame.arguments, WRAPPER, value); + mSCRIPT_PUSH(&frame.stack, WRAPPER, value); mScriptInvoke(&deinitMember, &frame); mScriptFrameDeinit(&frame); } diff --git a/src/tools/docgen.c b/src/tools/docgen.c index cdabb472c77..e2c444ed270 100644 --- a/src/tools/docgen.c +++ b/src/tools/docgen.c @@ -362,7 +362,7 @@ bool call(struct mScriptValue* obj, const char* method, struct mScriptFrame* fra if (!mScriptObjectGet(obj, method, &fn)) { return false; } - mSCRIPT_PUSH(&frame->arguments, WRAPPER, obj); + mSCRIPT_PUSH(&frame->stack, WRAPPER, obj); return mScriptInvoke(&fn, frame); } @@ -394,12 +394,12 @@ void explainCore(struct mCore* core) { mScriptFrameInit(&frame); call(value, "base", &frame); - mScriptPopU32(&frame.returnValues, &baseVal); + mScriptPopU32(&frame.stack, &baseVal); mScriptFrameDeinit(&frame); mScriptFrameInit(&frame); call(value, "name", &frame); - shortName = mScriptValueUnwrap(mScriptListGetPointer(&frame.returnValues, 0)); + shortName = mScriptValueUnwrap(mScriptListGetPointer(&frame.stack, 0)); mScriptFrameDeinit(&frame); fprintf(out, " base: 0x%x\n", baseVal); From cfd30b7a95edf1dafaf5cfb6d691578d8b6554c5 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 8 Nov 2024 21:38:25 -0800 Subject: [PATCH 273/338] GBA Savedata: Fix erroneously setting the error bit --- src/gba/savedata.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/gba/savedata.c b/src/gba/savedata.c index ca5d35cbba7..ced279b7f67 100644 --- a/src/gba/savedata.c +++ b/src/gba/savedata.c @@ -376,9 +376,10 @@ uint8_t GBASavedataReadFlash(struct GBASavedata* savedata, uint16_t address) { } } if (mTimingIsScheduled(savedata->timing, &savedata->dust) && (address >> 12) == savedata->settling) { - // This should read /Q7 ("data# polling") and Q6 flipping ("toggle bit") every read, - // but just data# polling is sufficient for games to figure it out - return savedata->currentBank[address] ^ 0x80; + // This should read /Q7 ("data# polling"), Q6 flipping ("toggle bit") + // every read, and /Q5 ("error bit" cleared), but just data# polling + // is sufficient for games to figure it out + return (savedata->currentBank[address] ^ 0x80) & 0x80; } return savedata->currentBank[address]; } From 3d493239d77676a183e0a61426cf41036dbe2f1f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 17 Nov 2024 02:27:19 -0800 Subject: [PATCH 274/338] GBA Savedata: Update flash busy comment --- src/gba/savedata.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/gba/savedata.c b/src/gba/savedata.c index ced279b7f67..a9cd682ca1e 100644 --- a/src/gba/savedata.c +++ b/src/gba/savedata.c @@ -376,9 +376,9 @@ uint8_t GBASavedataReadFlash(struct GBASavedata* savedata, uint16_t address) { } } if (mTimingIsScheduled(savedata->timing, &savedata->dust) && (address >> 12) == savedata->settling) { - // This should read /Q7 ("data# polling"), Q6 flipping ("toggle bit") - // every read, and /Q5 ("error bit" cleared), but just data# polling - // is sufficient for games to figure it out + // This should read Q7 XOR data bit 7 (data# polling), Q6 flipping + // every read (toggle bit), and /Q5 (error bit cleared), but implementing + // just data# polling is sufficient for games to figure it out return (savedata->currentBank[address] ^ 0x80) & 0x80; } return savedata->currentBank[address]; From d5fbd0ff1cbc88dd22d9ad81a5e660f1ddae9249 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 17 Nov 2024 02:24:44 -0800 Subject: [PATCH 275/338] GBA VFame: Refactor reordering code to be simpler --- src/gba/cart/vfame.c | 79 +++++++++++++++++++++----------------------- 1 file changed, 38 insertions(+), 41 deletions(-) diff --git a/src/gba/cart/vfame.c b/src/gba/cart/vfame.c index 260db35b843..b66b7d756e1 100644 --- a/src/gba/cart/vfame.c +++ b/src/gba/cart/vfame.c @@ -1,4 +1,5 @@ /* Copyright (c) 2016 taizou + * Copyright (c) 2013-2024 Jeffrey Pfau * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this @@ -8,35 +9,42 @@ #include #include -static const uint8_t ADDRESS_REORDERING[4][16] = { - { 15, 14, 9, 1, 8, 10, 7, 3, 5, 11, 4, 0, 13, 12, 2, 6 }, - { 15, 7, 13, 5, 11, 6, 0, 9, 12, 2, 10, 14, 3, 1, 8, 4 }, - { 15, 0, 3, 12, 2, 4, 14, 13, 1, 8, 6, 7, 9, 5, 11, 10 } -}; -static const uint8_t ADDRESS_REORDERING_GEORGE[4][16] = { - { 15, 7, 13, 1, 11, 10, 14, 9, 12, 2, 4, 0, 3, 5, 8, 6 }, - { 15, 14, 3, 12, 8, 4, 0, 13, 5, 11, 6, 7, 9, 1, 2, 10 }, - { 15, 0, 9, 5, 2, 6, 7, 3, 1, 8, 10, 14, 13, 12, 11, 4 } -}; -static const uint8_t ADDRESS_REORDERING_ALTERNATE[4][16] = { - { 15, 0, 13, 5, 8, 4, 7, 3, 1, 2, 10, 14, 9, 12, 11, 6 }, - { 15, 7, 9, 1, 2, 6, 14, 13, 12, 11, 4, 0, 3, 5, 8, 10 }, - { 15, 14, 3, 12, 11, 10, 0, 9, 5, 8, 6, 7, 13, 1, 2, 4 } -}; -static const uint8_t VALUE_REORDERING[4][16] = { - { 5, 4, 3, 2, 1, 0, 7, 6 }, - { 3, 2, 1, 0, 7, 6, 5, 4 }, - { 1, 0, 7, 6, 5, 4, 3, 2 } -}; -static const uint8_t VALUE_REORDERING_GEORGE[4][16] = { - { 3, 0, 7, 2, 1, 4, 5, 6 }, - { 1, 4, 3, 0, 5, 6, 7, 2 }, - { 5, 2, 1, 6, 7, 0, 3, 4 } +#define DIGIMON_SAPPHIRE_CHINESE_CRC32 0x793A328F + +static const uint8_t ADDRESS_REORDERING[][3][16] = { + [VFAME_STANDARD] = { + { 15, 14, 9, 1, 8, 10, 7, 3, 5, 11, 4, 0, 13, 12, 2, 6 }, + { 15, 7, 13, 5, 11, 6, 0, 9, 12, 2, 10, 14, 3, 1, 8, 4 }, + { 15, 0, 3, 12, 2, 4, 14, 13, 1, 8, 6, 7, 9, 5, 11, 10 } + }, + [VFAME_GEORGE] = { + { 15, 7, 13, 1, 11, 10, 14, 9, 12, 2, 4, 0, 3, 5, 8, 6 }, + { 15, 14, 3, 12, 8, 4, 0, 13, 5, 11, 6, 7, 9, 1, 2, 10 }, + { 15, 0, 9, 5, 2, 6, 7, 3, 1, 8, 10, 14, 13, 12, 11, 4 } + }, + [VFAME_ALTERNATE] = { + { 15, 0, 13, 5, 8, 4, 7, 3, 1, 2, 10, 14, 9, 12, 11, 6 }, + { 15, 7, 9, 1, 2, 6, 14, 13, 12, 11, 4, 0, 3, 5, 8, 10 }, + { 15, 14, 3, 12, 11, 10, 0, 9, 5, 8, 6, 7, 13, 1, 2, 4 } + }, }; -static const uint8_t VALUE_REORDERING_ALTERNATE[4][16] = { - { 5, 4, 7, 2, 1, 0, 3, 6 }, - { 1, 2, 3, 0, 5, 6, 7, 4 }, - { 3, 0, 1, 6, 7, 4, 5, 2 } + +static const uint8_t VALUE_REORDERING[][3][8] = { + [VFAME_STANDARD] = { + { 5, 4, 3, 2, 1, 0, 7, 6 }, + { 3, 2, 1, 0, 7, 6, 5, 4 }, + { 1, 0, 7, 6, 5, 4, 3, 2 } + }, + [VFAME_GEORGE] = { + { 3, 0, 7, 2, 1, 4, 5, 6 }, + { 1, 4, 3, 0, 5, 6, 7, 2 }, + { 5, 2, 1, 6, 7, 0, 3, 4 } + }, + [VFAME_ALTERNATE] = { + { 5, 4, 7, 2, 1, 0, 3, 6 }, + { 1, 2, 3, 0, 5, 6, 7, 4 }, + { 3, 0, 1, 6, 7, 4, 5, 2 } + }, }; static const int8_t MODE_CHANGE_START_SEQUENCE[5] = { 0x99, 0x02, 0x05, 0x02, 0x03 }; @@ -268,25 +276,14 @@ static uint32_t _modifySramAddress(enum GBAVFameCartType type, uint32_t address, mode &= 0x3; if (mode == 0) { return address; - } else if (type == VFAME_GEORGE) { - return _reorderBits(address, ADDRESS_REORDERING_GEORGE[mode - 1], 16); - } else if (type == VFAME_ALTERNATE) { - return _reorderBits(address, ADDRESS_REORDERING_ALTERNATE[mode - 1], 16); - } else { - return _reorderBits(address, ADDRESS_REORDERING[mode - 1], 16); } + return _reorderBits(address, ADDRESS_REORDERING[type][mode - 1], 16); } static int8_t _modifySramValue(enum GBAVFameCartType type, uint8_t value, int mode) { int reorderType = (mode & 0xF) >> 2; if (reorderType != 0) { - if (type == VFAME_GEORGE) { - value = _reorderBits(value, VALUE_REORDERING_GEORGE[reorderType - 1], 8); - } else if (type == VFAME_ALTERNATE) { - value = _reorderBits(value, VALUE_REORDERING_ALTERNATE[reorderType - 1], 8); - } else { - value = _reorderBits(value, VALUE_REORDERING[reorderType - 1], 8); - } + value = _reorderBits(value, VALUE_REORDERING[type][reorderType - 1], 8); } if (mode & 0x80) { value ^= 0xAA; From 91cf8292617c912d6b49236e9342476a4e763fbd Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 17 Nov 2024 02:25:12 -0800 Subject: [PATCH 276/338] GBA Memory: Add initial support for N-in-1 style multicarts --- include/mgba/internal/gba/cart/unlicensed.h | 75 +++++++ include/mgba/internal/gba/cart/vfame.h | 41 ---- include/mgba/internal/gba/memory.h | 4 +- include/mgba/internal/gba/serialize.h | 58 +++++- src/gba/CMakeLists.txt | 1 + src/gba/cart/matrix.c | 4 +- src/gba/cart/unlicensed.c | 219 ++++++++++++++++++++ src/gba/cart/vfame.c | 29 +-- src/gba/gba.c | 5 +- src/gba/io.c | 2 + src/gba/memory.c | 15 +- src/gba/overrides.c | 6 + src/gba/serialize.c | 31 ++- 13 files changed, 409 insertions(+), 81 deletions(-) create mode 100644 include/mgba/internal/gba/cart/unlicensed.h delete mode 100644 include/mgba/internal/gba/cart/vfame.h create mode 100644 src/gba/cart/unlicensed.c diff --git a/include/mgba/internal/gba/cart/unlicensed.h b/include/mgba/internal/gba/cart/unlicensed.h new file mode 100644 index 00000000000..ec13abb55c7 --- /dev/null +++ b/include/mgba/internal/gba/cart/unlicensed.h @@ -0,0 +1,75 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * Copyright (c) 2016 taizou + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#ifndef GBA_UNLICENSED_H +#define GBA_UNLICENSED_H + +#include + +CXX_GUARD_START + +#include + +enum GBAVFameCartType { + VFAME_STANDARD = 0, + VFAME_GEORGE = 1, + VFAME_ALTERNATE = 2, +}; + +enum GBAUnlCartType { + GBA_UNL_CART_NONE = 0, + GBA_UNL_CART_VFAME = 1, + GBA_UNL_CART_MULTICART = 2, +}; + +struct GBAVFameCart { + enum GBAVFameCartType cartType; + int sramMode; + int romMode; + int8_t writeSequence[5]; + bool acceptingModeChange; +}; + +struct GBAMulticart { + struct mTimingEvent settle; + uint32_t* rom; + size_t fullSize; + + uint8_t bank; + uint8_t offset; + uint8_t size; + bool sramActive; + uint8_t unk; +}; + +struct GBAUnlCart { + enum GBAUnlCartType type; + union { + struct GBAVFameCart vfame; + struct GBAMulticart multi; + }; +}; + +struct GBA; +struct GBAMemory; +void GBAUnlCartInit(struct GBA*); +void GBAUnlCartReset(struct GBA*); +void GBAUnlCartUnload(struct GBA*); +void GBAUnlCartDetect(struct GBA*); +void GBAUnlCartWriteSRAM(struct GBA*, uint32_t address, uint8_t value); + +struct GBASerializedState; +void GBAUnlCartSerialize(const struct GBA* gba, struct GBASerializedState* state); +void GBAUnlCartDeserialize(struct GBA* gba, const struct GBASerializedState* state); + +bool GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize, uint32_t crc32); +void GBAVFameSramWrite(struct GBAVFameCart* cart, uint32_t address, uint8_t value, uint8_t* sramData); +uint32_t GBAVFameModifyRomAddress(struct GBAVFameCart* cart, uint32_t address, size_t romSize); +uint32_t GBAVFameGetPatternValue(uint32_t address, int bits); + +CXX_GUARD_END + +#endif diff --git a/include/mgba/internal/gba/cart/vfame.h b/include/mgba/internal/gba/cart/vfame.h deleted file mode 100644 index 5bee2884846..00000000000 --- a/include/mgba/internal/gba/cart/vfame.h +++ /dev/null @@ -1,41 +0,0 @@ -/* Copyright (c) 2016 taizou - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ - -// Support for copy protected unlicensed games from the company Vast Fame - -#ifndef GBA_VFAME_H -#define GBA_VFAME_H - -#include - -CXX_GUARD_START - -#define DIGIMON_SAPPHIRE_CHINESE_CRC32 0x793A328F - -enum GBAVFameCartType { - VFAME_NO = 0, - VFAME_STANDARD = 1, - VFAME_GEORGE = 2, - VFAME_ALTERNATE = 3, -}; - -struct GBAVFameCart { - enum GBAVFameCartType cartType; - int sramMode; - int romMode; - int8_t writeSequence[5]; - bool acceptingModeChange; -}; - -void GBAVFameInit(struct GBAVFameCart* cart); -void GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize, uint32_t crc32); -void GBAVFameSramWrite(struct GBAVFameCart* cart, uint32_t address, uint8_t value, uint8_t* sramData); -uint32_t GBAVFameModifyRomAddress(struct GBAVFameCart* cart, uint32_t address, size_t romSize); -uint32_t GBAVFameGetPatternValue(uint32_t address, int bits); - -CXX_GUARD_END - -#endif diff --git a/include/mgba/internal/gba/memory.h b/include/mgba/internal/gba/memory.h index c88e1d092c2..1b32763fc8f 100644 --- a/include/mgba/internal/gba/memory.h +++ b/include/mgba/internal/gba/memory.h @@ -18,7 +18,7 @@ CXX_GUARD_START #include #include #include -#include +#include enum GBAMemoryRegion { GBA_REGION_BIOS = 0x0, @@ -108,8 +108,8 @@ struct GBAMemory { struct GBACartridgeHardware hw; struct GBASavedata savedata; - struct GBAVFameCart vfame; struct GBAMatrix matrix; + struct GBAUnlCart unl; struct GBACartEReader ereader; size_t romSize; uint32_t romMask; diff --git a/include/mgba/internal/gba/serialize.h b/include/mgba/internal/gba/serialize.h index 8b1823a173d..48393ed7bae 100644 --- a/include/mgba/internal/gba/serialize.h +++ b/include/mgba/internal/gba/serialize.h @@ -186,11 +186,14 @@ mLOG_DECLARE_CATEGORY(GBA_STATE); * | bit 3: Reserved * | bits 4 - 15: Light counter * | 0x002C0 - 0x002C0: Light sample - * | 0x002C1 - 0x002C3: Flags + * | 0x002C1: Flags * | bits 0 - 1: Tilt state machine * | bits 2 - 3: GB Player inputs posted - * | bits 4 - 8: GB Player transmit position - * | bits 9 - 23: Reserved + * | bits 4 - 7: GB Player transmit position + * | 0x002C2 - 0x002C3: Unlicensed cart flags + * | bits 0 - 4: Cartridge type + * | bits 5 - 7: Cartridge subtype + * | bits 8 - 15: Reserved * 0x002C4 - 0x002C7: SIO next event * 0x002C8 - 0x002CB: Current DMA transfer word * 0x002CC - 0x002CF: Last DMA transfer PC @@ -230,8 +233,23 @@ mLOG_DECLARE_CATEGORY(GBA_STATE); * | bits 15 - 31: Reserved * 0x00320 - 0x00323: Next IRQ event * 0x00324 - 0x00327: Interruptable BIOS stall cycles - * 0x00328 - 0x00367: Matrix memory mapping table - * 0x00368 - 0x0036F: Reserved (leave zero) + * 0x00328 - 0x0036F: Special cartridge state, one of: + * | Matrix Memory: + * | 0x00328 - 0x00367: Matrix memory mapping table + * | 0x00368 - 0x0036F: Reserved (leave zero) + * | Unlicensed multicart: + * | 0x00328: Bank value + * | 0x00329: Offset value + * | 0x0032A: Size value + * | 0x0032B: SRAM active value + * | 0x0032C: Unknown value + * | 0x0032D: Current size + * | 0x0032E - 0x0032F: Current bank/offset + * | 0x00330 - 0x00333: Next settle event + * | 0x00334 - 0x00337: Flags + * | bit 0: Is settling occuring? + * | bits 1 - 31: Reserved + * | 0x00338 - 0x0036F: Reserved (leave zero) * 0x00370 - 0x0037F: Audio FIFO A samples * 0x00380 - 0x0038F: Audio FIFO B samples * 0x00390 - 0x003CF: Audio rendered samples @@ -269,9 +287,14 @@ DECL_BITS(GBASerializedHWFlags1, LightCounter, 4, 12); DECL_BITFIELD(GBASerializedHWFlags2, uint8_t); DECL_BITS(GBASerializedHWFlags2, TiltState, 0, 2); DECL_BITS(GBASerializedHWFlags2, GbpInputsPosted, 2, 2); -DECL_BITS(GBASerializedHWFlags2, GbpTxPosition, 4, 5); +DECL_BITS(GBASerializedHWFlags2, GbpTxPosition, 4, 4); -DECL_BITFIELD(GBASerializedHWFlags3, uint16_t); +DECL_BITFIELD(GBASerializedUnlCartFlags, uint16_t); +DECL_BITS(GBASerializedUnlCartFlags, Type, 0, 5); +DECL_BITS(GBASerializedUnlCartFlags, Subtype, 5, 3); + +DECL_BITFIELD(GBASerializedMulticartFlags, uint32_t); +DECL_BIT(GBASerializedMulticartFlags, DustSettling, 0); DECL_BITFIELD(GBASerializedSavedataFlags, uint8_t); DECL_BITS(GBASerializedSavedataFlags, FlashState, 0, 2); @@ -370,7 +393,7 @@ struct GBASerializedState { GBASerializedHWFlags1 flags1; uint8_t lightSample; GBASerializedHWFlags2 flags2; - GBASerializedHWFlags3 flags3; + GBASerializedUnlCartFlags unlCartFlags; uint32_t sioNextEvent; } hw; @@ -407,8 +430,23 @@ struct GBASerializedState { uint32_t nextIrq; int32_t biosStall; - uint32_t matrixMappings[16]; - uint32_t reservedMatrix[2]; + union { + struct { + uint32_t mappings[16]; + uint32_t reserved[2]; + } matrix2; + struct { + uint8_t bank; + uint8_t offset; + uint8_t size; + uint8_t sramActive; + uint8_t unk; + uint8_t currentSize; + uint16_t currentOffset; + uint32_t settleNextEvent; + GBASerializedMulticartFlags flags; + } multicart; + }; struct { int8_t chA[16]; diff --git a/src/gba/CMakeLists.txt b/src/gba/CMakeLists.txt index 01a968a41b3..71ab7bbb199 100644 --- a/src/gba/CMakeLists.txt +++ b/src/gba/CMakeLists.txt @@ -6,6 +6,7 @@ set(SOURCE_FILES cart/ereader.c cart/gpio.c cart/matrix.c + cart/unlicensed.c cart/vfame.c cheats.c cheats/codebreaker.c diff --git a/src/gba/cart/matrix.c b/src/gba/cart/matrix.c index c594d66b913..9ccbe883235 100644 --- a/src/gba/cart/matrix.c +++ b/src/gba/cart/matrix.c @@ -109,7 +109,7 @@ void GBAMatrixSerialize(const struct GBA* gba, struct GBASerializedState* state) int i; for (i = 0; i < 16; ++i) { - STORE_32(gba->memory.matrix.mappings[i], i << 2, state->matrixMappings); + STORE_32(gba->memory.matrix.mappings[i], i << 2, state->matrix2.mappings); } } @@ -121,7 +121,7 @@ void GBAMatrixDeserialize(struct GBA* gba, const struct GBASerializedState* stat int i; for (i = 0; i < 16; ++i) { - LOAD_32(gba->memory.matrix.mappings[i], i << 2, state->matrixMappings); + LOAD_32(gba->memory.matrix.mappings[i], i << 2, state->matrix2.mappings); gba->memory.matrix.paddr = gba->memory.matrix.mappings[i]; gba->memory.matrix.vaddr = i << 9; _remapMatrix(gba); diff --git a/src/gba/cart/unlicensed.c b/src/gba/cart/unlicensed.c new file mode 100644 index 00000000000..318ffe891e5 --- /dev/null +++ b/src/gba/cart/unlicensed.c @@ -0,0 +1,219 @@ +/* Copyright (c) 2013-2024 Jeffrey Pfau + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +#include + +#include +#include +#include +#include + +#define MULTI_SETTLE 512 +#define MULTI_BLOCK 0x80000 +#define MULTI_BANK 0x2000000 + +enum GBMulticartCfgOffset { + GBA_MULTICART_CFG_BANK = 0x2, + GBA_MULTICART_CFG_OFFSET = 0x3, + GBA_MULTICART_CFG_SIZE = 0x4, + GBA_MULTICART_CFG_SRAM = 0x5, + GBA_MULTICART_CFG_UNK = 0x6, +}; + +static void _multicartSettle(struct mTiming* timing, void* context, uint32_t cyclesLate); + +void GBAUnlCartInit(struct GBA* gba) { + memset(&gba->memory.unl, 0, sizeof(gba->memory.unl)); +} + +void GBAUnlCartDetect(struct GBA* gba) { + if (!gba->memory.rom) { + return; + } + + struct GBACartridge* cart = (struct GBACartridge*) gba->memory.rom; + if (GBAVFameDetect(&gba->memory.unl.vfame, gba->memory.rom, gba->memory.romSize, gba->romCrc32)) { + gba->memory.unl.type = GBA_UNL_CART_VFAME; + return; + } + + if (memcmp(&cart->id, "AXVJ01", 6) == 0) { + if (gba->romVf && gba->romVf->size(gba->romVf) >= 0x04000000) { + // Bootleg multicart + // TODO: Identify a bit more precisely + gba->isPristine = false; + GBASavedataInitSRAM(&gba->memory.savedata); + gba->memory.unl.type = GBA_UNL_CART_MULTICART; + + gba->romVf->unmap(gba->romVf, gba->memory.rom, gba->memory.romSize); + gba->memory.unl.multi.fullSize = gba->romVf->size(gba->romVf); + gba->memory.unl.multi.rom = gba->romVf->map(gba->romVf, gba->memory.unl.multi.fullSize, MAP_READ); + gba->memory.rom = gba->memory.unl.multi.rom; + gba->memory.hw.gpioBase = NULL; + + gba->memory.unl.multi.settle.context = gba; + gba->memory.unl.multi.settle.callback = _multicartSettle; + gba->memory.unl.multi.settle.name = "GBA Unlicensed Multicart Settle"; + gba->memory.unl.multi.settle.priority = 0x71; + } + } +} + +void GBAUnlCartReset(struct GBA* gba) { + if (gba->memory.unl.type == GBA_UNL_CART_MULTICART) { + gba->memory.unl.multi.bank = 0; + gba->memory.unl.multi.offset = 0; + gba->memory.unl.multi.size = 0; + gba->memory.rom = gba->memory.unl.multi.rom; + gba->memory.romSize = GBA_SIZE_ROM0; + } +} + +void GBAUnlCartUnload(struct GBA* gba) { + if (gba->memory.unl.type == GBA_UNL_CART_MULTICART && gba->romVf) { + gba->romVf->unmap(gba->romVf, gba->memory.unl.multi.rom, gba->memory.unl.multi.size); + gba->memory.unl.multi.rom = NULL; + gba->memory.rom = NULL; + } +} + +void GBAUnlCartWriteSRAM(struct GBA* gba, uint32_t address, uint8_t value) { + struct GBAUnlCart* unl = &gba->memory.unl; + + switch (unl->type) { + case GBA_UNL_CART_VFAME: + GBAVFameSramWrite(&unl->vfame, address, value, gba->memory.savedata.data); + return; + case GBA_UNL_CART_MULTICART: + mLOG(GBA_MEM, DEBUG, "Multicart writing SRAM %06X:%02X", address, value); + switch (address) { + case GBA_MULTICART_CFG_BANK: + unl->multi.bank = value >> 4; + mTimingDeschedule(&gba->timing, &unl->multi.settle); + mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); + break; + case GBA_MULTICART_CFG_OFFSET: + unl->multi.offset = value & 0x3F; + mTimingDeschedule(&gba->timing, &unl->multi.settle); + mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); + break; + case GBA_MULTICART_CFG_SIZE: + unl->multi.size = 0x40 - (value & 0x3F); + mTimingDeschedule(&gba->timing, &unl->multi.settle); + mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); + break; + case GBA_MULTICART_CFG_SRAM: + if (value == 0 && unl->multi.sramActive) { + unl->multi.sramActive = false; + } else if (value == 1 && !unl->multi.sramActive) { + unl->multi.sramActive = true; + } + break; + case GBA_MULTICART_CFG_UNK: + // TODO: What does this do? + unl->multi.unk = value; + break; + default: + break; + } + break; + case GBA_UNL_CART_NONE: + break; + } + + gba->memory.savedata.data[address & (GBA_SIZE_SRAM - 1)] = value; +} + +static void _multicartSettle(struct mTiming* timing, void* context, uint32_t cyclesLate) { + UNUSED(timing); + UNUSED(cyclesLate); + struct GBA* gba = context; + mLOG(GBA_MEM, INFO, "Switching to bank %i offset %i, size %i", + gba->memory.unl.multi.bank, gba->memory.unl.multi.offset, gba->memory.unl.multi.size); + size_t offset = gba->memory.unl.multi.bank * (MULTI_BANK >> 2) + gba->memory.unl.multi.offset * (MULTI_BLOCK >> 2); + size_t size = gba->memory.unl.multi.size * MULTI_BLOCK; + if (offset * 4 >= gba->memory.unl.multi.fullSize || offset * 4 + size > gba->memory.unl.multi.fullSize) { + mLOG(GBA_MEM, GAME_ERROR, "Bank switch was out of bounds, %07" PRIz "X + %" PRIz "X > %07" PRIz "X", + offset * 4, size, gba->memory.unl.multi.fullSize); + return; + } + gba->memory.rom = gba->memory.unl.multi.rom + offset; + gba->memory.romSize = size; +} + +void GBAUnlCartSerialize(const struct GBA* gba, struct GBASerializedState* state) { + GBASerializedUnlCartFlags flags = 0; + const struct GBAUnlCart* unl = &gba->memory.unl; + switch (unl->type) { + case GBA_UNL_CART_NONE: + return; + case GBA_UNL_CART_VFAME: + flags = GBASerializedUnlCartFlagsSetType(flags, GBA_UNL_CART_VFAME); + flags = GBASerializedUnlCartFlagsSetSubtype(flags, unl->vfame.cartType); + mLOG(GBA_MEM, STUB, "Vast Fame save states are not yet implemented"); + break; + case GBA_UNL_CART_MULTICART: + flags = GBASerializedUnlCartFlagsSetType(0, GBA_UNL_CART_MULTICART); + state->multicart.bank = unl->multi.bank; + state->multicart.offset = unl->multi.offset; + state->multicart.size = unl->multi.size; + state->multicart.sramActive = unl->multi.sramActive; + state->multicart.unk = unl->multi.unk; + state->multicart.currentSize = gba->memory.romSize / MULTI_BLOCK; + STORE_16((gba->memory.rom - unl->multi.rom) / 0x20000, 0, &state->multicart.currentOffset); + STORE_32(unl->multi.settle.when, 0, &state->multicart.settleNextEvent); + if (mTimingIsScheduled(&gba->timing, &unl->multi.settle)) { + STORE_32(GBASerializedMulticartFlagsFillDustSettling(0), 0, &state->multicart.flags); + } + break; + } + STORE_32(flags, 0, &state->hw.unlCartFlags); +} + +void GBAUnlCartDeserialize(struct GBA* gba, const struct GBASerializedState* state) { + GBASerializedUnlCartFlags flags; + struct GBAUnlCart* unl = &gba->memory.unl; + + LOAD_32(flags, 0, &state->hw.unlCartFlags); + enum GBAUnlCartType type = GBASerializedUnlCartFlagsGetType(flags); + if (type != unl->type) { + mLOG(GBA_STATE, WARN, "Save state expects different bootleg type; not restoring bootleg state"); + return; + } + + uint32_t when; + uint32_t offset; + size_t size; + GBASerializedMulticartFlags multiFlags; + + switch (type) { + case GBA_UNL_CART_NONE: + return; + case GBA_UNL_CART_VFAME: + mLOG(GBA_MEM, STUB, "Vast Fame save states are not yet implemented"); + return; + case GBA_UNL_CART_MULTICART: + unl->multi.bank = state->multicart.bank; + unl->multi.offset = state->multicart.offset; + unl->multi.size = state->multicart.size; + unl->multi.sramActive = state->multicart.sramActive; + unl->multi.unk = state->multicart.unk; + size = state->multicart.currentSize * MULTI_BLOCK; + LOAD_16(offset, 0, &state->multicart.currentOffset); + offset *= 0x20000; + if (offset * 4 >= gba->memory.unl.multi.fullSize || offset * 4 + size > gba->memory.unl.multi.fullSize) { + mLOG(GBA_STATE, WARN, "Multicart save state has corrupted ROM offset"); + } else { + gba->memory.romSize = size; + gba->memory.rom = unl->multi.rom + offset; + } + LOAD_32(multiFlags, 0, &state->multicart.flags); + if (GBASerializedMulticartFlagsIsDustSettling(multiFlags)) { + LOAD_32(when, 0, &state->multicart.settleNextEvent); + mTimingSchedule(&gba->timing, &unl->multi.settle, when); + } + break; + } +} diff --git a/src/gba/cart/vfame.c b/src/gba/cart/vfame.c index b66b7d756e1..a45a420c007 100644 --- a/src/gba/cart/vfame.c +++ b/src/gba/cart/vfame.c @@ -4,7 +4,7 @@ * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ -#include +#include #include #include @@ -60,25 +60,19 @@ static int8_t _modifySramValue(enum GBAVFameCartType type, uint8_t value, int mo static uint32_t _modifySramAddress(enum GBAVFameCartType type, uint32_t address, int mode); static int _reorderBits(uint32_t value, const uint8_t* reordering, int reorderLength); -void GBAVFameInit(struct GBAVFameCart* cart) { - cart->cartType = VFAME_NO; - cart->sramMode = -1; - cart->romMode = -1; - cart->acceptingModeChange = false; -} - -void GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize, uint32_t crc32) { - cart->cartType = VFAME_NO; - +bool GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize, uint32_t crc32) { // The initialisation code is also present & run in the dumps of Digimon Ruby & Sapphire from hacked/deprotected reprint carts, // which would break if run in "proper" VFame mode so we need to exclude those.. if (romSize == 0x2000000) { // the deprotected dumps are 32MB but no real VF games are this size - return; + return false; } + bool detected = false; + // Most games have the same init sequence in the same place // but LOTR/Mo Jie Qi Bing doesn't, probably because it's based on the Kiki KaiKai engine, so just detect based on its title if (memcmp(INIT_SEQUENCE, &rom[0x57], sizeof(INIT_SEQUENCE)) == 0 || memcmp("\0LORD\0WORD\0\0AKIJ", &((struct GBACartridge*) rom)->title, 16) == 0) { + detected = true; cart->cartType = VFAME_STANDARD; mLOG(GBA_MEM, INFO, "Vast Fame game detected"); } @@ -87,13 +81,23 @@ void GBAVFameDetect(struct GBAVFameCart* cart, uint32_t* rom, size_t romSize, ui // Their initialisation seems to be identical so the difference must be in the cart HW itself // Other undumped games may have similar differences if (memcmp("George Sango", &((struct GBACartridge*) rom)->title, 12) == 0) { + detected = true; cart->cartType = VFAME_GEORGE; mLOG(GBA_MEM, INFO, "George mode"); } else if (crc32 == DIGIMON_SAPPHIRE_CHINESE_CRC32) { // Chinese version of Digimon Sapphire; header is identical to the English version which uses the normal reordering // so we have to use some other way to detect it + detected = true; cart->cartType = VFAME_ALTERNATE; } + + if (detected) { + cart->sramMode = -1; + cart->romMode = -1; + cart->acceptingModeChange = false; + } + + return detected; } // This is not currently being used but would be called on ROM reads @@ -235,7 +239,6 @@ static uint32_t _patternRightShift2(uint32_t addr) { } void GBAVFameSramWrite(struct GBAVFameCart* cart, uint32_t address, uint8_t value, uint8_t* sramData) { - address &= 0x00FFFFFF; // A certain sequence of writes to SRAM FFF8->FFFC can enable or disable "mode change" mode // Currently unknown if these writes have to be sequential, or what happens if you write different values, if anything if (address >= 0xFFF8 && address <= 0xFFFC) { diff --git a/src/gba/gba.c b/src/gba/gba.c index 6b833838e47..1b84038ae1a 100644 --- a/src/gba/gba.c +++ b/src/gba/gba.c @@ -140,6 +140,9 @@ static void GBAInit(void* cpu, struct mCPUComponent* component) { void GBAUnloadROM(struct GBA* gba) { GBAMemoryClearAGBPrint(gba); + if (gba->memory.unl.type) { + GBAUnlCartUnload(gba); + } if (gba->memory.rom && !gba->isPristine) { if (gba->yankedRomSize) { gba->yankedRomSize = 0; @@ -492,7 +495,7 @@ bool GBALoadROM(struct GBA* gba, struct VFile* vf) { gba->cpu->memory.setActiveRegion(gba->cpu, gba->cpu->gprs[ARM_PC]); } GBAHardwareInit(&gba->memory.hw, &((uint16_t*) gba->memory.rom)[GPIO_REG_DATA >> 1]); - GBAVFameDetect(&gba->memory.vfame, gba->memory.rom, gba->memory.romSize, gba->romCrc32); + GBAUnlCartDetect(gba); // TODO: error check return true; } diff --git a/src/gba/io.c b/src/gba/io.c index cb6058f7f6b..a72171c1fdb 100644 --- a/src/gba/io.c +++ b/src/gba/io.c @@ -1033,6 +1033,7 @@ void GBAIOSerialize(struct GBA* gba, struct GBASerializedState* state) { STORE_32(gba->bus, 0, &state->bus); GBAHardwareSerialize(&gba->memory.hw, state); + GBAUnlCartSerialize(gba, state); } void GBAIODeserialize(struct GBA* gba, const struct GBASerializedState* state) { @@ -1082,4 +1083,5 @@ void GBAIODeserialize(struct GBA* gba, const struct GBASerializedState* state) { GBADMARecalculateCycles(gba); GBADMAUpdate(gba); GBAHardwareDeserialize(&gba->memory.hw, state); + GBAUnlCartDeserialize(gba, state); } diff --git a/src/gba/memory.c b/src/gba/memory.c index 87e31f746ea..53d0f7cc938 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -93,7 +93,7 @@ void GBAMemoryInit(struct GBA* gba) { gba->memory.iwram = &gba->memory.wram[GBA_SIZE_EWRAM >> 2]; GBADMAInit(gba); - GBAVFameInit(&gba->memory.vfame); + GBAUnlCartInit(gba); gba->memory.ereader.p = gba; gba->memory.ereader.dots = NULL; @@ -139,6 +139,7 @@ void GBAMemoryReset(struct GBA* gba) { } GBADMAReset(gba); + GBAUnlCartReset(gba); memset(&gba->memory.matrix, 0, sizeof(gba->memory.matrix)); } @@ -411,7 +412,7 @@ static void GBASetActiveRegion(struct ARMCore* cpu, uint32_t address) { wait += waitstatesRegion[address >> BASE_OFFSET]; \ if ((address & (GBA_SIZE_ROM0 - 4)) < memory->romSize) { \ LOAD_32(value, address & (GBA_SIZE_ROM0 - 4), memory->rom); \ - } else if (memory->vfame.cartType) { \ + } else if (memory->unl.type == GBA_UNL_CART_VFAME) { \ value = GBAVFameGetPatternValue(address, 32); \ } else { \ mLOG(GBA_MEM, GAME_ERROR, "Out of bounds ROM Load32: 0x%08X", address); \ @@ -576,7 +577,7 @@ uint32_t GBALoad16(struct ARMCore* cpu, uint32_t address, int* cycleCounter) { wait = memory->waitstatesNonseq16[address >> BASE_OFFSET]; if ((address & (GBA_SIZE_ROM0 - 2)) < memory->romSize) { LOAD_16(value, address & (GBA_SIZE_ROM0 - 2), memory->rom); - } else if (memory->vfame.cartType) { + } else if (memory->unl.type == GBA_UNL_CART_VFAME) { value = GBAVFameGetPatternValue(address, 16); } else if ((address & (GBA_SIZE_ROM0 - 2)) >= AGB_PRINT_BASE) { uint32_t agbPrintAddr = address & 0x00FFFFFF; @@ -601,7 +602,7 @@ uint32_t GBALoad16(struct ARMCore* cpu, uint32_t address, int* cycleCounter) { value = GBACartEReaderRead(&memory->ereader, address); } else if ((address & (GBA_SIZE_ROM0 - 2)) < memory->romSize) { LOAD_16(value, address & (GBA_SIZE_ROM0 - 2), memory->rom); - } else if (memory->vfame.cartType) { + } else if (memory->unl.type == GBA_UNL_CART_VFAME) { value = GBAVFameGetPatternValue(address, 16); } else { mLOG(GBA_MEM, GAME_ERROR, "Out of bounds ROM Load16: 0x%08X", address); @@ -692,7 +693,7 @@ uint32_t GBALoad8(struct ARMCore* cpu, uint32_t address, int* cycleCounter) { wait = memory->waitstatesNonseq16[address >> BASE_OFFSET]; if ((address & (GBA_SIZE_ROM0 - 1)) < memory->romSize) { value = ((uint8_t*) memory->rom)[address & (GBA_SIZE_ROM0 - 1)]; - } else if (memory->vfame.cartType) { + } else if (memory->unl.type == GBA_UNL_CART_VFAME) { value = GBAVFameGetPatternValue(address, 8); } else { mLOG(GBA_MEM, GAME_ERROR, "Out of bounds ROM Load8: 0x%08X", address); @@ -1056,8 +1057,8 @@ void GBAStore8(struct ARMCore* cpu, uint32_t address, int8_t value, int* cycleCo } else if (memory->savedata.type == GBA_SAVEDATA_FLASH512 || memory->savedata.type == GBA_SAVEDATA_FLASH1M) { GBASavedataWriteFlash(&memory->savedata, address, value); } else if (memory->savedata.type == GBA_SAVEDATA_SRAM) { - if (memory->vfame.cartType) { - GBAVFameSramWrite(&memory->vfame, address, value, memory->savedata.data); + if (memory->unl.type) { + GBAUnlCartWriteSRAM(gba, address & 0xFFFF, value); } else { memory->savedata.data[address & (GBA_SIZE_SRAM - 1)] = value; } diff --git a/src/gba/overrides.c b/src/gba/overrides.c index a63616e613b..1e3e9e6fc42 100644 --- a/src/gba/overrides.c +++ b/src/gba/overrides.c @@ -377,6 +377,12 @@ void GBAOverrideApplyDefaults(struct GBA* gba, const struct Configuration* overr struct GBACartridgeOverride override = { .idleLoop = GBA_IDLE_LOOP_NONE }; const struct GBACartridge* cart = (const struct GBACartridge*) gba->memory.rom; if (cart) { + if (gba->memory.unl.type == GBA_UNL_CART_MULTICART) { + override.savetype = GBA_SAVEDATA_SRAM; + GBAOverrideApply(gba, &override); + return; + } + memcpy(override.id, &cart->id, sizeof(override.id)); static const uint32_t pokemonTable[] = { diff --git a/src/gba/serialize.c b/src/gba/serialize.c index 5eabaedea8a..9d6130385b1 100644 --- a/src/gba/serialize.c +++ b/src/gba/serialize.c @@ -32,8 +32,17 @@ void GBASerialize(struct GBA* gba, struct GBASerializedState* state) { STORE_64LE(gba->timing.globalCycles, 0, &state->globalCycles); if (gba->memory.rom) { - state->id = ((struct GBACartridge*) gba->memory.rom)->id; - memcpy(state->title, ((struct GBACartridge*) gba->memory.rom)->title, sizeof(state->title)); + switch (gba->memory.unl.type) { + case GBA_UNL_CART_NONE: + case GBA_UNL_CART_VFAME: + state->id = ((struct GBACartridge*) gba->memory.rom)->id; + memcpy(state->title, ((struct GBACartridge*) gba->memory.rom)->title, sizeof(state->title)); + break; + case GBA_UNL_CART_MULTICART: + state->id = ((struct GBACartridge*) gba->memory.unl.multi.rom)->id; + memcpy(state->title, ((struct GBACartridge*) gba->memory.unl.multi.rom)->title, sizeof(state->title)); + break; + } } else { state->id = 0; memset(state->title, 0, sizeof(state->title)); @@ -106,9 +115,21 @@ bool GBADeserialize(struct GBA* gba, const struct GBASerializedState* state) { error = true; } } - if (gba->memory.rom && (state->id != ((struct GBACartridge*) gba->memory.rom)->id || memcmp(state->title, ((struct GBACartridge*) gba->memory.rom)->title, sizeof(state->title)))) { - mLOG(GBA_STATE, WARN, "Savestate is for a different game"); - error = true; + if (gba->memory.rom) { + struct GBACartridge* cart; + switch (gba->memory.unl.type) { + case GBA_UNL_CART_NONE: + case GBA_UNL_CART_VFAME: + cart = (struct GBACartridge*) gba->memory.rom; + break; + case GBA_UNL_CART_MULTICART: + cart = (struct GBACartridge*) gba->memory.unl.multi.rom; + break; + } + if (state->id != cart->id || memcmp(state->title, cart->title, sizeof(state->title))) { + mLOG(GBA_STATE, WARN, "Savestate is for a different game"); + error = true; + } } else if (!gba->memory.rom && state->id != 0) { mLOG(GBA_STATE, WARN, "Savestate is for a game, but no game loaded"); error = true; From dc263295dd58f6b03726767220f9b401a53a971c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 17 Nov 2024 03:34:33 -0800 Subject: [PATCH 277/338] GBA Memory: Add unlicensed cart write handling stub --- include/mgba/internal/gba/cart/unlicensed.h | 1 + src/gba/cart/unlicensed.c | 13 +++++++++++++ src/gba/memory.c | 4 ++++ 3 files changed, 18 insertions(+) diff --git a/include/mgba/internal/gba/cart/unlicensed.h b/include/mgba/internal/gba/cart/unlicensed.h index ec13abb55c7..816aa1dfd11 100644 --- a/include/mgba/internal/gba/cart/unlicensed.h +++ b/include/mgba/internal/gba/cart/unlicensed.h @@ -60,6 +60,7 @@ void GBAUnlCartReset(struct GBA*); void GBAUnlCartUnload(struct GBA*); void GBAUnlCartDetect(struct GBA*); void GBAUnlCartWriteSRAM(struct GBA*, uint32_t address, uint8_t value); +void GBAUnlCartWriteROM(struct GBA*, uint32_t address, uint16_t value); struct GBASerializedState; void GBAUnlCartSerialize(const struct GBA* gba, struct GBASerializedState* state); diff --git a/src/gba/cart/unlicensed.c b/src/gba/cart/unlicensed.c index 318ffe891e5..442ec9865d2 100644 --- a/src/gba/cart/unlicensed.c +++ b/src/gba/cart/unlicensed.c @@ -126,6 +126,19 @@ void GBAUnlCartWriteSRAM(struct GBA* gba, uint32_t address, uint8_t value) { gba->memory.savedata.data[address & (GBA_SIZE_SRAM - 1)] = value; } +void GBAUnlCartWriteROM(struct GBA* gba, uint32_t address, uint16_t value) { + struct GBAUnlCart* unl = &gba->memory.unl; + + switch (unl->type) { + case GBA_UNL_CART_VFAME: + case GBA_UNL_CART_NONE: + break; + case GBA_UNL_CART_MULTICART: + mLOG(GBA_MEM, STUB, "Unimplemented writing to ROM %07X:%04X", address, value); + break; + } +} + static void _multicartSettle(struct mTiming* timing, void* context, uint32_t cyclesLate) { UNUSED(timing); UNUSED(cyclesLate); diff --git a/src/gba/memory.c b/src/gba/memory.c index 53d0f7cc938..1561aef91d1 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -963,6 +963,10 @@ void GBAStore16(struct ARMCore* cpu, uint32_t address, int16_t value, int* cycle break; } } + if (memory->unl.type) { + GBAUnlCartWriteROM(gba, address & (GBA_SIZE_ROM0 - 1), value); + break; + } mLOG(GBA_MEM, GAME_ERROR, "Bad cartridge Store16: 0x%08X", address); break; case GBA_REGION_ROM2_EX: From d9b43463d0e1d8b006c5333edccecb6c2639d43b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 18 Nov 2024 00:43:27 -0800 Subject: [PATCH 278/338] CMake: Set both -mmacosx-version-min and CMAKE_OSX_DEPLOYMENT_TARGET --- CMakeLists.txt | 2 +- src/platform/qt/CMakeLists.txt | 1 + src/platform/sdl/CMakeLists.txt | 1 + 3 files changed, 3 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 7857e9c388e..dd4a08829e8 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -249,7 +249,7 @@ if(APPLE) endif() if(NOT CMAKE_SYSTEM_VERSION VERSION_LESS "10.0") # Darwin 10.x is Mac OS X 10.6 - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mmacosx-version-min=10.6") + set(CMAKE_OSX_DEPLOYMENT_TARGET "10.6") endif() # Not supported until Xcode 9 if(CMAKE_C_COMPILER_ID STREQUAL "AppleClang" AND CMAKE_C_COMPILER_VERSION VERSION_LESS "9") diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index 3cfe83ad0e6..530fe4cfe82 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -79,6 +79,7 @@ if(APPLE) endif() set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mmacosx-version-min=${MIN_VER}") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mmacosx-version-min=${MIN_VER}") + set(CMAKE_OSX_DEPLOYMENT_TARGET ${MIN_VER}) if (CMAKE_CXX_COMPILER_ID MATCHES "Clang") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -stdlib=libc++") endif() diff --git a/src/platform/sdl/CMakeLists.txt b/src/platform/sdl/CMakeLists.txt index d62c74694ab..e4dd17673d9 100644 --- a/src/platform/sdl/CMakeLists.txt +++ b/src/platform/sdl/CMakeLists.txt @@ -24,6 +24,7 @@ if (SDL_VERSION EQUAL "2") if(APPLE) set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mmacosx-version-min=10.7") + set(CMAKE_OSX_DEPLOYMENT_TARGET "10.7") endif() set(SDLMAIN_LIBRARY ${SDL2MAIN_LIBRARY}) endif() From 2a0ed00d0d41e44f587168ea354f0a5ab15acba5 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 18 Nov 2024 00:55:55 -0800 Subject: [PATCH 279/338] CMake: I'm tired of putting out fires --- CMakeLists.txt | 1 + src/platform/qt/CMakeLists.txt | 2 -- src/platform/sdl/CMakeLists.txt | 1 - 3 files changed, 1 insertion(+), 3 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index dd4a08829e8..5daa78976d9 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -759,6 +759,7 @@ if(USE_ELF) endif() if (USE_DISCORD_RPC) + set(CMAKE_OSX_DEPLOYMENT_TARGET "10.7") add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/src/third-party/discord-rpc discord-rpc EXCLUDE_FROM_ALL) list(APPEND FEATURES DISCORD_RPC) include_directories(AFTER ${CMAKE_CURRENT_SOURCE_DIR}/src/third-party/discord-rpc/include) diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index 530fe4cfe82..3134512f26c 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -77,8 +77,6 @@ if(APPLE) else() set(MIN_VER 10.8) endif() - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mmacosx-version-min=${MIN_VER}") - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mmacosx-version-min=${MIN_VER}") set(CMAKE_OSX_DEPLOYMENT_TARGET ${MIN_VER}) if (CMAKE_CXX_COMPILER_ID MATCHES "Clang") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -stdlib=libc++") diff --git a/src/platform/sdl/CMakeLists.txt b/src/platform/sdl/CMakeLists.txt index e4dd17673d9..5246f959b96 100644 --- a/src/platform/sdl/CMakeLists.txt +++ b/src/platform/sdl/CMakeLists.txt @@ -23,7 +23,6 @@ if (SDL_VERSION EQUAL "2") endif() if(APPLE) - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mmacosx-version-min=10.7") set(CMAKE_OSX_DEPLOYMENT_TARGET "10.7") endif() set(SDLMAIN_LIBRARY ${SDL2MAIN_LIBRARY}) From cca3267ef6afb411ab24f76938a1c49a82923062 Mon Sep 17 00:00:00 2001 From: CasualPokePlayer <50538166+CasualPokePlayer@users.noreply.github.com> Date: Tue, 19 Nov 2024 22:46:23 -0800 Subject: [PATCH 280/338] Serialize light counter to the correct bitfield Resolves #3294 --- src/gba/cart/gpio.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gba/cart/gpio.c b/src/gba/cart/gpio.c index 73ed859c549..0bffbc08846 100644 --- a/src/gba/cart/gpio.c +++ b/src/gba/cart/gpio.c @@ -480,11 +480,11 @@ void GBAHardwareSerialize(const struct GBACartridgeHardware* hw, struct GBASeria STORE_16(hw->tiltY, 0, &state->hw.tiltSampleY); state->hw.lightSample = hw->lightSample; flags1 = GBASerializedHWFlags1SetLightEdge(flags1, hw->lightEdge); + flags1 = GBASerializedHWFlags1SetLightCounter(flags1, hw->lightCounter); STORE_16(flags1, 0, &state->hw.flags1); GBASerializedHWFlags2 flags2 = 0; flags2 = GBASerializedHWFlags2SetTiltState(flags2, hw->tiltState); - flags2 = GBASerializedHWFlags1SetLightCounter(flags2, hw->lightCounter); // GBP/SIO stuff is only here for legacy reasons flags2 = GBASerializedHWFlags2SetGbpInputsPosted(flags2, hw->p->sio.gbp.inputsPosted); From f930184efba64e4c155e67f3495a7d64147243ce Mon Sep 17 00:00:00 2001 From: Adam Higerd Date: Tue, 19 Nov 2024 16:41:42 -0600 Subject: [PATCH 281/338] Qt: save shader settings when OK/Apply clicked --- src/platform/qt/SettingsView.cpp | 5 +++++ src/platform/qt/SettingsView.h | 1 + src/platform/qt/ShaderSelector.cpp | 8 ++++---- src/platform/qt/ShaderSelector.h | 1 + 4 files changed, 11 insertions(+), 4 deletions(-) diff --git a/src/platform/qt/SettingsView.cpp b/src/platform/qt/SettingsView.cpp index c86dcf06eef..f9357bbcb88 100644 --- a/src/platform/qt/SettingsView.cpp +++ b/src/platform/qt/SettingsView.cpp @@ -423,8 +423,11 @@ void SettingsView::setShaderSelector(ShaderSelector* shaderSelector) { } if (!m_shader) { m_ui.stackedWidget->removeWidget(m_dummyShader); + } else { + QObject::disconnect(m_shader, nullptr, this, nullptr); } m_shader = shaderSelector; + QObject::connect(this, &SettingsView::saveSettingsRequested, m_shader, &ShaderSelector::saveSettings); if (shaderSelector) { addPage(tr("Shaders"), m_shader, Page::SHADERS); } else { @@ -683,6 +686,8 @@ void SettingsView::updateConfig() { saveSetting("gb.colors", gbColors); #endif + emit saveSettingsRequested(); + m_controller->write(); emit pathsChanged(); diff --git a/src/platform/qt/SettingsView.h b/src/platform/qt/SettingsView.h index 85cf35a9981..1e45ec87aca 100644 --- a/src/platform/qt/SettingsView.h +++ b/src/platform/qt/SettingsView.h @@ -61,6 +61,7 @@ Q_OBJECT void pathsChanged(); void languageChanged(); void libraryCleared(); + void saveSettingsRequested(); public slots: void selectPage(Page); diff --git a/src/platform/qt/ShaderSelector.cpp b/src/platform/qt/ShaderSelector.cpp index 44bca3855a8..ac214349e41 100644 --- a/src/platform/qt/ShaderSelector.cpp +++ b/src/platform/qt/ShaderSelector.cpp @@ -49,6 +49,10 @@ ShaderSelector::~ShaderSelector() { clear(); } +void ShaderSelector::saveSettings() { + emit saved(); +} + void ShaderSelector::clear() { m_ui.shaderName->setText(tr("No shader active")); m_ui.description->clear(); @@ -269,10 +273,6 @@ void ShaderSelector::buttonPressed(QAbstractButton* button) { case QDialogButtonBox::Reset: emit reset(); break; - case QDialogButtonBox::Ok: - emit saved(); - close(); - break; case QDialogButtonBox::RestoreDefaults: emit resetToDefault(); break; diff --git a/src/platform/qt/ShaderSelector.h b/src/platform/qt/ShaderSelector.h index 4dc9214af0b..0726b5edfbe 100644 --- a/src/platform/qt/ShaderSelector.h +++ b/src/platform/qt/ShaderSelector.h @@ -28,6 +28,7 @@ Q_OBJECT ~ShaderSelector(); public slots: + void saveSettings(); void refreshShaders(); void clear(); From a2e7e5b902043c567167cc4753e74a973209eada Mon Sep 17 00:00:00 2001 From: Adam Higerd Date: Tue, 19 Nov 2024 16:50:12 -0600 Subject: [PATCH 282/338] Qt: don't save shader choice until OK/Apply is clicked --- src/platform/qt/SettingsView.cpp | 1 + src/platform/qt/ShaderSelector.cpp | 40 +++++++++++++++++++++++------- src/platform/qt/ShaderSelector.h | 7 +++--- 3 files changed, 36 insertions(+), 12 deletions(-) diff --git a/src/platform/qt/SettingsView.cpp b/src/platform/qt/SettingsView.cpp index f9357bbcb88..a7be4026935 100644 --- a/src/platform/qt/SettingsView.cpp +++ b/src/platform/qt/SettingsView.cpp @@ -428,6 +428,7 @@ void SettingsView::setShaderSelector(ShaderSelector* shaderSelector) { } m_shader = shaderSelector; QObject::connect(this, &SettingsView::saveSettingsRequested, m_shader, &ShaderSelector::saveSettings); + QObject::connect(m_ui.buttonBox, &QDialogButtonBox::rejected, m_shader, &ShaderSelector::revert); if (shaderSelector) { addPage(tr("Shaders"), m_shader, Page::SHADERS); } else { diff --git a/src/platform/qt/ShaderSelector.cpp b/src/platform/qt/ShaderSelector.cpp index ac214349e41..473b1d7e9b8 100644 --- a/src/platform/qt/ShaderSelector.cpp +++ b/src/platform/qt/ShaderSelector.cpp @@ -50,7 +50,25 @@ ShaderSelector::~ShaderSelector() { } void ShaderSelector::saveSettings() { - emit saved(); + QString oldPath = config->getOption("shader"); + if (oldPath != m_shaderPath) { + if (m_shaderPath.isEmpty()) { + clearShader(true); + } else { + loadShader(m_shaderPath, true); + } + } + emit saveSettingsRequested(); +} + +void ShaderSelector::revert() { + QString shaderPath = m_config->getOption("shader"); + if (shaderPath.isEmpty()) { + clearShader(); + } else { + loadShader(shaderPath); + emit reset(); + } } void ShaderSelector::clear() { @@ -78,7 +96,7 @@ void ShaderSelector::selectShader() { } } -void ShaderSelector::loadShader(const QString& path) { +void ShaderSelector::loadShader(const QString& path, bool saveToSettings) { VDir* shader = VFileDevice::openDir(path); if (!shader) { shader = VFileDevice::openArchive(path); @@ -89,14 +107,18 @@ void ShaderSelector::loadShader(const QString& path) { m_display->setShaders(shader); shader->close(shader); m_shaderPath = path; - m_config->setOption("shader", m_shaderPath); + if (saveToSettings) { + m_config->setOption("shader", path); + } } -void ShaderSelector::clearShader() { +void ShaderSelector::clearShader(bool saveToSettings) { m_display->clearShaders(); - refreshShaders(); m_shaderPath = ""; - m_config->setOption("shader", m_shaderPath); + if (saveToSettings) { + m_config->setOption("shader", m_shaderPath); + } + refreshShaders(); } void ShaderSelector::refreshShaders() { @@ -121,7 +143,7 @@ void ShaderSelector::refreshShaders() { m_ui.author->clear(); } - disconnect(this, &ShaderSelector::saved, 0, 0); + disconnect(this, &ShaderSelector::saveSettingsRequested, 0, 0); disconnect(this, &ShaderSelector::reset, 0, 0); disconnect(this, &ShaderSelector::resetToDefault, 0, 0); @@ -160,7 +182,7 @@ void ShaderSelector::addUniform(QGridLayout* settings, const QString& section, c connect(f, static_cast(&QDoubleSpinBox::valueChanged), [value](double v) { *value = v; }); - connect(this, &ShaderSelector::saved, [this, section, name, f]() { + connect(this, &ShaderSelector::saveSettingsRequested, [this, section, name, f]() { m_config->setQtOption(name, f->value(), section); }); connect(this, &ShaderSelector::reset, [this, section, name, f]() { @@ -194,7 +216,7 @@ void ShaderSelector::addUniform(QGridLayout* settings, const QString& section, c connect(i, static_cast(&QSpinBox::valueChanged), [value](int v) { *value = v; }); - connect(this, &ShaderSelector::saved, [this, section, name, i]() { + connect(this, &ShaderSelector::saveSettingsRequested, [this, section, name, i]() { m_config->setQtOption(name, i->value(), section); }); connect(this, &ShaderSelector::reset, [this, section, name, i]() { diff --git a/src/platform/qt/ShaderSelector.h b/src/platform/qt/ShaderSelector.h index 0726b5edfbe..4ba074236c0 100644 --- a/src/platform/qt/ShaderSelector.h +++ b/src/platform/qt/ShaderSelector.h @@ -31,15 +31,16 @@ public slots: void saveSettings(); void refreshShaders(); void clear(); + void revert(); private slots: void selectShader(); - void loadShader(const QString& path); - void clearShader(); + void loadShader(const QString& path, bool saveToSettings = false); + void clearShader(bool saveToSettings = false); void buttonPressed(QAbstractButton*); signals: - void saved(); + void saveSettingsRequested(); void reset(); void resetToDefault(); From 122128eae56840775132bd2bbe1f856149db5aa3 Mon Sep 17 00:00:00 2001 From: Adam Higerd Date: Tue, 19 Nov 2024 17:20:48 -0600 Subject: [PATCH 283/338] Qt: load unpacked shaders, warn on shader load error --- src/platform/qt/Display.h | 2 +- src/platform/qt/DisplayGL.cpp | 16 +++++++++----- src/platform/qt/DisplayGL.h | 4 ++-- src/platform/qt/DisplayQt.h | 2 +- src/platform/qt/ShaderSelector.cpp | 34 ++++++++++++++++++++---------- 5 files changed, 38 insertions(+), 20 deletions(-) diff --git a/src/platform/qt/Display.h b/src/platform/qt/Display.h index 3cc2fc61f99..ef525162fef 100644 --- a/src/platform/qt/Display.h +++ b/src/platform/qt/Display.h @@ -81,7 +81,7 @@ public slots: virtual void filter(bool filter); virtual void swapInterval(int interval) = 0; virtual void framePosted() = 0; - virtual void setShaders(struct VDir*) = 0; + virtual bool setShaders(struct VDir*) = 0; virtual void clearShaders() = 0; virtual void resizeContext() = 0; diff --git a/src/platform/qt/DisplayGL.cpp b/src/platform/qt/DisplayGL.cpp index e62e9685eaa..b3a7d62c8af 100644 --- a/src/platform/qt/DisplayGL.cpp +++ b/src/platform/qt/DisplayGL.cpp @@ -462,8 +462,10 @@ void DisplayGL::framePosted() { QMetaObject::invokeMethod(m_painter.get(), "draw"); } -void DisplayGL::setShaders(struct VDir* shaders) { - QMetaObject::invokeMethod(m_painter.get(), "setShaders", Qt::BlockingQueuedConnection, Q_ARG(struct VDir*, shaders)); +bool DisplayGL::setShaders(struct VDir* shaders) { + bool success = false; + QMetaObject::invokeMethod(m_painter.get(), "setShaders", Qt::BlockingQueuedConnection, Q_RETURN_ARG(bool, success), Q_ARG(struct VDir*, shaders)); + return success; } void DisplayGL::clearShaders() { @@ -996,10 +998,11 @@ void PainterGL::interrupt() { m_interrupter.interrupt(m_context); } -void PainterGL::setShaders(struct VDir* dir) { +bool PainterGL::setShaders(struct VDir* dir) { if (!supportsShaders()) { - return; + return false; } + bool success = false; #if defined(BUILD_GLES2) || defined(BUILD_GLES3) if (!m_started) { makeCurrent(); @@ -1009,7 +1012,9 @@ void PainterGL::setShaders(struct VDir* dir) { mGLES2ShaderDetach(reinterpret_cast(m_backend)); mGLES2ShaderFree(&m_shader); } - if (mGLES2ShaderLoad(&m_shader, dir)) { + + success = mGLES2ShaderLoad(&m_shader, dir); + if (success) { mGLES2ShaderAttach(reinterpret_cast(m_backend), static_cast(m_shader.passes), m_shader.nPasses); } @@ -1017,6 +1022,7 @@ void PainterGL::setShaders(struct VDir* dir) { m_gl->doneCurrent(); } #endif + return success; } void PainterGL::clearShaders() { diff --git a/src/platform/qt/DisplayGL.h b/src/platform/qt/DisplayGL.h index 5b0aab2cd4d..18a7f791172 100644 --- a/src/platform/qt/DisplayGL.h +++ b/src/platform/qt/DisplayGL.h @@ -113,7 +113,7 @@ public slots: void filter(bool filter) override; void swapInterval(int interval) override; void framePosted() override; - void setShaders(struct VDir*) override; + bool setShaders(struct VDir*) override; void clearShaders() override; void resizeContext() override; void setVideoScale(int scale) override; @@ -184,7 +184,7 @@ public slots: void resizeContext(); void setBackgroundImage(const QImage&); - void setShaders(struct VDir*); + bool setShaders(struct VDir*); void clearShaders(); VideoShader* shaders(); QSize contentSize() const; diff --git a/src/platform/qt/DisplayQt.h b/src/platform/qt/DisplayQt.h index a6816a18b3b..8a3ec988e14 100644 --- a/src/platform/qt/DisplayQt.h +++ b/src/platform/qt/DisplayQt.h @@ -41,7 +41,7 @@ public slots: void swapInterval(int) override {}; void filter(bool filter) override; void framePosted() override; - void setShaders(struct VDir*) override {} + bool setShaders(struct VDir*) override { return false; } void clearShaders() override {} void resizeContext() override; void setBackgroundImage(const QImage&) override; diff --git a/src/platform/qt/ShaderSelector.cpp b/src/platform/qt/ShaderSelector.cpp index 473b1d7e9b8..204ad725205 100644 --- a/src/platform/qt/ShaderSelector.cpp +++ b/src/platform/qt/ShaderSelector.cpp @@ -16,6 +16,7 @@ #include #include #include +#include #include #include @@ -50,7 +51,7 @@ ShaderSelector::~ShaderSelector() { } void ShaderSelector::saveSettings() { - QString oldPath = config->getOption("shader"); + QString oldPath = m_config->getOption("shader"); if (oldPath != m_shaderPath) { if (m_shaderPath.isEmpty()) { clearShader(true); @@ -88,7 +89,8 @@ void ShaderSelector::selectShader() { #if !defined(USE_LIBZIP) && !defined(USE_MINIZIP) QString name = GBAApp::app()->getOpenDirectoryName(this, tr("Load shader"), path.absolutePath()); #else - QString name = GBAApp::app()->getOpenFileName(this, tr("Load shader"), "mGBA Shaders (*.shader)", path.absolutePath()); + QString filters = QStringLiteral("%1 (*.shader manifest.ini)").arg(tr("mGBA Shaders")); + QString name = GBAApp::app()->getOpenFileName(this, tr("Load shader"), filters, path.absolutePath()); #endif if (!name.isNull()) { loadShader(name); @@ -97,18 +99,28 @@ void ShaderSelector::selectShader() { } void ShaderSelector::loadShader(const QString& path, bool saveToSettings) { - VDir* shader = VFileDevice::openDir(path); - if (!shader) { - shader = VFileDevice::openArchive(path); + static const QString manifestIni = "/manifest.ini"; + QString shaderPath = path; + if (shaderPath.endsWith(manifestIni)) { + shaderPath.chop(manifestIni.length()); } + VDir* shader = VFileDevice::openDir(shaderPath); if (!shader) { - return; + shader = VFileDevice::openArchive(shaderPath); } - m_display->setShaders(shader); - shader->close(shader); - m_shaderPath = path; - if (saveToSettings) { - m_config->setOption("shader", path); + bool error = !shader || !m_display->setShaders(shader); + if (!error) { + if (saveToSettings) { + m_config->setOption("shader", shaderPath); + } + m_shaderPath = shaderPath; + refreshShaders(); + } + if (shader) { + shader->close(shader); + } + if (error) { + QMessageBox::warning(this, tr("Error loading shader"), tr("The shader \"%1\" could not be loaded successfully.").arg(shaderPath)); } } From bdb0057fb3f363ce8e88be148c06af7413b87b69 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 23 Nov 2024 03:23:05 -0800 Subject: [PATCH 284/338] GBA Serialize: Add support for Vast Fame state --- include/mgba/internal/gba/serialize.h | 6 ++++++ src/gba/cart/unlicensed.c | 13 +++++++++++-- 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/include/mgba/internal/gba/serialize.h b/include/mgba/internal/gba/serialize.h index 48393ed7bae..eda589dfd18 100644 --- a/include/mgba/internal/gba/serialize.h +++ b/include/mgba/internal/gba/serialize.h @@ -446,6 +446,12 @@ struct GBASerializedState { uint32_t settleNextEvent; GBASerializedMulticartFlags flags; } multicart; + struct { + int16_t sramMode; + int16_t romMode; + int8_t writeSequence[5]; + bool acceptingModeChange; + } vfame; }; struct { diff --git a/src/gba/cart/unlicensed.c b/src/gba/cart/unlicensed.c index 442ec9865d2..3338a60e034 100644 --- a/src/gba/cart/unlicensed.c +++ b/src/gba/cart/unlicensed.c @@ -22,6 +22,9 @@ enum GBMulticartCfgOffset { GBA_MULTICART_CFG_UNK = 0x6, }; +static_assert(sizeof(((struct GBASerializedState*)(NULL))->vfame.writeSequence) == + sizeof(((struct GBAVFameCart*)(NULL))->writeSequence), "GBA savestate vfame writeSequence size mismatch"); + static void _multicartSettle(struct mTiming* timing, void* context, uint32_t cyclesLate); void GBAUnlCartInit(struct GBA* gba) { @@ -165,7 +168,10 @@ void GBAUnlCartSerialize(const struct GBA* gba, struct GBASerializedState* state case GBA_UNL_CART_VFAME: flags = GBASerializedUnlCartFlagsSetType(flags, GBA_UNL_CART_VFAME); flags = GBASerializedUnlCartFlagsSetSubtype(flags, unl->vfame.cartType); - mLOG(GBA_MEM, STUB, "Vast Fame save states are not yet implemented"); + STORE_16(unl->vfame.sramMode, 0, &state->vfame.sramMode); + STORE_16(unl->vfame.romMode, 0, &state->vfame.romMode); + memcpy(state->vfame.writeSequence, unl->vfame.writeSequence, sizeof(state->vfame.writeSequence)); + state->vfame.acceptingModeChange = unl->vfame.acceptingModeChange; break; case GBA_UNL_CART_MULTICART: flags = GBASerializedUnlCartFlagsSetType(0, GBA_UNL_CART_MULTICART); @@ -205,7 +211,10 @@ void GBAUnlCartDeserialize(struct GBA* gba, const struct GBASerializedState* sta case GBA_UNL_CART_NONE: return; case GBA_UNL_CART_VFAME: - mLOG(GBA_MEM, STUB, "Vast Fame save states are not yet implemented"); + LOAD_16(unl->vfame.sramMode, 0, &state->vfame.sramMode); + LOAD_16(unl->vfame.romMode, 0, &state->vfame.romMode); + memcpy(unl->vfame.writeSequence, state->vfame.writeSequence, sizeof(state->vfame.writeSequence)); + unl->vfame.acceptingModeChange = state->vfame.acceptingModeChange; return; case GBA_UNL_CART_MULTICART: unl->multi.bank = state->multicart.bank; From 822a2c8df5fbffc011660231923fc5b1dafb7645 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 23 Nov 2024 03:23:45 -0800 Subject: [PATCH 285/338] GBA Unlicensed Carts: Improve bank swapping behavior --- src/gba/cart/unlicensed.c | 26 ++++++++++++++++---------- 1 file changed, 16 insertions(+), 10 deletions(-) diff --git a/src/gba/cart/unlicensed.c b/src/gba/cart/unlicensed.c index 3338a60e034..ed3b9ce3acc 100644 --- a/src/gba/cart/unlicensed.c +++ b/src/gba/cart/unlicensed.c @@ -10,7 +10,7 @@ #include #include -#define MULTI_SETTLE 512 +#define MULTI_SETTLE 300 #define MULTI_BLOCK 0x80000 #define MULTI_BANK 0x2000000 @@ -94,18 +94,24 @@ void GBAUnlCartWriteSRAM(struct GBA* gba, uint32_t address, uint8_t value) { switch (address) { case GBA_MULTICART_CFG_BANK: unl->multi.bank = value >> 4; - mTimingDeschedule(&gba->timing, &unl->multi.settle); - mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); + if (!(unl->multi.offset & 0x80)) { + mTimingDeschedule(&gba->timing, &unl->multi.settle); + mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); + } break; case GBA_MULTICART_CFG_OFFSET: - unl->multi.offset = value & 0x3F; - mTimingDeschedule(&gba->timing, &unl->multi.settle); - mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); + unl->multi.offset = value; + if (!(unl->multi.offset & 0x80)) { + mTimingDeschedule(&gba->timing, &unl->multi.settle); + mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); + } break; case GBA_MULTICART_CFG_SIZE: unl->multi.size = 0x40 - (value & 0x3F); - mTimingDeschedule(&gba->timing, &unl->multi.settle); - mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); + if (!(unl->multi.offset & 0x80)) { + mTimingDeschedule(&gba->timing, &unl->multi.settle); + mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); + } break; case GBA_MULTICART_CFG_SRAM: if (value == 0 && unl->multi.sramActive) { @@ -147,8 +153,8 @@ static void _multicartSettle(struct mTiming* timing, void* context, uint32_t cyc UNUSED(cyclesLate); struct GBA* gba = context; mLOG(GBA_MEM, INFO, "Switching to bank %i offset %i, size %i", - gba->memory.unl.multi.bank, gba->memory.unl.multi.offset, gba->memory.unl.multi.size); - size_t offset = gba->memory.unl.multi.bank * (MULTI_BANK >> 2) + gba->memory.unl.multi.offset * (MULTI_BLOCK >> 2); + gba->memory.unl.multi.bank, gba->memory.unl.multi.offset & 0x3F, gba->memory.unl.multi.size); + size_t offset = gba->memory.unl.multi.bank * (MULTI_BANK >> 2) + (gba->memory.unl.multi.offset & 0x3F) * (MULTI_BLOCK >> 2); size_t size = gba->memory.unl.multi.size * MULTI_BLOCK; if (offset * 4 >= gba->memory.unl.multi.fullSize || offset * 4 + size > gba->memory.unl.multi.fullSize) { mLOG(GBA_MEM, GAME_ERROR, "Bank switch was out of bounds, %07" PRIz "X + %" PRIz "X > %07" PRIz "X", From a5e3e746b2f1bf9a4f1ed45e722676116c251c73 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 23 Nov 2024 19:46:44 -0800 Subject: [PATCH 286/338] GBA Unlicensed Carts: Prevent multicarts from remapping after being locked --- include/mgba/internal/gba/cart/unlicensed.h | 1 + include/mgba/internal/gba/serialize.h | 1 + src/gba/cart/unlicensed.c | 20 ++++++++++++++------ src/gba/io.c | 2 -- src/gba/serialize.c | 4 ++++ 5 files changed, 20 insertions(+), 8 deletions(-) diff --git a/include/mgba/internal/gba/cart/unlicensed.h b/include/mgba/internal/gba/cart/unlicensed.h index 816aa1dfd11..f9adbee7ed2 100644 --- a/include/mgba/internal/gba/cart/unlicensed.h +++ b/include/mgba/internal/gba/cart/unlicensed.h @@ -42,6 +42,7 @@ struct GBAMulticart { uint8_t offset; uint8_t size; bool sramActive; + bool locked; uint8_t unk; }; diff --git a/include/mgba/internal/gba/serialize.h b/include/mgba/internal/gba/serialize.h index eda589dfd18..6e9a3124a2e 100644 --- a/include/mgba/internal/gba/serialize.h +++ b/include/mgba/internal/gba/serialize.h @@ -295,6 +295,7 @@ DECL_BITS(GBASerializedUnlCartFlags, Subtype, 5, 3); DECL_BITFIELD(GBASerializedMulticartFlags, uint32_t); DECL_BIT(GBASerializedMulticartFlags, DustSettling, 0); +DECL_BIT(GBASerializedMulticartFlags, Locked, 1); DECL_BITFIELD(GBASerializedSavedataFlags, uint8_t); DECL_BITS(GBASerializedSavedataFlags, FlashState, 0, 2); diff --git a/src/gba/cart/unlicensed.c b/src/gba/cart/unlicensed.c index ed3b9ce3acc..a286850e5b8 100644 --- a/src/gba/cart/unlicensed.c +++ b/src/gba/cart/unlicensed.c @@ -69,6 +69,7 @@ void GBAUnlCartReset(struct GBA* gba) { gba->memory.unl.multi.bank = 0; gba->memory.unl.multi.offset = 0; gba->memory.unl.multi.size = 0; + gba->memory.unl.multi.locked = false; gba->memory.rom = gba->memory.unl.multi.rom; gba->memory.romSize = GBA_SIZE_ROM0; } @@ -93,22 +94,25 @@ void GBAUnlCartWriteSRAM(struct GBA* gba, uint32_t address, uint8_t value) { mLOG(GBA_MEM, DEBUG, "Multicart writing SRAM %06X:%02X", address, value); switch (address) { case GBA_MULTICART_CFG_BANK: - unl->multi.bank = value >> 4; - if (!(unl->multi.offset & 0x80)) { + if (!unl->multi.locked) { + unl->multi.bank = value >> 4; mTimingDeschedule(&gba->timing, &unl->multi.settle); mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); } break; case GBA_MULTICART_CFG_OFFSET: - unl->multi.offset = value; - if (!(unl->multi.offset & 0x80)) { + if (!unl->multi.locked) { + unl->multi.offset = value; mTimingDeschedule(&gba->timing, &unl->multi.settle); mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); + if (unl->multi.offset & 0x80) { + unl->multi.locked = true; + } } break; case GBA_MULTICART_CFG_SIZE: unl->multi.size = 0x40 - (value & 0x3F); - if (!(unl->multi.offset & 0x80)) { + if (!unl->multi.locked) { mTimingDeschedule(&gba->timing, &unl->multi.settle); mTimingSchedule(&gba->timing, &unl->multi.settle, MULTI_SETTLE); } @@ -167,6 +171,7 @@ static void _multicartSettle(struct mTiming* timing, void* context, uint32_t cyc void GBAUnlCartSerialize(const struct GBA* gba, struct GBASerializedState* state) { GBASerializedUnlCartFlags flags = 0; + GBASerializedMulticartFlags multiFlags = 0; const struct GBAUnlCart* unl = &gba->memory.unl; switch (unl->type) { case GBA_UNL_CART_NONE: @@ -187,11 +192,13 @@ void GBAUnlCartSerialize(const struct GBA* gba, struct GBASerializedState* state state->multicart.sramActive = unl->multi.sramActive; state->multicart.unk = unl->multi.unk; state->multicart.currentSize = gba->memory.romSize / MULTI_BLOCK; + multiFlags = GBASerializedMulticartFlagsSetLocked(flags, unl->multi.locked); STORE_16((gba->memory.rom - unl->multi.rom) / 0x20000, 0, &state->multicart.currentOffset); STORE_32(unl->multi.settle.when, 0, &state->multicart.settleNextEvent); if (mTimingIsScheduled(&gba->timing, &unl->multi.settle)) { - STORE_32(GBASerializedMulticartFlagsFillDustSettling(0), 0, &state->multicart.flags); + multiFlags = GBASerializedMulticartFlagsFillDustSettling(multiFlags); } + STORE_32(multiFlags, 0, &state->multicart.flags); break; } STORE_32(flags, 0, &state->hw.unlCartFlags); @@ -238,6 +245,7 @@ void GBAUnlCartDeserialize(struct GBA* gba, const struct GBASerializedState* sta gba->memory.rom = unl->multi.rom + offset; } LOAD_32(multiFlags, 0, &state->multicart.flags); + unl->multi.locked = GBASerializedMulticartFlagsGetLocked(multiFlags); if (GBASerializedMulticartFlagsIsDustSettling(multiFlags)) { LOAD_32(when, 0, &state->multicart.settleNextEvent); mTimingSchedule(&gba->timing, &unl->multi.settle, when); diff --git a/src/gba/io.c b/src/gba/io.c index a72171c1fdb..cb6058f7f6b 100644 --- a/src/gba/io.c +++ b/src/gba/io.c @@ -1033,7 +1033,6 @@ void GBAIOSerialize(struct GBA* gba, struct GBASerializedState* state) { STORE_32(gba->bus, 0, &state->bus); GBAHardwareSerialize(&gba->memory.hw, state); - GBAUnlCartSerialize(gba, state); } void GBAIODeserialize(struct GBA* gba, const struct GBASerializedState* state) { @@ -1083,5 +1082,4 @@ void GBAIODeserialize(struct GBA* gba, const struct GBASerializedState* state) { GBADMARecalculateCycles(gba); GBADMAUpdate(gba); GBAHardwareDeserialize(&gba->memory.hw, state); - GBAUnlCartDeserialize(gba, state); } diff --git a/src/gba/serialize.c b/src/gba/serialize.c index 9d6130385b1..3866c0c807c 100644 --- a/src/gba/serialize.c +++ b/src/gba/serialize.c @@ -83,6 +83,7 @@ void GBASerialize(struct GBA* gba, struct GBASerializedState* state) { GBAMemorySerialize(&gba->memory, state); GBAIOSerialize(gba, state); + GBAUnlCartSerialize(gba, state); GBAVideoSerialize(&gba->video, state); GBAAudioSerialize(&gba->audio, state); GBASavedataSerialize(&gba->memory.savedata, state); @@ -180,6 +181,9 @@ bool GBADeserialize(struct GBA* gba, const struct GBASerializedState* state) { mLOG(GBA_STATE, WARN, "Savestate has unaligned PC and is probably corrupted"); gba->cpu->gprs[ARM_PC] &= ~1; } + + // Since this can remap the ROM, we need to do this before we reset the pipeline + GBAUnlCartDeserialize(gba, state); gba->memory.activeRegion = -1; gba->cpu->memory.setActiveRegion(gba->cpu, gba->cpu->gprs[ARM_PC]); if (state->biosPrefetch) { From 7ec56763f9d6c68f8d3f7f16a9e34fffcd765492 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 24 Nov 2024 17:55:04 -0800 Subject: [PATCH 287/338] Qt: Fix installer updates if a version number is in the filename (fixes #3109) --- CHANGES | 1 + src/platform/qt/GBAApp.cpp | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGES b/CHANGES index e432bee6768..f0a3d785f35 100644 --- a/CHANGES +++ b/CHANGES @@ -39,6 +39,7 @@ Other fixes: - Qt: Fix crash when applying changes to GB I/O registers in I/O view - Qt: Fix LCDC background priority/enable bit being mis-mapped in I/O view - Qt: Fix saving named states breaking when screenshot states disabled (fixes mgba.io/i/3320) + - Qt: Fix installer updates if a version number is in the filename (fixes mgba.io/i/3109) - Updater: Fix updating appimage across filesystems Misc: - Core: Handle relative paths for saves, screenshots, etc consistently (fixes mgba.io/i/2826) diff --git a/src/platform/qt/GBAApp.cpp b/src/platform/qt/GBAApp.cpp index fdc710c0ceb..90fc8917064 100644 --- a/src/platform/qt/GBAApp.cpp +++ b/src/platform/qt/GBAApp.cpp @@ -370,7 +370,7 @@ void GBAApp::cleanupAfterUpdate() { void GBAApp::restartForUpdate() { QFileInfo updaterPath(m_updater.updateInfo().url.path()); QDir configDir(ConfigController::configDir()); - if (updaterPath.completeSuffix() == "exe") { + if (updaterPath.suffix() == "exe") { m_invokeOnExit = configDir.filePath(QLatin1String("update.exe")); } else { QFile updater(":/updater"); From f9851e6b752f1f792b98eb8c427bae070dee42ac Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 25 Nov 2024 19:22:03 -0800 Subject: [PATCH 288/338] GBA BIOS: Move SoftReset implementation to assembly This improves the timing of the SoftReset implementation (though it's still way faster than Nintendo's official implementation), which is important for some multicarts. --- CHANGES | 1 + src/gba/bios.c | 26 +------------------------- src/gba/hle-bios.c | 22 ++++++++++++++++++---- src/gba/hle-bios.s | 43 ++++++++++++++++++++++++++++++++++++++++++- 4 files changed, 62 insertions(+), 30 deletions(-) diff --git a/CHANGES b/CHANGES index f0a3d785f35..9f505f816f0 100644 --- a/CHANGES +++ b/CHANGES @@ -49,6 +49,7 @@ Misc: - GB Serialize: Add missing savestate support for MBC6 and NT (newer) - GBA: Improve detection of valid ELF ROMs - GBA Audio: Remove broken XQ audio pending rewrite + - GBA BIOS: Move SoftReset implementation to assembly - GBA Memory: Improve VRAM access stall cycle estimation - GBA SIO: Rewrite lockstep driver for improved stability - GBA Video: Add special circlular window handling in OpenGL renderer diff --git a/src/gba/bios.c b/src/gba/bios.c index caca48a0b79..1ff5004d35b 100644 --- a/src/gba/bios.c +++ b/src/gba/bios.c @@ -35,30 +35,6 @@ static int _mulWait(int32_t r) { } } -static void _SoftReset(struct GBA* gba) { - struct ARMCore* cpu = gba->cpu; - ARMSetPrivilegeMode(cpu, MODE_IRQ); - cpu->spsr.packed = 0; - cpu->gprs[ARM_LR] = 0; - cpu->gprs[ARM_SP] = GBA_SP_BASE_IRQ; - ARMSetPrivilegeMode(cpu, MODE_SUPERVISOR); - cpu->spsr.packed = 0; - cpu->gprs[ARM_LR] = 0; - cpu->gprs[ARM_SP] = GBA_SP_BASE_SUPERVISOR; - ARMSetPrivilegeMode(cpu, MODE_SYSTEM); - cpu->gprs[ARM_LR] = 0; - cpu->gprs[ARM_SP] = GBA_SP_BASE_SYSTEM; - int8_t flag = ((int8_t*) gba->memory.iwram)[0x7FFA]; - memset(((int8_t*) gba->memory.iwram) + GBA_SIZE_IWRAM - 0x200, 0, 0x200); - if (flag) { - cpu->gprs[ARM_PC] = GBA_BASE_EWRAM; - } else { - cpu->gprs[ARM_PC] = GBA_BASE_ROM0; - } - _ARMSetMode(cpu, MODE_ARM); - ARMWritePC(cpu); -} - static void _RegisterRamReset(struct GBA* gba) { uint32_t registers = gba->cpu->gprs[0]; struct ARMCore* cpu = gba->cpu; @@ -445,7 +421,7 @@ void GBASwi16(struct ARMCore* cpu, int immediate) { bool useStall = false; switch (immediate) { case GBA_SWI_SOFT_RESET: - _SoftReset(gba); + ARMRaiseSWI(cpu); break; case GBA_SWI_REGISTER_RAM_RESET: _RegisterRamReset(gba); diff --git a/src/gba/hle-bios.c b/src/gba/hle-bios.c index 8f689fa7a7e..f3c58b62b9c 100644 --- a/src/gba/hle-bios.c +++ b/src/gba/hle-bios.c @@ -20,7 +20,7 @@ const uint8_t hleBios[GBA_SIZE_BIOS] = { 0x00, 0x00, 0xa0, 0xe1, 0x00, 0x00, 0xa0, 0xe1, 0x04, 0x40, 0xbd, 0xe8, 0x93, 0xf0, 0x29, 0xe3, 0x00, 0x08, 0xbd, 0xe8, 0x0b, 0xf0, 0x69, 0xe1, 0x00, 0x58, 0xbd, 0xe8, 0x0e, 0xf0, 0xb0, 0xe1, 0x00, 0x00, 0x00, 0x00, - 0x04, 0x20, 0xa0, 0xe3, 0x00, 0x00, 0x00, 0x00, 0xb0, 0x01, 0x00, 0x00, + 0x04, 0x20, 0xa0, 0xe3, 0x00, 0x00, 0x00, 0x00, 0xe4, 0x03, 0x00, 0x00, 0xb0, 0x01, 0x00, 0x00, 0xb4, 0x01, 0x00, 0x00, 0xb0, 0x01, 0x00, 0x00, 0xcc, 0x01, 0x00, 0x00, 0xc4, 0x01, 0x00, 0x00, 0x48, 0x03, 0x00, 0x00, 0x48, 0x03, 0x00, 0x00, 0x48, 0x03, 0x00, 0x00, 0x48, 0x03, 0x00, 0x00, @@ -79,12 +79,26 @@ const uint8_t hleBios[GBA_SIZE_BIOS] = { 0x00, 0x10, 0x9e, 0xe5, 0x00, 0x00, 0x51, 0xe3, 0x00, 0x10, 0xa0, 0xe3, 0x00, 0x00, 0x00, 0x1a, 0xc0, 0xe0, 0x4e, 0xe2, 0x1e, 0xff, 0x2f, 0xe1, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf0, 0x29, 0xe1, 0xc0, 0x00, 0x00, 0x02, - 0x4c, 0xd0, 0x9f, 0xe5, 0x00, 0x50, 0x2d, 0xe9, 0x00, 0xc0, 0x4f, 0xe1, + 0xe0, 0xd0, 0x9f, 0xe5, 0x00, 0x50, 0x2d, 0xe9, 0x00, 0xc0, 0x4f, 0xe1, 0x00, 0xe0, 0x0f, 0xe1, 0x00, 0x50, 0x2d, 0xe9, 0x02, 0xe3, 0xa0, 0xe3, 0x9c, 0xc0, 0xde, 0xe5, 0xa5, 0x00, 0x5c, 0xe3, 0x04, 0x00, 0x00, 0x1a, 0xb4, 0xc0, 0xde, 0xe5, 0x80, 0x00, 0x1c, 0xe3, 0x04, 0xe0, 0x8f, 0xe2, - 0x20, 0xf0, 0x9f, 0x15, 0x20, 0xf0, 0x9f, 0x05, 0x14, 0xd0, 0x9f, 0xe5, + 0xb4, 0xf0, 0x9f, 0x15, 0xb4, 0xf0, 0x9f, 0x05, 0xa8, 0xd0, 0x9f, 0xe5, 0x10, 0xc0, 0x1d, 0xe5, 0x0c, 0xf0, 0x69, 0xe1, 0x00, 0x50, 0x3d, 0xe9, 0x04, 0xf0, 0x5e, 0xe2, 0x00, 0x00, 0x00, 0x00, 0x04, 0xe0, 0xa0, 0x03, - 0xf0, 0x7f, 0x00, 0x03, 0x00, 0x20, 0xfe, 0x09, 0x00, 0xc0, 0xff, 0x09 + 0x00, 0xf0, 0x69, 0xe3, 0x00, 0xe0, 0xa0, 0xe3, 0x90, 0xd0, 0x9f, 0xe5, + 0x92, 0xf0, 0x21, 0xe3, 0x00, 0xf0, 0x69, 0xe3, 0x00, 0xe0, 0xa0, 0xe3, + 0x84, 0xd0, 0x9f, 0xe5, 0x9f, 0xf0, 0x21, 0xe3, 0x00, 0xf0, 0x69, 0xe3, + 0x00, 0xe0, 0xa0, 0xe3, 0x78, 0xd0, 0x9f, 0xe5, 0x93, 0xf0, 0x21, 0xe3, + 0x01, 0x03, 0xa0, 0xe3, 0x02, 0x1c, 0x40, 0xe2, 0x06, 0x00, 0x50, 0xe5, + 0x00, 0x20, 0xa0, 0xe3, 0x00, 0x30, 0xa0, 0xe3, 0x00, 0x40, 0xa0, 0xe3, + 0x00, 0x50, 0xa0, 0xe3, 0x00, 0x60, 0xa0, 0xe3, 0x00, 0x70, 0xa0, 0xe3, + 0x00, 0x80, 0xa0, 0xe3, 0x00, 0x90, 0xa0, 0xe3, 0x00, 0xa0, 0xa0, 0xe3, + 0x00, 0xb0, 0xa0, 0xe3, 0x00, 0xc0, 0xa0, 0xe3, 0xfc, 0x03, 0xa1, 0xe8, + 0x01, 0x03, 0x51, 0xe3, 0xfc, 0xff, 0xff, 0x1a, 0x00, 0x00, 0x50, 0xe3, + 0x00, 0x00, 0xa0, 0xe3, 0x00, 0x10, 0xa0, 0xe3, 0x02, 0xe3, 0xa0, 0x03, + 0x02, 0xe4, 0xa0, 0x13, 0x0e, 0xf0, 0xb0, 0xe1, 0x00, 0x00, 0x00, 0x00, + 0x00, 0xf0, 0x29, 0xe1, 0xf0, 0x7f, 0x00, 0x03, 0x00, 0x20, 0xfe, 0x09, + 0x00, 0xc0, 0xff, 0x09, 0xe0, 0x7f, 0x00, 0x03, 0xa0, 0x7f, 0x00, 0x03, + 0x00, 0x7f, 0x00, 0x03 }; diff --git a/src/gba/hle-bios.s b/src/gba/hle-bios.s index aa77160c17d..871d798499e 100644 --- a/src/gba/hle-bios.s +++ b/src/gba/hle-bios.s @@ -129,7 +129,6 @@ subs pc, lr, #4 .word 0x03A0E004 @ Unimplemented -SoftReset: RegisterRamReset: Stop: GetBiosChecksum: @@ -358,3 +357,45 @@ ldmdb sp!, {r12, lr} subs pc, lr, #4 .word 0 .word 0x03A0E004 + +SoftReset: +msr spsr, #0 +mov lr, #0 +ldr sp, =0x03007FE0 +msr cpsr_c, #0x92 +msr spsr, #0 +mov lr, #0 +ldr sp, =0x03007FA0 +msr cpsr_c, #0x9F +msr spsr, #0 +mov lr, #0 +ldr sp, =0x03007F00 +msr cpsr_c, #0x93 +mov r0, #0x04000000 +sub r1, r0, #0x200 +ldrb r0, [r0, #-6] +mov r2, #0 +mov r3, #0 +mov r4, #0 +mov r5, #0 +mov r6, #0 +mov r7, #0 +mov r8, #0 +mov r9, #0 +mov r10, #0 +mov r11, #0 +mov r12, #0 +1: +stmia r1!, {r2, r3, r4, r5, r6, r7, r8, r9} +cmp r1, #0x04000000 +bne 1b +cmp r0, #0 +mov r0, #0 +mov r1, #0 +moveq lr, #0x08000000 +movne lr, #0x02000000 +movs pc, lr +.word 0 +.word 0xE129F000 + +.ltorg From a9bddb92e3152f58df6242f1f773fc8d9421af79 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Mon, 25 Nov 2024 19:27:51 -0800 Subject: [PATCH 289/338] GBA Unlicensed Carts: Detect "SPIDERMAN3" header too --- src/gba/cart/unlicensed.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gba/cart/unlicensed.c b/src/gba/cart/unlicensed.c index a286850e5b8..a0f18fc5e17 100644 --- a/src/gba/cart/unlicensed.c +++ b/src/gba/cart/unlicensed.c @@ -42,7 +42,7 @@ void GBAUnlCartDetect(struct GBA* gba) { return; } - if (memcmp(&cart->id, "AXVJ01", 6) == 0) { + if (memcmp(&cart->id, "AXVJ01", 6) == 0 || memcmp(&cart->id, "BI3P52", 6) == 0) { if (gba->romVf && gba->romVf->size(gba->romVf) >= 0x04000000) { // Bootleg multicart // TODO: Identify a bit more precisely From 1eb130a28bd951b8e90ddc77a919f3aa84852d8b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 3 Dec 2024 23:04:41 -0800 Subject: [PATCH 290/338] GBA SIO: Allow externally-clocked NORMAL transfers (fixes #3360) --- src/gba/sio.c | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/src/gba/sio.c b/src/gba/sio.c index 60c7c2286d0..22b79675e79 100644 --- a/src/gba/sio.c +++ b/src/gba/sio.c @@ -211,11 +211,7 @@ void GBASIOWriteSIOCNT(struct GBASIO* sio, uint16_t value) { sio->rcnt = GBASIORegisterRCNTFillSc(sio->rcnt); } if (GBASIONormalIsStart(value) && !GBASIONormalIsStart(sio->siocnt)) { - if (GBASIONormalIsSc(value)) { - _startTransfer(sio); - } else { - // TODO - } + _startTransfer(sio); } break; default: From 938ee55d42445d57fcdb501af43bb190be27f4b9 Mon Sep 17 00:00:00 2001 From: Adam Higerd Date: Tue, 19 Nov 2024 10:41:34 -0600 Subject: [PATCH 291/338] Qt: honor control characters in ScriptingTextBuffer::print --- .../qt/scripting/ScriptingTextBuffer.cpp | 76 +++++++++++++++---- .../qt/scripting/ScriptingTextBuffer.h | 7 ++ 2 files changed, 67 insertions(+), 16 deletions(-) diff --git a/src/platform/qt/scripting/ScriptingTextBuffer.cpp b/src/platform/qt/scripting/ScriptingTextBuffer.cpp index da05bd2b990..c209adcd5a5 100644 --- a/src/platform/qt/scripting/ScriptingTextBuffer.cpp +++ b/src/platform/qt/scripting/ScriptingTextBuffer.cpp @@ -49,26 +49,70 @@ void ScriptingTextBuffer::setBufferName(const QString& name) { emit bufferNameChanged(name); } +void ScriptingTextBuffer::lineBreak() { + bool nextBlockExists = m_shim.cursor.movePosition(QTextCursor::NextBlock, QTextCursor::MoveAnchor, 1); + if (!nextBlockExists) { + m_shim.cursor.movePosition(QTextCursor::EndOfBlock, QTextCursor::MoveAnchor, 1); + m_shim.cursor.insertBlock(); + } +} + +void ScriptingTextBuffer::carriageReturn() { + m_shim.cursor.movePosition(QTextCursor::StartOfLine, QTextCursor::MoveAnchor, 1); +} + +void ScriptingTextBuffer::tab() { + QTextCursor& cursor = m_shim.cursor; + int column = cursor.positionInBlock(); + int move = tabStop - (column % tabStop) + 1; + if (column + move >= m_dims.width()) { + lineBreak(); + } else if (column + move <= cursor.block().length()) { + cursor.movePosition(QTextCursor::Right, QTextCursor::MoveAnchor, move - 1); + } else { + move = column + move - cursor.block().length(); + cursor.movePosition(QTextCursor::EndOfLine, QTextCursor::MoveAnchor, 1); + cursor.insertText(QString(move, ' ')); + } +} + +void ScriptingTextBuffer::insertString(const QString& text) { + QTextCursor& cursor = m_shim.cursor; + if (cursor.positionInBlock() >= m_dims.width()) { + lineBreak(); + } + cursor.movePosition(QTextCursor::Right, QTextCursor::KeepAnchor, text.length()); + cursor.insertText(text); +} + void ScriptingTextBuffer::print(const QString& text) { QMutexLocker locker(&m_mutex); - for (QString split : text.split('\n')) { - while (m_shim.cursor.positionInBlock() + split.length() > m_dims.width()) { - int cut = m_dims.width() - m_shim.cursor.positionInBlock(); - if (!m_shim.cursor.atBlockEnd()) { - m_shim.cursor.movePosition(QTextCursor::EndOfBlock, QTextCursor::KeepAnchor); - } - m_shim.cursor.insertText(split.left(cut)); - if (m_shim.cursor.atEnd()) { - m_shim.cursor.insertBlock(); - } else { - m_shim.cursor.movePosition(QTextCursor::NextBlock, QTextCursor::MoveAnchor, 1); - } - split = split.mid(cut); + + QTextCursor& cursor = m_shim.cursor; + QString toInsert; + + for (const QChar& ch : text) { + int column = cursor.positionInBlock(); + if (ch == '\t' || ch == '\n' || ch == '\r' || column + toInsert.length() >= m_dims.width()) { + insertString(toInsert); + toInsert.clear(); } - if (!m_shim.cursor.atBlockEnd()) { - m_shim.cursor.movePosition(QTextCursor::NextCharacter, QTextCursor::KeepAnchor, split.length()); + switch (ch.unicode()) { + case '\t': + tab(); + break; + case '\n': + lineBreak(); + break; + case '\r': + carriageReturn(); + break; + default: + toInsert += ch; } - m_shim.cursor.insertText(split); + } + if (!toInsert.isEmpty()) { + insertString(toInsert); } } diff --git a/src/platform/qt/scripting/ScriptingTextBuffer.h b/src/platform/qt/scripting/ScriptingTextBuffer.h index b4a9c5b8312..717a5d284e2 100644 --- a/src/platform/qt/scripting/ScriptingTextBuffer.h +++ b/src/platform/qt/scripting/ScriptingTextBuffer.h @@ -36,6 +36,8 @@ public slots: void bufferNameChanged(const QString&); private: + enum { tabStop = 4 }; + struct ScriptingBufferShim : public mScriptTextBuffer { ScriptingTextBuffer* p; QTextCursor cursor; @@ -44,6 +46,11 @@ public slots: QMutex m_mutex; QString m_name; + void lineBreak(); + void carriageReturn(); + void tab(); + void insertString(const QString& text); + static void init(struct mScriptTextBuffer*, const char* name); static void deinit(struct mScriptTextBuffer*); From 00d17c6f42de52d051b84b52b4b45b9d784bb755 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 7 Dec 2024 17:06:01 -0800 Subject: [PATCH 292/338] GBA BIOS: Fix reseting SWI mode SPSR in SoftReset --- src/gba/hle-bios.c | 31 +++++++++++++++---------------- src/gba/hle-bios.s | 7 +++---- 2 files changed, 18 insertions(+), 20 deletions(-) diff --git a/src/gba/hle-bios.c b/src/gba/hle-bios.c index f3c58b62b9c..5b1acd3ba3d 100644 --- a/src/gba/hle-bios.c +++ b/src/gba/hle-bios.c @@ -79,26 +79,25 @@ const uint8_t hleBios[GBA_SIZE_BIOS] = { 0x00, 0x10, 0x9e, 0xe5, 0x00, 0x00, 0x51, 0xe3, 0x00, 0x10, 0xa0, 0xe3, 0x00, 0x00, 0x00, 0x1a, 0xc0, 0xe0, 0x4e, 0xe2, 0x1e, 0xff, 0x2f, 0xe1, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf0, 0x29, 0xe1, 0xc0, 0x00, 0x00, 0x02, - 0xe0, 0xd0, 0x9f, 0xe5, 0x00, 0x50, 0x2d, 0xe9, 0x00, 0xc0, 0x4f, 0xe1, + 0xdc, 0xd0, 0x9f, 0xe5, 0x00, 0x50, 0x2d, 0xe9, 0x00, 0xc0, 0x4f, 0xe1, 0x00, 0xe0, 0x0f, 0xe1, 0x00, 0x50, 0x2d, 0xe9, 0x02, 0xe3, 0xa0, 0xe3, 0x9c, 0xc0, 0xde, 0xe5, 0xa5, 0x00, 0x5c, 0xe3, 0x04, 0x00, 0x00, 0x1a, 0xb4, 0xc0, 0xde, 0xe5, 0x80, 0x00, 0x1c, 0xe3, 0x04, 0xe0, 0x8f, 0xe2, - 0xb4, 0xf0, 0x9f, 0x15, 0xb4, 0xf0, 0x9f, 0x05, 0xa8, 0xd0, 0x9f, 0xe5, + 0xb0, 0xf0, 0x9f, 0x15, 0xb0, 0xf0, 0x9f, 0x05, 0xa4, 0xd0, 0x9f, 0xe5, 0x10, 0xc0, 0x1d, 0xe5, 0x0c, 0xf0, 0x69, 0xe1, 0x00, 0x50, 0x3d, 0xe9, 0x04, 0xf0, 0x5e, 0xe2, 0x00, 0x00, 0x00, 0x00, 0x04, 0xe0, 0xa0, 0x03, - 0x00, 0xf0, 0x69, 0xe3, 0x00, 0xe0, 0xa0, 0xe3, 0x90, 0xd0, 0x9f, 0xe5, + 0x00, 0xf0, 0x69, 0xe3, 0x00, 0xe0, 0xa0, 0xe3, 0x8c, 0xd0, 0x9f, 0xe5, 0x92, 0xf0, 0x21, 0xe3, 0x00, 0xf0, 0x69, 0xe3, 0x00, 0xe0, 0xa0, 0xe3, - 0x84, 0xd0, 0x9f, 0xe5, 0x9f, 0xf0, 0x21, 0xe3, 0x00, 0xf0, 0x69, 0xe3, - 0x00, 0xe0, 0xa0, 0xe3, 0x78, 0xd0, 0x9f, 0xe5, 0x93, 0xf0, 0x21, 0xe3, - 0x01, 0x03, 0xa0, 0xe3, 0x02, 0x1c, 0x40, 0xe2, 0x06, 0x00, 0x50, 0xe5, - 0x00, 0x20, 0xa0, 0xe3, 0x00, 0x30, 0xa0, 0xe3, 0x00, 0x40, 0xa0, 0xe3, - 0x00, 0x50, 0xa0, 0xe3, 0x00, 0x60, 0xa0, 0xe3, 0x00, 0x70, 0xa0, 0xe3, - 0x00, 0x80, 0xa0, 0xe3, 0x00, 0x90, 0xa0, 0xe3, 0x00, 0xa0, 0xa0, 0xe3, - 0x00, 0xb0, 0xa0, 0xe3, 0x00, 0xc0, 0xa0, 0xe3, 0xfc, 0x03, 0xa1, 0xe8, - 0x01, 0x03, 0x51, 0xe3, 0xfc, 0xff, 0xff, 0x1a, 0x00, 0x00, 0x50, 0xe3, - 0x00, 0x00, 0xa0, 0xe3, 0x00, 0x10, 0xa0, 0xe3, 0x02, 0xe3, 0xa0, 0x03, - 0x02, 0xe4, 0xa0, 0x13, 0x0e, 0xf0, 0xb0, 0xe1, 0x00, 0x00, 0x00, 0x00, - 0x00, 0xf0, 0x29, 0xe1, 0xf0, 0x7f, 0x00, 0x03, 0x00, 0x20, 0xfe, 0x09, - 0x00, 0xc0, 0xff, 0x09, 0xe0, 0x7f, 0x00, 0x03, 0xa0, 0x7f, 0x00, 0x03, - 0x00, 0x7f, 0x00, 0x03 + 0x80, 0xd0, 0x9f, 0xe5, 0x93, 0xf0, 0x21, 0xe3, 0x00, 0xf0, 0x69, 0xe3, + 0x00, 0xe0, 0xa0, 0xe3, 0x74, 0xd0, 0x9f, 0xe5, 0x01, 0x03, 0xa0, 0xe3, + 0x02, 0x1c, 0x40, 0xe2, 0x06, 0x00, 0x50, 0xe5, 0x00, 0x20, 0xa0, 0xe3, + 0x00, 0x30, 0xa0, 0xe3, 0x00, 0x40, 0xa0, 0xe3, 0x00, 0x50, 0xa0, 0xe3, + 0x00, 0x60, 0xa0, 0xe3, 0x00, 0x70, 0xa0, 0xe3, 0x00, 0x80, 0xa0, 0xe3, + 0x00, 0x90, 0xa0, 0xe3, 0x00, 0xa0, 0xa0, 0xe3, 0x00, 0xb0, 0xa0, 0xe3, + 0x00, 0xc0, 0xa0, 0xe3, 0xfc, 0x03, 0xa1, 0xe8, 0x01, 0x03, 0x51, 0xe3, + 0xfc, 0xff, 0xff, 0x1a, 0x00, 0x00, 0x50, 0xe3, 0x00, 0x00, 0xa0, 0xe3, + 0x00, 0x10, 0xa0, 0xe3, 0x02, 0xe3, 0xa0, 0x03, 0x02, 0xe4, 0xa0, 0x13, + 0x0e, 0xf0, 0xb0, 0xe1, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf0, 0x29, 0xe1, + 0xf0, 0x7f, 0x00, 0x03, 0x00, 0x20, 0xfe, 0x09, 0x00, 0xc0, 0xff, 0x09, + 0x00, 0x7f, 0x00, 0x03, 0xa0, 0x7f, 0x00, 0x03, 0xe0, 0x7f, 0x00, 0x03 }; diff --git a/src/gba/hle-bios.s b/src/gba/hle-bios.s index 871d798499e..eccbaa1433e 100644 --- a/src/gba/hle-bios.s +++ b/src/gba/hle-bios.s @@ -361,16 +361,15 @@ subs pc, lr, #4 SoftReset: msr spsr, #0 mov lr, #0 -ldr sp, =0x03007FE0 +ldr sp, =0x03007F00 msr cpsr_c, #0x92 msr spsr, #0 mov lr, #0 ldr sp, =0x03007FA0 -msr cpsr_c, #0x9F +msr cpsr_c, #0x93 msr spsr, #0 mov lr, #0 -ldr sp, =0x03007F00 -msr cpsr_c, #0x93 +ldr sp, =0x03007FE0 mov r0, #0x04000000 sub r1, r0, #0x200 ldrb r0, [r0, #-6] From f4595f4578cf9943ae787519eb3346837484cb89 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 7 Dec 2024 21:27:03 -0800 Subject: [PATCH 293/338] CHANGES: Update for 0.10.4 --- CHANGES | 47 +++++++++++++++++++++++++++-------------------- 1 file changed, 27 insertions(+), 20 deletions(-) diff --git a/CHANGES b/CHANGES index 9f505f816f0..08d9526ffdf 100644 --- a/CHANGES +++ b/CHANGES @@ -8,39 +8,20 @@ Features: - Debugger: Add range watchpoints Emulation fixes: - ARM: Add framework for coprocessor support - - GB Audio: Fix audio envelope timing resetting too often (fixes mgba.io/i/3164) - - GB I/O: Fix STAT writing IRQ trigger conditions (fixes mgba.io/i/2501) - GB Serialize: Add missing Pocket Cam state to savestates - GB Video: Implement DMG-style sprite ordering - GBA: Unhandled bkpt should be treated as an undefined exception - GBA: Add baseline CP0 (Wii U VC) and CP1 (DCC) implementations - - GBA GPIO: Fix gyro read-out start (fixes mgba.io/i/3141) - - GBA I/O: Fix HALTCNT access behavior (fixes mgba.io/i/2309) - - GBA I/O: Fix audio register 8-bit write behavior (fixes mgba.io/i/3086) - GBA Serialize: Fix some minor save state edge cases - - GBA Serialize: Properly restore GPIO register state (fixes mgba.io/i/3294) - - GBA SIO: Fix MULTI mode SIOCNT bit 7 writes on secondary GBAs (fixes mgba.io/i/3110) - GBA Video: Disable BG target 1 blending when OBJ blending (fixes mgba.io/i/2722) - GBA Video: Improve emulation of window start/end conditions (fixes mgba.io/i/1945) Other fixes: - Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963) - - Core: Fix patch autoloading leaking the file handle - Debugger: Fix writing to specific segment in command-line debugger - - GB: Fix uninitialized save data when loading undersized temporary saves - - GB, GBA Core: Fix memory leak if reloading debug symbols - GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1 - GBA: Fix getting game info for multiboot ROMs - - GBA Audio: Fix crash if audio FIFOs and timers get out of sync - - GBA Audio: Fix crash in audio subsampling if timing lockstep breaks - - GBA Core: Fix loading symbols from ELF files if the file doesn't end with .elf - - GBA Memory: Let raw access read high MMIO addresses - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) - Qt: Fix potential crash when configuring shortcuts - - Qt: Fix crash when applying changes to GB I/O registers in I/O view - - Qt: Fix LCDC background priority/enable bit being mis-mapped in I/O view - - Qt: Fix saving named states breaking when screenshot states disabled (fixes mgba.io/i/3320) - - Qt: Fix installer updates if a version number is in the filename (fixes mgba.io/i/3109) - - Updater: Fix updating appimage across filesystems Misc: - Core: Handle relative paths for saves, screenshots, etc consistently (fixes mgba.io/i/2826) - Core: Improve rumble emulation by averaging state over entire frame (fixes mgba.io/i/3232) @@ -60,10 +41,36 @@ Misc: - Qt: Remove maligned double-click-to-fullscreen shortcut (closes mgba.io/i/2632) - Qt: Pass logging context through to video proxy thread (fixes mgba.io/i/3095) - Qt: Show maker code and game version in ROM info - - Qt: Make window corners square on Windows 11 (fixes mgba.io/i/3285) - Qt: Show a dummy shader settings tab if shaders aren't supported - Res: Port NSO-gba-colors shader (closes mgba.io/i/2834) - Scripting: Add `callbacks:oneshot` for single-call callbacks + +0.10.4: (2024-12-07) +Emulation fixes: + - GB Audio: Fix audio envelope timing resetting too often (fixes mgba.io/i/3164) + - GB I/O: Fix STAT writing IRQ trigger conditions (fixes mgba.io/i/2501) + - GBA GPIO: Fix gyro read-out start (fixes mgba.io/i/3141) + - GBA I/O: Fix HALTCNT access behavior (fixes mgba.io/i/2309) + - GBA I/O: Fix audio register 8-bit write behavior (fixes mgba.io/i/3086) + - GBA Serialize: Properly restore GPIO register state (fixes mgba.io/i/3294) + - GBA SIO: Fix MULTI mode SIOCNT bit 7 writes on secondary GBAs (fixes mgba.io/i/3110) +Other fixes: + - Core: Fix patch autoloading leaking the file handle + - GB: Fix uninitialized save data when loading undersized temporary saves + - GB, GBA Core: Fix memory leak if reloading debug symbols + - GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1 + - GBA Audio: Fix crash if audio FIFOs and timers get out of sync + - GBA Audio: Fix crash in audio subsampling if timing lockstep breaks + - GBA Core: Fix loading symbols from ELF files if the file doesn't end with .elf + - GBA Memory: Let raw access read high MMIO addresses + - Qt: Fix crash when applying changes to GB I/O registers in I/O view + - Qt: Fix LCDC background priority/enable bit being mis-mapped in I/O view + - Qt: Fix saving named states breaking when screenshot states disabled (fixes mgba.io/i/3320) + - Qt: Fix potential crash on Wayland with OpenGL (fixes mgba.io/i/3276) + - Qt: Fix installer updates if a version number is in the filename (fixes mgba.io/i/3109) + - Updater: Fix updating appimage across filesystems +Misc: + - Qt: Make window corners square on Windows 11 (fixes mgba.io/i/3285) - Switch: Add bilinear filtering option (closes mgba.io/i/3111) - Vita: Add imc0 and xmc0 mount point support From 109fbe60f5fd983af394c8e518e97d9a88a304cd Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 11 Dec 2024 16:24:51 -0800 Subject: [PATCH 294/338] GBA Hardware: Fix loading states unconditionally overwriting GPIO memory --- CHANGES | 1 + include/mgba/gba/interface.h | 4 +++- src/gba/cart/gpio.c | 2 +- 3 files changed, 5 insertions(+), 2 deletions(-) diff --git a/CHANGES b/CHANGES index 08d9526ffdf..f3a8cc53984 100644 --- a/CHANGES +++ b/CHANGES @@ -19,6 +19,7 @@ Other fixes: - Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963) - Debugger: Fix writing to specific segment in command-line debugger - GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1 + - GBA Hardware: Fix loading states unconditionally overwriting GPIO memory - GBA: Fix getting game info for multiboot ROMs - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) - Qt: Fix potential crash when configuring shortcuts diff --git a/include/mgba/gba/interface.h b/include/mgba/gba/interface.h index cbbb4d23a2f..298292dd3e3 100644 --- a/include/mgba/gba/interface.h +++ b/include/mgba/gba/interface.h @@ -68,7 +68,9 @@ enum GBAHardwareDevice { HW_TILT = 16, HW_GB_PLAYER = 32, HW_GB_PLAYER_DETECTION = 64, - HW_EREADER = 128 + HW_EREADER = 128, + + HW_GPIO = HW_RTC | HW_RUMBLE | HW_LIGHT_SENSOR | HW_GYRO | HW_TILT, }; struct Configuration; diff --git a/src/gba/cart/gpio.c b/src/gba/cart/gpio.c index 0bffbc08846..48cb8c340b4 100644 --- a/src/gba/cart/gpio.c +++ b/src/gba/cart/gpio.c @@ -502,7 +502,7 @@ void GBAHardwareDeserialize(struct GBACartridgeHardware* hw, const struct GBASer LOAD_16(hw->direction, 0, &state->hw.pinDirection); hw->devices = state->hw.devices; - if (hw->gpioBase) { + if ((hw->devices & HW_GPIO) && hw->gpioBase) { if (hw->readWrite) { STORE_16(hw->pinState, 0, hw->gpioBase); STORE_16(hw->direction, 2, hw->gpioBase); From 655211651ad664c910b8264d6c3cb616d2ae1d75 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 11 Dec 2024 16:25:17 -0800 Subject: [PATCH 295/338] GBA Memory: Properly narrow down GPIO write validity check --- src/gba/memory.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gba/memory.c b/src/gba/memory.c index 1561aef91d1..bdaf22c36ef 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -915,7 +915,7 @@ void GBAStore16(struct ARMCore* cpu, uint32_t address, int16_t value, int* cycle break; case GBA_REGION_ROM0: if (IS_GPIO_REGISTER(address & 0xFFFFFE)) { - if (memory->hw.devices == HW_NONE) { + if (!(memory->hw.devices & HW_GPIO)) { mLOG(GBA_HW, WARN, "Write to GPIO address %08X on cartridge without GPIO", address); break; } From edaa27796bbd2c991b5c9ccd2af6f43c361715a4 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 11 Dec 2024 17:24:22 -0800 Subject: [PATCH 296/338] GBA: Improve reset behavior of various hardware components --- include/mgba/internal/gba/cart/gpio.h | 1 + include/mgba/internal/gba/savedata.h | 1 + src/gba/cart/gpio.c | 15 +++++++++++++++ src/gba/memory.c | 10 ++++++++++ src/gba/savedata.c | 7 ++++++- 5 files changed, 33 insertions(+), 1 deletion(-) diff --git a/include/mgba/internal/gba/cart/gpio.h b/include/mgba/internal/gba/cart/gpio.h index 77785e6122c..be3cd91738b 100644 --- a/include/mgba/internal/gba/cart/gpio.h +++ b/include/mgba/internal/gba/cart/gpio.h @@ -86,6 +86,7 @@ struct GBACartridgeHardware { }; void GBAHardwareInit(struct GBACartridgeHardware* gpio, uint16_t* gpioBase); +void GBAHardwareReset(struct GBACartridgeHardware* gpio); void GBAHardwareClear(struct GBACartridgeHardware* gpio); void GBAHardwareInitRTC(struct GBACartridgeHardware* gpio); diff --git a/include/mgba/internal/gba/savedata.h b/include/mgba/internal/gba/savedata.h index 274241a766e..e69d0783455 100644 --- a/include/mgba/internal/gba/savedata.h +++ b/include/mgba/internal/gba/savedata.h @@ -91,6 +91,7 @@ struct GBASavedataRTCBuffer { }; void GBASavedataInit(struct GBASavedata* savedata, struct VFile* vf); +void GBASavedataReset(struct GBASavedata* savedata); void GBASavedataDeinit(struct GBASavedata* savedata); void GBASavedataMask(struct GBASavedata* savedata, struct VFile* vf, bool writeback); diff --git a/src/gba/cart/gpio.c b/src/gba/cart/gpio.c index 48cb8c340b4..a44bab29419 100644 --- a/src/gba/cart/gpio.c +++ b/src/gba/cart/gpio.c @@ -47,6 +47,20 @@ void GBAHardwareInit(struct GBACartridgeHardware* hw, uint16_t* base) { GBAHardwareClear(hw); } +void GBAHardwareReset(struct GBACartridgeHardware* hw) { + hw->readWrite = GPIO_WRITE_ONLY; + hw->pinState = 0; + hw->direction = 0; + hw->lightCounter = 0; + hw->lightEdge = false; + hw->lightSample = 0xFF; + hw->gyroSample = 0; + hw->gyroEdge = 0; + hw->tiltX = 0xFFF; + hw->tiltY = 0xFFF; + hw->tiltState = 0; +} + void GBAHardwareClear(struct GBACartridgeHardware* hw) { hw->devices = HW_NONE | (hw->devices & HW_GB_PLAYER_DETECTION); hw->readWrite = GPIO_WRITE_ONLY; @@ -503,6 +517,7 @@ void GBAHardwareDeserialize(struct GBACartridgeHardware* hw, const struct GBASer hw->devices = state->hw.devices; if ((hw->devices & HW_GPIO) && hw->gpioBase) { + // TODO: This needs to update the pristine state somehow if (hw->readWrite) { STORE_16(hw->pinState, 0, hw->gpioBase); STORE_16(hw->direction, 2, hw->gpioBase); diff --git a/src/gba/memory.c b/src/gba/memory.c index bdaf22c36ef..4f074657a1c 100644 --- a/src/gba/memory.c +++ b/src/gba/memory.c @@ -138,6 +138,16 @@ void GBAMemoryReset(struct GBA* gba) { mLOG(GBA_MEM, FATAL, "Could not map memory"); } + if (!gba->memory.rom) { + gba->isPristine = false; + } + + if (gba->memory.hw.devices & HW_GPIO) { + _pristineCow(gba); + } + + GBASavedataReset(&gba->memory.savedata); + GBAHardwareReset(&gba->memory.hw); GBADMAReset(gba); GBAUnlCartReset(gba); memset(&gba->memory.matrix, 0, sizeof(gba->memory.matrix)); diff --git a/src/gba/savedata.c b/src/gba/savedata.c index a9cd682ca1e..c0d2c889a52 100644 --- a/src/gba/savedata.c +++ b/src/gba/savedata.c @@ -45,7 +45,7 @@ static void _ashesToAshes(struct mTiming* timing, void* user, uint32_t cyclesLat void GBASavedataInit(struct GBASavedata* savedata, struct VFile* vf) { savedata->type = GBA_SAVEDATA_AUTODETECT; - savedata->data = 0; + savedata->data = NULL; savedata->command = EEPROM_COMMAND_NULL; savedata->flashState = FLASH_STATE_RAW; savedata->vf = vf; @@ -63,6 +63,11 @@ void GBASavedataInit(struct GBASavedata* savedata, struct VFile* vf) { savedata->dust.callback = _ashesToAshes; } +void GBASavedataReset(struct GBASavedata* savedata) { + savedata->command = EEPROM_COMMAND_NULL; + savedata->flashState = FLASH_STATE_RAW; +} + void GBASavedataDeinit(struct GBASavedata* savedata) { if (savedata->vf) { size_t size = GBASavedataSize(savedata); From 3c32fd867b2cf82c021989f7731d6cce2b9f3c54 Mon Sep 17 00:00:00 2001 From: Daniel Nylander Date: Thu, 12 Dec 2024 11:35:14 +0100 Subject: [PATCH 297/338] Update setup.iss.in with Swedish (#3367) --- src/platform/windows/setup/setup.iss.in | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/platform/windows/setup/setup.iss.in b/src/platform/windows/setup/setup.iss.in index 7fdda053ee7..157cca63e8d 100644 --- a/src/platform/windows/setup/setup.iss.in +++ b/src/platform/windows/setup/setup.iss.in @@ -75,6 +75,7 @@ Name: "korean"; MessagesFile: "compiler:Languages\Korean.isl" Name: "dutch"; MessagesFile: "compiler:Languages\Dutch.isl" Name: "brazilianportuguese"; MessagesFile: "compiler:Languages\BrazilianPortuguese.isl" Name: "russian"; MessagesFile: "compiler:Languages\Russian.isl" +Name: "swedish"; MessagesFile: "compiler:Languages\Swedish.isl" Name: "turkish"; MessagesFile: "compiler:Languages\Turkish.isl" Name: "chinesesimplified"; MessagesFile: "compiler:Languages\ChineseSimplified.isl" @@ -118,6 +119,7 @@ korean.FileAssoc=Register file associations dutch.FileAssoc=Register file associations brazilianportuguese.FileAssoc=Register file associations russian.FileAssoc=Register file associations +swedish.FileAssoc=Registrera filassociationer turkish.FileAssoc=Register file associations chinesesimplified.FileAssoc=Register file associations @@ -153,6 +155,7 @@ procedure InitializeWizard(); if ExpandConstant('{language}') = 'dutch' then noReleaseWarning := 'You are about to install a development build of {#AppName}.' + #13#10#13#10 + 'Development builds may contain bugs that are not yet discovered. Please report any issues you can find to the GitHub project page.'; if ExpandConstant('{language}') = 'brazilianportuguese' then noReleaseWarning := 'You are about to install a development build of {#AppName}.' + #13#10#13#10 + 'Development builds may contain bugs that are not yet discovered. Please report any issues you can find to the GitHub project page.'; if ExpandConstant('{language}') = 'russian' then noReleaseWarning := 'You are about to install a development build of {#AppName}.' + #13#10#13#10 + 'Development builds may contain bugs that are not yet discovered. Please report any issues you can find to the GitHub project page.'; + if ExpandConstant('{language}') = 'swedish' then noReleaseWarning := 'Du är på väg att installera en utvecklingsversion av {#AppName}.' + #13#10#13#10 + 'Utvecklingsversioner kan innehålla buggar som ännu inte hittats. Rapportera alla problem som du hittar på projektsidan på GitHub.'; if ExpandConstant('{language}') = 'turkish' then noReleaseWarning := 'You are about to install a development build of {#AppName}.' + #13#10#13#10 + 'Development builds may contain bugs that are not yet discovered. Please report any issues you can find to the GitHub project page.'; if ExpandConstant('{language}') = 'chinesesimplified' then noReleaseWarning := 'You are about to install a development build of {#AppName}.' + #13#10#13#10 + 'Development builds may contain bugs that are not yet discovered. Please report any issues you can find to the GitHub project page.'; MsgBox(noReleaseWarning, mbInformation, MB_OK); From 23bb66820092fa96c1df81c8fea0ea4b1059d0d0 Mon Sep 17 00:00:00 2001 From: Felipe Date: Mon, 16 Sep 2024 18:57:18 +0000 Subject: [PATCH 298/338] Qt: Update translation (Portuguese (Brazil)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/pt_BR/ --- src/platform/qt/ts/mgba-pt_BR.ts | 138 +++++++++++++++---------------- 1 file changed, 69 insertions(+), 69 deletions(-) diff --git a/src/platform/qt/ts/mgba-pt_BR.ts b/src/platform/qt/ts/mgba-pt_BR.ts index 5b8c0df522d..3326cfcdead 100644 --- a/src/platform/qt/ts/mgba-pt_BR.ts +++ b/src/platform/qt/ts/mgba-pt_BR.ts @@ -198,12 +198,12 @@ Tamanho do download: %3 Audio device is missing its core - O núcleo do dispositivo de áudio está ausente + O dispositivo de áudio está com o núcleo ausente Writing data to read-only audio device - Gravando dados no dispositivo somente-leitura do áudio + Gravando os dados no dispositivo somente-leitura do áudio @@ -292,7 +292,7 @@ Tamanho do download: %3 BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? - Os dados do BattleChip estão ausente. Os Portais do BattleChip Gates ainda funcionarão mas alguns gráficos estarão ausentes. Você gostaria de baixar os dados agora? + Os dados do BattleChip estão ausentes. Os Portais do BattleChip ainda funcionarão mas alguns gráficos estarão ausentes. Você gostaria de baixar os dados agora? @@ -448,7 +448,7 @@ Tamanho do download: %3 Failed to open save file; in-game saves cannot be updated. Please ensure the save directory is writable without additional privileges (e.g. UAC on Windows). - Falhou em abrir o abrir o arquivo de save; Os saves dentro do jogo não podem ser atualizados. Por favor tenha certeza que o diretório de save seja gravável sem privilégios adicionais (ex: UAC no Windows). + Falhou em abrir o arquivo do save; Os saves dentro do jogo não podem ser atualizados. Por favor tenha certeza que o diretório do save seja gravável sem privilégios adicionais (ex: UAC no Windows). @@ -482,7 +482,7 @@ Tamanho do download: %3 Failed to create an OpenGL 3 context, trying old-style... - + Falhou em criar um contexto do OpenGL 3, tentando o estilo antigo... @@ -694,12 +694,12 @@ Tamanho do download: %3 Build finished - Compilação concluída + Build concluído Forwarder finished building - O encaminhador encerrou a compilação + O encaminhador concluiu a compilação @@ -752,7 +752,7 @@ Tamanho do download: %3 Disable scanline effects - Desativar efeitos da scanline + Desativar os efeitos da scanline @@ -886,7 +886,7 @@ Tamanho do download: %3 Break - Pausar + Interromper @@ -1168,17 +1168,17 @@ Tamanho do download: %3 Mode 0: 4 tile layers - Modo 0: 4 camadas de mosaicos + Modo 0: 4 camadas dos mosaicos Mode 1: 2 tile layers + 1 rotated/scaled tile layer - Modo 1: 2 camadas de mosaicos + 1 camada de mosaico rotacionada/redimensionada + Modo 1: 2 camadas dis mosaicos + 1 camada de mosaico rotacionada/redimensionada Mode 2: 2 rotated/scaled tile layers - Modo 2: 2 camadas de mosaicos rotacionadas/redimensionadas + Modo 2: 2 camadas dos mosaicos rotacionadas/redimensionadas @@ -1357,7 +1357,7 @@ Tamanho do download: %3 Overflow wraps - Embrulhos do excesso + Embrulhos da sobrecarga @@ -1439,7 +1439,7 @@ Tamanho do download: %3 End y - Final y + Y Final @@ -2281,7 +2281,7 @@ Tamanho do download: %3 Start timing - Iniciar timing + Iniciar a cronometragem @@ -2664,7 +2664,7 @@ Tamanho do download: %3 Gamepak prefetch - Pré-carga do Gamepak + Prefetch do Gamepak @@ -2699,7 +2699,7 @@ Tamanho do download: %3 Active face buttons - Botões de face ativos + Botões faciais ativos @@ -3054,7 +3054,7 @@ Tamanho do download: %3 %1 State - Estado %1 + State %1 @@ -3408,63 +3408,63 @@ Tamanho do download: %3 Memory access logging - + Registro de acesso a memória Log file - + Arquivo do registro Browse - Explorar + Explorar Log additional information (uses 3× space) - + Informação adicional do registro (usa 3x mais espaço) Load existing file if present - + Carregar o arquivo existente se estiver presente Regions - + Regiões Export ROM snapshot - + Exportar a snapshot da ROM Start - + Iniciar Stop - Parar + Parar Failed to open memory log file - + Falhou em abrir o arquivo do registro da memória Select access log file - + Selecionar o arquivo de registro do acesso Memory access logs (*.mal) - + Registros de acesso a memória (*.mal) @@ -3773,7 +3773,7 @@ Tamanho do download: %3 Signed Integer: - Inteiro com Sinal: + Inteiro Assinado: @@ -4254,7 +4254,7 @@ Tamanho do download: %3 Windows PAL (*.pal);;Adobe Color Table (*.act) - Windows PAL (*.pal);;Tabela de Cores da Adobe (*.act) + Windows PAL (*.pal);;Tabela de Cores do Adobe (*.act) @@ -4372,12 +4372,12 @@ Tamanho do download: %3 Maker Code: - + Código do Criador: Revision: - + Revisão: @@ -4430,7 +4430,7 @@ Tamanho do download: %3 Open issue list in browser - Abrir lista de problemas no navegador + Abrir a lista de problemas no navegador @@ -4488,7 +4488,7 @@ Tamanho do download: %3 No valid formats found - Não foram encontrados formatos válidos + Não foram achados formatos válidos @@ -4498,7 +4498,7 @@ Tamanho do download: %3 No valid conversions found - Não foram encontradas conversões válidas + Não foram achadas conversões válidas @@ -4660,7 +4660,7 @@ Tamanho do download: %3 &Load most recent - + &Carregar o mais recente @@ -4871,7 +4871,7 @@ Tamanho do download: %3 Less than an hour ago - Menos do que uma hora atrás + Menos do que a uma hora atrás @@ -5166,12 +5166,12 @@ Tamanho do download: %3 Show frame count in OSD - Mostrar contagem dos frames no OSD + Mostrar a contagem dos frames no OSD Show emulation info on reset - Mostrar informações da emulação ao resetar + Mostrar as informações da emulação ao resetar @@ -5191,7 +5191,7 @@ Tamanho do download: %3 Update channel: - Canal da atualização: + Canal de atualização: @@ -5271,7 +5271,7 @@ Tamanho do download: %3 Dynamically update window title - Atualizar título da janela dinamicamente + Atualizar o título da janela dinamicamente @@ -5297,7 +5297,7 @@ Tamanho do download: %3 Enable VBA bug compatibility in ROM hacks - Ativar compatibilidade dos bugs do VBA nos hacks das ROMs + Ativar a compatibilidade dos bugs do VBA nos hacks das ROMs @@ -5455,7 +5455,7 @@ Tamanho do download: %3 Enable Game Boy Player features by default - Ativar funções do Game Boy Player por padrão + Ativar as funções do Game Boy Player por padrão @@ -5475,7 +5475,7 @@ Tamanho do download: %3 High-resolution scale: - Escala de alta-resolução: + Escala da alta-resolução: @@ -5499,7 +5499,7 @@ Tamanho do download: %3 Use BIOS file if found - Usar o arquivo da BIOS se encontrado + Usar o arquivo da BIOS se for achado @@ -5677,7 +5677,7 @@ Tamanho do download: %3 Unload Shader - Descarregar Shader + Descarregar o Shader @@ -5986,7 +5986,7 @@ Tamanho do download: %3 Select e-Reader dotcode - Selecionar dotcode do e-Reader + Selecionar o dotcode do e-Reader @@ -6100,12 +6100,12 @@ Tamanho do download: %3 Load ROM in archive... - Carregar ROM no arquivo compactado... + Carregar a ROM no arquivo compactado... Add folder to library... - Adicionar pasta a biblioteca... + Adicionar a pasta a biblioteca... @@ -6130,7 +6130,7 @@ Tamanho do download: %3 Boot BIOS - Dar Boot na BIOS + Inicializar a BIOS @@ -6180,7 +6180,7 @@ Tamanho do download: %3 Load state file... - Carregar arquivo do state... + Carregar o arquivo do state... @@ -6190,7 +6190,7 @@ Tamanho do download: %3 Select save game - Selecione save do jogo + Selecione o save do jogo @@ -6206,7 +6206,7 @@ Tamanho do download: %3 Select e-Reader card images - Selecionar imagens do cartão do e-Reader + Selecionar as imagens do cartão do e-Reader @@ -6236,7 +6236,7 @@ Tamanho do download: %3 Convert e-Reader card image to raw... - Converter imagem do cartão do e-Reader pro natural... + Converter a imagem do cartão do e-Reader pro natural... @@ -6302,7 +6302,7 @@ Tamanho do download: %3 Reset needed - É necessário resetar + Um reset é necessário @@ -6357,7 +6357,7 @@ Tamanho do download: %3 Fast forward (held) - Avanço rápido (segurado) + Avanço rápido (pressionado) @@ -6392,7 +6392,7 @@ Tamanho do download: %3 Rewind (held) - Retroceder (segurado) + Retroceder (pressionado) @@ -6412,12 +6412,12 @@ Tamanho do download: %3 Increase solar level - Aumentar nível solar + Aumentar o nível solar Decrease solar level - Diminuir nível solar + Diminuir o nível solar @@ -6452,7 +6452,7 @@ Tamanho do download: %3 &Lock frame size - + &Travar o tamanho do frame @@ -6537,7 +6537,7 @@ Tamanho do download: %3 Adjust layer placement... - Ajustar posicionamento da camada... + Ajustar o posicionamento da camada... @@ -6567,7 +6567,7 @@ Tamanho do download: %3 Scan e-Reader dotcodes... - Escanear dotcodes do e-Reader... + Escanear os dotcodes do e-Reader... @@ -6597,7 +6597,7 @@ Tamanho do download: %3 Open debugger console... - Abrir console do debugger... + Abrir o console do debugger... @@ -6662,7 +6662,7 @@ Tamanho do download: %3 Log memory &accesses... - + Registrar os acessos a &memória... @@ -6682,7 +6682,7 @@ Tamanho do download: %3 GameShark Button (held) - Botão do GameShark (segurado) + Botão do GameShark (pressionado) @@ -6750,12 +6750,12 @@ Tamanho do download: %3 %1 kiB - %1 kiBs + %1 kBs %1 MiB - %1 MiBs + %1 MBs From f7d2c464d4a0c7351d3020f057ed8627a02d32d9 Mon Sep 17 00:00:00 2001 From: Hoseok Seo Date: Sun, 22 Sep 2024 03:11:33 +0000 Subject: [PATCH 299/338] Qt: Update translation (Korean) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/ko/ --- src/platform/qt/ts/mgba-ko.ts | 36 +++++++++++++++++------------------ 1 file changed, 18 insertions(+), 18 deletions(-) diff --git a/src/platform/qt/ts/mgba-ko.ts b/src/platform/qt/ts/mgba-ko.ts index 5eb6849150f..2e5bdd0aafd 100644 --- a/src/platform/qt/ts/mgba-ko.ts +++ b/src/platform/qt/ts/mgba-ko.ts @@ -482,7 +482,7 @@ Download size: %3 Failed to create an OpenGL 3 context, trying old-style... - + OpenGL 3 컨í…스트를 만들 수 없습니다. ì´ì „ 스타ì¼ì„ ì‹œë„ ì¤‘ìž…ë‹ˆë‹¤... @@ -3408,63 +3408,63 @@ Download size: %3 Memory access logging - + 메모리 ì ‘ì† ë¡œê¹… Log file - + 로그 íŒŒì¼ Browse - + 찾아보기 Log additional information (uses 3× space) - + 로그 추가 ì •ë³´ (3× 공간 사용) Load existing file if present - + 기존 파ì¼ì´ 있으면 로드 Regions - + 지역 Export ROM snapshot - + ROM 스냅샷 내보내기 Start - 시작 + 시작 Stop - 정지 + 정지 Failed to open memory log file - + 메모리 로그 파ì¼ì„ ì—´ 수 ì—†ìŒ Select access log file - + ì ‘ì† íŒŒì¼ ì„ íƒ Memory access logs (*.mal) - + 메모리 ì ‘ì† ë¡œê·¸ (*.mal) @@ -4372,12 +4372,12 @@ Download size: %3 Maker Code: - + ë©”ì´ì»¤ 코드: Revision: - + 리비전: @@ -4660,7 +4660,7 @@ Download size: %3 &Load most recent - + 최신 항목 로드 (&L) @@ -6374,7 +6374,7 @@ Download size: %3 &Lock frame size - + 프레임 í¬ê¸° 잠금 (&L) @@ -6655,7 +6655,7 @@ Download size: %3 Log memory &accesses... - + 메모리 ë° ì ‘ì† ê¸°ë¡... From 7d2fbb060a44441d8642ae1c60158b8e6dcee9d2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 30 Jan 2022 08:07:04 +0100 Subject: [PATCH 300/338] Qt: Added translation (Chinese (Traditional)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/zh_Hant/ --- src/platform/qt/ts/mgba-zh_Hant.ts | 6174 ++++++++++++++++++++++++++++ 1 file changed, 6174 insertions(+) create mode 100644 src/platform/qt/ts/mgba-zh_Hant.ts diff --git a/src/platform/qt/ts/mgba-zh_Hant.ts b/src/platform/qt/ts/mgba-zh_Hant.ts new file mode 100644 index 00000000000..9d127cda024 --- /dev/null +++ b/src/platform/qt/ts/mgba-zh_Hant.ts @@ -0,0 +1,6174 @@ + + + + + AboutScreen + + + About + + + + + <a href="http://mgba.io/">Website</a> • <a href="https://forums.mgba.io/">Forums / Support</a> • <a href="https://patreon.com/mgba">Donate</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">Source</a> + + + + + Branch: <tt>{gitBranch}</tt><br/>Revision: <tt>{gitCommit}</tt> + + + + + {projectName} would like to thank the following patrons from Patreon: + + + + + © 2013 – {year} Jeffrey Pfau, licensed under the Mozilla Public License, version 2.0 +Game Boy Advance is a registered trademark of Nintendo Co., Ltd. + + + + + {projectName} is an open-source Game Boy Advance emulator + + + + + ApplicationUpdatePrompt + + + An update is available + + + + + ArchiveInspector + + + Open in archive... + + + + + Loading... + + + + + AssetTile + + + Tile # + + + + + Palette # + + + + + Address + + + + + Red + + + + + Green + + + + + Blue + + + + + BattleChipView + + + BattleChip Gate + + + + + Chip name + + + + + Insert + + + + + Save + + + + + Load + + + + + Add + + + + + Remove + + + + + Gate type + + + + + Inserted + + + + + Chip ID + + + + + Update Chip data + + + + + Show advanced + + + + + CheatsView + + + Cheats + + + + + Add New Code + + + + + Remove + + + + + Add Lines + + + + + Code type + + + + + Save + + + + + Load + + + + + Enter codes here... + + + + + DebuggerConsole + + + Debugger + + + + + Enter command (try `help` for more info) + + + + + Break + + + + + DolphinConnector + + + Connect to Dolphin + + + + + Local computer + + + + + IP address + + + + + Connect + + + + + Disconnect + + + + + Close + + + + + Reset on connect + + + + + FrameView + + + Inspect frame + + + + + Magnification + + + + + Freeze frame + + + + + Backdrop color + + + + + Disable scanline effects + + + + + Export + + + + + Reset + + + + + GIFView + + + Record GIF/WebP/APNG + + + + + Loop + + + + + Start + + + + + Stop + + + + + Select File + + + + + APNG + + + + + GIF + + + + + WebP + + + + + Frameskip + + + + + IOViewer + + + I/O Viewer + + + + + 0x0000 + + + + + B + + + + + LibraryTree + + + Name + + + + + Location + + + + + Platform + + + + + Size + + + + + CRC32 + + + + + LoadSaveState + + + + %1 State + + + + + + + + + + + + + No Save + + + + + 5 + + + + + 6 + + + + + 8 + + + + + 4 + + + + + 1 + + + + + 3 + + + + + 7 + + + + + 9 + + + + + 2 + + + + + Cancel + + + + + LogView + + + Logs + + + + + Enabled Levels + + + + + Debug + + + + + Stub + + + + + Info + + + + + Warning + + + + + Error + + + + + Fatal + + + + + Game Error + + + + + Advanced settings + + + + + Clear + + + + + Max Lines + + + + + MapView + + + Maps + + + + + Magnification + + + + + Export + + + + + Copy + + + + + MemoryDump + + + Save Memory Range + + + + + Start Address: + + + + + Byte Count: + + + + + Dump across banks + + + + + MemorySearch + + + Memory Search + + + + + Address + + + + + Current Value + + + + + + Type + + + + + Value + + + + + Numeric + + + + + Text + + + + + Width + + + + + + Guess + + + + + 1 Byte (8-bit) + + + + + 2 Bytes (16-bit) + + + + + 4 Bytes (32-bit) + + + + + Number type + + + + + Decimal + + + + + Hexadecimal + + + + + Search type + + + + + Equal to value + + + + + Greater than value + + + + + Less than value + + + + + Unknown/changed + + + + + Changed by value + + + + + Unchanged + + + + + Increased + + + + + Decreased + + + + + Search ROM + + + + + New Search + + + + + Search Within + + + + + Open in Memory Viewer + + + + + Refresh + + + + + MemoryView + + + Memory + + + + + Inspect Address: + + + + + Set Alignment: + + + + + &1 Byte + + + + + &2 Bytes + + + + + &4 Bytes + + + + + Unsigned Integer: + + + + + Signed Integer: + + + + + String: + + + + + Load TBL + + + + + Copy Selection + + + + + Paste + + + + + Save Selection + + + + + Save Range + + + + + Load + + + + + ObjView + + + Sprites + + + + + Address + + + + + Copy + + + + + Magnification + + + + + Geometry + + + + + Position + + + + + , + + + + + Dimensions + + + + + × + + + + + Matrix + + + + + Export + + + + + Attributes + + + + + Transform + + + + + Off + + + + + Palette + + + + + Double Size + + + + + + + Return, Ctrl+R + + + + + Flipped + + + + + H + Short for horizontal + + + + + V + Short for vertical + + + + + Mode + + + + + Normal + + + + + Mosaic + + + + + Enabled + + + + + Priority + + + + + Tile + + + + + OverrideView + + + Game Overrides + + + + + Game Boy Advance + + + + + + + + Autodetect + + + + + Realtime clock + + + + + Gyroscope + + + + + Tilt + + + + + Light sensor + + + + + Rumble + + + + + Save type + + + + + None + + + + + SRAM + + + + + Flash 512kb + + + + + Flash 1Mb + + + + + EEPROM 8kB + + + + + EEPROM 512 bytes + + + + + SRAM 64kB (bootlegs only) + + + + + Idle loop + + + + + Game Boy Player features + + + + + VBA bug compatibility mode + + + + + Game Boy + + + + + Game Boy model + + + + + Memory bank controller + + + + + Background Colors + + + + + Sprite Colors 1 + + + + + Sprite Colors 2 + + + + + Palette preset + + + + + PaletteView + + + Palette + + + + + Background + + + + + Objects + + + + + Selection + + + + + Red + + + + + Green + + + + + Blue + + + + + 16-bit value + + + + + Hex code + + + + + Palette index + + + + + Export BG + + + + + Export OBJ + + + + + PlacementControl + + + Adjust placement + + + + + All + + + + + Offset + + + + + X + + + + + Y + + + + + PrinterView + + + Game Boy Printer + + + + + Hurry up! + + + + + Tear off + + + + + Magnification + + + + + Copy + + + + + QGBA::AboutScreen + + + 2021 + + + + + QGBA::ApplicationUpdatePrompt + + + An update to %1 is available. + + + + + + +Do you want to download and install it now? You will need to restart the emulator when the download is complete. + + + + + +Auto-update is not available on this platform. If you wish to update you will need to do it manually. + + + + + Current version: %1 +New version: %2 +Download size: %3 + + + + + Downloading update... + + + + + Downloading failed. Please update manually. + + + + + Downloading done. Press OK to restart %1 and install the update. + + + + + QGBA::ApplicationUpdater + + + Stable + + + + + Development + + + + + Unknown + + + + + (None) + + + + + QGBA::AssetTile + + + %0%1%2 + + + + + + + 0x%0 (%1) + + + + + QGBA::CheatsModel + + + (untitled) + + + + + Failed to open cheats file: %1 + + + + + QGBA::CheatsView + + + + Autodetect (recommended) + + + + + + Select cheats file + + + + + QGBA::CoreController + + + Failed to open save file: %1 + + + + + Failed to open game file: %1 + + + + + Can't yank pack in unexpected platform! + + + + + Failed to open snapshot file for reading: %1 + + + + + Failed to open snapshot file for writing: %1 + + + + + QGBA::CoreManager + + + Failed to open game file: %1 + + + + + Could not load game. Are you sure it's in the correct format? + + + + + Failed to open save file; in-game saves cannot be updated. Please ensure the save directory is writable without additional privileges (e.g. UAC on Windows). + + + + + QGBA::FrameView + + + Export frame + + + + + Portable Network Graphics (*.png) + + + + + None + + + + + Background + + + + + Window + + + + + Objwin + + + + + Sprite + + + + + Backdrop + + + + + Frame + + + + + %1 %2 + + + + + QGBA::GBAApp + + + Enable Discord Rich Presence + + + + + QGBA::GBAKeyEditor + + + Clear Button + + + + + Clear Analog + + + + + Refresh + + + + + Set all + + + + + QGBA::GDBWindow + + + Server settings + + + + + Local port + + + + + Bind address + + + + + Break + + + + + Stop + + + + + Start + + + + + Crash + + + + + Could not start GDB server + + + + + QGBA::GIFView + + + Failed to open output file: %1 + + + + + Select output file + + + + + Graphics Interchange Format (*.gif);;WebP ( *.webp);;Animated Portable Network Graphics (*.png *.apng) + + + + + QGBA::IOViewer + + + Background mode + + + + + Mode 0: 4 tile layers + + + + + Mode 1: 2 tile layers + 1 rotated/scaled tile layer + + + + + Mode 2: 2 rotated/scaled tile layers + + + + + Mode 3: Full 15-bit bitmap + + + + + Mode 4: Full 8-bit bitmap + + + + + Mode 5: Small 15-bit bitmap + + + + + CGB Mode + + + + + Frame select + + + + + Unlocked HBlank + + + + + Linear OBJ tile mapping + + + + + Force blank screen + + + + + Enable background 0 + + + + + Enable background 1 + + + + + Enable background 2 + + + + + Enable background 3 + + + + + Enable OBJ + + + + + Enable Window 0 + + + + + Enable Window 1 + + + + + Enable OBJ Window + + + + + Swap green components + + + + + Currently in VBlank + + + + + Currently in HBlank + + + + + Currently in VCounter + + + + + Enable VBlank IRQ generation + + + + + Enable HBlank IRQ generation + + + + + Enable VCounter IRQ generation + + + + + VCounter scanline + + + + + Current scanline + + + + + + + + Priority + + + + + + + + Tile data base (* 16kB) + + + + + + + + Enable mosaic + + + + + + + + Enable 256-color + + + + + + + + Tile map base (* 2kB) + + + + + + + + Background dimensions + + + + + + Overflow wraps + + + + + + + + + + Horizontal offset + + + + + + + + + + Vertical offset + + + + + + + + + + + + + + + + Fractional part + + + + + + + + + + + + Integer part + + + + + + + + Integer part (low) + + + + + + + + Integer part (high) + + + + + + End x + + + + + + Start x + + + + + + End y + + + + + + Start y + + + + + Window 0 enable BG 0 + + + + + Window 0 enable BG 1 + + + + + Window 0 enable BG 2 + + + + + Window 0 enable BG 3 + + + + + Window 0 enable OBJ + + + + + Window 0 enable blend + + + + + Window 1 enable BG 0 + + + + + Window 1 enable BG 1 + + + + + Window 1 enable BG 2 + + + + + Window 1 enable BG 3 + + + + + Window 1 enable OBJ + + + + + Window 1 enable blend + + + + + Outside window enable BG 0 + + + + + Outside window enable BG 1 + + + + + Outside window enable BG 2 + + + + + Outside window enable BG 3 + + + + + Outside window enable OBJ + + + + + Outside window enable blend + + + + + OBJ window enable BG 0 + + + + + OBJ window enable BG 1 + + + + + OBJ window enable BG 2 + + + + + OBJ window enable BG 3 + + + + + OBJ window enable OBJ + + + + + OBJ window enable blend + + + + + Background mosaic size vertical + + + + + Background mosaic size horizontal + + + + + Object mosaic size vertical + + + + + Object mosaic size horizontal + + + + + BG 0 target 1 + + + + + BG 1 target 1 + + + + + BG 2 target 1 + + + + + BG 3 target 1 + + + + + OBJ target 1 + + + + + Backdrop target 1 + + + + + Blend mode + + + + + Disabled + + + + + Additive blending + + + + + Brighten + + + + + Darken + + + + + BG 0 target 2 + + + + + BG 1 target 2 + + + + + BG 2 target 2 + + + + + BG 3 target 2 + + + + + OBJ target 2 + + + + + Backdrop target 2 + + + + + Blend A (target 1) + + + + + Blend B (target 2) + + + + + Blend Y + + + + + + Sweep shifts + + + + + + Sweep subtract + + + + + + Sweep time (in 1/128s) + + + + + + + + + + + + Sound length + + + + + + + + Duty cycle + + + + + + + + + + Envelope step time + + + + + + + + + + Envelope increase + + + + + + + + + + Initial volume + + + + + + + Sound frequency + + + + + + + + + + + + Timed + + + + + + + + + + + + Reset + + + + + Double-size wave table + + + + + Active wave table + + + + + + Enable channel 3 + + + + + + Volume + + + + + + 0% + + + + + + + 100% + + + + + + + 50% + + + + + + + 25% + + + + + + + + 75% + + + + + + Clock divider + + + + + + Register stages + + + + + + 15 + + + + + + 7 + + + + + + Shifter frequency + + + + + PSG volume right + + + + + PSG volume left + + + + + + Enable channel 1 right + + + + + + Enable channel 2 right + + + + + + Enable channel 3 right + + + + + + Enable channel 4 right + + + + + + Enable channel 1 left + + + + + + Enable channel 2 left + + + + + + Enable channel 3 left + + + + + + Enable channel 4 left + + + + + PSG master volume + + + + + Loud channel A + + + + + Loud channel B + + + + + Enable channel A right + + + + + Enable channel A left + + + + + Channel A timer + + + + + + 0 + + + + + + + + + + + + + 1 + + + + + Channel A reset + + + + + Enable channel B right + + + + + Enable channel B left + + + + + Channel B timer + + + + + Channel B reset + + + + + + Active channel 1 + + + + + + Active channel 2 + + + + + + Active channel 3 + + + + + + Active channel 4 + + + + + + Enable audio + + + + + Bias + + + + + Resolution + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Sample + + + + + + + + + + + + Address (low) + + + + + + + + + + + + Address (high) + + + + + + + Sound frequency (low) + + + + + + + Sound frequency (high) + + + + + Source (high) + + + + + Source (low) + + + + + Destination (high) + + + + + Destination (low) + + + + + + Green (low) + + + + + + Green (high) + + + + + + + + Word count + + + + + + + + Destination offset + + + + + + + + + + + + Increment + + + + + + + + + + + + Decrement + + + + + + + + + + + + Fixed + + + + + + + + Increment and reload + + + + + + + + Source offset + + + + + + + + Repeat + + + + + + + + 32-bit + + + + + + + + Start timing + + + + + + + + + Immediate + + + + + + + + + + + + VBlank + + + + + + + + + + + HBlank + + + + + + + + + + + + + IRQ + + + + + + + + + + + + + + + Enable + + + + + + + Audio FIFO + + + + + Video Capture + + + + + DRQ + + + + + + + + + + + + Value + + + + + + + + Scale + + + + + + + + + 1/64 + + + + + + + + + 1/256 + + + + + + + + + 1/1024 + + + + + + + Cascade + + + + + + A + + + + + + B + + + + + + Select + + + + + + Start + + + + + + Right + + + + + + Left + + + + + + Up + + + + + + Down + + + + + + R + + + + + + L + + + + + Condition + + + + + SC + + + + + SD + + + + + SI + + + + + SO + + + + + + VCounter + + + + + + Timer 0 + + + + + + Timer 1 + + + + + + Timer 2 + + + + + + Timer 3 + + + + + + SIO + + + + + + DMA 0 + + + + + + DMA 1 + + + + + + DMA 2 + + + + + + DMA 3 + + + + + + Keypad + + + + + + Gamepak + + + + + SRAM wait + + + + + + + + + 4 + + + + + + + + 3 + + + + + + + + + 2 + + + + + + + + + 8 + + + + + Cart 0 non-sequential + + + + + Cart 0 sequential + + + + + Cart 1 non-sequential + + + + + Cart 1 sequential + + + + + Cart 2 non-sequential + + + + + Cart 2 sequential + + + + + PHI terminal + + + + + + Disable + + + + + 4.19MHz + + + + + 8.38MHz + + + + + 16.78MHz + + + + + Gamepak prefetch + + + + + Enable IRQs + + + + + Right/A + + + + + Left/B + + + + + Up/Select + + + + + Down/Start + + + + + Active D-pad + + + + + Active face buttons + + + + + Internal clock + + + + + 32× clocking (CGB only) + + + + + Transfer active + + + + + Divider + + + + + 1/16 + + + + + + LCD STAT + + + + + + Timer + + + + + + Serial + + + + + + Joypad + + + + + Volume right + + + + + Output right + + + + + Volume left + + + + + Output left + + + + + Background enable/priority + + + + + Enable sprites + + + + + Double-height sprites + + + + + Background tile map + + + + + + 0x9800 – 0x9BFF + + + + + + 0x9C00 – 0x9FFF + + + + + Background tile data + + + + + 0x8800 – 0x87FF + + + + + 0x8000 – 0x8FFF + + + + + Enable window + + + + + Window tile map + + + + + Enable LCD + + + + + Mode + + + + + 0: HBlank + + + + + 1: VBlank + + + + + 2: OAM scan + + + + + 3: HDraw + + + + + In LYC + + + + + Enable HBlank (mode 0) IRQ + + + + + Enable VBlank (mode 1) IRQ + + + + + Enable OAM (mode 2) IRQ + + + + + Enable LYC IRQ + + + + + Current Y coordinate + + + + + Comparison Y coordinate + + + + + Start upper byte + + + + + + + Color 0 shade + + + + + + + Color 1 shade + + + + + + + Color 2 shade + + + + + + + Color 3 shade + + + + + Prepare to switch speed + + + + + Double speed + + + + + VRAM bank + + + + + Length + + + + + Timing + + + + + Write bit + + + + + Read bit + + + + + + Unknown + + + + + + Current index + + + + + + Auto-increment + + + + + + Red + + + + + + Blue + + + + + Sprite ordering + + + + + OAM order + + + + + x coordinate sorting + + + + + WRAM bank + + + + + QGBA::KeyEditor + + + + --- + + + + + Super (L) + + + + + Super (R) + + + + + Menu + + + + + QGBA::LoadSaveState + + + Load State + + + + + Save State + + + + + Empty + + + + + Corrupted + + + + + Slot %1 + + + + + QGBA::LogConfigModel + + + + Default + + + + + Fatal + + + + + Error + + + + + Warning + + + + + Info + + + + + Debug + + + + + Stub + + + + + Game Error + + + + + QGBA::LogController + + + [%1] %2: %3 + + + + + An error occurred + + + + + DEBUG + + + + + STUB + + + + + INFO + + + + + WARN + + + + + ERROR + + + + + FATAL + + + + + GAME ERROR + + + + + QGBA::MapView + + + Priority + + + + + + Map base + + + + + + Tile base + + + + + Size + + + + + + Offset + + + + + Xform + + + + + Map Addr. + + + + + Mirror + + + + + None + + + + + Both + + + + + Horizontal + + + + + Vertical + + + + + + + N/A + + + + + Export map + + + + + Portable Network Graphics (*.png) + + + + + QGBA::MemoryDump + + + Save memory region + + + + + Failed to open output file: %1 + + + + + QGBA::MemoryModel + + + Copy selection + + + + + Save selection + + + + + Paste + + + + + Load + + + + + All + + + + + Load TBL + + + + + Save selected memory + + + + + Failed to open output file: %1 + + + + + Load memory + + + + + Failed to open input file: %1 + + + + + TBL + + + + + ISO-8859-1 + + + + + QGBA::MemorySearch + + + (%0/%1×) + + + + + (â…Ÿ%0×) + + + + + (%0×) + + + + + %1 byte%2 + + + + + QGBA::ObjView + + + + 0x%0 + + + + + Off + + + + + + + + + + + + --- + + + + + Normal + + + + + Trans + + + + + OBJWIN + + + + + Invalid + + + + + + N/A + + + + + Export sprite + + + + + Portable Network Graphics (*.png) + + + + + QGBA::OverrideView + + + Official MBCs + + + + + Licensed MBCs + + + + + Unlicensed MBCs + + + + + QGBA::PaletteView + + + #%0 + + + + + 0x%0 + + + + + + + + 0x%0 (%1) + + + + + Export palette + + + + + Windows PAL (*.pal);;Adobe Color Table (*.act) + + + + + Failed to open output palette file: %1 + + + + + QGBA::ROMInfo + + + + + + + (unknown) + + + + + + bytes + + + + + (no database present) + + + + + QGBA::ReportView + + + Bug report archive + + + + + ZIP archive (*.zip) + + + + + QGBA::SaveConverter + + + Save games and save states (%1) + + + + + Select save game or save state + + + + + Save games (%1) + + + + + Select save game + + + + + Conversion failed + + + + + Failed to convert the save game. This is probably a bug. + + + + + No file selected + + + + + Could not open file + + + + + No valid formats found + + + + + Please select a valid input file + + + + + No valid conversions found + + + + + Cannot convert save games between platforms + + + + + QGBA::SettingsView + + + + Qt Multimedia + + + + + SDL + + + + + Software (Qt) + + + + + OpenGL + + + + + OpenGL (force version 1.x) + + + + + None + + + + + None (Still Image) + + + + + Keyboard + + + + + Controllers + + + + + Shortcuts + + + + + + Shaders + + + + + Select BIOS + + + + + Select directory + + + + + (%1×%2) + + + + + Never + + + + + Just now + + + + + Less than an hour ago + + + + + %n hour(s) ago + + + + + + + %n day(s) ago + + + + + + + QGBA::ShaderSelector + + + No shader active + + + + + Load shader + + + + + No shader loaded + + + + + by %1 + + + + + Preprocessing + + + + + Pass %1 + + + + + QGBA::ShortcutModel + + + Action + + + + + Keyboard + + + + + Gamepad + + + + + QGBA::TileView + + + Export tiles + + + + + + Portable Network Graphics (*.png) + + + + + Export tile + + + + + QGBA::VideoView + + + Failed to open output video file: %1 + + + + + Native (%0x%1) + + + + + Select output file + + + + + QGBA::Window + + + Game Boy Advance ROMs (%1) + + + + + Game Boy ROMs (%1) + + + + + All ROMs (%1) + + + + + %1 Video Logs (*.mvl) + + + + + Archives (%1) + + + + + + + Select ROM + + + + + Select folder + + + + + + Select save + + + + + Select patch + + + + + Patches (*.ips *.ups *.bps) + + + + + Select e-Reader dotcode + + + + + e-Reader card (*.raw *.bin *.bmp) + + + + + Select image + + + + + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) + + + + + GameShark saves (*.sps *.xps) + + + + + Select video log + + + + + Video logs (*.mvl) + + + + + Crash + + + + + The game has crashed with the following error: + +%1 + + + + + Couldn't Start + + + + + Could not start game. + + + + + Unimplemented BIOS call + + + + + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. + + + + + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. + + + + + Really make portable? + + + + + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? + + + + + Restart needed + + + + + Some changes will not take effect until the emulator is restarted. + + + + + - Player %1 of %2 + + + + + %1 - %2 + + + + + %1 - %2 - %3 + + + + + %1 - %2 (%3 fps) - %4 + + + + + &File + + + + + Load &ROM... + + + + + Load ROM in archive... + + + + + Add folder to library... + + + + + Save games (%1) + + + + + Select save game + + + + + mGBA save state files (%1) + + + + + + Select save state + + + + + Select e-Reader card images + + + + + Image file (*.png *.jpg *.jpeg) + + + + + Conversion finished + + + + + %1 of %2 e-Reader cards converted successfully. + + + + + Load alternate save game... + + + + + Load temporary save game... + + + + + Load &patch... + + + + + Boot BIOS + + + + + Replace ROM... + + + + + Scan e-Reader dotcodes... + + + + + Convert e-Reader card image to raw... + + + + + ROM &info... + + + + + Recent + + + + + Make portable + + + + + &Load state + + + + + Load state file... + + + + + &Save state + + + + + Save state file... + + + + + Quick load + + + + + Quick save + + + + + Load recent + + + + + Save recent + + + + + Undo load state + + + + + Undo save state + + + + + + State &%1 + + + + + Load camera image... + + + + + Convert save game... + + + + + GameShark saves (*.gsv *.sps *.xps) + + + + + Import GameShark Save... + + + + + Export GameShark Save... + + + + + New multiplayer window + + + + + Connect to Dolphin... + + + + + Report bug... + + + + + About... + + + + + E&xit + + + + + &Emulation + + + + + &Reset + + + + + Sh&utdown + + + + + Yank game pak + + + + + &Pause + + + + + &Next frame + + + + + Fast forward (held) + + + + + &Fast forward + + + + + Fast forward speed + + + + + Unbounded + + + + + %0x + + + + + Rewind (held) + + + + + Re&wind + + + + + Step backwards + + + + + Sync to &video + + + + + Sync to &audio + + + + + Solar sensor + + + + + Increase solar level + + + + + Decrease solar level + + + + + Brightest solar level + + + + + Darkest solar level + + + + + Brightness %1 + + + + + Game Boy Printer... + + + + + BattleChip Gate... + + + + + Audio/&Video + + + + + Frame size + + + + + %1× + + + + + Toggle fullscreen + + + + + Lock aspect ratio + + + + + Force integer scaling + + + + + Interframe blending + + + + + Bilinear filtering + + + + + Frame&skip + + + + + Mute + + + + + FPS target + + + + + Native (59.7275) + + + + + Take &screenshot + + + + + F12 + + + + + Record A/V... + + + + + Record GIF/WebP/APNG... + + + + + Video layers + + + + + Audio channels + + + + + Adjust layer placement... + + + + + &Tools + + + + + View &logs... + + + + + Game &overrides... + + + + + Game Pak sensors... + + + + + &Cheats... + + + + + Settings... + + + + + Open debugger console... + + + + + Start &GDB server... + + + + + View &palette... + + + + + View &sprites... + + + + + View &tiles... + + + + + View &map... + + + + + &Frame inspector... + + + + + View memory... + + + + + Search memory... + + + + + View &I/O registers... + + + + + Record debug video log... + + + + + Stop debug video log + + + + + Exit fullscreen + + + + + GameShark Button (held) + + + + + Autofire + + + + + Autofire A + + + + + Autofire B + + + + + Autofire L + + + + + Autofire R + + + + + Autofire Start + + + + + Autofire Select + + + + + Autofire Up + + + + + Autofire Right + + + + + Autofire Down + + + + + Autofire Left + + + + + Clear + + + + + QObject + + + %1 byte + + + + + %1 kiB + + + + + %1 MiB + + + + + GBA + + + + + GB + + + + + ? + + + + + QShortcut + + + Shift + + + + + Control + + + + + Alt + + + + + Meta + + + + + ROMInfo + + + ROM Info + + + + + Game name: + + + + + Internal name: + + + + + Game ID: + + + + + File size: + + + + + CRC32: + + + + + ReportView + + + Generate Bug Report + + + + + <html><head/><body><p>To file a bug report, please first generate a report file to attach to the bug report you're about to file. It is recommended that you include the save files, as these often help with debugging issues. This will collect some information about the version of {projectName} you're running, your configuration, your computer, and the game you currently have open (if any). Once this collection is completed you can review all of the information gathered below and save it to a zip file. The collection will automatically attempt to redact any personal information, such as your username if it's in any of the paths gathered, but just in case you can edit it afterwards. After you have generated and saved it, please click the button below or go to <a href="https://mgba.io/i/"><span style=" text-decoration: underline; color:#2980b9;">mgba.io/i</span></a> to file the bug report on GitHub. Make sure to attach the report you generated!</p></body></html> + + + + + Generate report + + + + + Save + + + + + Open issue list in browser + + + + + Include save file + + + + + Create and include savestate + + + + + SaveConverter + + + Convert/Extract Save Game + + + + + Input file + + + + + + Browse + + + + + Output file + + + + + %1 %2 save game + + + + + little endian + + + + + big endian + + + + + SRAM + + + + + %1 flash + + + + + %1 EEPROM + + + + + %1 SRAM + RTC + + + + + %1 SRAM + + + + + packed MBC2 + + + + + unpacked MBC2 + + + + + MBC6 flash + + + + + MBC6 combined SRAM + flash + + + + + MBC6 SRAM + + + + + TAMA5 + + + + + %1 (%2) + + + + + %1 save state with embedded %2 save game + + + + + %1 SharkPort %2 save game + + + + + %1 GameShark Advance SP %2 save game + + + + + SensorView + + + Sensors + + + + + Realtime clock + + + + + Fixed time + + + + + System time + + + + + Start time at + + + + + Now + + + + + MM/dd/yy hh:mm:ss AP + + + + + Light sensor + + + + + Brightness + + + + + Tilt sensor + + + + + + Set Y + + + + + + Set X + + + + + Gyroscope + + + + + Sensitivity + + + + + SettingsView + + + Settings + + + + + Audio/Video + + + + + Interface + + + + + Update + + + + + Emulation + + + + + Enhancements + + + + + BIOS + + + + + Paths + + + + + Logging + + + + + Game Boy + + + + + Audio driver: + + + + + Audio buffer: + + + + + + 1536 + + + + + 512 + + + + + 768 + + + + + 1024 + + + + + 2048 + + + + + 3072 + + + + + 4096 + + + + + samples + + + + + Sample rate: + + + + + + 44100 + + + + + 22050 + + + + + 32000 + + + + + 48000 + + + + + Hz + + + + + Volume: + + + + + + + + Mute + + + + + Fast forward volume: + + + + + Audio in multiplayer: + + + + + All windows + + + + + Player 1 window only + + + + + Currently active player window + + + + + Display driver: + + + + + Frameskip: + + + + + Skip every + + + + + + frames + + + + + FPS target: + + + + + frames per second + + + + + Sync: + + + + + Video + + + + + Audio + + + + + Lock aspect ratio + + + + + Force integer scaling + + + + + Bilinear filtering + + + + + + Pause + + + + + When inactive: + + + + + When minimized: + + + + + Current channel: + + + + + Current version: + + + + + Update channel: + + + + + Available version: + + + + + (Unknown) + + + + + Last checked: + + + + + Automatically check on start + + + + + Check now + + + + + Default color palette only + + + + + SGB color palette if available + + + + + GBC color palette if available + + + + + SGB (preferred) or GBC color palette if available + + + + + Game Boy Camera + + + + + Driver: + + + + + Source: + + + + + Native (59.7275) + + + + + Interframe blending + + + + + Language + + + + + Library: + + + + + List view + + + + + Tree view + + + + + Show when no game open + + + + + Clear cache + + + + + Allow opposing input directions + + + + + Suspend screensaver + + + + + Dynamically update window title + + + + + Show filename instead of ROM name in title bar + + + + + Show OSD messages + + + + + Enable Discord Rich Presence + + + + + Automatically save state + + + + + Automatically load state + + + + + Automatically save cheats + + + + + Automatically load cheats + + + + + Show FPS in title bar + + + + + Fast forward speed: + + + + + + Unbounded + + + + + Fast forward (held) speed: + + + + + Autofire interval: + + + + + Enable rewind + + + + + Rewind history: + + + + + Idle loops: + + + + + Run all + + + + + Remove known + + + + + Detect and remove + + + + + Preload entire ROM into memory + + + + + Save state extra data: + + + + + + Save game + + + + + Load state extra data: + + + + + Models + + + + + GB only: + + + + + SGB compatible: + + + + + GBC only: + + + + + GBC compatible: + + + + + SGB and GBC compatible: + + + + + Game Boy palette + + + + + Preset: + + + + + + Screenshot + + + + + + Cheat codes + + + + + Enable Game Boy Player features by default + + + + + Enable VBA bug compatibility in ROM hacks + + + + + Video renderer: + + + + + Software + + + + + OpenGL + + + + + OpenGL enhancements + + + + + High-resolution scale: + + + + + (240×160) + + + + + XQ GBA audio (experimental) + + + + + GB BIOS file: + + + + + + + + + + + + + Browse + + + + + Use BIOS file if found + + + + + Skip BIOS intro + + + + + GBA BIOS file: + + + + + GBC BIOS file: + + + + + SGB BIOS file: + + + + + Save games + + + + + + + + + Same directory as the ROM + + + + + Save states + + + + + Screenshots + + + + + Patches + + + + + Cheats + + + + + Log to file + + + + + Log to console + + + + + Select Log File + + + + + Default BG colors: + + + + + Default sprite colors 1: + + + + + Default sprite colors 2: + + + + + Super Game Boy borders + + + + + ShaderSelector + + + Shaders + + + + + Active Shader: + + + + + Name + + + + + Author + + + + + Description + + + + + Unload Shader + + + + + Load New Shader + + + + + ShortcutView + + + Edit Shortcuts + + + + + Keyboard + + + + + Gamepad + + + + + Clear + + + + + TileView + + + Tiles + + + + + Export Selected + + + + + Export All + + + + + 256 colors + + + + + Magnification + + + + + Tiles per row + + + + + Fit to window + + + + + Copy Selected + + + + + Copy All + + + + + VideoView + + + Record Video + + + + + Start + + + + + Stop + + + + + Select File + + + + + Presets + + + + + High &Quality + + + + + &YouTube + + + + + + WebM + + + + + + MP4 + + + + + &Lossless + + + + + 4K + + + + + &1080p + + + + + &720p + + + + + &480p + + + + + &Native + + + + + Format + + + + + MKV + + + + + AVI + + + + + HEVC + + + + + HEVC (NVENC) + + + + + VP8 + + + + + VP9 + + + + + FFV1 + + + + + + None + + + + + FLAC + + + + + Opus + + + + + Vorbis + + + + + MP3 + + + + + AAC + + + + + Uncompressed + + + + + Bitrate (kbps) + + + + + ABR + + + + + H.264 + + + + + H.264 (NVENC) + + + + + VBR + + + + + CRF + + + + + Dimensions + + + + + Lock aspect ratio + + + + + Show advanced + + + + From 66a909a9b731296db5fd0a1e511b7cce69c63485 Mon Sep 17 00:00:00 2001 From: cyruuspmd5de3b0e46e4e4998 Date: Sun, 30 Jan 2022 07:29:05 +0000 Subject: [PATCH 301/338] Qt: Update translation (Chinese (Traditional)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/zh_Hant/ --- src/platform/qt/ts/mgba-zh_Hant.ts | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/src/platform/qt/ts/mgba-zh_Hant.ts b/src/platform/qt/ts/mgba-zh_Hant.ts index 9d127cda024..9198b253fa4 100644 --- a/src/platform/qt/ts/mgba-zh_Hant.ts +++ b/src/platform/qt/ts/mgba-zh_Hant.ts @@ -6,33 +6,34 @@ About - + 關於 <a href="http://mgba.io/">Website</a> • <a href="https://forums.mgba.io/">Forums / Support</a> • <a href="https://patreon.com/mgba">Donate</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">Source</a> - + <a href="http://mgba.io/">網站</a> • <a href="https://forums.mgba.io/">論壇ã€æ”¯æŒ</a> • <a href="https://patreon.com/mgba">æ助</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">æºä»£ç¢¼</a> Branch: <tt>{gitBranch}</tt><br/>Revision: <tt>{gitCommit}</tt> - + 分支: <tt>{gitBranch}</tt><br/>修訂版: <tt>{gitCommit}</tt> {projectName} would like to thank the following patrons from Patreon: - + {projectName} æ„Ÿè¬ä»¥ä¸‹ä¾†è‡ª Patreon 的讚助者: © 2013 – {year} Jeffrey Pfau, licensed under the Mozilla Public License, version 2.0 Game Boy Advance is a registered trademark of Nintendo Co., Ltd. - + © 2013 – {year} Jeffrey Pfau,基於 Mozilla 公共許å¯è­‰ï¼ˆç‰ˆæœ¬ 2.0)授權 +Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標。 {projectName} is an open-source Game Boy Advance emulator - + {projectName} 是開放æºä»£ç¢¼çš„ Game Boy Advance 模擬器 @@ -40,7 +41,7 @@ Game Boy Advance is a registered trademark of Nintendo Co., Ltd. An update is available - + 有å¯ç”¨çš„æ›´æ–° @@ -48,12 +49,12 @@ Game Boy Advance is a registered trademark of Nintendo Co., Ltd. Open in archive... - + 在壓縮文件中打開... Loading... - + 正在載入... @@ -61,12 +62,12 @@ Game Boy Advance is a registered trademark of Nintendo Co., Ltd. Tile # - + 圖塊 # Palette # - + èª¿è‰²æ¿ # From 63492252d245f43666f15cfdde6e3cff9cd1487a Mon Sep 17 00:00:00 2001 From: Still Hsu Date: Thu, 21 Apr 2022 04:10:02 +0000 Subject: [PATCH 302/338] Qt: Update translation (Chinese (Traditional)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/zh_Hant/ --- src/platform/qt/ts/mgba-zh_Hant.ts | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/src/platform/qt/ts/mgba-zh_Hant.ts b/src/platform/qt/ts/mgba-zh_Hant.ts index 9198b253fa4..5950c0fb814 100644 --- a/src/platform/qt/ts/mgba-zh_Hant.ts +++ b/src/platform/qt/ts/mgba-zh_Hant.ts @@ -33,7 +33,7 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 {projectName} is an open-source Game Boy Advance emulator - {projectName} 是開放æºä»£ç¢¼çš„ Game Boy Advance 模擬器 + {projectName} 是開æºçš„ Game Boy Advance 模擬器 @@ -72,22 +72,22 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Address - + åœ°å€ Red - + 红 Green - + 綠 Blue - + è— @@ -158,42 +158,42 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Cheats - + 金手指 Add New Code - + 新增金手指 Remove - + 移除 Add Lines - + 新增行 Code type - + 代碼類型 Save - + 儲存 Load - + 載入 Enter codes here... - + 在此輸入代碼... From 97d3f34a258da3822905b2374a6665960e3e4fe9 Mon Sep 17 00:00:00 2001 From: reimu105 Date: Tue, 12 Dec 2023 13:15:37 +0000 Subject: [PATCH 303/338] Qt: Update translation (Chinese (Traditional)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/zh_Hant/ --- src/platform/qt/ts/mgba-zh_Hant.ts | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/platform/qt/ts/mgba-zh_Hant.ts b/src/platform/qt/ts/mgba-zh_Hant.ts index 5950c0fb814..8acf4e60712 100644 --- a/src/platform/qt/ts/mgba-zh_Hant.ts +++ b/src/platform/qt/ts/mgba-zh_Hant.ts @@ -110,22 +110,22 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Save - + 存檔 Load - + è®€å– Add - + 加入 Remove - + 移除 @@ -229,17 +229,17 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 IP address - + IPä½å€ Connect - + 連接 Disconnect - + æ–·é–‹ From 50e30447fb7bcd2886cb997a27b42319414e96b0 Mon Sep 17 00:00:00 2001 From: Gabriel Kao Date: Thu, 24 Oct 2024 07:11:06 +0000 Subject: [PATCH 304/338] Qt: Update translation (Chinese (Traditional Han script)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/zh_Hant/ --- src/platform/qt/ts/mgba-zh_Hant.ts | 2161 ++++++++++++++-------------- 1 file changed, 1084 insertions(+), 1077 deletions(-) diff --git a/src/platform/qt/ts/mgba-zh_Hant.ts b/src/platform/qt/ts/mgba-zh_Hant.ts index 8acf4e60712..279452fe565 100644 --- a/src/platform/qt/ts/mgba-zh_Hant.ts +++ b/src/platform/qt/ts/mgba-zh_Hant.ts @@ -11,7 +11,7 @@ <a href="http://mgba.io/">Website</a> • <a href="https://forums.mgba.io/">Forums / Support</a> • <a href="https://patreon.com/mgba">Donate</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">Source</a> - <a href="http://mgba.io/">網站</a> • <a href="https://forums.mgba.io/">論壇ã€æ”¯æŒ</a> • <a href="https://patreon.com/mgba">æ助</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">æºä»£ç¢¼</a> + <a href="http://mgba.io/">網站</a> • <a href="https://forums.mgba.io/">論壇ã€å–å¾—å”助</a> • <a href="https://patreon.com/mgba">贊助</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">原始碼</a> @@ -21,7 +21,7 @@ {projectName} would like to thank the following patrons from Patreon: - {projectName} æ„Ÿè¬ä»¥ä¸‹ä¾†è‡ª Patreon 的讚助者: + {projectName} æ„Ÿè¬ä»¥ä¸‹ Patreon 贊助者: @@ -67,17 +67,17 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Palette # - èª¿è‰²æ¿ # + 調色盤 # Address - åœ°å€ + ä½å€ Red - 红 + ç´… @@ -95,17 +95,17 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 BattleChip Gate - + 戰鬥晶片閘 Chip name - + 晶片å稱 Insert - + æ’å…¥ @@ -130,27 +130,27 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Gate type - + 閘門類別 Inserted - + å·²æ’å…¥ Chip ID - + 晶片ID Update Chip data - + 更新晶片資料 Show advanced - + 顯示進階é¸é … @@ -168,12 +168,12 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Remove - 移除 + 移除 Add Lines - 新增行 + 新增一行 @@ -183,7 +183,7 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Save - 儲存 + 儲存 @@ -201,17 +201,17 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Debugger - + 除錯器 Enter command (try `help` for more info) - + 輸入指令 (更多資訊請見「幫助ã€) Break - + 中斷 @@ -219,12 +219,12 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Connect to Dolphin - + 連接 Dolphin Local computer - + å€åŸŸé›»è…¦ @@ -239,17 +239,17 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Disconnect - æ–·é–‹ + 中斷連接 Close - + 關閉 Reset on connect - + 連接後é‡æ–°å•Ÿå‹• @@ -257,37 +257,37 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Inspect frame - + 檢查畫格 Magnification - + 放大 Freeze frame - + æš«åœç•«æ ¼ Backdrop color - + 背景é¡è‰² Disable scanline effects - + åœç”¨æŽƒæ線特效 Export - + 匯出 Reset - + é‡æ–°å•Ÿå‹• @@ -295,47 +295,47 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Record GIF/WebP/APNG - + 錄製 GIF/WebP/APNG Loop - + 循環 Start - + 開始 Stop - + åœæ­¢ Select File - + é¸æ“‡æª”案 APNG - + APNG GIF - + GIF WebP - + WebP Frameskip - + è·³éŽç•«æ ¼ @@ -343,17 +343,17 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 I/O Viewer - + I/O 檢視器 0x0000 - + 0x0000 B - + B @@ -361,27 +361,27 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Name - + å稱 Location - + ä½ç½® Platform - + å¹³å° Size - + å¤§å° CRC32 - + CRC32 @@ -390,7 +390,7 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 %1 State - + %1 å³æ™‚存檔 @@ -403,57 +403,57 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 No Save - + 無存檔 5 - + 5 6 - + 6 8 - + 8 4 - + 4 1 - + 1 3 - + 3 7 - + 7 9 - + 9 2 - + 2 Cancel - + å–消 @@ -461,62 +461,62 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Logs - + 記錄 Enabled Levels - + å·²å•Ÿç”¨çš„é—œå¡ Debug - + 除錯 Stub - + æ¸¬è©¦æ¨ Info - + 資訊 Warning - + 警告 Error - + 錯誤 Fatal - + åš´é‡ Game Error - + éŠæˆ²éŒ¯èª¤ Advanced settings - + 進階設定 Clear - + 清除 Max Lines - + 最大行數 @@ -524,22 +524,22 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Maps - + 映射 Magnification - + 放大 Export - + 匯出 Copy - + 複製 @@ -547,22 +547,22 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Save Memory Range - + è¨˜æ†¶é«”å„²å­˜ç¯„åœ Start Address: - + 起始ä½å€: Byte Count: - + ä½å…ƒçµ„數: Dump across banks - + è·¨è¨˜æ†¶åº«å‚¾å° @@ -570,149 +570,149 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Memory Search - + æœå°‹è¨˜æ†¶é«” Address - + ä½å€ Current Value - + ç›®å‰çš„值 Type - + 型別 Value - + 值 Numeric - + 數字 Text - + 文字 Width - + 寬度 Guess - + é æ¸¬ 1 Byte (8-bit) - + 1 ä½å…ƒçµ„ (8 ä½å…ƒ) 2 Bytes (16-bit) - + 2 ä½å…ƒçµ„ (16 ä½å…ƒ) 4 Bytes (32-bit) - + 4 ä½å…ƒçµ„ (32 ä½å…ƒ) Number type - + 數字型別 Decimal - + åé€²ä½ Hexadecimal - + åå…­é€²ä½ Search type - + æœå°‹åž‹åˆ¥ Equal to value - + 等於值 Greater than value - + 大於值 Less than value - + å°æ–¼å€¼ Unknown/changed - + 未知/已變更 Changed by value - + 數值變更 Unchanged - + 未變更 Increased - + 增加 Decreased - + 減少 Search ROM - + æœå°‹ ROM New Search - + æ–°çš„æœå°‹ Search Within - + 在...裡æœå°‹ Open in Memory Viewer - + 在記憶體檢視器中打開 Refresh - + é‡æ–°æ•´ç† @@ -720,77 +720,77 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Memory - + 記憶體 Inspect Address: - + 檢查ä½å€: Set Alignment: - + 資料å°é½Šè¨­å®š: &1 Byte - + 1 ä½å…ƒçµ„ (&1) &2 Bytes - + 2 ä½å…ƒçµ„ (&2) &4 Bytes - + 4 ä½å…ƒçµ„ (&4) Unsigned Integer: - + 無符號整數: Signed Integer: - + 有符號整數: String: - + 字串: Load TBL - + è®€å– TBL Copy Selection - + è¤‡è£½æ‰€é¸ Paste - + 貼上 Save Selection - + å„²å­˜æ‰€é¸ Save Range - + å„²å­˜ç¯„åœ Load - + è®€å– @@ -798,136 +798,136 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Sprites - + 角色圖 Address - + ä½å€ Copy - + 複製 Magnification - + 放大 Geometry - + 幾何 Position - + ä½ç½® , - + , Dimensions - + 維度 × - + × Matrix - + 矩陣 Export - + 匯出 Attributes - + 屬性 Transform - + è®Šæ› Off - + é—œ Palette - + 調色盤 Double Size - + å…©å€å¤§å° Return, Ctrl+R - + 返回,Ctrl+R Flipped - + 已翻轉 H Short for horizontal - + H V Short for vertical - + V Mode - + æ¨¡å¼ Normal - + 正常 Mosaic - + 馬賽克 Enabled - + 已啟用 Priority - + 優先度 Tile - + 圖塊 @@ -935,12 +935,12 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Game Overrides - + éŠæˆ²æ›¿ä»£ Game Boy Advance - + Game Boy Advance @@ -948,122 +948,122 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Autodetect - + 自動åµæ¸¬ Realtime clock - + 實時計時器 Gyroscope - + 陀螺儀 Tilt - + 傾斜 Light sensor - + 光感測器 Rumble - + 震動 Save type - + 存檔類型 None - + ç„¡ SRAM - + SRAM Flash 512kb - + Flash 512kb Flash 1Mb - + Flash 1Mb EEPROM 8kB - + EEPROM 8kB EEPROM 512 bytes - + EEPROM 512 bytes SRAM 64kB (bootlegs only) - + SRAM 64kB (僅用於盜版å¡å¸¶) Idle loop - + 閒置迴圈 Game Boy Player features - + Game Boy Player 特性 VBA bug compatibility mode - + VBA éŒ¯èª¤ç›¸å®¹æ€§æ¨¡å¼ Game Boy - + Game Boy Game Boy model - + Game Boy 型號 Memory bank controller - + 記憶庫控制器 Background Colors - + 背景é¡è‰² Sprite Colors 1 - + 角色圖é¡è‰² 1 Sprite Colors 2 - + 角色圖é¡è‰² 2 Palette preset - + é è¨­èª¿è‰²ç›¤ @@ -1071,62 +1071,62 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Palette - + 調色盤 Background - + 背景 Objects - + 物件 Selection - + é¸å– Red - + ç´… Green - + 綠 Blue - + è— 16-bit value - + 16 ä½å…ƒæ•¸å€¼ Hex code - + å六進ä½ç¢¼ Palette index - + 調色盤索引值 Export BG - + 匯出背景 Export OBJ - + 匯出 OBJ @@ -1134,27 +1134,27 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Adjust placement - + 調整ä½ç½® All - + 全部 Offset - + åç§»é‡ X - + X Y - + Y @@ -1162,27 +1162,27 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 Game Boy Printer - + Game Boy Printer Hurry up! - + å¿«ä¸€é»žï¼ Tear off - + 撕裂 Magnification - + 放大 Copy - + 複製 @@ -1190,7 +1190,7 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 2021 - + 2021 @@ -1199,41 +1199,46 @@ Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標 An update to %1 is available. - + %1 有å¯ç”¨çš„更新。 + Do you want to download and install it now? You will need to restart the emulator when the download is complete. - + +您想è¦ç«‹å³ä¸‹è¼‰ä¸¦å®‰è£å—Žï¼Ÿä¸‹è¼‰å®Œæˆå¾Œï¼Œæ‚¨éœ€è¦é‡æ–°å•Ÿå‹•æ¨¡æ“¬å™¨ã€‚ Auto-update is not available on this platform. If you wish to update you will need to do it manually. - + +此平å°ä¸æ”¯æ´è‡ªå‹•æ›´æ–°ã€‚若您希望更新則必須手動進行。 Current version: %1 New version: %2 Download size: %3 - + ç¾åœ¨ç‰ˆæœ¬: %1 +新版本: %2 +下載的檔案大å°: %3 Downloading update... - + 正在下載更新... Downloading failed. Please update manually. - + 下載失敗。請手動更新。 Downloading done. Press OK to restart %1 and install the update. - + 下載完æˆã€‚按下 OK é‡æ–°å•Ÿå‹• %1 並安è£æ›´æ–°ã€‚ @@ -1241,22 +1246,22 @@ Download size: %3 Stable - + 穩定版本 Development - + 開發版本 Unknown - + 未知 (None) - + (ç„¡) @@ -1264,14 +1269,14 @@ Download size: %3 %0%1%2 - + %0%1%2 0x%0 (%1) - + 0x%0 (%1) @@ -1279,12 +1284,12 @@ Download size: %3 (untitled) - + (無標題) Failed to open cheats file: %1 - + 金手指開啟失敗: %1 @@ -1293,13 +1298,13 @@ Download size: %3 Autodetect (recommended) - + 自動åµæ¸¬ (建議) Select cheats file - + é¸æ“‡é‡‘手指 @@ -1307,27 +1312,27 @@ Download size: %3 Failed to open save file: %1 - + 存檔開啟失敗: %1 Failed to open game file: %1 - + éŠæˆ²é–‹å•Ÿå¤±æ•—: %1 Can't yank pack in unexpected platform! - + 無法在é æ–™å¤–çš„å¹³å°æ‹”除å¡å¸¶ï¼ Failed to open snapshot file for reading: %1 - + 讀å–快照失敗: %1 Failed to open snapshot file for writing: %1 - + 寫入快照失敗: %1 @@ -1335,17 +1340,17 @@ Download size: %3 Failed to open game file: %1 - + éŠæˆ²é–‹å•Ÿå¤±æ•—: %1 Could not load game. Are you sure it's in the correct format? - + 無法讀å–éŠæˆ²ã€‚您確定格å¼æ­£ç¢ºå—Žï¼Ÿ Failed to open save file; in-game saves cannot be updated. Please ensure the save directory is writable without additional privileges (e.g. UAC on Windows). - + 無法開啟存檔;éŠæˆ²å…§å­˜æª”無法更新。請確定存檔路徑的寫入ä¸éœ€è¦é¡å¤–æ¬Šé™ (å³ Windows çš„ UAC)。 @@ -1353,52 +1358,52 @@ Download size: %3 Export frame - + 匯出畫格 Portable Network Graphics (*.png) - + å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) None - + ç„¡ Background - + 背景 Window - + 視窗 Objwin - + Objwin Sprite - + 角色圖 Backdrop - + 背景 Frame - + ç•«æ ¼ %1 %2 - + %1 %2 @@ -1406,7 +1411,7 @@ Download size: %3 Enable Discord Rich Presence - + 啟用 Discord Rich Presence @@ -1414,22 +1419,22 @@ Download size: %3 Clear Button - + 清除按鈕 Clear Analog - + 清除類比輸入 Refresh - + é‡æ–°æ•´ç† Set all - + 設定全部 @@ -1437,42 +1442,42 @@ Download size: %3 Server settings - + 伺æœå™¨è¨­å®š Local port - + å€åŸŸåŸ  Bind address - + ç¶å®šä½å€ Break - + 中斷 Stop - + åœæ­¢ Start - + 開始 Crash - + 當機 Could not start GDB server - + 無法啟動 GDB 伺æœå™¨ @@ -1480,17 +1485,17 @@ Download size: %3 Failed to open output file: %1 - + 輸出檔案開啟失敗: %1 Select output file - + é¸æ“‡è¼¸å‡ºçš„檔案 Graphics Interchange Format (*.gif);;WebP ( *.webp);;Animated Portable Network Graphics (*.png *.apng) - + 圖形互æ›æ ¼å¼ (*.gif);;WebP ( *.webp);;å‹•æ…‹å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png *.apng) @@ -1498,147 +1503,147 @@ Download size: %3 Background mode - + èƒŒæ™¯æ¨¡å¼ Mode 0: 4 tile layers - + æ¨¡å¼ 0: 4 個圖塊層 Mode 1: 2 tile layers + 1 rotated/scaled tile layer - + æ¨¡å¼ 1:2 個圖塊層 + 1 個å¯æ—‹è½‰/縮放圖塊層 Mode 2: 2 rotated/scaled tile layers - + æ¨¡å¼ 2:2 個å¯æ—‹è½‰/縮放圖塊層 Mode 3: Full 15-bit bitmap - + æ¨¡å¼ 3: 完全 15 ä½å…ƒé»žé™£ Mode 4: Full 8-bit bitmap - + æ¨¡å¼ 4: 完全 8 ä½å…ƒé»žé™£ Mode 5: Small 15-bit bitmap - + æ¨¡å¼ 5: 15 ä½å…ƒç´°å°é»žé™£ CGB Mode - + CGB æ¨¡å¼ Frame select - + ç•«æ ¼é¸æ“‡ Unlocked HBlank - + 解鎖的 HBlank Linear OBJ tile mapping - + 線性 OBJ 圖塊映射 Force blank screen - + 強制清空螢幕 Enable background 0 - + 啟用背景 0 Enable background 1 - + 啟用背景 1 Enable background 2 - + 啟用背景 2 Enable background 3 - + 啟用背景 3 Enable OBJ - + 啟用 OBJ Enable Window 0 - + 啟用視窗 0 Enable Window 1 - + 啟用視窗 1 Enable OBJ Window - + 啟用 OBJ 視窗 Swap green components - + 替æ›ç¶ è‰²çµ„件 Currently in VBlank - + ç›®å‰ VBlank 值 Currently in HBlank - + ç›®å‰ HBlank 值 Currently in VCounter - + ç›®å‰ VCounter 值 Enable VBlank IRQ generation - + å…許 VBlank 生æˆä¸­æ–·è«‹æ±‚ (IRQ) Enable HBlank IRQ generation - + å…許 HBlank 生æˆä¸­æ–·è«‹æ±‚ (IRQ) Enable VCounter IRQ generation - + å…許 VCounter 生æˆä¸­æ–·è«‹æ±‚ (IRQ) VCounter scanline - + VCounter 掃æç·š Current scanline - + ç›®å‰çš„掃æç·š @@ -1646,7 +1651,7 @@ Download size: %3 Priority - + 優先度 @@ -1654,7 +1659,7 @@ Download size: %3 Tile data base (* 16kB) - + 圖塊資料基底 (* 16kB) @@ -1662,7 +1667,7 @@ Download size: %3 Enable mosaic - + 啟用馬賽克 @@ -1670,7 +1675,7 @@ Download size: %3 Enable 256-color - + 啟用 256 色 @@ -1678,7 +1683,7 @@ Download size: %3 Tile map base (* 2kB) - + 圖塊映射基底 (* 2kB) @@ -1686,13 +1691,13 @@ Download size: %3 Background dimensions - + 背景維度 Overflow wraps - + 溢ä½å›žç¹ž @@ -1702,7 +1707,7 @@ Download size: %3 Horizontal offset - + æ°´å¹³åç§»é‡ @@ -1712,7 +1717,7 @@ Download size: %3 Vertical offset - + åž‚ç›´åç§»é‡ @@ -1728,7 +1733,7 @@ Download size: %3 Fractional part - + 分數部分 @@ -1740,7 +1745,7 @@ Download size: %3 Integer part - + 整數部分 @@ -1748,7 +1753,7 @@ Download size: %3 Integer part (low) - + 整數部分 (低ä½) @@ -1756,289 +1761,289 @@ Download size: %3 Integer part (high) - + 整數部分 (高ä½) End x - + 最終 x Start x - + 起始 x End y - + 最終 y Start y - + 起始 y Window 0 enable BG 0 - + 視窗 0 啟用 BG 0 Window 0 enable BG 1 - + 視窗 0 啟用 BG 1 Window 0 enable BG 2 - + 視窗 0 啟用 BG 2 Window 0 enable BG 3 - + 視窗 0 啟用 BG 3 Window 0 enable OBJ - + 視窗 0 啟用 OBJ Window 0 enable blend - + 視窗 0 å•Ÿç”¨æ··åˆ Window 1 enable BG 0 - + 視窗 1 啟用 BG 0 Window 1 enable BG 1 - + 視窗 1 啟用 BG 1 Window 1 enable BG 2 - + 視窗 1 啟用 BG 2 Window 1 enable BG 3 - + 視窗 1 啟用 BG 3 Window 1 enable OBJ - + 視窗 1 啟用 OBJ Window 1 enable blend - + 視窗 1 å•Ÿç”¨æ··åˆ Outside window enable BG 0 - + 外å´è¦–窗啟用 BG 0 Outside window enable BG 1 - + 外å´è¦–窗啟用 BG 1 Outside window enable BG 2 - + 外å´è¦–窗啟用 BG 2 Outside window enable BG 3 - + 外å´è¦–窗啟用 BG 3 Outside window enable OBJ - + 外å´è¦–窗啟用 OBJ Outside window enable blend - + 外å´è¦–çª—å•Ÿç”¨æ··åˆ OBJ window enable BG 0 - + OBJ 視窗啟用 BG 0 OBJ window enable BG 1 - + OBJ 視窗啟用 BG 1 OBJ window enable BG 2 - + OBJ 視窗啟用 BG 2 OBJ window enable BG 3 - + OBJ 視窗啟用 BG 3 OBJ window enable OBJ - + OBJ 視窗啟用 OBJ OBJ window enable blend - + OBJ è¦–çª—å•Ÿç”¨æ··åˆ Background mosaic size vertical - + èƒŒæ™¯é¦¬è³½å…‹åž‚ç›´å¤§å° Background mosaic size horizontal - + èƒŒæ™¯é¦¬è³½å…‹æ°´å¹³å¤§å° Object mosaic size vertical - + ç‰©ä»¶é¦¬è³½å…‹åž‚ç›´å¤§å° Object mosaic size horizontal - + ç‰©ä»¶é¦¬è³½å…‹æ°´å¹³å¤§å° BG 0 target 1 - + BG 0 目標 1 BG 1 target 1 - + BG 1 目標 1 BG 2 target 1 - + BG 2 目標 1 BG 3 target 1 - + BG 3 目標 1 OBJ target 1 - + OBJ 目標 1 Backdrop target 1 - + 背景目標 1 Blend mode - + æ··åˆæ¨¡å¼ Disabled - + å·²åœç”¨ Additive blending - + åŠ ç®—æ··åˆ Brighten - + 增亮 Darken - + 變暗 BG 0 target 2 - + BG 0 目標 2 BG 1 target 2 - + BG 1 目標 2 BG 2 target 2 - + BG 2 目標 2 BG 3 target 2 - + BG 3 目標 2 OBJ target 2 - + OBJ 目標 2 Backdrop target 2 - + 背景目標 2 Blend A (target 1) - + æ··åˆ A (目標 1) Blend B (target 2) - + æ··åˆ B (目標 2) Blend Y - + æ··åˆ Y Sweep shifts - + 掃æä½ç§» Sweep subtract - + 掃æ相減 Sweep time (in 1/128s) - + 掃æ時間 (1/128 秒) @@ -2050,7 +2055,7 @@ Download size: %3 Sound length - + è²éŸ³é•·åº¦ @@ -2058,7 +2063,7 @@ Download size: %3 Duty cycle - + 工作週期 @@ -2068,7 +2073,7 @@ Download size: %3 Envelope step time - + 包å°æ­¥é€²æ™‚é–“ @@ -2078,7 +2083,7 @@ Download size: %3 Envelope increase - + å¢žåŠ åŒ…å° @@ -2088,14 +2093,14 @@ Download size: %3 Initial volume - + åˆå§‹éŸ³é‡ Sound frequency - + è²éŸ³é »çŽ‡ @@ -2107,7 +2112,7 @@ Download size: %3 Timed - + 已排定時間 @@ -2119,56 +2124,56 @@ Download size: %3 Reset - + é‡æ–°å•Ÿå‹• Double-size wave table - + é›™å€å°ºå¯¸æ³¢å½¢è¡¨ Active wave table - + 使用中的波形表 Enable channel 3 - + å•Ÿç”¨é »é“ 3 Volume - + éŸ³é‡ 0% - + 0% 100% - + 100% 50% - + 50% 25% - + 25% @@ -2176,131 +2181,131 @@ Download size: %3 75% - + 75% Clock divider - + 時é˜åˆ†é »å™¨ Register stages - + 暫存器階段 15 - + 15 7 - + 7 Shifter frequency - + 移ä½å™¨é »çŽ‡ PSG volume right - + å¯ç¨‹å¼åŒ–發è²å™¨éŸ³é‡ï¼Žå³ PSG volume left - + å¯ç¨‹å¼åŒ–發è²å™¨éŸ³é‡ï¼Žå·¦ Enable channel 1 right - + 啟用å³å´é »é“ 1 Enable channel 2 right - + 啟用å³å´é »é“ 2 Enable channel 3 right - + 啟用å³å´é »é“ 3 Enable channel 4 right - + 啟用å³å´é »é“ 4 Enable channel 1 left - + 啟用左å´é »é“ 1 Enable channel 2 left - + 啟用左å´é »é“ 2 Enable channel 3 left - + 啟用左å´é »é“ 3 Enable channel 4 left - + 啟用左å´é »é“ 4 PSG master volume - + å¯ç¨‹å¼åŒ–發è²å™¨ç¸½éŸ³é‡ Loud channel A - + æšè²é »é“ A Loud channel B - + æšè²é »é“ B Enable channel A right - + 啟用å³å´é »é“ A Enable channel A left - + 啟用左å´é »é“ A Channel A timer - + é »é“ A 計時器 0 - + 0 @@ -2313,72 +2318,72 @@ Download size: %3 1 - + 1 Channel A reset - + é »é“ A é‡è¨­ Enable channel B right - + 啟用å³å´é »é“ B Enable channel B left - + 啟用左å´é »é“ B Channel B timer - + é »é“ B 計時器 Channel B reset - + é »é“ B é‡è¨­ Active channel 1 - + ä½¿ç”¨ä¸­çš„é »é“ 1 Active channel 2 - + ä½¿ç”¨ä¸­çš„é »é“ 2 Active channel 3 - + ä½¿ç”¨ä¸­çš„é »é“ 3 Active channel 4 - + ä½¿ç”¨ä¸­çš„é »é“ 4 Enable audio - + 啟用音訊 Bias - + å移 Resolution - + 解æžåº¦ @@ -2454,7 +2459,7 @@ Download size: %3 Sample - + å–樣 @@ -2466,7 +2471,7 @@ Download size: %3 Address (low) - + ä½å€ (低) @@ -2478,53 +2483,53 @@ Download size: %3 Address (high) - + ä½å€ (高) Sound frequency (low) - + è²éŸ³é »çŽ‡ (低) Sound frequency (high) - + è²éŸ³é »çŽ‡ (高) Source (high) - + ä¾†æº (高) Source (low) - + ä¾†æº (低) Destination (high) - + 目的地 (高) Destination (low) - + 目的地 (低) Green (low) - + 綠 (低) Green (high) - + 綠 (高) @@ -2532,7 +2537,7 @@ Download size: %3 Word count - + 字數 @@ -2540,7 +2545,7 @@ Download size: %3 Destination offset - + 目的地åç§»é‡ @@ -2552,7 +2557,7 @@ Download size: %3 Increment - + éžå¢ž @@ -2564,7 +2569,7 @@ Download size: %3 Decrement - + éžæ¸› @@ -2576,7 +2581,7 @@ Download size: %3 Fixed - + 固定 @@ -2584,7 +2589,7 @@ Download size: %3 Increment and reload - + éžå¢žä¸¦é‡æ–°è®€å– @@ -2592,7 +2597,7 @@ Download size: %3 Source offset - + 來æºåç§»é‡ @@ -2600,7 +2605,7 @@ Download size: %3 Repeat - + é‡è¤‡ @@ -2608,7 +2613,7 @@ Download size: %3 32-bit - + 32 ä½å…ƒ @@ -2616,7 +2621,7 @@ Download size: %3 Start timing - + 開始時間 @@ -2625,7 +2630,7 @@ Download size: %3 Immediate - + ç«‹å³ @@ -2637,7 +2642,7 @@ Download size: %3 VBlank - + VBlank @@ -2648,7 +2653,7 @@ Download size: %3 HBlank - + HBlank @@ -2661,7 +2666,7 @@ Download size: %3 IRQ - + 中斷請求 (IRQ) @@ -2676,24 +2681,24 @@ Download size: %3 Enable - + 啟用 Audio FIFO - + 音訊先進先出 Video Capture - + è¦–è¨Šæ“·å– DRQ - + 資料請求 (DRQ) @@ -2705,7 +2710,7 @@ Download size: %3 Value - + 值 @@ -2713,7 +2718,7 @@ Download size: %3 Scale - + 比例 @@ -2722,7 +2727,7 @@ Download size: %3 1/64 - + 1/64 @@ -2731,7 +2736,7 @@ Download size: %3 1/256 - + 1/256 @@ -2740,176 +2745,176 @@ Download size: %3 1/1024 - + 1/1024 Cascade - + ä¸²è¯ A - + A B - + B Select - + Select Start - + Start Right - + å³ Left - + å·¦ Up - + 上 Down - + 下 R - + R L - + L Condition - + Condition SC - + SC SD - + SD SI - + SI SO - + SO VCounter - + VCounter Timer 0 - + Timer 0 Timer 1 - + Timer 1 Timer 2 - + Timer 2 Timer 3 - + Timer 3 SIO - + SIO DMA 0 - + DMA 0 DMA 1 - + DMA 1 DMA 2 - + DMA 2 DMA 3 - + DMA 3 Keypad - + éµç›¤ Gamepak - + éŠæˆ²å¡å¸¶ SRAM wait - + SRAM 等候 @@ -2918,7 +2923,7 @@ Download size: %3 4 - + 4 @@ -2926,7 +2931,7 @@ Download size: %3 3 - + 3 @@ -2935,7 +2940,7 @@ Download size: %3 2 - + 2 @@ -2944,412 +2949,412 @@ Download size: %3 8 - + 8 Cart 0 non-sequential - + å¡å¸¶ 0 (éžæŒ‰åº) Cart 0 sequential - + å¡å¸¶ 0 (按åº) Cart 1 non-sequential - + å¡å¸¶ 1 (éžæŒ‰åº) Cart 1 sequential - + å¡å¸¶ 1 (按åº) Cart 2 non-sequential - + å¡å¸¶ 2 (éžæŒ‰åº) Cart 2 sequential - + å¡å¸¶ 2 (按åº) PHI terminal - + PHI 終端 Disable - + åœç”¨ 4.19MHz - + 4.19MHz 8.38MHz - + 8.38MHz 16.78MHz - + 16.78MHz Gamepak prefetch - + éŠæˆ²å¡å¸¶é è®€ Enable IRQs - + 啟用中斷請求 (IRQ) Right/A - + å³/A Left/B - + å·¦/B Up/Select - + 上/Select Down/Start - + 下/Start Active D-pad - + 使用中的åå­—éµ Active face buttons - + 使用中的正é¢æŒ‰éˆ• Internal clock - + å…§éƒ¨æ™‚é˜ 32× clocking (CGB only) - + 32 å€æ™‚脈 (僅 CGB é©ç”¨) Transfer active - + 傳é€ä½¿ç”¨ç‹€æ…‹ Divider - + 除數 1/16 - + 1/16 LCD STAT - + LCD STAT Timer - + 計時器 Serial - + 串列 Joypad - + æ–æ¡¿ Volume right - + å³å´éŸ³é‡ Output right - + å³å´è¼¸å‡º Volume left - + å·¦å´éŸ³é‡ Output left - + å·¦å´è¼¸å‡º Background enable/priority - + 背景啟用/優先度 Enable sprites - + 啟用角色圖 Double-height sprites - + å…©å€é«˜åº¦è§’色圖 Background tile map - + 背景圖塊映射 0x9800 – 0x9BFF - + 0x9800 – 0x9BFF 0x9C00 – 0x9FFF - + 0x9C00 – 0x9FFF Background tile data - + 背景圖塊資料 0x8800 – 0x87FF - + 0x8800 – 0x87FF 0x8000 – 0x8FFF - + 0x8000 – 0x8FFF Enable window - + 啟用視窗 Window tile map - + 視窗圖塊映射 Enable LCD - + 啟用 LCD Mode - + æ¨¡å¼ 0: HBlank - + 0: HBlank 1: VBlank - + 1: VBlank 2: OAM scan - + 2: 掃æ OAM 3: HDraw - + 3: HDraw In LYC - + æ–¼ LYC Enable HBlank (mode 0) IRQ - + 啟用 HBlank (æ¨¡å¼ 0) 中斷請求 (IRQ) Enable VBlank (mode 1) IRQ - + 啟用 VBlank (æ¨¡å¼ 1) 中斷請求 (IRQ) Enable OAM (mode 2) IRQ - + 啟用 OAM (æ¨¡å¼ 2) 中斷請求 (IRQ) Enable LYC IRQ - + 啟用 LYC 中斷請求 (IRQ) Current Y coordinate - + ç¾åœ¨ Y 座標 Comparison Y coordinate - + å°ç…§ Y 座標 Start upper byte - + 起始高ä½å…ƒçµ„ Color 0 shade - + 色彩 0 é™°å½± Color 1 shade - + 色彩 1 é™°å½± Color 2 shade - + 色彩 2 é™°å½± Color 3 shade - + 色彩 3 é™°å½± Prepare to switch speed - + 準備切æ›é€Ÿåº¦ Double speed - + é›™å€é€Ÿåº¦ VRAM bank - + VRAM bank Length - + 長度 Timing - + 時間點 Write bit - + 寫入ä½å…ƒ Read bit - + 讀å–ä½å…ƒ Unknown - + 未知 Current index - + ç¾åœ¨ç´¢å¼•å€¼ Auto-increment - + 自動éžå¢ž Red - + ç´… Blue - + è— Sprite ordering - + è§’è‰²åœ–é †åº OAM order - + OAM é †åº x coordinate sorting - + X åº§æ¨™æŽ’åº WRAM bank - + WRAM bank @@ -3358,22 +3363,22 @@ Download size: %3 --- - + --- Super (L) - + Super (L) Super (R) - + Super (R) Menu - + é¸å–® @@ -3381,27 +3386,27 @@ Download size: %3 Load State - + 讀å–å³æ™‚存檔 Save State - + 儲存å³æ™‚存檔 Empty - + 空 Corrupted - + æ毀 Slot %1 - + 儲存槽 %1 @@ -3410,42 +3415,42 @@ Download size: %3 Default - + é è¨­ Fatal - + åš´é‡ Error - + 錯誤 Warning - + 警告 Info - + 資訊 Debug - + 除錯 Stub - + æ¸¬è©¦æ¨ Game Error - + éŠæˆ²éŒ¯èª¤ @@ -3453,47 +3458,47 @@ Download size: %3 [%1] %2: %3 - + [%1] %2: %3 An error occurred - + 錯誤發生 DEBUG - + DEBUG STUB - + STUB INFO - + INFO WARN - + WARN ERROR - + ERROR FATAL - + FATAL GAME ERROR - + GAME ERROR @@ -3501,82 +3506,82 @@ Download size: %3 Priority - + 優先度 Map base - + 映射基底 Tile base - + 圖塊基底 Size - + å¤§å° Offset - + åç§»é‡ Xform - + Xform Map Addr. - + 映射ä½å€ Mirror - + é¡åƒ None - + ç„¡ Both - + 兩者 Horizontal - + æ°´å¹³ Vertical - + åž‚ç›´ N/A - + N/A Export map - + 匯出映射 Portable Network Graphics (*.png) - + å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) @@ -3584,12 +3589,12 @@ Download size: %3 Save memory region - + 儲存記憶體å€åŸŸ Failed to open output file: %1 - + 輸出檔案開啟失敗: %1 @@ -3597,62 +3602,62 @@ Download size: %3 Copy selection - + è¤‡è£½æ‰€é¸ Save selection - + å„²å­˜æ‰€é¸ Paste - + 貼上 Load - + è®€å– All - + 全部 Load TBL - + è®€å– TBL Save selected memory - + 儲存é¸å–的記憶體 Failed to open output file: %1 - + 輸出檔案開啟失敗: %1 Load memory - + 讀å–記憶體 Failed to open input file: %1 - + 輸入檔案開啟失敗: %1 TBL - + TBL ISO-8859-1 - + ISO-8859-1 @@ -3660,22 +3665,22 @@ Download size: %3 (%0/%1×) - + (%0/%1×) (â…Ÿ%0×) - + (â…Ÿ%0×) (%0×) - + (%0×) %1 byte%2 - + %1 ä½å…ƒçµ„%2 @@ -3684,12 +3689,12 @@ Download size: %3 0x%0 - + 0x%0 Off - + é—œ @@ -3701,43 +3706,43 @@ Download size: %3 --- - + --- Normal - + 正常 Trans - + Trans OBJWIN - + OBJWIN Invalid - + 無效 N/A - + N/A Export sprite - + 匯出角色圖 Portable Network Graphics (*.png) - + å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) @@ -3745,17 +3750,17 @@ Download size: %3 Official MBCs - + 官方記憶庫控制器 (MBC) Licensed MBCs - + 已授權的記憶庫控制器 (MBC) Unlicensed MBCs - + 未授權的記憶庫控制器 (MBC) @@ -3763,12 +3768,12 @@ Download size: %3 #%0 - + #%0 0x%0 - + 0x%0 @@ -3776,22 +3781,22 @@ Download size: %3 0x%0 (%1) - + 0x%0 (%1) Export palette - + 匯出調色盤 Windows PAL (*.pal);;Adobe Color Table (*.act) - + Windows PAL (*.pal);;Adobe Color Table (*.act) Failed to open output palette file: %1 - + 輸出調色盤開啟失敗: %1 @@ -3803,18 +3808,18 @@ Download size: %3 (unknown) - + (未知) bytes - + ä½å…ƒçµ„ (no database present) - + (無資料庫存在) @@ -3822,12 +3827,12 @@ Download size: %3 Bug report archive - + 錯誤回報記錄 ZIP archive (*.zip) - + ZIP 壓縮檔 (*.zip) @@ -3835,62 +3840,62 @@ Download size: %3 Save games and save states (%1) - + 儲存éŠæˆ²ä¸¦å„²å­˜å³æ™‚存檔 (%1) Select save game or save state - + é¸æ“‡éŠæˆ²å­˜æª”或å³æ™‚存檔 Save games (%1) - + éŠæˆ²å­˜æª” (%1) Select save game - + é¸æ“‡éŠæˆ²å­˜æª” Conversion failed - + 轉檔失敗 Failed to convert the save game. This is probably a bug. - + 存檔轉æ›å¤±æ•—。這å¯èƒ½æ˜¯å€‹ bug。 No file selected - + 未é¸å–檔案 Could not open file - + 無法開啟檔案 No valid formats found - + 找ä¸åˆ°æœ‰æ•ˆçš„æ ¼å¼ Please select a valid input file - + è«‹é¸æ“‡æœ‰æ•ˆçš„輸入檔 No valid conversions found - + 找ä¸åˆ°æœ‰æ•ˆçš„轉æ›æ–¹æ³• Cannot convert save games between platforms - + 無法在ä¸åŒå¹³å°é–“轉æ›å­˜æª” @@ -3899,101 +3904,101 @@ Download size: %3 Qt Multimedia - + Qt 多媒體 SDL - + SDL Software (Qt) - + 軟體 (Qt) OpenGL - + OpenGL OpenGL (force version 1.x) - + OpenGL (強制使用 1.x 版) None - + ç„¡ None (Still Image) - + ç„¡ (éœæ…‹å½±åƒ) Keyboard - + éµç›¤ Controllers - + 控制器 Shortcuts - + å¿«æ·éµ Shaders - + 著色器 Select BIOS - + é¸æ“‡ BIOS Select directory - + é¸æ“‡è³‡æ–™å¤¾ (%1×%2) - + (%1×%2) Never - + æ°¸ä¸ Just now - + 剛剛 Less than an hour ago - + 一å°æ™‚å…§ %n hour(s) ago - - + + %n å°æ™‚å‰ %n day(s) ago - - + + %n æ—¥å‰ @@ -4002,32 +4007,32 @@ Download size: %3 No shader active - + 無使用中的著色器 Load shader - + 讀å–著色器 No shader loaded - + 未讀å–著色器 by %1 - + ç”± %1 Preprocessing - + é è™•ç† Pass %1 - + é€šé“ %1 @@ -4035,17 +4040,17 @@ Download size: %3 Action - + 動作 Keyboard - + éµç›¤ Gamepad - + éŠæˆ²æ‰‹æŠŠ @@ -4053,18 +4058,18 @@ Download size: %3 Export tiles - + 匯出圖塊 Portable Network Graphics (*.png) - + å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) Export tile - + 匯出圖塊 @@ -4072,17 +4077,17 @@ Download size: %3 Failed to open output video file: %1 - + 輸出影片開啟失敗: %1 Native (%0x%1) - + 原始畫質 (%0x%1) Select output file - + é¸æ“‡è¼¸å‡ºçš„檔案 @@ -4090,759 +4095,761 @@ Download size: %3 Game Boy Advance ROMs (%1) - + Game Boy Advance ROMs (%1) Game Boy ROMs (%1) - + Game Boy ROMs (%1) All ROMs (%1) - + 所有 ROMs (%1) %1 Video Logs (*.mvl) - + %1 影片記錄檔 (*.mvl) Archives (%1) - + 壓縮檔 (%1) Select ROM - + é¸æ“‡ ROM Select folder - + é¸æ“‡è³‡æ–™å¤¾ Select save - + é¸æ“‡å­˜æª” Select patch - + é¸æ“‡ä¿®è£œæª” Patches (*.ips *.ups *.bps) - + 修補檔 (*.ips *.ups *.bps) Select e-Reader dotcode - + é¸æ“‡ e-Reader 點碼 e-Reader card (*.raw *.bin *.bmp) - + e-Reader å¡ç‰‡ (*.raw *.bin *.bmp) Select image - + é¸æ“‡åœ–片 Image file (*.png *.gif *.jpg *.jpeg);;All files (*) - + 圖檔 (*.png *.gif *.jpg *.jpeg);;所有檔案 (*) GameShark saves (*.sps *.xps) - + GameShark 存檔 (*.sps *.xps) Select video log - + é¸æ“‡å½±ç‰‡è¨˜éŒ„檔 Video logs (*.mvl) - + 影片記錄檔 (*.mvl) Crash - + 當機 The game has crashed with the following error: %1 - + éŠæˆ²å› ä»¥ä¸‹éŒ¯èª¤ç•¶æ©Ÿ: + +%1 Couldn't Start - + 無法啟動 Could not start game. - + 無法啟動éŠæˆ²ã€‚ Unimplemented BIOS call - + 未實è£çš„ BIOS å‘¼å« This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + æ­¤éŠæˆ²ä½¿ç”¨äº†æœªå¯¦è£çš„ BIOS 呼å«ã€‚為了ç²å¾—最佳體驗,請使用官方 BIOS。 Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + 建立é©ç•¶çš„顯示è£ç½®å¤±æ•—,回歸到軟體顯示。éŠæˆ²å¯èƒ½æœƒè·‘得很慢,尤其在使用大螢幕的時候。 Really make portable? - + 這真的å¯æ”œï¼Ÿ This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + 模擬器會從執行檔所在的資料夾讀å–設定檔。確定è¦ç¹¼çºŒå—Žï¼Ÿ Restart needed - + 需è¦é‡æ–°å•Ÿå‹• Some changes will not take effect until the emulator is restarted. - + 有些變更在模擬器é‡æ–°å•Ÿå‹•å‰ä¸æœƒç”Ÿæ•ˆã€‚ - Player %1 of %2 - + - Player %1 of %2 %1 - %2 - + %1 - %2 %1 - %2 - %3 - + %1 - %2 - %3 %1 - %2 (%3 fps) - %4 - + %1 - %2 (%3 fps) - %4 &File - + 檔案 (&F) Load &ROM... - + è®€å– ROM (&R) ... Load ROM in archive... - + 從壓縮檔讀å–ROM... Add folder to library... - + 加入資料夾至收è—... Save games (%1) - + éŠæˆ²å­˜æª” (%1) Select save game - + é¸æ“‡å­˜æª” mGBA save state files (%1) - + mGBA å³æ™‚存檔 (%1) Select save state - + é¸æ“‡å³æ™‚存檔 Select e-Reader card images - + é¸å– e-Reader å¡ç‰‡åœ–檔 Image file (*.png *.jpg *.jpeg) - + 圖檔 (*.png *.jpg *.jpeg) Conversion finished - + è½‰æª”å®Œæˆ %1 of %2 e-Reader cards converted successfully. - + %1 å¼µ e-Reader å¡ç‰‡è½‰æ›æˆåŠŸã€‚ (å…± %2 å¼µ) Load alternate save game... - + 讀å–å¦ä¸€ä»½å­˜æª”... Load temporary save game... - + 讀å–暫時存檔... Load &patch... - + 讀å–並修補 (&P) ... Boot BIOS - + å•Ÿå‹• BIOS Replace ROM... - + å–代 ROM... Scan e-Reader dotcodes... - + 掃æ e-Reader 點碼 Convert e-Reader card image to raw... - + è½‰æ› e-Reader å¡ç‰‡åœ–檔為原始資料 ROM &info... - + ROM 資訊 (&I) Recent - + 最近使用 Make portable - + å¯æ”œåŒ– &Load state - + 讀å–å³æ™‚存檔 (&L) Load state file... - + 讀å–å³æ™‚存檔... &Save state - + 儲存å³æ™‚存檔 (&S) Save state file... - + 儲存å³æ™‚存檔... Quick load - + å¿«é€Ÿè®€å– Quick save - + 快速儲存 Load recent - + 讀å–最近存檔 Save recent - + 儲存最近存檔 Undo load state - + å–消讀å–å³æ™‚存檔 Undo save state - + å–消儲存å³æ™‚存檔 State &%1 - + å³æ™‚存檔 (&%1) Load camera image... - + 讀å–相機影åƒ... Convert save game... - + 轉æ›å­˜æª”... GameShark saves (*.gsv *.sps *.xps) - + GameShark 存檔 (*.gsv *.sps *.xps) Import GameShark Save... - + 匯入 GameShark 存檔 Export GameShark Save... - + 匯出 GameShark 存檔 New multiplayer window - + 新增多人éŠæˆ²è¦–窗 Connect to Dolphin... - + 連接 Dolphin... Report bug... - + 回報錯誤... About... - + 關於... E&xit - + 離開 (&E) &Emulation - + 模擬 (&E) &Reset - + é‡æ–°å•Ÿå‹• (&R) Sh&utdown - + 關機 (&S) Yank game pak - + 拔除éŠæˆ²å¡å¸¶ &Pause - + æš«åœ (&P) &Next frame - + 下一畫格 (&N) Fast forward (held) - + 快轉 (長按) &Fast forward - + 快轉 (&F) Fast forward speed - + 快轉速率 Unbounded - + ç„¡é™åˆ¶ %0x - + %0x Rewind (held) - + 倒轉 (長按) Re&wind - + 倒轉 (&R) Step backwards - + é€æ ¼å€’轉 Sync to &video - + 與畫é¢åŒæ­¥ (&V) Sync to &audio - + 與音訊åŒæ­¥ (&A) Solar sensor - + 日光感測器 Increase solar level - + 增加日光等級 Decrease solar level - + é™ä½Žæ—¥å…‰ç­‰ç´š Brightest solar level - + 最大日光等級 Darkest solar level - + 最å°æ—¥å…‰ç­‰ç´š Brightness %1 - + 亮度 %1 Game Boy Printer... - + Game Boy Printer... BattleChip Gate... - + 戰鬥晶片閘... Audio/&Video - + 音訊/視訊 (&V) Frame size - + ç•«æ ¼å¤§å° %1× - + %1× Toggle fullscreen - + 切æ›å…¨èž¢å¹• Lock aspect ratio - + 鎖定長寬比 Force integer scaling - + 強制整數å€æ”¾å¤§ Interframe blending - + ç•«æ ¼é–“æ··åˆ Bilinear filtering - + 雙線性éŽæ¿¾ Frame&skip - + è·³éŽç•«æ ¼ (&S) Mute - + éœéŸ³ FPS target - + FPS 目標 Native (59.7275) - + 原生 (59.7275) Take &screenshot - + 螢幕截圖 (&S) F12 - + F12 Record A/V... - + 錄製音訊/å½±åƒ... Record GIF/WebP/APNG... - + 錄製 GIF/WebP/APNG... Video layers - + 視訊圖層 Audio channels - + éŸ³è¨Šé€šé“ Adjust layer placement... - + 調整圖層ä½ç½®... &Tools - + 工具 (&T) View &logs... - + 查看記錄檔 (&L) Game &overrides... - + éŠæˆ²æ›¿ä»£ (&O) Game Pak sensors... - + éŠæˆ²å¡å¸¶æ„Ÿæ¸¬å™¨... &Cheats... - + 金手指 (&C) Settings... - + 設定... Open debugger console... - + 打開除錯器控制å°... Start &GDB server... - + å•Ÿå‹• GDB 伺æœå™¨ (&G) View &palette... - + 檢視調色盤 (&P) View &sprites... - + 檢視角色圖 (&S) View &tiles... - + 檢視圖塊 (&T) View &map... - + 檢視映射 (&M) &Frame inspector... - + 畫格檢視器 (&F) View memory... - + 檢視記憶體... Search memory... - + æœå°‹è¨˜æ†¶é«”... View &I/O registers... - + 檢視 I/O 暫存器 (&I) Record debug video log... - + 錄製除錯影片記錄檔。 Stop debug video log - + åœæ­¢é™¤éŒ¯å½±ç‰‡è¨˜éŒ„檔 Exit fullscreen - + 離開全螢幕 GameShark Button (held) - + Gameshark 按鈕 (長按) Autofire - + 自動連射 Autofire A - + 自動連射 A Autofire B - + 自動連射 B Autofire L - + 自動連射 L Autofire R - + 自動連射 R Autofire Start - + 自動連射 Start Autofire Select - + 自動連射 Select Autofire Up - + 自動連射 上 Autofire Right - + 自動連射 å³ Autofire Down - + 自動連射 下 Autofire Left - + 自動連射 å·¦ Clear - + 清除 @@ -4850,32 +4857,32 @@ Download size: %3 %1 byte - + %1 ä½å…ƒçµ„ %1 kiB - + %1 kiB %1 MiB - + %1 MiB GBA - + GBA GB - + GB ? - + ? @@ -4883,22 +4890,22 @@ Download size: %3 Shift - + Shift Control - + Control Alt - + Alt Meta - + Meta @@ -4906,32 +4913,32 @@ Download size: %3 ROM Info - + ROM 資訊 Game name: - + éŠæˆ²å稱: Internal name: - + 內部å稱: Game ID: - + éŠæˆ² ID File size: - + 檔案大å°: CRC32: - + CRC32: @@ -4939,37 +4946,37 @@ Download size: %3 Generate Bug Report - + 產生錯誤報告 <html><head/><body><p>To file a bug report, please first generate a report file to attach to the bug report you're about to file. It is recommended that you include the save files, as these often help with debugging issues. This will collect some information about the version of {projectName} you're running, your configuration, your computer, and the game you currently have open (if any). Once this collection is completed you can review all of the information gathered below and save it to a zip file. The collection will automatically attempt to redact any personal information, such as your username if it's in any of the paths gathered, but just in case you can edit it afterwards. After you have generated and saved it, please click the button below or go to <a href="https://mgba.io/i/"><span style=" text-decoration: underline; color:#2980b9;">mgba.io/i</span></a> to file the bug report on GitHub. Make sure to attach the report you generated!</p></body></html> - + <html><head/><body><p>è‹¥è¦æ出錯誤報告,請先產生一份報告檔,å†å°‡å ±å‘Šæª”附加到è¦æ出的錯誤報告中。建議您附上存檔,因為存檔通常å°é™¤éŒ¯å¾ˆæœ‰å¹«åŠ©ã€‚錯誤報告會收集以下資料:正在執行的 {projectName} 版本ã€è¨­å®šã€é›»è…¦è³‡è¨Šã€ç›®å‰é–‹å•Ÿçš„éŠæˆ² (若有的話)。在資料收集完æˆå¾Œï¼Œæ‚¨å¯ä»¥æª¢æŸ¥æ‰€æœ‰æ”¶é›†çš„è³‡æ–™ï¼Œä¸¦å„²å­˜æˆ zip 壓縮檔。錯誤報告會嘗試自動塗銷所有個人資訊,例如路徑包å«çš„使用者å稱。以防è¬ä¸€æ‚¨é‚„是å¯ä»¥åœ¨é€™ä¹‹å¾Œè‡ªè¡Œç·¨è¼¯ã€‚生æˆä¸¦å„²å­˜å ±å‘Šä¹‹å¾Œï¼Œè«‹é»žæ“Šä¸‹æ–¹æŒ‰éˆ•ï¼Œæˆ–å‰å¾€ <a href="https://mgba.io/i/"><span style=" text-decoration: underline; color:#2980b9;">mgba.io/i</span></a> 以在 GitHub 上æ出報告。請確定附上產生的報告ï¼</p></body></html> Generate report - + 產生報告 Save - + 儲存 Open issue list in browser - + 在ç€è¦½å™¨ä¸­æ‰“é–‹å•é¡Œæ¸…å–® Include save file - + 附加存檔 Create and include savestate - + 建立並加入å³æ™‚存檔 @@ -4977,113 +4984,113 @@ Download size: %3 Convert/Extract Save Game - + 轉æ›/æ“·å–存檔 Input file - + 輸入檔案 Browse - + ç€è¦½ Output file - + 輸出檔案 %1 %2 save game - + %1 %2 éŠæˆ²å­˜æª” little endian - + ä½å…ƒçµ„ç”±å°åˆ°å¤§ big endian - + ä½å…ƒçµ„ç”±å¤§åˆ°å° SRAM - + SRAM %1 flash - + %1 flash %1 EEPROM - + %1 EEPROM %1 SRAM + RTC - + %1 SRAM + RTC %1 SRAM - + %1 SRAM packed MBC2 - + åŒ…è£ MBC2 unpacked MBC2 - + æœªåŒ…è£ MBC2 MBC6 flash - + MBC6 flash MBC6 combined SRAM + flash - + MBC6 åˆä½µ SRAM + flash MBC6 SRAM - + MBC6 SRAM TAMA5 - + TAMA5 %1 (%2) - + %1 (%2) %1 save state with embedded %2 save game - + %1 å³æ™‚存檔與嵌入的 %2 éŠæˆ²å­˜æª” %1 SharkPort %2 save game - + %1 SharkPort %2 存檔 %1 GameShark Advance SP %2 save game - + %1 GameShark Advance SP %2 存檔 @@ -5091,74 +5098,74 @@ Download size: %3 Sensors - + 感測器 Realtime clock - + 實時計時器 Fixed time - + 固定時間 System time - + 系統時間 Start time at - + 開始時間於 Now - + ç¾åœ¨ MM/dd/yy hh:mm:ss AP - + yy/MM/dd hh:mm:ss AP Light sensor - + 光感測器 Brightness - + 亮度 Tilt sensor - + 傾斜感測器 Set Y - + 設定 Y Set X - + 設定 X Gyroscope - + 陀螺儀 Sensitivity - + éˆæ•åº¦ @@ -5166,139 +5173,139 @@ Download size: %3 Settings - + 設定 Audio/Video - + 音訊/視訊 Interface - + ä»‹é¢ Update - + æ›´æ–° Emulation - + 模擬 Enhancements - + 增強 BIOS - + BIOS Paths - + 路徑 Logging - + 記錄 Game Boy - + Game Boy Audio driver: - + 音訊驅動: Audio buffer: - + 音訊緩è¡: 1536 - + 1536 512 - + 512 768 - + 768 1024 - + 1024 2048 - + 2048 3072 - + 3072 4096 - + 4096 samples - + å–樣 Sample rate: - + å–樣率: 44100 - + 44100 22050 - + 22050 32000 - + 32000 48000 - + 48000 Hz - + Hz Volume: - + 音é‡: @@ -5306,453 +5313,453 @@ Download size: %3 Mute - + éœéŸ³ Fast forward volume: - + 快轉音é‡: Audio in multiplayer: - + 多人éŠæˆ²éŸ³è¨Š: All windows - + 所有視窗 Player 1 window only - + 僅玩家 1 視窗 Currently active player window - + ç¾åœ¨ä½¿ç”¨ä¸­çš„玩家視窗 Display driver: - + 顯示驅動: Frameskip: - + è·³éŽç•«æ ¼: Skip every - + æ¯éš” N ç•«æ ¼è·³éŽ frames - + ç•«æ ¼ FPS target: - + FPS 目標: frames per second - + æ¯ç§’畫格數 (FPS) Sync: - + åŒæ­¥: Video - + 視訊 Audio - + 音訊 Lock aspect ratio - + 鎖定長寬比 Force integer scaling - + 強制整數å€æ”¾å¤§ Bilinear filtering - + 雙線性éŽæ¿¾ Pause - + æš«åœ When inactive: - + 閒置時: When minimized: - + 最å°åŒ–時: Current channel: - + ç›®å‰é »é“: Current version: - + ç¾åœ¨ç‰ˆæœ¬: Update channel: - + æ›´æ–°é »é“: Available version: - + å¯ç”¨ç‰ˆæœ¬: (Unknown) - + (未知) Last checked: - + 上次檢查時間: Automatically check on start - + 啟動時自動檢查 Check now - + ç¾åœ¨æª¢æŸ¥ Default color palette only - + 僅使用é è¨­èª¿è‰²ç›¤ SGB color palette if available - + è‹¥å¯ç”¨ï¼Œä½¿ç”¨SGB調色盤 GBC color palette if available - + è‹¥å¯ç”¨ï¼Œä½¿ç”¨GBC調色盤 SGB (preferred) or GBC color palette if available - + è‹¥å¯ç”¨ï¼Œä½¿ç”¨ SGB (優先) 或 GBC調色盤 Game Boy Camera - + Game Boy Camera Driver: - + é©…å‹•: Source: - + 來æº: Native (59.7275) - + 原生 (59.7275) Interframe blending - + ç•«æ ¼é–“æ··åˆ Language - + 語言 Library: - + 資料庫: List view - + 清單顯示 Tree view - + 樹狀顯示 Show when no game open - + ç„¡éŠæˆ²å•Ÿå‹•æ™‚顯示 Clear cache - + æ¸…é™¤å¿«å– Allow opposing input directions - + å…許相åæ–¹å‘輸入 Suspend screensaver - + æš«åœèž¢å¹•ä¿è­·ç¨‹å¼ Dynamically update window title - + 動態更新視窗標題 Show filename instead of ROM name in title bar - + 標題顯示檔案åç¨±è€Œéž ROM å稱 Show OSD messages - + 顯示 OSD è¨Šæ¯ Enable Discord Rich Presence - + 啟用 Discord Rich Presence Automatically save state - + 自動儲存å³æ™‚存檔 Automatically load state - + 自動讀å–å³æ™‚存檔 Automatically save cheats - + 自動儲存金手指 Automatically load cheats - + 自動讀å–金手指 Show FPS in title bar - + 標題顯示 FPS Fast forward speed: - + 快轉速率: Unbounded - + ç„¡é™åˆ¶ Fast forward (held) speed: - + 快轉 (長按) 速率: Autofire interval: - + 自動連射間隔: Enable rewind - + 啟用倒轉 Rewind history: - + 倒轉歷å²: Idle loops: - + 閒置迴圈: Run all - + 執行全部 Remove known - + 移除已知 Detect and remove - + åµæ¸¬ä¸¦ç§»é™¤ Preload entire ROM into memory - + é å…ˆè®€å–整個 ROM 至記憶體中 Save state extra data: - + 儲存å³æ™‚存檔é¡å¤–資料: Save game - + 儲存éŠæˆ² Load state extra data: - + 讀å–å³æ™‚存檔é¡å¤–資料: Models - + 模型 GB only: - + 僅 GB: SGB compatible: - + SGB 相容: GBC only: - + 僅 GBC: GBC compatible: - + GBC 相容: SGB and GBC compatible: - + SGB & GBC 相容: Game Boy palette - + Game Boy 調色盤 Preset: - + é è¨­: Screenshot - + 螢幕截圖 Cheat codes - + 金手指代碼 Enable Game Boy Player features by default - + é è¨­å•Ÿç”¨ Game Boy Player 功能 Enable VBA bug compatibility in ROM hacks - + ROM 修改啟用 VBA 錯誤相容性 Video renderer: - + 渲染器: Software - + 軟體 OpenGL - + OpenGL OpenGL enhancements - + OpenGL 增強 High-resolution scale: - + 高畫質比例: (240×160) - + (240×160) XQ GBA audio (experimental) - + XQ GBA 音訊 (測試版) GB BIOS file: - + GB BIOS 檔案: @@ -5765,37 +5772,37 @@ Download size: %3 Browse - + ç€è¦½ Use BIOS file if found - + 若存在,使用 BIOS 檔案 Skip BIOS intro - + è·³éŽ BIOS é–‹é ­ç•«é¢ GBA BIOS file: - + GBA BIOS 檔案: GBC BIOS file: - + GBC BIOS 檔案: SGB BIOS file: - + SGB BIOS 檔案: Save games - + éŠæˆ²å­˜æª” @@ -5804,62 +5811,62 @@ Download size: %3 Same directory as the ROM - + 與 ROM åŒç›®éŒ„ Save states - + å³æ™‚存檔 Screenshots - + 螢幕截圖 Patches - + 修補檔 Cheats - + 金手指 Log to file - + 記錄到檔案 Log to console - + è¨˜éŒ„åˆ°æŽ§åˆ¶å° Select Log File - + é¸æ“‡è¨˜éŒ„檔 Default BG colors: - + é è¨­ BG é¡è‰²çµ„: Default sprite colors 1: - + é è¨­è§’色圖é¡è‰²çµ„ 1 Default sprite colors 2: - + é è¨­è§’色圖é¡è‰²çµ„ 2 Super Game Boy borders - + Super Game Boy é‚Šç•Œ @@ -5867,37 +5874,37 @@ Download size: %3 Shaders - + 著色器 Active Shader: - + 使用中的著色器: Name - + å稱 Author - + 作者 Description - + æè¿° Unload Shader - + å¸é™¤è‘—色器 Load New Shader - + 讀å–新著色器 @@ -5905,22 +5912,22 @@ Download size: %3 Edit Shortcuts - + 編輯快æ·éµ Keyboard - + éµç›¤ Gamepad - + éŠæˆ²æ‰‹æŠŠ Clear - + 清除 @@ -5928,47 +5935,47 @@ Download size: %3 Tiles - + 圖塊 Export Selected - + åŒ¯å‡ºæ‰€é¸ Export All - + 匯出全部 256 colors - + 256 色 Magnification - + 放大 Tiles per row - + æ¯è¡Œåœ–塊數 Fit to window - + è²¼åˆè¦–窗 Copy Selected - + 複製é¸å– Copy All - + 複製全部 @@ -5976,200 +5983,200 @@ Download size: %3 Record Video - + 錄影 Start - + Start Stop - + åœæ­¢ Select File - + é¸æ“‡æª”案 Presets - + é è¨­ High &Quality - + 高畫質 (&Q) &YouTube - + YouTube (&Y) WebM - + WebM MP4 - + MP4 &Lossless - + ç„¡æå“質 (&L) 4K - + 4K &1080p - + 1080p (&1) &720p - + 720p (&7) &480p - + 480p (&4) &Native - + 原始畫質 (&N) Format - + æ ¼å¼ MKV - + MKV AVI - + AVI HEVC - + HEVC HEVC (NVENC) - + HEVC (NVENC) VP8 - + VP8 VP9 - + VP9 FFV1 - + FFV1 None - + ç„¡ FLAC - + FLAC Opus - + Opus Vorbis - + Vorbis MP3 - + MP3 AAC - + AAC Uncompressed - + 未壓縮 Bitrate (kbps) - + ä½å…ƒçŽ‡ (kbps) ABR - + ABR H.264 - + H.264 H.264 (NVENC) - + H.264 (NVENC) VBR - + VBR CRF - + CRF Dimensions - + 維度 Lock aspect ratio - + 鎖定長寬比 Show advanced - + 顯示進階é¸é … From 54a9457c65dcdf443d103ebdb867fe28f0a2583c Mon Sep 17 00:00:00 2001 From: Hexaae Date: Sat, 30 Nov 2024 11:47:20 +0000 Subject: [PATCH 305/338] Qt: Update translation (Italian) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/it/ --- src/platform/qt/ts/mgba-it.ts | 68 +++++++++++++++++------------------ 1 file changed, 34 insertions(+), 34 deletions(-) diff --git a/src/platform/qt/ts/mgba-it.ts b/src/platform/qt/ts/mgba-it.ts index 7338f41f626..aa709370371 100644 --- a/src/platform/qt/ts/mgba-it.ts +++ b/src/platform/qt/ts/mgba-it.ts @@ -21,7 +21,7 @@ %1 Video Logs (*.mvl) - %1 log Video (*.mvl) + %1 registro Video (*.mvl) @@ -482,7 +482,7 @@ Dimensione del download: %3 Failed to create an OpenGL 3 context, trying old-style... - + Impossibile creare un contesto OpenGL 3, provo con il vecchio stile... @@ -3181,7 +3181,7 @@ Dimensione del download: %3 Stub - Matrice + Stub @@ -3242,7 +3242,7 @@ Dimensione del download: %3 Logs - Log + Registri @@ -3257,7 +3257,7 @@ Dimensione del download: %3 Stub - Matrice + Stub @@ -3408,63 +3408,63 @@ Dimensione del download: %3 Memory access logging - + Registrazione accessi alla memoria Log file - + File di registro Browse - Sfoglia + Sfoglia Log additional information (uses 3× space) - + Registra informazioni aggiuntive (utilizza 3× spazio) Load existing file if present - + Carica file esistente se presente Regions - + Regioni Export ROM snapshot - + Esporta istantanea ROM Start - + Avvia Stop - Ferma + Ferma Failed to open memory log file - + Impossibile aprire il file di registro della memoria Select access log file - + Seleziona il file di registro di accesso Memory access logs (*.mal) - + Registri degli accessi alla memoria (*.mal) @@ -4038,7 +4038,7 @@ Dimensione del download: %3 Realtime clock - Clock in tempo reale + Orologio in tempo reale @@ -4372,12 +4372,12 @@ Dimensione del download: %3 Maker Code: - + Codice fabbricante: Revision: - + Revisione: @@ -4660,7 +4660,7 @@ Dimensione del download: %3 &Load most recent - + &Carica il più recente @@ -4698,7 +4698,7 @@ Dimensione del download: %3 Realtime clock - Clock in tempo reale + Orologio in tempo reale @@ -4713,7 +4713,7 @@ Dimensione del download: %3 Start time at - Avvia tempo a + Avvia ora alle @@ -4932,7 +4932,7 @@ Dimensione del download: %3 Logging - Log + Registrazione @@ -5387,17 +5387,17 @@ Dimensione del download: %3 Log to file - Registro log in file + Registro salvato su file Log to console - Registro log in console + Registro mostrato in console Select Log File - Seleziona file log + Seleziona file registro @@ -6026,12 +6026,12 @@ Dimensione del download: %3 Select video log - Seleziona log video + Seleziona registro video Video logs (*.mvl) - Log video (*.mvl) + Registro video (*.mvl) @@ -6376,7 +6376,7 @@ Dimensione del download: %3 &Lock frame size - + &Blocca dimensione cornice @@ -6436,7 +6436,7 @@ Dimensione del download: %3 Game &overrides... - Valore specifico per il gioco... + Sovrascrivi funzioni del gioco... @@ -6657,17 +6657,17 @@ Dimensione del download: %3 Log memory &accesses... - + Registra memoria &accessi... Record debug video log... - Registra video log di debug... + Salva registro video di debug... Stop debug video log - Ferma video log di debug + Ferma registro video di debug From 9099ff0d44800228b56aced2b0bd63bc3d7a595a Mon Sep 17 00:00:00 2001 From: ibizastweet Date: Wed, 4 Dec 2024 22:10:10 +0000 Subject: [PATCH 306/338] Qt: Update translation (French) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/fr/ --- src/platform/qt/ts/mgba-fr.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/platform/qt/ts/mgba-fr.ts b/src/platform/qt/ts/mgba-fr.ts index 27eb207a978..32db450141f 100644 --- a/src/platform/qt/ts/mgba-fr.ts +++ b/src/platform/qt/ts/mgba-fr.ts @@ -557,7 +557,7 @@ Taille du téléchargement : %3 Banner - + Bannière From 1e21b38793db2a5685025fe1915c94b97b165e9c Mon Sep 17 00:00:00 2001 From: Daniel Nylander Date: Sat, 7 Dec 2024 07:57:11 +0000 Subject: [PATCH 307/338] Qt: Update translation (Swedish) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/sv/ --- src/platform/qt/ts/mgba-sv.ts | 2008 +++++++++++++++++---------------- 1 file changed, 1005 insertions(+), 1003 deletions(-) diff --git a/src/platform/qt/ts/mgba-sv.ts b/src/platform/qt/ts/mgba-sv.ts index 4017ea4899d..6f6d30651cf 100644 --- a/src/platform/qt/ts/mgba-sv.ts +++ b/src/platform/qt/ts/mgba-sv.ts @@ -6,22 +6,22 @@ Game Boy Advance ROMs (%1) - + Game Boy Advance ROM-filer (%1) Game Boy ROMs (%1) - + Game Boy ROM-filer (%1) All ROMs (%1) - + Alla ROM-filer (%1) %1 Video Logs (*.mvl) - + %1 Videologgar (*.mvl) @@ -29,12 +29,12 @@ About - Om mGBA + Om <a href="http://mgba.io/">Website</a> • <a href="https://forums.mgba.io/">Forums / Support</a> • <a href="https://patreon.com/mgba">Donate</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">Source</a> - <a href="http://mgba.io/">Hemsida</a> • <a href="https://forums.mgba.io/">Forum / Hjälp</a> • <a href="https://patreon.com/mgba">Stödja mGBA</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">Källkod</a> + <a href="http://mgba.io/">Webbsida</a> • <a href="https://forums.mgba.io/">Forum / Support</a> • <a href="https://patreon.com/mgba">Donera</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">Källkod</a> @@ -56,7 +56,7 @@ Game Boy Advance är ett registrerat varumärke av Nintendo Co., Ltd. {projectName} is an open-source Game Boy Advance emulator - {projectName} är en emulator för Game Boy Advance, byggt pÃ¥ öppen källkod + {projectName} är en emulator för Game Boy Advance som är byggt pÃ¥ öppen källkod @@ -64,13 +64,13 @@ Game Boy Advance är ett registrerat varumärke av Nintendo Co., Ltd. An update is available - En uppdatering är tillgänglig + En uppdatering finns tillgänglig An update to %1 is available. - En uppdatering till %1 är tillgänglig. + En uppdatering till %1 finns tillgänglig. @@ -78,38 +78,38 @@ Game Boy Advance är ett registrerat varumärke av Nintendo Co., Ltd. Do you want to download and install it now? You will need to restart the emulator when the download is complete. -Vill du ladda ner och installera det nu? Programmet mÃ¥ste startas om när nedladdningen är klar. +Vill du hämta ner och installera det nu? Programmet mÃ¥ste startas om när hämtningen är klar. Auto-update is not available on this platform. If you wish to update you will need to do it manually. -Det finns ej automatiska uppdateringar för detta operativ system. Önskar du uppdatera programmet mÃ¥ste du göra det manuellt. +Automatiska uppdateringar är inte tillgängligt för denna plattform. Vill du uppdatera sÃ¥ mÃ¥ste du göra det manuellt. Current version: %1 New version: %2 Download size: %3 - Nuvarande version: %1 -Nästa version: %2 -Nedladdningsstorlek: %3 + Aktuell version: %1 +Ny version: %2 +Hämtningsstorlek: %3 Downloading update... - Uppdatering laddas ner... + Uppdateringen hämtas... Downloading failed. Please update manually. - Nedladdningen misslyckades. Uppdateringen mÃ¥ste installeras manuellt. + Hämtningen misslyckades. Uppdatera manuellt. Downloading done. Press OK to restart %1 and install the update. - Nedladdning klar. Välj OK för att starta om %1 och installera uppdateringen. + Hämtningen är klar. Välj OK för att starta om %1 och installera uppdateringen. @@ -117,7 +117,7 @@ Nedladdningsstorlek: %3 Stable - Standard + Stabil @@ -140,12 +140,12 @@ Nedladdningsstorlek: %3 Open in archive... - Öppna i arkiveringsprogram... + Öppna i arkiv... Loading... - Laddas... + Läser in... @@ -232,7 +232,7 @@ Nedladdningsstorlek: %3 Chip name - Chip namn + Chipnamn @@ -247,7 +247,7 @@ Nedladdningsstorlek: %3 Load - Ladda + Läs in @@ -262,7 +262,7 @@ Nedladdningsstorlek: %3 Gate type - Gate typ + Gate-typ @@ -277,7 +277,7 @@ Nedladdningsstorlek: %3 Update Chip data - Uppdatera Chip-data + Uppdatera Chip-data @@ -321,7 +321,7 @@ Nedladdningsstorlek: %3 Failed to open cheats file: %1 - Misslyckades att öppna cheats-filen: %1 + Misslyckades att öppna fuskfilen: %1 @@ -329,7 +329,7 @@ Nedladdningsstorlek: %3 Cheats - Cheats + Fusk @@ -339,49 +339,49 @@ Nedladdningsstorlek: %3 Remove - Ta bort + Ta bort Add Lines - + Lägg till rader Code type - + Kodtyp Save - Spara + Spara Load - Ladda + Läs in Enter codes here... - + Ange koder här... Autodetect (recommended) - + Identifiera automatiskt (rekommenderas) Select cheats file - + Välj fuskfil Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. - + Vissa fusk kunde inte läggas till. Försäkra dig om att de är formaterade korrekt och/eller prova andra fusktyper. @@ -389,7 +389,7 @@ Nedladdningsstorlek: %3 Reset r%1-%2 %3 - + Starta om r%1-%2 %3 @@ -400,22 +400,22 @@ Nedladdningsstorlek: %3 Reset the game? - + Starta om spelet? Most games will require a reset to load the new save. Do you want to reset now? - + De flesta spel kommer att kräva en omstart för att läsa in ny sparning. Vill du starta om nu? Failed to open save file: %1 - + Misslyckades med att öppna sparad fil: %1 Failed to open game file: %1 - + Misslyckades med att öppna spelfil: %1 @@ -425,12 +425,12 @@ Nedladdningsstorlek: %3 Failed to open snapshot file for reading: %1 - + Misslyckades med att öppna ögonblicksfil för läsning: %1 Failed to open snapshot file for writing: %1 - + Misslyckades med att öppna ögonblicksfil för skrivning: %1 @@ -438,17 +438,17 @@ Nedladdningsstorlek: %3 Failed to open game file: %1 - + Misslyckades med att öppna spelfil: %1 Could not load game. Are you sure it's in the correct format? - + Kunde inte läsa in spelet. Är du säker pÃ¥ att det är i korrekt format? Failed to open save file; in-game saves cannot be updated. Please ensure the save directory is writable without additional privileges (e.g. UAC on Windows). - + Misslyckades med att öppna sparad fil; sparningar i spel kan inte uppdateras. Försäkra dig om att sparkatalogen är skrivbar utan att ytterligare behörighet krävs (t.ex UAC i Windows). @@ -456,17 +456,17 @@ Nedladdningsstorlek: %3 Debugger - + Felsökare Enter command (try `help` for more info) - + Ange kommando (prova 'help' för mer info) Break - + Bryt @@ -474,7 +474,7 @@ Nedladdningsstorlek: %3 Could not open CLI history for writing - + Kunde inte öppna CLI-historik för skrivning @@ -482,7 +482,7 @@ Nedladdningsstorlek: %3 Failed to create an OpenGL 3 context, trying old-style... - + Misslyckades med att skapa en OpenGL 3-kontext, provar old-style... @@ -490,47 +490,47 @@ Nedladdningsstorlek: %3 Connect to Dolphin - + Anslut till Dolphin Local computer - + Lokal dator IP address - + IP-adress Connect - + Anslut Disconnect - + Koppla frÃ¥n Close - + Stäng Reset on connect - + Starta om vid anslutning Couldn't Connect - + Kunde inte ansluta Could not connect to Dolphin. - + Kunde inte ansluta till Dolphin. @@ -538,12 +538,12 @@ Nedladdningsstorlek: %3 3DS - + 3DS Vita - + Vita @@ -551,12 +551,12 @@ Nedladdningsstorlek: %3 Icon - + Ikon Banner - + Banner @@ -564,17 +564,17 @@ Nedladdningsstorlek: %3 Bubble - + Bubbla Background - + Bakgrund Startup - + Uppstart @@ -587,24 +587,24 @@ Nedladdningsstorlek: %3 Files - + Filer ROM file: - + ROM-fil: Browse - + Bläddra Output filename: - + Filnamn för utdata: @@ -614,17 +614,17 @@ Nedladdningsstorlek: %3 Latest stable version - + Senaste stabila version Latest development build - + Senaste utvecklingsversionen Specific file - + Specifik fil @@ -634,57 +634,57 @@ Nedladdningsstorlek: %3 System - + System 3DS - + 3DS Vita - + Vita Presentation - + Presentation Title: - + Titel: Images: - + Bilder: Use default image - + Använd standardbild Preferred size: - + Föredragen storlek: Select image file - + Välj bildfil Select ROM file - + Välj ROM-fil Select output filename - + Välj filnamn för utdata @@ -694,7 +694,7 @@ Nedladdningsstorlek: %3 Build finished - + Byggnation färdig @@ -704,7 +704,7 @@ Nedladdningsstorlek: %3 Build failed - + Byggnation misslyckades @@ -714,17 +714,17 @@ Nedladdningsstorlek: %3 %1 installable package (*.%2) - + %1 installerbara paket (*.%2) Select an image - + Välj en bild Image files (*.png *.jpg *.bmp) - + Bildfiler (*.png *.jpg *.bmp) @@ -732,87 +732,87 @@ Nedladdningsstorlek: %3 Inspect frame - + Inspektera bildruta Magnification - + Förstoring Freeze frame - + Frys bildruta Backdrop color - + Bakgrundsfärg Disable scanline effects - + Inaktivera scanline-effekter Export - + Exportera Reset - + Nollställ Export frame - + Exportera bildruta Portable Network Graphics (*.png) - + Portable Network Graphics (*.png) None - + Ingen Background - + Bakgrund Window - + Fönster Objwin - + Objwin Sprite - + Sprite Backdrop - + Bakgrund Frame - + Bildruta %1 %2 - + %1 %2 @@ -820,7 +820,7 @@ Nedladdningsstorlek: %3 Enable Discord Rich Presence - + Aktivera Discord Rich Presence @@ -828,22 +828,22 @@ Nedladdningsstorlek: %3 Clear Button - + Töm knapp Clear Analog - + Töm analog Refresh - + Uppdatera Set all - + Ställ in alla @@ -851,17 +851,17 @@ Nedladdningsstorlek: %3 Server settings - + Serverinställningar Local port - + Lokal port Bind address - + Bunden adress @@ -871,42 +871,42 @@ Nedladdningsstorlek: %3 Standard GDB - + Standard GDB Internal change detection - + Upptäck interna ändringar Break on all writes - + Bryt vid alla skrivningar Break - + Bryt Stop - + Stoppa Start - + Starta Crash - + Krasch Could not start GDB server - + Kunde inte starta GDB-server @@ -914,62 +914,62 @@ Nedladdningsstorlek: %3 Record GIF/WebP/APNG - + Spela in GIF/WebP/APNG Loop - + Loopa Start - + Starta Stop - + Stoppa Select File - + Välj fil APNG - + APNG GIF - + GIF WebP - + WebP Frameskip - + Hoppa över bildrutor Failed to open output file: %1 - + Misslyckades med att öppna utdatafil: %1 Select output file - + Välj utdatafil Graphics Interchange Format (*.gif);;WebP ( *.webp);;Animated Portable Network Graphics (*.png *.apng) - + Graphics Interchange Format (*.gif);;WebP ( *.webp);;Animated Portable Network Graphics (*.png *.apng) @@ -978,167 +978,167 @@ Nedladdningsstorlek: %3 Autodetect - + Identifiera automatiskt Game Boy (DMG) - + Game Boy (DMG) Game Boy Pocket (MGB) - + Game Boy Pocket (MGB) Super Game Boy (SGB) - + Super Game Boy (SGB) Super Game Boy 2 (SGB) - + Super Game Boy 2 (SGB) Game Boy Color (CGB) - + Game Boy Color (CGB) Game Boy Advance (AGB) - + Game Boy Advance (AGB) Super Game Boy Color (SGB + CGB) - + Super Game Boy Color (SGB + CGB) ROM Only - + Endast ROM MBC1 - + MBC1 MBC2 - + MBC2 MBC3 - + MBC3 MBC3 + RTC - + MBC3 + RTC MBC5 - + MBC5 MBC5 + Rumble - + MBC5 + Rumble MBC6 - + MBC6 MBC7 (Tilt) - + MBC7 (Tilt) MMM01 - + MMM01 HuC-1 - + HuC-1 HuC-3 - + HuC-3 Pocket Cam - + Pocket Cam TAMA5 - + TAMA5 Wisdom Tree - + Wisdom Tree NT (old 1) - + NT (gammal 1) NT (old 2) - + NT (gammal 2) NT (new) - + NT (ny) Pokémon Jade/Diamond - + Pokémon Jade/Diamond BBD - + BBD Hitek - + Hitek GGB-81 - + GGB-81 Li Cheng - + Li Cheng Sachen (MMC1) - + Sachen (MMC1) Sachen (MMC2) - + Sachen (MMC2) @@ -1146,12 +1146,12 @@ Nedladdningsstorlek: %3 I/O Viewer - + I/O-visare 0x0000 - + 0x0000 @@ -1163,42 +1163,42 @@ Nedladdningsstorlek: %3 Background mode - + Bakgrundsläge Mode 0: 4 tile layers - + Läge 0: 4 bricklager Mode 1: 2 tile layers + 1 rotated/scaled tile layer - + Läge 1: 2 bricklager + 1 roterat/skalat bricklager Mode 2: 2 rotated/scaled tile layers - + Läge 2: 2 roterade/skalade bricklager Mode 3: Full 15-bit bitmap - + Läge 3: Full 15-bitars bitmap Mode 4: Full 8-bit bitmap - + Läge 4: Full 8-bitars bitmap Mode 5: Small 15-bit bitmap - + Läge 5: Liten 15-bitars bitmap CGB Mode - + CGB-läge @@ -1208,92 +1208,92 @@ Nedladdningsstorlek: %3 Unlocked HBlank - + OlÃ¥st HBlank Linear OBJ tile mapping - + Linjär OBJ-brickmappning Force blank screen - + Tvinga blank skärm Enable background 0 - + Aktivera bakgrund 0 Enable background 1 - + Aktivera bakgrund 1 Enable background 2 - + Aktivera bakgrund 2 Enable background 3 - + Aktivera bakgrund 3 Enable OBJ - + Aktivera OBJ Enable Window 0 - + Aktivera fönster 0 Enable Window 1 - + Aktivera fönster 1 Enable OBJ Window - + Aktivera OBJ-fönster Swap green components - + Byt gröna komponenter Currently in VBlank - + För närvarande i VBlank Currently in HBlank - + För närvarande i HBlank Currently in VCounter - + För närvarande i VCounter Enable VBlank IRQ generation - + Aktivera VBlank IRQ-generering Enable HBlank IRQ generation - + Aktivera HBlank IRQ-generering Enable VCounter IRQ generation - + Aktivera VCounter IRQ-generering @@ -1311,7 +1311,7 @@ Nedladdningsstorlek: %3 Priority - + Prioritet @@ -1319,7 +1319,7 @@ Nedladdningsstorlek: %3 Tile data base (* 16kB) - + Brickdatabas (* 16kB) @@ -1327,7 +1327,7 @@ Nedladdningsstorlek: %3 Enable mosaic - + Aktivera mosaik @@ -1335,7 +1335,7 @@ Nedladdningsstorlek: %3 Enable 256-color - + Aktivera 256-färger @@ -1343,7 +1343,7 @@ Nedladdningsstorlek: %3 Tile map base (* 2kB) - + Brickkartbas (* 2kB) @@ -1351,7 +1351,7 @@ Nedladdningsstorlek: %3 Background dimensions - + Bakgrundsdimensioner @@ -1367,7 +1367,7 @@ Nedladdningsstorlek: %3 Horizontal offset - + Horisontell marginal @@ -1377,7 +1377,7 @@ Nedladdningsstorlek: %3 Vertical offset - + Vertikal marginal @@ -1405,7 +1405,7 @@ Nedladdningsstorlek: %3 Integer part - + Heltalsdel @@ -1413,7 +1413,7 @@ Nedladdningsstorlek: %3 Integer part (low) - + Heltalsdel (lÃ¥g) @@ -1421,7 +1421,7 @@ Nedladdningsstorlek: %3 Integer part (high) - + Heltalsdel (hög) @@ -1625,7 +1625,7 @@ Nedladdningsstorlek: %3 Disabled - + Inaktiverad @@ -1635,12 +1635,12 @@ Nedladdningsstorlek: %3 Brighten - + Ljusare Darken - + Mörkare @@ -1715,7 +1715,7 @@ Nedladdningsstorlek: %3 Sound length - + Ljudlängd @@ -1753,14 +1753,14 @@ Nedladdningsstorlek: %3 Initial volume - + Initial volym Sound frequency - + Ljudfrekvens @@ -1784,7 +1784,7 @@ Nedladdningsstorlek: %3 Reset - + Nollställ @@ -1800,40 +1800,40 @@ Nedladdningsstorlek: %3 Enable channel 3 - + Aktivera kanal 3 Volume - + Volym 0% - + 0% 100% - + 100% 50% - + 50% 25% - + 25% @@ -1841,7 +1841,7 @@ Nedladdningsstorlek: %3 75% - + 75% @@ -1859,13 +1859,13 @@ Nedladdningsstorlek: %3 15 - + 15 7 - + 7 @@ -1887,49 +1887,49 @@ Nedladdningsstorlek: %3 Enable channel 1 right - + Aktivera kanal 1 höger Enable channel 2 right - + Aktivera kanal 2 höger Enable channel 3 right - + Aktivera kanal 3 höger Enable channel 4 right - + Aktivera kanal 4 höger Enable channel 1 left - + Aktivera kanal 1 vänster Enable channel 2 left - + Aktivera kanal 2 vänster Enable channel 3 left - + Aktivera kanal 3 vänster Enable channel 4 left - + Aktivera kanal 4 vänster @@ -1949,12 +1949,12 @@ Nedladdningsstorlek: %3 Enable channel A right - + Aktivera kanal A höger Enable channel A left - + Aktivera kanal A vänster @@ -1965,7 +1965,7 @@ Nedladdningsstorlek: %3 0 - + 0 @@ -1978,7 +1978,7 @@ Nedladdningsstorlek: %3 1 - + 1 @@ -1988,12 +1988,12 @@ Nedladdningsstorlek: %3 Enable channel B right - + Aktivera kanal B höger Enable channel B left - + Aktivera kanal B vänster @@ -2009,31 +2009,31 @@ Nedladdningsstorlek: %3 Active channel 1 - + Aktiv kanal 1 Active channel 2 - + Aktiv kanal 2 Active channel 3 - + Aktiv kanal 3 Active channel 4 - + Aktiv kanal 4 Enable audio - + Aktivera ljud @@ -2043,7 +2043,7 @@ Nedladdningsstorlek: %3 Resolution - + Upplösning @@ -2119,7 +2119,7 @@ Nedladdningsstorlek: %3 Sample - + Sampling @@ -2131,7 +2131,7 @@ Nedladdningsstorlek: %3 Address (low) - + Adress (lÃ¥g) @@ -2143,53 +2143,53 @@ Nedladdningsstorlek: %3 Address (high) - + Adress (hög) Sound frequency (low) - + Ljudfrekvens (lÃ¥g) Sound frequency (high) - + Ljudfrekvens (hög) Source (high) - + Källa (hög) Source (low) - + Källa (lÃ¥g) Destination (high) - + Destination (hög) Destination (low) - + Destination (lÃ¥g) Green (low) - + Grön (lÃ¥g) Green (high) - + Grön (hög) @@ -2197,7 +2197,7 @@ Nedladdningsstorlek: %3 Word count - + Antal ord @@ -2217,7 +2217,7 @@ Nedladdningsstorlek: %3 Increment - + Öka @@ -2229,7 +2229,7 @@ Nedladdningsstorlek: %3 Decrement - + Minska @@ -2241,7 +2241,7 @@ Nedladdningsstorlek: %3 Fixed - + Fast @@ -2249,7 +2249,7 @@ Nedladdningsstorlek: %3 Increment and reload - + Öka och läs om @@ -2265,7 +2265,7 @@ Nedladdningsstorlek: %3 Repeat - + Upprepa @@ -2290,7 +2290,7 @@ Nedladdningsstorlek: %3 Immediate - + Direkt @@ -2302,7 +2302,7 @@ Nedladdningsstorlek: %3 VBlank - + VBlank @@ -2313,7 +2313,7 @@ Nedladdningsstorlek: %3 HBlank - + HBlank @@ -2326,7 +2326,7 @@ Nedladdningsstorlek: %3 IRQ - + IRQ @@ -2341,24 +2341,24 @@ Nedladdningsstorlek: %3 Enable - + Aktivera Audio FIFO - + Ljud-FIFO Video Capture - + VideofÃ¥ngst DRQ - + DRQ @@ -2370,7 +2370,7 @@ Nedladdningsstorlek: %3 Value - + Värde @@ -2378,7 +2378,7 @@ Nedladdningsstorlek: %3 Scale - + Skala @@ -2387,7 +2387,7 @@ Nedladdningsstorlek: %3 1/64 - + 1/64 @@ -2396,7 +2396,7 @@ Nedladdningsstorlek: %3 1/256 - + 1/256 @@ -2405,7 +2405,7 @@ Nedladdningsstorlek: %3 1/1024 - + 1/1024 @@ -2418,55 +2418,55 @@ Nedladdningsstorlek: %3 A - + A Select - + Select Start - + Start Right - + Höger Left - + Vänster Up - + Upp Down - + Ner R - + R L - + L @@ -2476,28 +2476,28 @@ Nedladdningsstorlek: %3 SC - + SC SD - + SD SI - + SI SO - + SO VCounter - + VCounter @@ -2527,31 +2527,31 @@ Nedladdningsstorlek: %3 SIO - + SIO DMA 0 - + DMA 0 DMA 1 - + DMA 1 DMA 2 - + DMA 2 DMA 3 - + DMA 3 @@ -2563,7 +2563,7 @@ Nedladdningsstorlek: %3 Gamepak - + Gamepak @@ -2577,7 +2577,7 @@ Nedladdningsstorlek: %3 4 - + 4 @@ -2585,7 +2585,7 @@ Nedladdningsstorlek: %3 3 - + 3 @@ -2594,7 +2594,7 @@ Nedladdningsstorlek: %3 2 - + 2 @@ -2603,7 +2603,7 @@ Nedladdningsstorlek: %3 8 - + 8 @@ -2644,22 +2644,22 @@ Nedladdningsstorlek: %3 Disable - + Inaktivera 4.19MHz - + 4.19MHz 8.38MHz - + 8.38MHz 16.78MHz - + 16.78MHz @@ -2669,27 +2669,27 @@ Nedladdningsstorlek: %3 Enable IRQs - + Aktivera IRQer Right/A - + Höger/A Left/B - + Vänster/B Up/Select - + Upp/Select Down/Start - + Ner/Start @@ -2699,12 +2699,12 @@ Nedladdningsstorlek: %3 Active face buttons - + Aktiva handlingsknappar Internal clock - + Intern klocka @@ -2724,7 +2724,7 @@ Nedladdningsstorlek: %3 1/16 - + 1/16 @@ -2753,99 +2753,99 @@ Nedladdningsstorlek: %3 Volume right - + Volym höger Output right - + UtgÃ¥ng höger Volume left - + Volym vänster Output left - + UtgÃ¥ng vänster Background enable/priority - + Bakgrund aktivera/prioritet Enable sprites - + Aktivera sprites Double-height sprites - + Sprites med dubbelhöjd Background tile map - + Brickkarta för bakgrund 0x9800 – 0x9BFF - + 0x9800 – 0x9BFF 0x9C00 – 0x9FFF - + 0x9C00 – 0x9FFF Background tile data - + Brickdata för bakgrund 0x8800 – 0x87FF - + 0x8800 – 0x87FF 0x8000 – 0x8FFF - + 0x8000 – 0x8FFF Enable window - + Aktivera fönster Window tile map - + Brickkarta för fönster Enable LCD - + Aktivera LCD Mode - + Läge 0: HBlank - + 0: HBlank 1: VBlank - + 1: VBlank @@ -2855,7 +2855,7 @@ Nedladdningsstorlek: %3 3: HDraw - + 3: HDraw @@ -2865,27 +2865,27 @@ Nedladdningsstorlek: %3 Enable HBlank (mode 0) IRQ - + Aktivera HBlank (läge 0) IRQ Enable VBlank (mode 1) IRQ - + Aktivera VBlank (läge 1) IRQ Enable OAM (mode 2) IRQ - + Aktivera OAM (läge 2) IRQ Enable LYC IRQ - + Aktivera LYC IRQ Current Y coordinate - + Aktuell Y-koordinat @@ -2928,12 +2928,12 @@ Nedladdningsstorlek: %3 Prepare to switch speed - + Förbered att växla hastighet Double speed - + Dubbel hastighet @@ -2943,7 +2943,7 @@ Nedladdningsstorlek: %3 Length - + Längd @@ -2964,13 +2964,13 @@ Nedladdningsstorlek: %3 Unknown - Okänd + Okänd Current index - + Aktuellt index @@ -2982,23 +2982,23 @@ Nedladdningsstorlek: %3 Red - Röd + Röd Blue - BlÃ¥ + BlÃ¥ Sprite ordering - + Spriteordning OAM order - + OAM-ordning @@ -3008,7 +3008,7 @@ Nedladdningsstorlek: %3 WRAM bank - + WRAM-bank @@ -3017,7 +3017,7 @@ Nedladdningsstorlek: %3 --- - + --- @@ -3025,27 +3025,27 @@ Nedladdningsstorlek: %3 Name - + Namn Location - + Plats Platform - + Plattform Size - + Storlek CRC32 - + CRC32 @@ -3054,7 +3054,7 @@ Nedladdningsstorlek: %3 %1 State - + %1 tillstÃ¥nd @@ -3067,82 +3067,82 @@ Nedladdningsstorlek: %3 No Save - + Inget sparat 5 - + 5 6 - + 6 8 - + 8 4 - + 4 1 - + 1 3 - + 3 7 - + 7 9 - + 9 2 - + 2 Cancel - + Avbryt Load State - + Läs in tillstÃ¥nd Save State - + Spara tillstÃ¥nd Empty - + Tom Corrupted - + Skadat Slot %1 - + Plats %1 @@ -3151,42 +3151,42 @@ Nedladdningsstorlek: %3 Default - + Standard Fatal - + Ödesdigert Error - + Fel Warning - + Varning Info - + Info Debug - + Felsökning Stub - + Stub Game Error - + Spelfel @@ -3194,47 +3194,47 @@ Nedladdningsstorlek: %3 [%1] %2: %3 - + [%1] %2: %3 An error occurred - + Ett fel inträffade DEBUG - + FELSÖK STUB - + STUB INFO - + INFO WARN - + VARN ERROR - + FEL FATAL - + ÖDESDIGERT GAME ERROR - + SPELFEL @@ -3242,62 +3242,62 @@ Nedladdningsstorlek: %3 Logs - + Loggar Enabled Levels - + Aktiverade nivÃ¥er Debug - + Felsök Stub - + Stub Info - + Info Warning - + Varning Error - + Fel Fatal - + Ödesdigert Game Error - + Spelfel Advanced settings - + Avancerade inställningar Clear - + Töm Max Lines - + Max rader @@ -3305,44 +3305,44 @@ Nedladdningsstorlek: %3 Maps - + Kartor Magnification - + Förstoring Export - + Exportera Copy - + Kopiera Priority - + Prioritet Map base - + Kartbas Tile base - + Brickbas Size - + Storlek @@ -3353,54 +3353,54 @@ Nedladdningsstorlek: %3 Xform - + Xform Map Addr. - + Kartadr. Mirror - + Spegla None - + Ingen Both - + BÃ¥da Horizontal - + Horisontal Vertical - + Vertikal N/A - + Inte tillgänglig Export map - + Exportera karta Portable Network Graphics (*.png) - + Portable Network Graphics (*.png) @@ -3408,63 +3408,63 @@ Nedladdningsstorlek: %3 Memory access logging - + Loggning av minnesÃ¥tkomst Log file - + Loggfil Browse - + Bläddra Log additional information (uses 3× space) - + Logga ytterligare information (använder 3× utrymme) Load existing file if present - + Läs in befintlig fil om tillgänglig Regions - + Regioner Export ROM snapshot - + Exportera ROM-ögonblicksbild Start - + Starta Stop - + Stoppa Failed to open memory log file - + Misslyckades med att öppna minnesloggfil Select access log file - + Välj Ã¥tkomstloggfil Memory access logs (*.mal) - + MinnesÃ¥tkomstloggar (*.mal) @@ -3472,12 +3472,12 @@ Nedladdningsstorlek: %3 Save Memory Range - + Spara minnesomfÃ¥ng Start Address: - + Startadress: @@ -3492,12 +3492,12 @@ Nedladdningsstorlek: %3 Save memory region - + Spara minnesregion Failed to open output file: %1 - + Misslyckades med att öppna utdatafil: %1 @@ -3505,62 +3505,62 @@ Nedladdningsstorlek: %3 Copy selection - + Kopiera markering Save selection - + Spara markering Paste - + Klistra in Load - Ladda + Läs in All - + Alla Load TBL - + Läs in TBL Save selected memory - + Spara markerat minne Failed to open output file: %1 - + Misslyckades med att öppna utdatafil: %1 Load memory - + Läs in minne Failed to open input file: %1 - + Misslyckades med att öppna indatafil: %1 TBL - + TBL ISO-8859-1 - + ISO-8859-1 @@ -3568,169 +3568,169 @@ Nedladdningsstorlek: %3 Memory Search - + Minnessökning Address - Adress + Adress Current Value - + Aktuellt värde Type - + Typ Value - + Värde Numeric - + Numerisk Text - + Text Width - + Bredd Guess - + Gissa 1 Byte (8-bit) - + 1 Byte (8-bit) 2 Bytes (16-bit) - + 2 Bytes (16-bit) 4 Bytes (32-bit) - + 4 Bytes (32-bit) Number type - + Nummertyp Decimal - + Decimal Hexadecimal - + Hexadecimal Search type - + Söktyp Equal to value - + Lika med värdet Greater than value - + Större än värdet Less than value - + Mindre än värdet Unknown/changed - + Okänt/ändrat Changed by value - + Ändrat med värdet Unchanged - + Oförändrat Increased - + Ökat Decreased - + Minskat Search ROM - + Sök ROM New Search - + Ny sökning Search Within - + Sök inom Open in Memory Viewer - + Öppna i minnesvisare Refresh - + Uppdatera (%0/%1×) - + (%0/%1×) (â…Ÿ%0×) - + (â…Ÿ%0×) (%0×) - + (%0×) %1 byte%2 - + %1 byte%2 @@ -3738,77 +3738,77 @@ Nedladdningsstorlek: %3 Memory - + Minne Inspect Address: - + Inspektera adress: Set Alignment: - + Ställ in justering: &1 Byte - + &1 Byte &2 Bytes - + &2 Bytes &4 Bytes - + &4 Bytes Unsigned Integer: - + Osignerat heltal: Signed Integer: - + Signerat heltal: String: - + Sträng: Load TBL - + Läs in TBL Copy Selection - + Kopiera markering Paste - + Klistra in Save Selection - + Spara markering Save Range - + Spara omfÃ¥ng Load - Ladda + Läs in @@ -3816,7 +3816,7 @@ Nedladdningsstorlek: %3 Frame %1 - + Bildruta %1 @@ -3842,134 +3842,134 @@ Nedladdningsstorlek: %3 Sprites - + Spritar Address - Adress + Adress Copy - + Kopiera Magnification - + Förstoring Geometry - + Geometri Position - + Position Dimensions - + Dimensioner Matrix - + Matris Export - + Exportera Attributes - + Attribut Transform - + Transformera Off - + Av Palette - + Palett Double Size - + Dubbel storlek Return, Ctrl+R - + Ã…tergÃ¥, Ctrl+R Flipped - + Vänd H Short for horizontal - + H V Short for vertical - + V Mode - + Läge Normal - + Normal Mosaic - + Mosaik Enabled - + Aktiverad Priority - + Prioritet Tile - + Ruta 0x%0 - + 0x%0 @@ -3981,38 +3981,38 @@ Nedladdningsstorlek: %3 --- - + --- Trans - + Trans OBJWIN - + OBJWIN Invalid - + Ogiltig N/A - + Inte tillgänglig Export sprite - + Exportera sprite Portable Network Graphics (*.png) - + Portable Network Graphics (*.png) @@ -4025,7 +4025,7 @@ Nedladdningsstorlek: %3 Game Boy Advance - + Game Boy Advance @@ -4033,17 +4033,17 @@ Nedladdningsstorlek: %3 Autodetect - + Identifiera automatiskt Realtime clock - + Realtidsklocka Gyroscope - + Gyroskop @@ -4053,52 +4053,52 @@ Nedladdningsstorlek: %3 Light sensor - + Ljussensor Rumble - + Rumble Save type - + Sparningstyp None - + Ingen SRAM - + SRAM Flash 512kb - + Flash 512kb Flash 1Mb - + Flash 1Mb EEPROM 8kB - + EEPROM 8kB EEPROM 512 bytes - + EEPROM 512 bytes SRAM 64kB (bootlegs only) - + SRAM 64kB (endast bootlegs) @@ -4118,12 +4118,12 @@ Nedladdningsstorlek: %3 Game Boy - + Game Boy Game Boy model - + Game Boy-modell @@ -4133,7 +4133,7 @@ Nedladdningsstorlek: %3 Background Colors - + Bakgrundsfärger @@ -4148,22 +4148,22 @@ Nedladdningsstorlek: %3 Palette preset - + Palettförval Official MBCs - + Officiella MBCer Licensed MBCs - + Licensierade MBCer Unlicensed MBCs - + Olicensierade MBCer @@ -4171,72 +4171,72 @@ Nedladdningsstorlek: %3 Palette - + Palett Background - + Bakgrund Objects - + Objekt Selection - + Markering Red - Röd + Röd Green - Grön + Grön Blue - BlÃ¥ + BlÃ¥ 16-bit value - + 16-bitarsvärde Hex code - + Hexkod Palette index - + Palettindex Export BG - + Exportera BG Export OBJ - + Exportera OBJ #%0 - + #%0 0x%0 - + 0x%0 @@ -4244,22 +4244,22 @@ Nedladdningsstorlek: %3 0x%0 (%1) - 0x%0 (%1) + 0x%0 (%1) Export palette - + Exportera palett Windows PAL (*.pal);;Adobe Color Table (*.act) - + Windows PAL (*.pal);;Adobe Color Table (*.act) Failed to open output palette file: %1 - + Misslyckades med att öppna utdatafil för palett: %1 @@ -4267,27 +4267,27 @@ Nedladdningsstorlek: %3 Adjust placement - + Justera placering All - + Alla Offset - + Förskjut X - + X Y - + Y @@ -4295,37 +4295,37 @@ Nedladdningsstorlek: %3 Game Boy Printer - + Game Boy-skrivare Hurry up! - + Skynda dig! Tear off - + Riv av Magnification - + Förstoring Copy - + Kopia Save Printout - + Spara utskrift Portable Network Graphics (*.png) - + Portable Network Graphics (*.png) @@ -4337,62 +4337,62 @@ Nedladdningsstorlek: %3 (unknown) - + (okänt) bytes - + bytes (no database present) - + (finns ingen databas) ROM Info - + ROM-info Game name: - + Spelnamn: Internal name: - + Internt namn: Game ID: - + Spel-ID: Maker Code: - + Tillverkarkod: Revision: - + Revision: File size: - + Filstorlek: CRC32: - + CRC32: Save file: - + Sparad fil: @@ -4400,17 +4400,17 @@ Nedladdningsstorlek: %3 Bug report archive - + Felrapportarkiv ZIP archive (*.zip) - + ZIP-arkiv (*.zip) Generate Bug Report - + Skapa felrapport @@ -4420,27 +4420,27 @@ Nedladdningsstorlek: %3 Generate report - + Skapa rapport Save - Spara + Spara Open issue list in browser - + Öppna fellista i webbläsaren Include save file - + Inkludera sparad fil Create and include savestate - + Skapa och inkludera sparat tillstÃ¥nd @@ -4448,178 +4448,178 @@ Nedladdningsstorlek: %3 Save games and save states (%1) - + Sparade spel och sparade tillstÃ¥nd (%1) Select save game or save state - + Välj sparat spel eller sparat tillstÃ¥nd Save games (%1) - + Sparade spel (%1) Select save game - + Välj sparat spel Conversion failed - + Konvertering misslyckades Failed to convert the save game. This is probably a bug. - + Misslyckades med att konvertera sparat spel. Detta är antagligen en bugg. No file selected - + Ingen fil vald Could not open file - + Kunde inte öppna filen No valid formats found - + Inga giltiga format hittades Please select a valid input file - + Välj en giltig indatafil No valid conversions found - + Inga giltiga konverteringar hittades Cannot convert save games between platforms - + Kan inte konvertera sparade spel mellan plattformar Convert/Extract Save Game - + Konvertera/Extrahera sparat spel Input file - + Indatafil Browse - + Bläddra Output file - + Utdatafil %1 %2 save game - + %1 %2 sparat spel little endian - + little endian big endian - + big endian SRAM - + SRAM %1 flash - + %1 flash %1 EEPROM - + %1 EEPROM + RTC - + + RTC %1 SRAM + RTC - + %1 SRAM + RTC %1 SRAM - + %1 SRAM packed MBC2 - + packad MBC2 unpacked MBC2 - + opackad MBC2 MBC6 flash - + MBC6 flash MBC6 combined SRAM + flash - + MBC6 kombinerat SRAM + flash MBC6 SRAM - + MBC6 SRAM TAMA5 - + TAMA5 %1 (%2) - + %1 (%2) %1 save state with embedded %2 save game - + %1 sparat tillstÃ¥nd med inbäddat %2 sparat spel %1 SharkPort %2 save game - + %1 SharkPort %2 sparat spel %1 GameShark Advance SP %2 save game - + %1 GameShark Advance SP %2 sparat spel @@ -4627,7 +4627,7 @@ Nedladdningsstorlek: %3 Untitled buffer - + Ej namngiven buffert @@ -4635,57 +4635,57 @@ Nedladdningsstorlek: %3 Scripting - + Skriptning Run - + Kör File - + Fil Load recent script - + Läs in senaste skript Load script... - + Läs in skript... &Load most recent - + &Läs in det senaste &Reset - + &Nollställ 0 - + 0 Select script to load - + Välj skript att läsa in Lua scripts (*.lua) - + Lua-skript (*.lua) All files (*.*) - + Alla filer (*.*) @@ -4693,22 +4693,22 @@ Nedladdningsstorlek: %3 Sensors - + Sensorer Realtime clock - + Realtidsklocka Fixed time - + Fast tid System time - + Systemtid @@ -4718,17 +4718,17 @@ Nedladdningsstorlek: %3 Now - + Nu Offset time - + Förskjut tid sec - + s @@ -4738,17 +4738,17 @@ Nedladdningsstorlek: %3 Light sensor - + Ljussensor Brightness - + Ljusstyrka Tilt sensor - + Tiltsensor @@ -4765,12 +4765,12 @@ Nedladdningsstorlek: %3 Gyroscope - + Gyroskop Sensitivity - + Känslighet @@ -4779,257 +4779,257 @@ Nedladdningsstorlek: %3 Qt Multimedia - + Qt Multimedia SDL - + SDL Software (Qt) - + Programvara (Qt) OpenGL - + OpenGL OpenGL (force version 1.x) - + OpenGL (tvinga version 1.x) None - + Ingen None (Still Image) - + Ingen (stillbild) Keyboard - + Tangentbord Controllers - + Handkontroller Shortcuts - + Genvägar Shaders - + Shaders Select BIOS - + Välj BIOS Select directory - + Välj katalog Select image - + Välj bild Image file (*.png *.jpg *.jpeg) - + Bildfil (*.png *.jpg *.jpeg) (%1×%2) - + (%1×%2) Never - + Aldrig Just now - + Just nyss Less than an hour ago - + Mindre än en timme sedan %n hour(s) ago - - - + + %n timme sedan + %n timmar sedan %n day(s) ago - - - + + %n dag sedan + %n dagar sedan Settings - + Inställningar Audio/Video - + Ljud/Video Gameplay - + Spelning Interface - + Gränssnitt Update - + Uppdatering Emulation - + Emulering Enhancements - + Förbättringar BIOS - + BIOS Paths - + Sökvägar Logging - + Loggning Game Boy - + Game Boy Audio driver: - + Ljuddrivrutin: Audio buffer: - + Ljudbuffert: 1536 - + 1536 512 - + 512 768 - + 768 1024 - + 1024 2048 - + 2048 3072 - + 3072 4096 - + 4096 samples - + samplingar Sample rate: - + Samplingsfrekvens: 44100 - + 44100 22050 - + 22050 32000 - + 32000 48000 - + 48000 Hz - + Hz Volume: - + Volym: @@ -5037,53 +5037,53 @@ Nedladdningsstorlek: %3 Mute - + Tyst Fast forward volume: - + Volym för snabbspolning: Audio in multiplayer: - + Ljud i flerspelarläge: All windows - + Alla fönster Player 1 window only - + Endast Spelare 1-fönstret Currently active player window - + Det aktuella aktiva spelarfönstret Display driver: - + Skärmdrivrutin: Frameskip: - + Hoppa över bildrutor: Skip every - + Hoppa över var frames - + bildrutor @@ -5093,160 +5093,160 @@ Nedladdningsstorlek: %3 frames per second - + bildrutor per sekund Sync: - + Synk: Video - + Video Audio - + Ljud Lock aspect ratio - + LÃ¥s bildförhÃ¥llandet Force integer scaling - + Tvinga heltalsskalning Bilinear filtering - + Bilinjär filtrering Show filename instead of ROM name in library view - + Visa filnamn istället för ROM-namn i biblioteksvyn Pause - + Paus When inactive: - + När inaktiv: On loading a game: - + Vid inläsning av ett spel: Load last state - + Läs in senaste tillstÃ¥nd Load cheats - + Läs in fusk Save entered cheats - + Spara angivna fusk When minimized: - + När minimerad: Current channel: - + Aktuell kanal: Current version: - + Aktuell version: Update channel: - + Uppdateringskanal: Available version: - + Tillgänglig version: (Unknown) - + (Okänd) Last checked: - + Senast kontrollerad: Automatically check on start - + Kontrollera automatiskt vid start Check now - + Kontrollera nu Default color palette only - + Endast standardfärgpalett SGB color palette if available - + SGB-färgpalett om tillgänglig GBC color palette if available - + GBC-färgpalett om tillgänglig SGB (preferred) or GBC color palette if available - + SGB (föredragen) eller GBC-färgpalett om tillgänglig Game Boy Camera - + Game Boy Camera Driver: - + Drivrutin: Source: - + Källa: Native (59.7275) - + Inbyggd (59.7275) @@ -5256,32 +5256,32 @@ Nedladdningsstorlek: %3 Language - + SprÃ¥k Library: - + Bibliotek: List view - + Listvy Tree view - + Trädvy Show when no game open - + Visa när inget spel är öppnat Clear cache - + Töm cache @@ -5291,27 +5291,27 @@ Nedladdningsstorlek: %3 Suspend screensaver - + Förhindra skärmsläckare Dynamically update window title - + Uppdatera fönstertiteln dynamiskt Show filename instead of ROM name in title bar - + Visa filnamn istället för ROM-namn i titelraden Show OSD messages - + Visa OSD-meddelanden Enable Discord Rich Presence - + Aktivera Discord Rich Presence @@ -5321,7 +5321,7 @@ Nedladdningsstorlek: %3 Show FPS in title bar - + Visa bilder/s i titelrad @@ -5331,7 +5331,7 @@ Nedladdningsstorlek: %3 Show emulation info on reset - + Visa emuleringsinfo vid omstart @@ -5341,7 +5341,7 @@ Nedladdningsstorlek: %3 Fast forward speed: - + Hastighet för snabbspolning: @@ -5382,22 +5382,22 @@ Nedladdningsstorlek: %3 Run all - + Kör alla Remove known - + Ta bort kända Detect and remove - + Upptäck och ta bort Preload entire ROM into memory - + Förinläs hela ROM till minnet @@ -5408,7 +5408,7 @@ Nedladdningsstorlek: %3 Save game - + Spara spel @@ -5418,59 +5418,59 @@ Nedladdningsstorlek: %3 Models - + Modeller GB only: - + Endast GB: SGB compatible: - + SGB-kompatibel: GBC only: - + Endast GBC: GBC compatible: - + GBC-kompatibel: SGB and GBC compatible: - + SGB och GBC-kompatibla: Game Boy palette - + Game Boy-palett Preset: - + Förval: Screenshot - + Skärmbild Cheat codes - + Fuskkoder Enable Game Boy Player features by default - + Aktivera Game Boy Player-funktioner som standard @@ -5480,32 +5480,32 @@ Nedladdningsstorlek: %3 Video renderer: - + Videorenderare: Software - + Programvara OpenGL enhancements - + OpenGL-förbättringar High-resolution scale: - + Högupplösningsskala: (240×160) - + (240×160) GB BIOS file: - + GB BIOS-fil: @@ -5519,37 +5519,37 @@ Nedladdningsstorlek: %3 Browse - + Bläddra Use BIOS file if found - + Använd BIOS-fil om hittad Skip BIOS intro - + Hoppa över BIOS-intro GBA BIOS file: - + GBA BIOS-fil: GBC BIOS file: - + GBC BIOS-fil: SGB BIOS file: - + SGB BIOS-fil: Save games - + Sparade spel @@ -5558,42 +5558,42 @@ Nedladdningsstorlek: %3 Same directory as the ROM - + Samma katalog som ROM Save states - + Sparade tillstÃ¥nd Screenshots - + Skärmbilder Patches - + Patchar Cheats - Cheats + Fusk Log to file - + Logga till fil Log to console - + Logga till konsoll Select Log File - + Välj loggfil @@ -5621,58 +5621,58 @@ Nedladdningsstorlek: %3 No shader active - + Ingen shader aktiv Load shader - + Läs in shader No shader loaded - + Ingen shader inläst by %1 - + av %1 Preprocessing - + Förbehandling Pass %1 - + Pass %1 Shaders - + Shaders Active Shader: - + Aktiv shader: Name - + Namn Author - + Upphovsperson Description - + Beskrivning @@ -5682,7 +5682,7 @@ Nedladdningsstorlek: %3 Load New Shader - + Läs in ny shader @@ -5690,17 +5690,17 @@ Nedladdningsstorlek: %3 Action - + Ã…tgärd Keyboard - + Tangentbord Gamepad - + Gamepad @@ -5708,22 +5708,22 @@ Nedladdningsstorlek: %3 Edit Shortcuts - + Redigera genvägar Keyboard - + Tangentbord Gamepad - + Gamepad Clear - + Töm @@ -5731,88 +5731,88 @@ Nedladdningsstorlek: %3 Export tiles - + Exportera brickor Portable Network Graphics (*.png) - + Portable Network Graphics (*.png) Export tile - + Exportera bricka Tiles - + Brickor Export Selected - + Exportera markerade Export All - + Exportera alla 256 colors - + 256 färger Palette - + Palett Magnification - + Förstoring Tiles per row - + Brickor per rad Fit to window - + Aktivera till fönster Displayed tiles - + Visade brickor Only BG tiles - + Endast BG-brickor Only OBJ tiles - + Endast OBJ-brickor Both - + BÃ¥da Copy Selected - + Kopiera markerade Copy All - + Kopiera alla @@ -5820,132 +5820,132 @@ Nedladdningsstorlek: %3 Failed to open output video file: %1 - + Misslyckades med att öppna utdatafil för video: %1 Native (%0x%1) - + Inbyggd (%0x%1) Select output file - + Välj utdatafil Record Video - + Spela in video Start - + Starta Stop - + Stoppa Select File - + Select File Presets - + Förval High &Quality - + Hög &kvalitet &YouTube - + &YouTube WebM - + WebM MP4 - + MP4 &Lossless - + &Förlustfri 4K - + 4K &1080p - + &1080p &720p - + &720p &480p - + &480p &Native - + &Inbyggd Format - + Format Bitrate (kbps) - + Bitfrekvens (kbps) ABR - + ABR VBR - + VBR CRF - + CRF Dimensions - + Dimensioner Lock aspect ratio - + LÃ¥s bildförhÃ¥llandet Show advanced - Visa avancerat + Visa avancerat @@ -5953,35 +5953,35 @@ Nedladdningsstorlek: %3 Archives (%1) - + Arkiv (%1) Select ROM - + Välj ROM Select folder - + Välj mapp Select save - + Välj sparning Select patch - + Välj patch Patches (*.ips *.ups *.bps) - + Patchar (*.ips *.ups *.bps) @@ -5991,54 +5991,56 @@ Nedladdningsstorlek: %3 e-Reader card (*.raw *.bin *.bmp) - + e-Reader-kort (*.raw *.bin *.bmp) Select image - + Välj bild Image file (*.png *.gif *.jpg *.jpeg);;All files (*) - + Bildfil (*.png *.gif *.jpg *.jpeg);;Alla filer (*) GameShark saves (*.sps *.xps) - + GameShark-sparningar (*.sps *.xps) Select video log - + Välj videologg Video logs (*.mvl) - + Videologgar (*.mvl) Crash - + Krasch The game has crashed with the following error: %1 - + Spelet har kraschat med följande fel: + +%1 Couldn't Start - + Kunde inte starta Could not start game. - + Kunde inte starta spel. @@ -6058,254 +6060,254 @@ Nedladdningsstorlek: %3 Really make portable? - + Verkligen göra portabel? This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + Detta komma att göra att emulatorn läser in sin konfiguration frÃ¥n samma katalog som den körbara filen. Vill du fortsätta? Restart needed - + Omstart krävs Some changes will not take effect until the emulator is restarted. - + Vissa ändringar kommer inte ge effekt tills emulatorn har startats om. - Player %1 of %2 - + - Spelare %1 av %2 %1 - %2 - + %1 - %2 %1 - %2 - %3 - + %1 - %2 - %3 %1 - %2 (%3 fps) - %4 - + %1 - %2 (%3 bilder/s) - %4 &File - + &Arkiv Load &ROM... - + Läs in &ROM... Load ROM in archive... - + Läs in ROM i arkiv... Add folder to library... - + Lägg till mapp till bibliotek... Save games (%1) - + Sparade spel (%1) Select save game - + Välj sparat spel mGBA save state files (%1) - + mGBA-filer för sparat tillstÃ¥nd (%1) Select save state - + Välj sparat tillstÃ¥nd Select e-Reader card images - + Välj e-Reader-kortavbilder Image file (*.png *.jpg *.jpeg) - + Bildfil (*.png *.jpg *.jpeg) Conversion finished - + Konvertering färdig %1 of %2 e-Reader cards converted successfully. - + %1 av %2 e-Reader-kort konverterades. Load alternate save game... - + Läs in alternativt sparat spel... Load temporary save game... - + Läs in temporärt sparat spel... Load &patch... - + Läs in &patch... Boot BIOS - + Starta upp BIOS Replace ROM... - + Ersätt ROM... Scan e-Reader dotcodes... - + Skanna e-Reader-punktkoder... Convert e-Reader card image to raw... - + Konvertera e-Reader-kortavbilder till raw... ROM &info... - + ROM-&info... Recent - + Senaste Make portable - + Gör den portabel &Load state - + &Läs in tillstÃ¥nd Load state file... - + Läs in tillstÃ¥ndsfil... &Save state - + &Spara tillstÃ¥nd Save state file... - + Spara tillstÃ¥ndsfil... Quick load - + Snabbinläsning Quick save - + Snabbsparning Load recent - + Läs in senaste Save recent - + Spara senaste Undo load state - + Ã…ngra inläst tillstÃ¥nd Undo save state - + Ã…ngra sparat tillstÃ¥nd State &%1 - + TillstÃ¥nd &%1 Load camera image... - + Läs in kamerabild... Convert save game... - + Konvertera sparat spel... GameShark saves (*.gsv *.sps *.xps) - + GameShark-sparningar (*.gsv *.sps *.xps) Reset needed - + Omstart krävs Some changes will not take effect until the game is reset. - + Vissa ändringar kommer inte bli effektiva tills spelet har startats om. Save games - + Sparade spel Import GameShark Save... - + Importera GameShark-sparning... Export GameShark Save... - + Exportera GameShark-sparning... Automatically determine - + Bestäm automatiskt @@ -6315,42 +6317,42 @@ Nedladdningsstorlek: %3 New multiplayer window - + Nytt flerspelarfönster Connect to Dolphin... - + Anslut till Dolphin... Report bug... - + Rapportera fel... About... - + Om... E&xit - + A&vsluta &Emulation - + &Emulering &Reset - + Starta &om Sh&utdown - + Stäng &ner @@ -6360,97 +6362,97 @@ Nedladdningsstorlek: %3 &Pause - + &Paus &Next frame - + &Nästa bildruta Fast forward (held) - + Snabbspolning (hÃ¥ll) &Fast forward - + Snabbs&pola Fast forward speed - + Snabbspolningshastighet Unbounded - + Obunden %0x - + %0x Increase fast forward speed - + Öka snabbspolningshastighet Decrease fast forward speed - + Sänk snabbspolningshastighet Rewind (held) - + Spola tillbaka (hÃ¥ll) Re&wind - + Spola ti&llbaka Step backwards - + Stega bakÃ¥t Solar sensor - + Solsensor Increase solar level - + Öka solnivÃ¥ Decrease solar level - + Sänk solnivÃ¥ Brightest solar level - + Starkaste solnivÃ¥n Darkest solar level - + Mörkaste solnivÃ¥n Brightness %1 - + Ljusstyrka %1 Game Boy Printer... - + Game Boy-skrivare... @@ -6460,37 +6462,37 @@ Nedladdningsstorlek: %3 Audio/&Video - + Ljud/&Video Frame size - + Bildrutestorlek %1× - + %1× Toggle fullscreen - + Växla helskärm &Lock frame size - + &LÃ¥s bildrutestorlek Lock aspect ratio - + LÃ¥s bildförhÃ¥llande Force integer scaling - + Tvinga heltalsskalning @@ -6500,7 +6502,7 @@ Nedladdningsstorlek: %3 Bilinear filtering - + Bilinjär filtrering @@ -6510,7 +6512,7 @@ Nedladdningsstorlek: %3 Mute - + Tyst @@ -6520,52 +6522,52 @@ Nedladdningsstorlek: %3 Native (59.7275) - + Inbyggd (59.7275) Take &screenshot - + Ta s&kärmbild F12 - + F12 Record A/V... - + Spela in ljud/bild... Record GIF/WebP/APNG... - + Spela in GIF/WebP/APNG... Video layers - + Videolager Audio channels - + Ljudkanaler Adjust layer placement... - + Justera lagerplacering... &Tools - + Ver&ktyg View &logs... - + Visa &loggar... @@ -6575,12 +6577,12 @@ Nedladdningsstorlek: %3 Game Pak sensors... - + Game Pak-sensorer... &Cheats... - + &Fusk... @@ -6590,22 +6592,22 @@ Nedladdningsstorlek: %3 Settings... - + Inställningar... Open debugger console... - + Öppna felsökningskonsoll... Start &GDB server... - + Starta &GDB-server... Scripting... - + Skriptning... @@ -6615,62 +6617,62 @@ Nedladdningsstorlek: %3 View &palette... - + Visa &palett... View &sprites... - + Visa &sprites... View &tiles... - + Visa &brickor... View &map... - + Visa &karta... &Frame inspector... - + Inspektera bi&ldrutor... View memory... - + Visa minne... Search memory... - + Sök i minnet... View &I/O registers... - + Visa I/&O-register... Log memory &accesses... - + Logga minnesÃ¥&tkomster... Record debug video log... - + Spela in felsökningsvideologg... Stop debug video log - + Stoppa felsökningsvideologg Exit fullscreen - + Avsluta helskärm @@ -6735,7 +6737,7 @@ Nedladdningsstorlek: %3 Clear - + Töm @@ -6743,47 +6745,47 @@ Nedladdningsstorlek: %3 %1 byte - + %1 byte %1 kiB - + %1 kiB %1 MiB - + %1 MiB GBA - + GBA GB - + GB ? - + ? Super (L) - + Super (L) Super (R) - + Super (R) Menu - + Menu @@ -6791,22 +6793,22 @@ Nedladdningsstorlek: %3 Shift - + Skift Control - + Control Alt - + Alt Meta - + Meta From 082dd755916790cd207b7b03cec98799b9866638 Mon Sep 17 00:00:00 2001 From: Roll8ack Date: Mon, 9 Dec 2024 06:33:52 +0000 Subject: [PATCH 308/338] Qt: Update translation (Chinese (Simplified Han script)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/zh_Hans/ --- src/platform/qt/ts/mgba-zh_CN.ts | 42 ++++++++++++++++---------------- 1 file changed, 21 insertions(+), 21 deletions(-) diff --git a/src/platform/qt/ts/mgba-zh_CN.ts b/src/platform/qt/ts/mgba-zh_CN.ts index 0a0dfef755b..be19fdd1444 100644 --- a/src/platform/qt/ts/mgba-zh_CN.ts +++ b/src/platform/qt/ts/mgba-zh_CN.ts @@ -482,7 +482,7 @@ Download size: %3 Failed to create an OpenGL 3 context, trying old-style... - + 创建OpenGL3环境失败,请å°è¯•æ—§å½¢å¼... @@ -1058,7 +1058,7 @@ Download size: %3 MBC7 (Tilt) - + MBC7 (Tilt) @@ -2714,7 +2714,7 @@ Download size: %3 Transfer active - ä¼ è¾“å¤„äºŽæ´»åŠ¨çŠ¶æ€ + ä¼ è¾“å¤„äºŽæ´»è·ƒçŠ¶æ€ @@ -3408,63 +3408,63 @@ Download size: %3 Memory access logging - + 内存访问日志 Log file - + 日志文件 Browse - æµè§ˆ + æµè§ˆ Log additional information (uses 3× space) - + 记录é¢å¤–ä¿¡æ¯ï¼ˆä½¿ç”¨ 3x 空间) Load existing file if present - + 存在的情况下载入已有文件 Regions - + 区域 Export ROM snapshot - + 导出ROMå¿«ç…§ Start - + å¯åŠ¨ Stop - åœæ­¢ + åœæ­¢ Failed to open memory log file - + 打开内存日志文件失败 Select access log file - + 选择访问日志文件 Memory access logs (*.mal) - + 内存访问日志(*.mal) @@ -4372,12 +4372,12 @@ Download size: %3 Maker Code: - + 创建者代ç ï¼š Revision: - + 修订: @@ -4559,7 +4559,7 @@ Download size: %3 + RTC - + + RTC @@ -4660,7 +4660,7 @@ Download size: %3 &Load most recent - + 载入最近的(&L) @@ -6480,7 +6480,7 @@ Download size: %3 &Lock frame size - + é”定帧大å°(&L) @@ -6655,7 +6655,7 @@ Download size: %3 Log memory &accesses... - + 记录内存访问(&a)... From 0df20d2da5f520d42e40f44cbe389fcc98add75e Mon Sep 17 00:00:00 2001 From: Momo cao Date: Mon, 9 Dec 2024 03:26:08 +0000 Subject: [PATCH 309/338] Qt: Update translation (Spanish (Latin America)) Translation: mGBA/Qt Translate-URL: https://hosted.weblate.org/projects/mgba/mgba-qt/es_419/ --- src/platform/qt/ts/mgba-es_419.ts | 96 +++++++++++++++---------------- 1 file changed, 48 insertions(+), 48 deletions(-) diff --git a/src/platform/qt/ts/mgba-es_419.ts b/src/platform/qt/ts/mgba-es_419.ts index cc40f84f70d..9311b210d6e 100644 --- a/src/platform/qt/ts/mgba-es_419.ts +++ b/src/platform/qt/ts/mgba-es_419.ts @@ -6,12 +6,12 @@ Game Boy Advance ROMs (%1) - ROMs para Game Boy Advance (%1) + ROMs de Game Boy Advance (%1) Game Boy ROMs (%1) - ROMs para Game Boy Advance (%1) + ROMs de Game Boy (%1) @@ -78,7 +78,7 @@ Game Boy Advance es una marca registrada de Nintendo Co., Ltd. Do you want to download and install it now? You will need to restart the emulator when the download is complete. -¿Quieres descargarlo e instalarlo ahora? Deberás reiniciar el emulador cuando se complete la descarga. +¿Quieres descargarla e instalarla ahora? Deberás reiniciar el emulador cuando se complete la descarga. @@ -109,7 +109,7 @@ Tamaño de descarga: %3 Downloading done. Press OK to restart %1 and install the update. - Descarga finalizada. Presiona OK para reiniciar %1 e instalar la actualización. + Descarga finalizada. Presiona Aceptar para reiniciar %1 e instalar la actualización. @@ -140,7 +140,7 @@ Tamaño de descarga: %3 Open in archive... - Abrir desde archivo comprimido... + Abrir archivo comprimido... @@ -272,7 +272,7 @@ Tamaño de descarga: %3 Chip ID - ID de chip + Identificador del chip @@ -466,7 +466,7 @@ Tamaño de descarga: %3 Break - Entrar a depuración + Interrumpir @@ -482,7 +482,7 @@ Tamaño de descarga: %3 Failed to create an OpenGL 3 context, trying old-style... - + Fallo al crear contexto OpenGL, intentando estilo antiguo… @@ -495,7 +495,7 @@ Tamaño de descarga: %3 Local computer - Ordenador local + Equipo local @@ -1615,7 +1615,7 @@ Tamaño de descarga: %3 Backdrop target 1 - Backdrop target 1 + Objetivo del cuadro 1 @@ -1670,7 +1670,7 @@ Tamaño de descarga: %3 Backdrop target 2 - Backdrop target 2 + Objetivo del cuadro 2 @@ -2568,7 +2568,7 @@ Tamaño de descarga: %3 SRAM wait - SRAM wait + Espera SRAM @@ -2664,7 +2664,7 @@ Tamaño de descarga: %3 Gamepak prefetch - Gamepak prefetch + Precargar Gamepak @@ -2778,7 +2778,7 @@ Tamaño de descarga: %3 Enable sprites - Habilitar sprites + Activar sprites @@ -2788,7 +2788,7 @@ Tamaño de descarga: %3 Background tile map - Mapa de tesela de fondo + Fondo de tile map @@ -3176,12 +3176,12 @@ Tamaño de descarga: %3 Debug - Depuración (Debug) + Depuración Stub - Stub + Borrador @@ -3252,12 +3252,12 @@ Tamaño de descarga: %3 Debug - Debug + Depuración Stub - Stub + Borrador @@ -3267,7 +3267,7 @@ Tamaño de descarga: %3 Warning - Warning + Advertencia @@ -3408,63 +3408,63 @@ Tamaño de descarga: %3 Memory access logging - + Registro de acceso a la memoria Log file - + Archivo de registro Browse - + Explorar Log additional information (uses 3× space) - + Registrar información adicional (usa x3 más espacio) Load existing file if present - + Cargar archivo existente si está presente Regions - + Regiones Export ROM snapshot - + Exportar captura de la ROM Start - + Comenzar Stop - Detener + Detener Failed to open memory log file - + Error al abrir el archivo de registro de memoria Select access log file - + Seleccionar archivo de registro de acceso Memory access logs (*.mal) - + Archivos de registro de memoria (*.mal) @@ -4020,7 +4020,7 @@ Tamaño de descarga: %3 Game Overrides - Ajustes específicos por juego + Ajustes de juego @@ -4113,7 +4113,7 @@ Tamaño de descarga: %3 VBA bug compatibility mode - Compatibilidad con bugs de VBA + Compatibilidad con errores de VBA @@ -4372,12 +4372,12 @@ Tamaño de descarga: %3 Maker Code: - + Código de fabricante: Revision: - + Revisión: @@ -4400,7 +4400,7 @@ Tamaño de descarga: %3 Bug report archive - Archivo del informe de errores + Archivo del reporte de errores @@ -4410,17 +4410,17 @@ Tamaño de descarga: %3 Generate Bug Report - Generar informe de error + Generar reporte de error <html><head/><body><p>To file a bug report, please first generate a report file to attach to the bug report you're about to file. It is recommended that you include the save files, as these often help with debugging issues. This will collect some information about the version of {projectName} you're running, your configuration, your computer, and the game you currently have open (if any). Once this collection is completed you can review all of the information gathered below and save it to a zip file. The collection will automatically attempt to redact any personal information, such as your username if it's in any of the paths gathered, but just in case you can edit it afterwards. After you have generated and saved it, please click the button below or go to <a href="https://mgba.io/i/"><span style=" text-decoration: underline; color:#2980b9;">mgba.io/i</span></a> to file the bug report on GitHub. Make sure to attach the report you generated!</p></body></html> - <html><head/><body><p>Antes de enviar un informe de errores, por favor primero genera un archivo de reporte para enviarlo como adjunto. Recomendamos adjuntar los archivos de guardado ya que puede ayudar con la investigación de reportes. Esto recopilará información sobre la versión de {projectName} que estás ejecutando y su configuración, tu ordenador, y el juego que tienes abierto (si hay alguno). Cuando esto termine, puedes ver toda la información y guardarla en un archivo ZIP. Este proceso intentará eliminar automáticamente tus datos personales (como tu usuario, si se encuentra en algunas de las rutas de directorio generadas), pero siempre se puede modificiar luego. Tras generar y guardar el reporte, pulsa el botón inferior o visita <a href="https://mgba.io/i/"><span style=" text-decoration: underline; color:#2980b9;">mgba.io/i</span></a> para subirlo a GitHub. ¡Asegúrate de adjuntar el informe que has generado!</p></body></html> + <html><head/><body><p>Antes de enviar un reporte de errores, por favor primero genera el archivo de reporte para enviarlo como adjunto. Recomendamos adjuntar los archivos de guardado ya que pueden ayudar con la investigación del error. Esto recopilará información sobre la versión de {projectName} que estás ejecutando y su configuración, tu equipo, y el juego que tienes abierto (si hay alguno). Cuando esto termine, podrás ver el reporte y guardarlo en un archivo comprimido (ZIP). Este proceso intentará eliminar automáticamente tus datos personales (por ejemplo, tu usuario, si se encuentra en algunas de las rutas de archivo), pero siempre podrás editarlo manualmente antes de enviarlo. Tras generar y guardar el reporte, pulsa el botón inferior o visita <a href="https://mgba.io/i/"><span style=" text-decoration: underline; color:#2980b9;">mgba.io/i</span></a> para crear un reporte de error en GitHub. ¡Asegúrate de adjuntar tu archivo!</p></body></html> Generate report - Generar informe + Generar reporte @@ -4430,7 +4430,7 @@ Tamaño de descarga: %3 Open issue list in browser - Abrir lista de informes en navegador + Abrir reporte de errores en el navegador @@ -4660,7 +4660,7 @@ Tamaño de descarga: %3 &Load most recent - + &Cargar más reciente @@ -5986,7 +5986,7 @@ Tamaño de descarga: %3 Select e-Reader dotcode - Seleccionar dotcode del e-Reader + Seleccionar código del e-Reader @@ -6271,12 +6271,12 @@ Tamaño de descarga: %3 Undo load state - Deshacer cargar estado + Deshacer estado cargado Undo save state - Deshacer guardar estado + Deshacer estado guardado @@ -6452,7 +6452,7 @@ Tamaño de descarga: %3 &Lock frame size - + &Bloquear tamaño de cuadro @@ -6567,7 +6567,7 @@ Tamaño de descarga: %3 Scan e-Reader dotcodes... - Escanear dotcodes del e-Reader... + Escanear código del e-Reader... @@ -6662,7 +6662,7 @@ Tamaño de descarga: %3 Log memory &accesses... - + Registrar &accesoa la memoria… From c2741c73db067192da63db3b6436a24288b30f22 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 12 Dec 2024 03:59:21 -0800 Subject: [PATCH 310/338] Qt: Rename LatAm Spanish to just "Spanish" --- src/platform/qt/ts/{mgba-es_419.ts => mgba-es.ts} | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename src/platform/qt/ts/{mgba-es_419.ts => mgba-es.ts} (99%) diff --git a/src/platform/qt/ts/mgba-es_419.ts b/src/platform/qt/ts/mgba-es.ts similarity index 99% rename from src/platform/qt/ts/mgba-es_419.ts rename to src/platform/qt/ts/mgba-es.ts index 9311b210d6e..57defd38aed 100644 --- a/src/platform/qt/ts/mgba-es_419.ts +++ b/src/platform/qt/ts/mgba-es.ts @@ -1,6 +1,6 @@ - + QGBA From 0ca391cffc584005486af609fcf4e5b6b3793777 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 12 Dec 2024 04:02:56 -0800 Subject: [PATCH 311/338] Qt: Fix up how the language names get displayed --- src/platform/qt/SettingsView.cpp | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/src/platform/qt/SettingsView.cpp b/src/platform/qt/SettingsView.cpp index a7be4026935..a72bf0d7bb8 100644 --- a/src/platform/qt/SettingsView.cpp +++ b/src/platform/qt/SettingsView.cpp @@ -357,7 +357,7 @@ SettingsView::SettingsView(ConfigController* controller, InputController* inputC }); QLocale englishLocale("en"); - m_ui.languages->addItem(englishLocale.nativeLanguageName(), englishLocale); + m_ui.languages->addItem("English", englishLocale); QDir ts(":/translations/"); for (auto& name : ts.entryList()) { if (!name.endsWith(".qm") || !name.startsWith(binaryName)) { @@ -367,7 +367,17 @@ SettingsView::SettingsView(ConfigController* controller, InputController* inputC if (locale.language() == QLocale::English) { continue; } - m_ui.languages->addItem(locale.nativeLanguageName(), locale); + QString endonym = locale.nativeLanguageName(); + // Manualy handle some cases that Qt can't seem to do properly + if (locale.language() == QLocale::Spanish) { + // Qt insists this is called español de España, regardless of if we set the country + endonym = u8"Español"; + } else if (locale.language() == QLocale::Portuguese && locale.country() == QLocale::Brazil) { + // Qt insists that Brazilian Portuguese is just called Português + endonym = u8"Português brasileiro"; + } + endonym[0] = endonym[0].toUpper(); + m_ui.languages->addItem(endonym, locale); if (locale.bcp47Name() == QLocale().bcp47Name()) { m_ui.languages->setCurrentIndex(m_ui.languages->count() - 1); } From 34e1ef45b65acb1593420c639ec5589245d3fe9b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 12 Dec 2024 04:04:51 -0800 Subject: [PATCH 312/338] Qt: Update translations --- src/platform/qt/ts/mgba-de.ts | 451 +- src/platform/qt/ts/mgba-en.ts | 451 +- src/platform/qt/ts/mgba-es.ts | 451 +- src/platform/qt/ts/mgba-fr.ts | 451 +- src/platform/qt/ts/mgba-hu.ts | 451 +- src/platform/qt/ts/mgba-it.ts | 451 +- src/platform/qt/ts/mgba-ja.ts | 451 +- src/platform/qt/ts/mgba-ko.ts | 451 +- src/platform/qt/ts/mgba-ms.ts | 451 +- src/platform/qt/ts/mgba-nb_NO.ts | 451 +- src/platform/qt/ts/mgba-pl.ts | 451 +- src/platform/qt/ts/mgba-pt_BR.ts | 451 +- src/platform/qt/ts/mgba-pt_PT.ts | 451 +- src/platform/qt/ts/mgba-ru.ts | 451 +- src/platform/qt/ts/mgba-sv.ts | 455 +- src/platform/qt/ts/mgba-template.ts | 451 +- src/platform/qt/ts/mgba-tr.ts | 451 +- src/platform/qt/ts/mgba-zh_CN.ts | 451 +- src/platform/qt/ts/mgba-zh_Hant.ts | 8371 +++++++++++++++------------ 19 files changed, 9027 insertions(+), 7466 deletions(-) diff --git a/src/platform/qt/ts/mgba-de.ts b/src/platform/qt/ts/mgba-de.ts index 4e65105da42..b430e275823 100644 --- a/src/platform/qt/ts/mgba-de.ts +++ b/src/platform/qt/ts/mgba-de.ts @@ -480,7 +480,7 @@ Download-Größe: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3015,7 +3015,7 @@ Download-Größe: %3 QGBA::KeyEditor - + --- --- @@ -3822,17 +3822,27 @@ Download-Größe: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached Versuch Multiplayer-Spieler zu trennen der nicht verbunden ist - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached Versuch Spieler-ID festzustellen von einem Multiplayer-Spieler der nicht verbunden ist - + Trying to get save ID for a multiplayer player that's not attached Versuch Speicherstand-ID festzustellen von einem Multiplayer-Spieler der nicht verbunden ist @@ -4331,21 +4341,21 @@ Download-Größe: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (unbekannt) - + bytes Bytes - + (no database present) (keine Datenbank vorhanden) @@ -4355,42 +4365,57 @@ Download-Größe: %3 ROM-Info - + + File information + + + + Game name: Spielname: - + + MD5 + + + + + ROM header + + + + Internal name: Interner Name: - + Game ID: Spiele-ID: - + Maker Code: - + Revision: - + File size: Dateigröße: - + CRC32: CRC32: - + Save file: Speicherstand: @@ -4823,58 +4848,67 @@ Download-Größe: %3 Gamepads - + Shortcuts Tastenkürzel - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Shader - + Select BIOS BIOS auswählen - + Select directory Verzeichnis auswählen - + Select image Bild auswählen - + Image file (*.png *.jpg *.jpeg) Bilddatei (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Nie - + Just now Gerade eben - + Less than an hour ago Vor weniger als einer Stunde - + %n hour(s) ago Vor %n Stunde @@ -4882,7 +4916,7 @@ Download-Größe: %3 - + %n day(s) ago Vor %n Tag @@ -5619,33 +5653,48 @@ Download-Größe: %3 QGBA::ShaderSelector - + No shader active Kein Shader aktiv - - + + Load shader Shader laden - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded Kein Shader geladen - + by %1 von %1 - + Preprocessing Vorbehandlung - + Pass %1 Durchlauf %1 @@ -5951,85 +6000,85 @@ Download-Größe: %3 QGBA::Window - + Archives (%1) Archive (%1) - - - + + + Select ROM ROM auswählen - - + + Select save Speicherdatei wählen - + Select patch Patch wählen - + Patches (*.ips *.ups *.bps) Korrekturen (*.ips *.ups *.bps) - + Select e-Reader card images Bilder der Lesegerät-Karte auswählen - + Image file (*.png *.jpg *.jpeg) Bilddatei (*.png *.jpg *.jpeg) - + Conversion finished Konvertierung abgeschlossen - + %1 of %2 e-Reader cards converted successfully. %1 von %2 Lesegerät-Karten erfolgreich konvertiert. - + Select image Bild auswählen - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Bild-Datei (*.png *.gif *.jpg *.jpeg);;Alle Dateien (*) - + GameShark saves (*.sps *.xps) GameShark-Speicherdaten (*.sps *.xps) - + Select video log Video-Log auswählen - + Video logs (*.mvl) Video-Logs (*.mvl) - + Crash Absturz - + The game has crashed with the following error: %1 @@ -6038,704 +6087,704 @@ Download-Größe: %3 %1 - + Unimplemented BIOS call Nicht implementierter BIOS-Aufruf - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Dieses Spiel verwendet einen BIOS-Aufruf, der nicht implementiert ist. Bitte verwenden Sie für die beste Spielerfahrung das offizielle BIOS. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Es konnte kein geeignetes Ausgabegerät erstellt werden, stattdessen wird Software-Rendering als Rückfalloption genutzt. Spiele laufen möglicherweise langsamer, besonders innerhalb großer Fenster. - + Really make portable? Portablen Modus wirklich aktivieren? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Diese Einstellung wird den Emulator so konfigurieren, dass er seine Konfiguration aus dem gleichen Verzeichnis wie die Programmdatei lädt. Möchten Sie fortfahren? - + Restart needed Neustart benötigt - + Some changes will not take effect until the emulator is restarted. Einige Änderungen werden erst übernommen, wenn der Emulator neu gestartet wurde. - + - Player %1 of %2 - Spieler %1 von %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 Bilder/Sekunde) - %4 - + &File &Datei - + Load &ROM... &ROM laden... - + Load ROM in archive... ROM aus Archiv laden... - + Save games Spielstände - + Automatically determine Automatisch erkennen - + Use player %0 save game Verwende Spielstand von Spieler %0 - + Load &patch... &Patch laden... - + Boot BIOS BIOS booten - + Replace ROM... ROM ersetzen... - + Convert e-Reader card image to raw... Lesegerät-Kartenbild in Rohdaten umwandeln â€¦ - + ROM &info... ROM-&Informationen... - + Recent Zuletzt verwendet - + Make portable Portablen Modus aktivieren - + &Load state Savestate (aktueller Zustand) &laden - + Load state file... Savestate-Datei laden... - + &Save state Savestate (aktueller Zustand) &speichern - + Save state file... Savestate-Datei speichern... - + Quick load Schnell laden - + Quick save Schnell speichern - + Load recent Lade zuletzt gespeicherten Savestate - + Save recent Speichere aktuellen Zustand - + Undo load state Laden des Savestate rückgängig machen - + Undo save state Speichern des Savestate rückgängig machen - - + + State &%1 Savestate &%1 - + Load camera image... Lade Kamerabild... - + Convert save game... Spielstand konvertieren... - + Reset needed Zurücksetzen erforderlich - + Some changes will not take effect until the game is reset. Einige Änderungen werden erst dann wirksam, wenn das Spiel zurückgesetzt wird. - + New multiplayer window Neues Multiplayer-Fenster - + Connect to Dolphin... Mit Dolphin verbinden... - + Report bug... Fehler melden... - + E&xit &Beenden - + &Emulation &Emulation - + &Reset Zu&rücksetzen - + Sh&utdown Schli&eßen - + Yank game pak Spielmodul herausziehen - + &Pause &Pause - + &Next frame &Nächstes Bild - + Fast forward (held) Schneller Vorlauf (gehalten) - + &Fast forward Schneller &Vorlauf - + Fast forward speed Vorlauf-Geschwindigkeit - + Unbounded Unbegrenzt - + %0x %0x - + Increase fast forward speed Vorspulgeschwindigkeit erhöhen - + Decrease fast forward speed Vorspulgeschwindigkeit senken - + Rewind (held) Zurückspulen (gehalten) - + Re&wind Zur&ückspulen - + Step backwards Schrittweiser Rücklauf - + Solar sensor Sonnen-Sensor - + Increase solar level Sonnen-Level erhöhen - + Decrease solar level Sonnen-Level verringern - + Brightest solar level Hellster Sonnen-Level - + Darkest solar level Dunkelster Sonnen-Level - + Brightness %1 Helligkeit %1 - + BattleChip Gate... BattleChip Gate... - + Audio/&Video Audio/&Video - + Frame size Bildgröße - + Toggle fullscreen Vollbildmodus umschalten - + &Lock frame size - + Lock aspect ratio Seitenverhältnis korrigieren - + Force integer scaling Pixelgenaue Skalierung (Integer scaling) - + Interframe blending Interframe-Ãœberblendung - + Frame&skip Frame&skip - + Mute Stummschalten - + FPS target Bildwiederholrate - + Take &screenshot &Screenshot erstellen - + F12 F12 - + Scripting... Scripting... - + Create forwarder... Forwarder erzeugen... - + Game state views Spiel-Zustände ansehen - + Log memory &accesses... - + Clear Leeren - + Game Boy Printer... Game Boy Printer... - + Video layers Video-Ebenen - + Audio channels Audio-Kanäle - + Adjust layer placement... Lage der Bildebenen anpassen... - + &Tools &Werkzeuge - + View &logs... &Logs ansehen... - + Game &overrides... Spiel-&Ãœberschreibungen... - + &Cheats... &Cheats... - + Open debugger console... Debugger-Konsole öffnen... - + Start &GDB server... &GDB-Server starten... - + Settings... Einstellungen... - + Select folder Ordner auswählen - + Save games (%1) Spielstände (%1) - + Select save game Spielstand auswählen - + mGBA save state files (%1) mGBA-Savestates (%1) - - + + Select save state Savestate auswählen - + Select e-Reader dotcode e-Reader-Code auswählen - + e-Reader card (*.raw *.bin *.bmp) e-Reader-Karte (*.raw *.bin *.bmp) - + GameShark saves (*.gsv *.sps *.xps) GameShark-Spielstände (*.gsv *.sps *.xps) - + Couldn't Start Konnte nicht gestartet werden - + Could not start game. Spiel konnte nicht gestartet werden. - + Add folder to library... Ordner zur Bibliothek hinzufügen... - + Load alternate save game... Alternativen Spielstand laden... - + Load temporary save game... Temporären Spielstand laden... - + Scan e-Reader dotcodes... e-Reader-Code einlesen... - + Import GameShark Save... GameShare-Speicherstand importieren... - + Export GameShark Save... GameShark-Speicherstand exportieren... - + About... Ãœber... - + %1× %1x - + Bilinear filtering Bilineare Filterung - + Native (59.7275) Nativ (59.7275) - + Record A/V... Audio/Video aufzeichnen... - + Record GIF/WebP/APNG... GIF/WebP/APNG aufzeichnen... - + Game Pak sensors... Spielmodul-Sensoren... - + View &palette... &Palette betrachten... - + View &sprites... &Sprites betrachten... - + View &tiles... &Tiles betrachten... - + View &map... &Map betrachten... - + &Frame inspector... &Bildbetrachter... - + View memory... Speicher betrachten... - + Search memory... Speicher durchsuchen... - + View &I/O registers... &I/O-Register betrachten... - + Record debug video log... Video-Protokoll aufzeichnen... - + Stop debug video log Aufzeichnen des Video-Protokolls beenden - + Exit fullscreen Vollbildmodus beenden - + GameShark Button (held) GameShark-Taste (gehalten) - + Autofire Autofeuer - + Autofire A Autofeuer A - + Autofire B Autofeuer B - + Autofire L Autofeuer L - + Autofire R Autofeuer R - + Autofire Start Autofeuer Start - + Autofire Select Autofeuer Select - + Autofire Up Autofeuer nach oben - + Autofire Right Autofeuer rechts - + Autofire Down Autofeuer nach unten - + Autofire Left Autofeuer links diff --git a/src/platform/qt/ts/mgba-en.ts b/src/platform/qt/ts/mgba-en.ts index cdb0f81b4c7..316c5d2c397 100644 --- a/src/platform/qt/ts/mgba-en.ts +++ b/src/platform/qt/ts/mgba-en.ts @@ -474,7 +474,7 @@ Download size: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3009,7 +3009,7 @@ Download size: %3 QGBA::KeyEditor - + --- @@ -3816,17 +3816,27 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4325,21 +4335,21 @@ Download size: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) - + bytes - + (no database present) @@ -4349,42 +4359,57 @@ Download size: %3 - + + File information + + + + Game name: - + + MD5 + + + + + ROM header + + + + Internal name: - + Game ID: - + Maker Code: - + Revision: - + File size: - + CRC32: - + Save file: @@ -4817,58 +4842,67 @@ Download size: %3 - + Shortcuts - - - Shaders + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + Shaders + + + + Select BIOS - + Select directory - + Select image - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago @@ -4876,7 +4910,7 @@ Download size: %3 - + %n day(s) ago @@ -5613,33 +5647,48 @@ Download size: %3 QGBA::ShaderSelector - + No shader active - - + + Load shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded - + by %1 - + Preprocessing - + Pass %1 @@ -5945,789 +5994,789 @@ Download size: %3 QGBA::Window - + Archives (%1) - - - + + + Select ROM - + Select folder - - + + Select save - + Select patch - + Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) - + Select image - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) - + Select video log - + Video logs (*.mvl) - + Crash - + The game has crashed with the following error: %1 - + Couldn't Start - + Could not start game. - + Unimplemented BIOS call - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + Really make portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + Restart needed - + Some changes will not take effect until the emulator is restarted. - + - Player %1 of %2 - + %1 - %2 - + %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File - + Load &ROM... - + Load ROM in archive... - + Add folder to library... - + Save games (%1) - + Select save game - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Load &patch... - + Boot BIOS - + Replace ROM... - + Scan e-Reader dotcodes... - + Convert e-Reader card image to raw... - + ROM &info... - + Recent - + Make portable - + &Load state - + Load state file... - + &Save state - + Save state file... - + Quick load - + Quick save - + Load recent - + Save recent - + Undo load state - + Undo save state - - + + State &%1 - + Load camera image... - + Convert save game... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games - + Import GameShark Save... - + Export GameShark Save... - + Automatically determine - + Use player %0 save game - + New multiplayer window - + Connect to Dolphin... - + Report bug... - + About... - + E&xit - + &Emulation - + &Reset - + Sh&utdown - + Yank game pak - + &Pause - + &Next frame - + Fast forward (held) - + &Fast forward - + Fast forward speed - + Unbounded - + %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) - + Re&wind - + Step backwards - + Solar sensor - + Increase solar level - + Decrease solar level - + Brightest solar level - + Darkest solar level - + Brightness %1 - + Game Boy Printer... - + BattleChip Gate... - + Audio/&Video - + Frame size - + %1× - + Toggle fullscreen - + &Lock frame size - + Lock aspect ratio - + Force integer scaling - + Interframe blending - + Bilinear filtering - + Frame&skip - + Mute - + FPS target - + Native (59.7275) - + Take &screenshot - + F12 - + Record A/V... - + Record GIF/WebP/APNG... - + Video layers - + Audio channels - + Adjust layer placement... - + &Tools - + View &logs... - + Game &overrides... - + Game Pak sensors... - + &Cheats... - + Create forwarder... - + Settings... - + Open debugger console... - + Start &GDB server... - + Scripting... - + Game state views - + View &palette... - + View &sprites... - + View &tiles... - + View &map... - + &Frame inspector... - + View memory... - + Search memory... - + View &I/O registers... - + Log memory &accesses... - + Record debug video log... - + Stop debug video log - + Exit fullscreen - + GameShark Button (held) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear diff --git a/src/platform/qt/ts/mgba-es.ts b/src/platform/qt/ts/mgba-es.ts index 57defd38aed..65223278e14 100644 --- a/src/platform/qt/ts/mgba-es.ts +++ b/src/platform/qt/ts/mgba-es.ts @@ -480,7 +480,7 @@ Tamaño de descarga: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... Fallo al crear contexto OpenGL, intentando estilo antiguo… @@ -3015,7 +3015,7 @@ Tamaño de descarga: %3 QGBA::KeyEditor - + --- --- @@ -3822,17 +3822,27 @@ Tamaño de descarga: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached Intentando desvincular a un multijugador que no está conectado - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached Intentando obtener el ID de un multijugador que no está conectado - + Trying to get save ID for a multiplayer player that's not attached Intentando obtener ID de guardado para un jugador multijugador que no está conectado @@ -4331,21 +4341,21 @@ Tamaño de descarga: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (desconocido) - + bytes bytes - + (no database present) (no hay base de datos) @@ -4355,42 +4365,57 @@ Tamaño de descarga: %3 Información de la ROM - + + File information + + + + Game name: Nombre del juego: - + + MD5 + + + + + ROM header + + + + Internal name: Nombre interno: - + Game ID: Id. de juego: - + Maker Code: Código de fabricante: - + Revision: Revisión: - + File size: Tamaño del archivo: - + CRC32: CRC32: - + Save file: Guardar: @@ -4823,58 +4848,67 @@ Tamaño de descarga: %3 Mandos - + Shortcuts Atajos de teclado - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Shaders - + Select BIOS Seleccionar BIOS - + Select directory Elegir carpeta - + Select image Seleccionar imagen - + Image file (*.png *.jpg *.jpeg) Archivo de imagen (*.png *.jpg *.jpeg) - + (%1×%2) - + Never Nunca - + Just now Ahora mismo - + Less than an hour ago Hace menos de una hora - + %n hour(s) ago Hace %n hora @@ -4882,7 +4916,7 @@ Tamaño de descarga: %3 - + %n day(s) ago Hace %n día @@ -5619,33 +5653,48 @@ Tamaño de descarga: %3 QGBA::ShaderSelector - + No shader active No hay shader activo - - + + Load shader Cargar shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded No hay shader cargado - + by %1 por %1 - + Preprocessing Preproceso - + Pass %1 Paso %1 @@ -5951,80 +6000,80 @@ Tamaño de descarga: %3 QGBA::Window - + Archives (%1) Contenedores (%1) - - - + + + Select ROM Seleccionar ROM - + Select folder Seleccionar carpeta - - + + Select save Seleccionar guardado - + Select patch Seleccionar parche - + Patches (*.ips *.ups *.bps) Parches (*.ips *.ups *.bps) - + Select e-Reader dotcode Seleccionar código del e-Reader - + e-Reader card (*.raw *.bin *.bmp) Tarjeta e-Reader (*.raw *.bin *.bmp) - + Select image Seleccionar imagen - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Archivo de imagen (*.png *.gif *.jpg *.jpeg);;Todos los archivos (*) - + GameShark saves (*.sps *.xps) Guardados de GameShark (*.sps *.xps) - + Select video log Seleccionar registro de vídeo - + Video logs (*.mvl) Registros de vídeo (*.mvl) - + Crash Cierre inesperado - + The game has crashed with the following error: %1 @@ -6033,709 +6082,709 @@ Tamaño de descarga: %3 %1 - + Unimplemented BIOS call Llamada a BIOS no implementada - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Este juego utiliza una llamada al BIOS que no se ha implementado. Utiliza el BIOS oficial para obtener la mejor experiencia. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. No se pudo crear un dispositivo de pantalla apropiado, recurriendo a software. Los juegos pueden funcionar lentamente, especialmente con ventanas grandes. - + Really make portable? ¿Hacer "portable"? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Esto hará que el emulador cargue su configuración desde el mismo directorio que el ejecutable. ¿Quieres continuar? - + Restart needed Reinicio necesario - + Some changes will not take effect until the emulator is restarted. Algunos cambios no surtirán efecto hasta que se reinicie el emulador. - + - Player %1 of %2 - Jugador %1 de %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &Archivo - + Load &ROM... Cargar &ROM... - + Load ROM in archive... Cargar ROM desde archivo comprimido... - + Add folder to library... Agregar carpeta a la biblioteca... - + Save games Datos de guardado - + Automatically determine Determinar automáticamente - + Use player %0 save game Usar la partida guardada del jugador %0 - + Load &patch... Cargar &parche... - + Boot BIOS Arrancar BIOS - + Replace ROM... Reemplazar ROM... - + ROM &info... &Información de la ROM... - + Recent Reciente - + Make portable Crear instalación portable - + &Load state Ca&rgar estado - + Report bug... Reportar error... - + About... Acerca de... - + Game Pak sensors... Sensores del cartucho... - + Clear Limpiar - + Load state file... Cargar archivo de estado... - + Save games (%1) Juegos guardados (%1) - + Select save game Elegir juego guardado - + mGBA save state files (%1) Archivos estados guardados mGBA (%1) - - + + Select save state Elegir estado guardado - + Select e-Reader card images Elegir imágenes de tarjeta e-Reader - + Image file (*.png *.jpg *.jpeg) Archivo de imagen (*.png *.jpg *.jpeg) - + Conversion finished Conversión terminada - + %1 of %2 e-Reader cards converted successfully. %1 de %2 tarjetas e-Reader convertidas con éxito. - + Load alternate save game... Cargar partida guardada alternativa... - + Load temporary save game... Cargar partida guardada temporal... - + Convert e-Reader card image to raw... Convertir imagen de tarjeta e-Reader a archivo en bruto... - + &Save state Guardar e&stado - + Save state file... Guardar archivo de estado... - + Quick load Cargado rápido - + Quick save Guardado rápido - + Load recent Cargar reciente - + Save recent Guardar reciente - + Undo load state Deshacer estado cargado - + Undo save state Deshacer estado guardado - - + + State &%1 Estado &%1 - + Load camera image... Cargar imagen para cámara... - + Convert save game... Convertir juego guardado... - + GameShark saves (*.gsv *.sps *.xps) Partidas guardadas de GameShark (*.gsv *.sps *.xps) - + Reset needed Reinicio necesario - + Some changes will not take effect until the game is reset. Algunos cambios no tendrán efecto hasta que se reinicie el juego. - + New multiplayer window Nueva ventana multijugador - + Connect to Dolphin... Conectar a Dolphin... - + E&xit Salir (&X) - + &Emulation &Emulación - + &Reset &Reiniciar - + Sh&utdown Apagar (&U) - + Yank game pak Sacar cartucho - + &Pause &Pausar - + &Next frame Cuadro siguie&nte - + Fast forward (held) Avance rápido (mantener) - + &Fast forward &Avance rápido - + Fast forward speed Velocidad de avance rápido - + Unbounded Sin límite - + %0x %0x - + Increase fast forward speed Aumentar la velocidad de avance rápido - + Decrease fast forward speed Disminuir velocidad de avance rápido - + Rewind (held) Rebobinar (mantener) - + Re&wind Re&bobinar - + Step backwards Paso hacia atrás - + Solar sensor Sensor solar - + Increase solar level Subir nivel - + Decrease solar level Bajar nivel - + Brightest solar level Más claro - + Darkest solar level Más oscuro - + Brightness %1 Brillo %1 - + Audio/&Video Audio/&vídeo - + Frame size Tamaño del cuadro - + Toggle fullscreen Pantalla completa - + &Lock frame size &Bloquear tamaño de cuadro - + Lock aspect ratio Bloquear proporción de aspecto - + Force integer scaling Forzar escala a enteros - + Bilinear filtering Filtro bilineal - + Frame&skip &Salto de cuadros - + Mute Silenciar - + FPS target Objetivo de FPS - + Native (59.7275) Nativo (59,7275) - + Take &screenshot Tomar pan&tallazo - + F12 F12 - + Game Boy Printer... Game Boy Printer... - + BattleChip Gate... BattleChip Gate... - + %1× %1× - + Interframe blending Mezcla entre cuadros - + Record A/V... Grabar A/V... - + Video layers Capas de vídeo - + Audio channels Canales de audio - + Adjust layer placement... Ajustar ubicación de capas... - + &Tools Herramien&tas - + View &logs... Ver re&gistros... - + Game &overrides... Ajustes específic&os por juego... - + Couldn't Start No se pudo iniciar - + Could not start game. No se pudo iniciar el juego. - + Scan e-Reader dotcodes... Escanear código del e-Reader... - + Import GameShark Save... Importar desde GameShark... - + Export GameShark Save... Exportar a GameShark... - + Record GIF/WebP/APNG... Grabar GIF/WebP/APNG... - + &Cheats... Tru&cos... - + Settings... Ajustes... - + Open debugger console... Abrir consola de depuración... - + Start &GDB server... Iniciar servidor &GDB... - + Scripting... Scripts... - + Create forwarder... Crear autocargador... - + Game state views Estado del juego - + View &palette... Ver &paleta... - + View &sprites... Ver &sprites... - + View &tiles... Ver m&osaicos... - + View &map... Ver &mapa... - + &Frame inspector... Inspec&tor de cuadros... - + View memory... Ver memoria... - + Search memory... Buscar memoria... - + View &I/O registers... Ver registros &I/O... - + Log memory &accesses... Registrar &accesoa la memoria… - + Record debug video log... Grabar registro de depuración de vídeo... - + Stop debug video log Detener registro de depuración de vídeo - + Exit fullscreen Salir de pantalla completa - + GameShark Button (held) Botón GameShark (mantener) - + Autofire Disparo automático - + Autofire A Disparo automático A - + Autofire B Disparo automático B - + Autofire L Disparo automático L - + Autofire R Disparo automático R - + Autofire Start Disparo automático Start - + Autofire Select Disparo automático Select - + Autofire Up Disparo automático arriba - + Autofire Right Disparo automático derecha - + Autofire Down Disparo automático abajo - + Autofire Left Disparo automático izquierda diff --git a/src/platform/qt/ts/mgba-fr.ts b/src/platform/qt/ts/mgba-fr.ts index 32db450141f..04411e5c3cb 100644 --- a/src/platform/qt/ts/mgba-fr.ts +++ b/src/platform/qt/ts/mgba-fr.ts @@ -481,7 +481,7 @@ Taille du téléchargement : %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3026,7 +3026,7 @@ Taille du téléchargement : %3 QGBA::KeyEditor - + --- --- @@ -3840,17 +3840,27 @@ Taille du téléchargement : %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4349,21 +4359,21 @@ Taille du téléchargement : %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (inconnu) - + bytes octets - + (no database present) (aucune base de donnée présente) @@ -4373,42 +4383,57 @@ Taille du téléchargement : %3 Informations sur la ROM - + + File information + + + + Game name: Nom du jeu : - + + MD5 + + + + + ROM header + + + + Internal name: Nom interne : - + Game ID: ID du jeu : - + Maker Code: - + Revision: - + File size: Taille du fichier : - + CRC32: CRC32 : - + Save file: @@ -4842,58 +4867,67 @@ Taille du téléchargement : %3 Contrôleurs - + Shortcuts Raccourcis - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Shaders - + Select BIOS Choisir le BIOS - + Select directory - + Select image Choisir une image - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago @@ -4901,7 +4935,7 @@ Taille du téléchargement : %3 - + %n day(s) ago @@ -5638,33 +5672,48 @@ Taille du téléchargement : %3 QGBA::ShaderSelector - + No shader active Aucun shader actif - - + + Load shader Charger un shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded Aucun shader chargé - + by %1 de %1 - + Preprocessing Pré-traitement - + Pass %1 Passe %1 @@ -5970,100 +6019,100 @@ Taille du téléchargement : %3 QGBA::Window - + Archives (%1) Archives (%1) - - - + + + Select ROM Choisir une ROM - + Select folder Choisir un dossier - - + + Select save Choisir une sauvegarde - + Select patch Sélectionner un correctif - + Patches (*.ips *.ups *.bps) Correctifs/Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode Sélectionnez le numéro de point du e-Reader - + e-Reader card (*.raw *.bin *.bmp) e-Reader carte (*.raw *.bin *.bmp) - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Select image Choisir une image - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Image (*.png *.gif *.jpg *.jpeg);;Tous les fichiers (*) - + GameShark saves (*.sps *.xps) Sauvegardes GameShark (*.sps *.xps) - + Select video log Sélectionner un journal vidéo - + Video logs (*.mvl) Journaux vidéo (*.mvl) - + Crash Plantage - + The game has crashed with the following error: %1 @@ -6072,689 +6121,689 @@ Taille du téléchargement : %3 %1 - + Unimplemented BIOS call Requête au BIOS non supporté - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Ce jeu utilise un appel BIOS qui n'est pas implémenté. Veuillez utiliser le BIOS officiel pour une meilleure expérience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Échec de la création d'un périphérique d'affichage approprié, retour à l'affichage du logiciel. Les jeux peuvent fonctionner lentement, en particulier avec des fenêtres plus grandes. - + Really make portable? Vraiment rendre portable ? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Cela amènera l'émulateur à charger sa configuration depuis le même répertoire que l'exécutable. Souhaitez vous continuer ? - + Restart needed Un redémarrage est nécessaire - + Some changes will not take effect until the emulator is restarted. Certains changements ne prendront effet qu'après le redémarrage de l'émulateur. - + - Player %1 of %2 - Joueur %1 of %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &Fichier - + Load &ROM... Charger une &ROM… - + Load ROM in archive... Charger la ROM d'une archive… - + Add folder to library... Ajouter un dossier à la bibliothèque… - + Load &patch... Charger un c&orrectif… - + Boot BIOS Démarrer le BIOS - + Replace ROM... Remplacer la ROM… - + Increase fast forward speed - + Decrease fast forward speed - + &Lock frame size - + Create forwarder... - + Game state views - + Log memory &accesses... - + Convert e-Reader card image to raw... - + ROM &info... &Infos sur la ROM… - + Recent Récent - + Make portable Rendre portable - + &Load state &Charger un état - + &Save state &Sauvegarder un état - + Quick load Chargement rapide - + Quick save Sauvegarde rapide - + Load recent Charger un fichier récent - + Save recent Sauvegarder un fichier récent - + Undo load state Annuler le chargement de l'état - + Undo save state Annuler la sauvegarde de l'état - - + + State &%1 État &%1 - + Load camera image... Charger une image de la caméra… - + Convert save game... - + New multiplayer window Nouvelle fenêtre multijoueur - + Connect to Dolphin... - + Report bug... Signalement de l'erreur… - + E&xit &Quitter - + &Emulation &Émulation - + &Reset &Réinitialiser - + Sh&utdown Extin&ction - + Yank game pak Yank game pak - + &Pause &Pause - + &Next frame &Image suivante - + Fast forward (held) Avance rapide (maintenir) - + &Fast forward A&vance rapide - + Fast forward speed Vitesse de l'avance rapide - + Unbounded Sans limites - + %0x %0x - + Rewind (held) Rembobiner (maintenir) - + Re&wind Rem&bobiner - + Step backwards Retour en arrière - + Solar sensor Capteur solaire - + Increase solar level Augmenter le niveau solaire - + Decrease solar level Diminuer le niveau solaire - + Brightest solar level Tester le niveau solaire - + Darkest solar level Assombrir le niveau solaire - + Brightness %1 Luminosité %1 - + Audio/&Video Audio/&Vidéo - + Frame size Taille de l'image - + Toggle fullscreen Basculer en plein écran - + Lock aspect ratio Bloquer les proportions - + Force integer scaling Forcer la mise à l'échelle par des nombres entiers - + Bilinear filtering Filtrage bilinèaire - + Frame&skip &Saut d'image - + Mute Muet - + FPS target FPS ciblé - + Take &screenshot Prendre une ca&pture d'écran - + F12 F12 - + Game Boy Printer... Imprimante GameBoy… - + Video layers Couches vidéo - + Audio channels Canaux audio - + Adjust layer placement... Ajuster la disposition… - + &Tools Ou&tils - + View &logs... Voir les &journaux… - + Game &overrides... - + Couldn't Start N'a pas pu démarrer - + Save games (%1) - + Select save game - + mGBA save state files (%1) - - + + Select save state - + GameShark saves (*.gsv *.sps *.xps) - + Could not start game. Impossible de démarrer le jeu. - + Load alternate save game... - + Load temporary save game... - + Scan e-Reader dotcodes... Scanner les dotcodes e-Reader... - + Load state file... Charger le fichier d'état... - + Save state file... Enregistrer le fichier d'état... - + Import GameShark Save... Importer la sauvegarde de GameShark... - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games Sauvegarder les jeux - + Export GameShark Save... Exporter la sauvegarde de GameShark... - + Automatically determine - + Use player %0 save game - + About... À propos de… - + BattleChip Gate... - + %1× %1× - + Interframe blending Mélange d'images - + Native (59.7275) Natif (59.7275) - + Record A/V... Enregistrer A/V... - + Record GIF/WebP/APNG... Enregistrer GIF/WebP/APNG... - + Game Pak sensors... Capteurs de la Game Pak... - + &Cheats... &Cheats… - + Settings... Paramètres… - + Open debugger console... Ouvrir la console de débug… - + Start &GDB server... Démarrer le serveur &GDB… - + Scripting... - + View &palette... Voir la &palette… - + View &sprites... Voir les &sprites… - + View &tiles... Voir les &tiles… - + View &map... Voir la &map… - + &Frame inspector... Inspecteur de &frame... - + View memory... Voir la mémoire… - + Search memory... Recherche dans la mémoire… - + View &I/O registers... Voir les registres d'&E/S... - + Record debug video log... Enregistrer le journal vidéo de débogage... - + Stop debug video log Arrêter le journal vidéo de débogage - + Exit fullscreen Quitter le plein écran - + GameShark Button (held) Bouton GameShark (maintenir) - + Autofire Tir automatique - + Autofire A Tir automatique A - + Autofire B Tir automatique B - + Autofire L Tir automatique L - + Autofire R Tir automatique R - + Autofire Start Tir automatique Start - + Autofire Select Tir automatique Select - + Autofire Up Tir automatique Up - + Autofire Right Tir automatique Right - + Autofire Down Tir automatique Down - + Autofire Left Tir automatique Gauche - + Clear Vider diff --git a/src/platform/qt/ts/mgba-hu.ts b/src/platform/qt/ts/mgba-hu.ts index a51655410d9..b7da40d8cd1 100644 --- a/src/platform/qt/ts/mgba-hu.ts +++ b/src/platform/qt/ts/mgba-hu.ts @@ -481,7 +481,7 @@ LetöltendÅ‘ adat: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3016,7 +3016,7 @@ LetöltendÅ‘ adat: %3 QGBA::KeyEditor - + --- @@ -3823,17 +3823,27 @@ LetöltendÅ‘ adat: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4332,21 +4342,21 @@ LetöltendÅ‘ adat: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) - + bytes - + (no database present) @@ -4356,42 +4366,57 @@ LetöltendÅ‘ adat: %3 - + + File information + + + + Game name: - + + MD5 + + + + + ROM header + + + + Internal name: - + Game ID: - + Maker Code: - + Revision: - + File size: - + CRC32: - + Save file: @@ -4824,65 +4849,74 @@ LetöltendÅ‘ adat: %3 - + Shortcuts - - - Shaders + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + Shaders + + + + Select BIOS - + Select directory - + Select image - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago - + %n day(s) ago @@ -5618,33 +5652,48 @@ LetöltendÅ‘ adat: %3 QGBA::ShaderSelector - + No shader active - - + + Load shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded - + by %1 - + Preprocessing - + Pass %1 @@ -5950,789 +5999,789 @@ LetöltendÅ‘ adat: %3 QGBA::Window - + Archives (%1) - - - + + + Select ROM - + Select folder - - + + Select save - + Select patch - + Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) - + Select image - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) - + Select video log - + Video logs (*.mvl) - + Crash - + The game has crashed with the following error: %1 - + Couldn't Start - + Could not start game. - + Unimplemented BIOS call - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + Really make portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + Restart needed - + Some changes will not take effect until the emulator is restarted. - + - Player %1 of %2 - + %1 - %2 - + %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File - + Load &ROM... - + Load ROM in archive... - + Add folder to library... - + Save games (%1) - + Select save game - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Load &patch... - + Boot BIOS - + Replace ROM... - + Scan e-Reader dotcodes... - + Convert e-Reader card image to raw... - + ROM &info... - + Recent - + Make portable - + &Load state - + Load state file... - + &Save state - + Save state file... - + Quick load - + Quick save - + Load recent - + Save recent - + Undo load state - + Undo save state - - + + State &%1 - + Load camera image... - + Convert save game... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games - + Import GameShark Save... - + Export GameShark Save... - + Automatically determine - + Use player %0 save game - + New multiplayer window - + Connect to Dolphin... - + Report bug... - + About... - + E&xit - + &Emulation - + &Reset - + Sh&utdown - + Yank game pak - + &Pause - + &Next frame - + Fast forward (held) - + &Fast forward - + Fast forward speed - + Unbounded - + %0x %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) - + Re&wind - + Step backwards - + Solar sensor - + Increase solar level - + Decrease solar level - + Brightest solar level - + Darkest solar level - + Brightness %1 - + Game Boy Printer... - + BattleChip Gate... - + Audio/&Video - + Frame size - + %1× %1× - + Toggle fullscreen - + &Lock frame size - + Lock aspect ratio - + Force integer scaling - + Interframe blending - + Bilinear filtering - + Frame&skip - + Mute - + FPS target - + Native (59.7275) - + Take &screenshot - + F12 - + Record A/V... - + Record GIF/WebP/APNG... - + Video layers - + Audio channels - + Adjust layer placement... - + &Tools - + View &logs... - + Game &overrides... - + Game Pak sensors... - + &Cheats... - + Create forwarder... - + Settings... - + Open debugger console... - + Start &GDB server... - + Scripting... - + Game state views - + View &palette... - + View &sprites... - + View &tiles... - + View &map... - + &Frame inspector... - + View memory... - + Search memory... - + View &I/O registers... - + Log memory &accesses... - + Record debug video log... - + Stop debug video log - + Exit fullscreen - + GameShark Button (held) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear Napló törlése diff --git a/src/platform/qt/ts/mgba-it.ts b/src/platform/qt/ts/mgba-it.ts index aa709370371..6aaf5d80925 100644 --- a/src/platform/qt/ts/mgba-it.ts +++ b/src/platform/qt/ts/mgba-it.ts @@ -480,7 +480,7 @@ Dimensione del download: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... Impossibile creare un contesto OpenGL 3, provo con il vecchio stile... @@ -3015,7 +3015,7 @@ Dimensione del download: %3 QGBA::KeyEditor - + --- --- @@ -3822,17 +3822,27 @@ Dimensione del download: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached Tentativo di scollegare un giocatore in multi che non è collegato - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached Cerco di ottenere l'ID giocatore per un giocatore in multi non collegato - + Trying to get save ID for a multiplayer player that's not attached Cerco di ottenere l'ID di salvataggio per un giocatore in multi non collegato @@ -4331,21 +4341,21 @@ Dimensione del download: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (sconosciuto) - + bytes bytes - + (no database present) (nessun database presente) @@ -4355,42 +4365,57 @@ Dimensione del download: %3 Informazioni sulla ROM - + + File information + + + + Game name: Nome del gioco: - + + MD5 + + + + + ROM header + + + + Internal name: Nome interno: - + Game ID: ID del gioco: - + Maker Code: Codice fabbricante: - + Revision: Revisione: - + File size: Dimensioni del file: - + CRC32: CRC32: - + Save file: Salva file: @@ -4823,58 +4848,67 @@ Dimensione del download: %3 Controller - + Shortcuts Scorciatoie - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Shader - + Select BIOS Seleziona BIOS - + Select directory Seleziona directory - + Select image Seleziona immagine - + Image file (*.png *.jpg *.jpeg) File immagine (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Mai - + Just now Proprio adesso - + Less than an hour ago Meno di un'ora fa - + %n hour(s) ago %n ora fa @@ -4882,7 +4916,7 @@ Dimensione del download: %3 - + %n day(s) ago %n giorno fa @@ -5619,33 +5653,48 @@ Dimensione del download: %3 QGBA::ShaderSelector - + No shader active Nessuno shader attivo - - + + Load shader Carica shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded Nessuno shader caricato - + by %1 di %1 - + Preprocessing Pre-elaborazione - + Pass %1 Pass %1 @@ -5951,95 +6000,95 @@ Dimensione del download: %3 QGBA::Window - + Archives (%1) Archivi (%1) - - - + + + Select ROM Seleziona ROM - - + + Select save Seleziona salvataggio - + Select patch Seleziona patch - + Patches (*.ips *.ups *.bps) Patch (*.ips *.ups *.bps) - + Select e-Reader dotcode Selezione e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) Scheda e-Reader (*.raw *.bin *.bmp) - + Select e-Reader card images Seleziona immagini carte e-Reader - + Image file (*.png *.jpg *.jpeg) File immagine (*.png *.jpg *.jpeg) - + Conversion finished Conversione terminata - + %1 of %2 e-Reader cards converted successfully. %1 di %2 carte e-Reader convertite con successo. - + Select image Seleziona immagine - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) File immagine (*.png *.gif *.jpg *.jpeg);;Tutti i file (*) - + GameShark saves (*.sps *.xps) Salvataggi GameShark (*.sps *.xps) - + Select video log Seleziona registro video - + Video logs (*.mvl) Registro video (*.mvl) - + Crash Errore fatale - + The game has crashed with the following error: %1 @@ -6048,694 +6097,694 @@ Dimensione del download: %3 %1 - + Unimplemented BIOS call BIOS non implementato - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Questo gioco utilizza una chiamata BIOS non implementata. Utilizza il BIOS ufficiale per una migliore esperienza. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Impossibile creare un dispositivo di visualizzazione appropriato, tornando alla visualizzazione software. I giochi possono funzionare lentamente, specialmente con finestre più grandi. - + Really make portable? Vuoi davvero rendere portatile l'applicazione? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? In questo modo l'emulatore carica la propria configurazione dalla stessa cartella dell'eseguibile. Vuoi continuare? - + Restart needed È necessario riavviare - + Some changes will not take effect until the emulator is restarted. Alcune modifiche non avranno effetto finché l'emulatore non verrà riavviato. - + - Player %1 of %2 - Giocatore %1 di %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File File - + Load &ROM... Carica ROM... - + Load ROM in archive... Carica la ROM in archivio... - + Load &patch... Carica patch... - + Boot BIOS Avvia BIOS - + Replace ROM... Sostituisci la ROM... - + Scan e-Reader dotcodes... Scansiona e-Reader dotcode... - + Convert e-Reader card image to raw... Converti immagini carte e-Reader in raw... - + ROM &info... Informazioni ROM... - + Recent Recenti - + Make portable Rendi portatile - + &Load state Carica stato - + &Save state Salva stato - + Quick load Caricamento rapido - + Quick save Salvataggio rapido - + Load recent Carica recente - + Save recent Salva recente - + Undo load state Annulla il caricamento dello stato - + Undo save state Annulla salvataggio stato - - + + State &%1 Stato %1 - + Load camera image... Carica immagine fotocamera... - + Convert save game... Converti salvataggi... - + GameShark saves (*.gsv *.sps *.xps) Salvataggi GameShark (*.gsv *.sps *.xps) - + Reset needed Reset necessario - + Some changes will not take effect until the game is reset. Alcune modifiche non si applicheranno finché il gioco non viene resettato. - + New multiplayer window Nuova finestra multigiocatore - + Connect to Dolphin... Connessione a Dolphin... - + Report bug... Segnala bug... - + E&xit Esci (&X) - + &Emulation Emulazione - + &Reset Reset - + Sh&utdown Spegni (&U) - + Yank game pak Stacca game pak - + &Pause Pausa - + &Next frame Salta il prossimo frame (&N) - + Fast forward (held) Avanzamento rapido (tieni premuto) - + &Fast forward Avanzamento rapido (&F) - + Fast forward speed Velocità di avanzamento rapido - + Unbounded Illimitata - + %0x %0x - + Increase fast forward speed Aumenta la velocità di avvolgimento veloce - + Decrease fast forward speed Diminuisci la velocità di avvolgimento veloce - + Rewind (held) Riavvolgimento (tieni premuto) - + Re&wind Riavvolgimento (&W) - + Step backwards Torna indietro - + Solar sensor Sensore solare - + Increase solar level Incrementa il livello solare - + Decrease solar level Riduci il livello solare - + Brightest solar level Livello solare massimo - + Darkest solar level Livello solare minimo - + Brightness %1 Luminosità %1 - + Audio/&Video Audio/Video - + Frame size Dimensione frame - + Toggle fullscreen Abilita schermo Intero - + &Lock frame size &Blocca dimensione cornice - + Lock aspect ratio Blocca rapporti aspetto - + Frame&skip Salto frame - + Mute Muto - + FPS target FPS finali - + Take &screenshot Acquisisci schermata - + F12 F12 - + Record GIF/WebP/APNG... Registra GIF / WebP / APNG ... - + Video layers Layers video - + Audio channels Canali audio - + &Tools Strumenti - + View &logs... Visualizza registri (&log)... - + Game &overrides... Sovrascrivi funzioni del gioco... - + &Cheats... Trucchi... - + Create forwarder... Crea Icona di avvio... - + Open debugger console... Apri console debugger... - + Start &GDB server... Avvia server GDB... - + Settings... Impostazioni... - + Select folder Seleziona cartella - + Couldn't Start Non è stato possibile avviare - + Could not start game. Non è stato possibile avviare il gioco. - + Add folder to library... Aggiungi cartella alla libreria... - + Load state file... Carica stato di salvataggio... - + Save state file... Salva stato di salvataggio... - + Import GameShark Save... Importa Salvataggio GameShark... - + Export GameShark Save... Esporta Salvataggio GameShark... - + About... Informazioni… - + Force integer scaling Forza ridimensionamento a interi - + Bilinear filtering Filtro bilineare - + Game Boy Printer... Stampante Game Boy... - + Save games (%1) Salvataggi (%1) - + Select save game Seleziona salvataggio - + mGBA save state files (%1) file di stati di salvataggio mGBA (%1) - - + + Select save state Seleziona stato di salvataggio - + Save games Salvataggi - + Load alternate save game... Carica stato di salvataggio alternativo... - + Load temporary save game... Carica salvataggio temporaneo... - + Automatically determine Determina automaticamente - + Use player %0 save game Usa il salvataggio del giocatore %0 - + BattleChip Gate... BattleChip Gate... - + %1× %1x - + Interframe blending Miscelazione dei frame - + Native (59.7275) Nativo (59.7) - + Record A/V... Registra A/V... - + Adjust layer placement... Regola posizionamento layer... - + Game Pak sensors... Sensori Game Pak... - + Scripting... Scripting... - + Game state views Viste degli stati del gioco - + View &palette... Mostra palette... - + View &sprites... Mostra sprites... - + View &tiles... Mostra tiles... - + View &map... Mostra mappa... - + &Frame inspector... &Frame inspector... - + View memory... Mostra memoria... - + Search memory... Ricerca memoria... - + View &I/O registers... Mostra registri I/O... - + Log memory &accesses... Registra memoria &accessi... - + Record debug video log... Salva registro video di debug... - + Stop debug video log Ferma registro video di debug - + Exit fullscreen Esci da Schermo Intero - + GameShark Button (held) Pulsante GameShark (tieni premuto) - + Autofire Pulsanti Autofire - + Autofire A Autofire A - + Autofire B Autofire B - + Autofire L Autofire L - + Autofire R Autofire R - + Autofire Start Autofire Start - + Autofire Select Autofire Select - + Autofire Up Autofire Su - + Autofire Right AAutofire Destra - + Autofire Down Autofire Giù - + Autofire Left Autofire Sinistra - + Clear Pulisci diff --git a/src/platform/qt/ts/mgba-ja.ts b/src/platform/qt/ts/mgba-ja.ts index dfb056123ed..8a242575307 100644 --- a/src/platform/qt/ts/mgba-ja.ts +++ b/src/platform/qt/ts/mgba-ja.ts @@ -480,7 +480,7 @@ Download size: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3015,7 +3015,7 @@ Download size: %3 QGBA::KeyEditor - + --- --- @@ -3822,17 +3822,27 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4331,21 +4341,21 @@ Download size: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (ä¸æ˜Ž) - + bytes ãƒã‚¤ãƒˆ - + (no database present) (データベースãªã—) @@ -4355,42 +4365,57 @@ Download size: %3 ROM情報 - + + File information + + + + Game name: ゲームå: - + + MD5 + + + + + ROM header + + + + Internal name: 内部å: - + Game ID: ゲームID: - + Maker Code: - + Revision: - + File size: ファイルサイズ: - + CRC32: CRC32: - + Save file: @@ -4823,65 +4848,74 @@ Download size: %3 コントローラー - + Shortcuts ショートカット - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders シェーダー - + Select BIOS BIOSã‚’é¸æŠž - + Select directory フォルダをé¸æŠž - + Select image ç”»åƒã‚’é–‹ã - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never 一度もã—ã¦ã„ãªã„ - + Just now ãŸã£ãŸä»Š - + Less than an hour ago 1時間以内 - + %n hour(s) ago %n æ™‚é–“å‰ - + %n day(s) ago %n æ—¥å‰ @@ -5617,33 +5651,48 @@ Download size: %3 QGBA::ShaderSelector - + No shader active アクティブãªã‚·ã‚§ãƒ¼ãƒ€ãƒ¼ãŒã‚ã‚Šã¾ã›ã‚“ - - + + Load shader シェーダーをロード - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded シェーダーãŒãƒ­ãƒ¼ãƒ‰ã•ã‚Œã¦ã„ã¾ã›ã‚“ - + by %1 by %1 - + Preprocessing å‰å‡¦ç†ä¸­ - + Pass %1 Pass %1 @@ -5949,80 +5998,80 @@ Download size: %3 QGBA::Window - + Archives (%1) アーカイブファイル (%1) - - - + + + Select ROM ROMã‚’é–‹ã - + Select folder フォルダを開ã - - + + Select save セーブを開ã - + Select patch パッãƒã‚’é–‹ã - + Patches (*.ips *.ups *.bps) パッãƒãƒ•ã‚¡ã‚¤ãƒ« (*.ips *.ups *.bps) - + Select e-Reader dotcode カードeã‚’é–‹ã - + e-Reader card (*.raw *.bin *.bmp) カードe (*.raw *.bin *.bmp) - + Select image ç”»åƒã‚’é–‹ã - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) ç”»åƒãƒ•ã‚¡ã‚¤ãƒ« (*.png *.gif *.jpg *.jpeg);;ã™ã¹ã¦ã®ãƒ•ã‚¡ã‚¤ãƒ« (*) - + GameShark saves (*.sps *.xps) GameSharkセーブファイル (*.sps *.xps) - + Select video log ビデオログを開ã - + Video logs (*.mvl) ビデオログ (*.mvl) - + Crash クラッシュ - + The game has crashed with the following error: %1 @@ -6031,709 +6080,709 @@ Download size: %3 %1 - + Couldn't Start 起動失敗 - + Could not start game. ゲームを起動ã§ãã¾ã›ã‚“ã§ã—ãŸã€‚ - + Unimplemented BIOS call 未実装ã®BIOS呼ã³å‡ºã— - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. ã“ã®ã‚²ãƒ¼ãƒ ã¯å®Ÿè£…ã•ã‚Œã¦ã„ãªã„BIOS呼ã³å‡ºã—を使用ã—ã¾ã™ã€‚最高ã®ã‚¨ã‚¯ã‚¹ãƒšãƒªã‚¨ãƒ³ã‚¹ã‚’å¾—ã‚‹ã«ã¯å…¬å¼ã®BIOSを使用ã—ã¦ãã ã•ã„。 - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. é©åˆ‡ãªãƒ‡ã‚£ã‚¹ãƒ—レイデãƒã‚¤ã‚¹ã®ä½œæˆã«å¤±æ•—ã—ã€ã‚½ãƒ•ãƒˆãƒ‡ã‚£ã‚¹ãƒ—レイã«ãƒ•ã‚©ãƒ¼ãƒ«ãƒãƒƒã‚¯ã—ã¾ã—ãŸã€‚特ã«å¤§ããªã‚¦ã‚£ãƒ³ãƒ‰ã‚¦ã§ã¯ã€ã‚²ãƒ¼ãƒ ã®å®Ÿè¡ŒãŒé…ã„å ´åˆãŒã‚ã‚Šã¾ã™ã€‚ - + Really make portable? 本当ã«ãƒãƒ¼ã‚¿ãƒ–ル化ã—ã¾ã™ã‹ï¼Ÿ - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? ãƒãƒ¼ã‚¿ãƒ–ル化ã™ã‚‹ã¨ã€ä»¥é™ã¯å®Ÿè¡Œãƒ•ã‚¡ã‚¤ãƒ«ã¨åŒã˜ãƒ‡ã‚£ãƒ¬ã‚¯ãƒˆãƒªã«è¨­å®šãƒ•ã‚¡ã‚¤ãƒ«ãŒç½®ã‹ã‚Œã‚‹ã‚ˆã†ã«ãªã‚Šã¾ã™ã€‚続行ã—ã¾ã™ã‹ï¼Ÿ - + Restart needed å†èµ·å‹•ãŒå¿…è¦ - + Some changes will not take effect until the emulator is restarted. 一部ã®å¤‰æ›´ã¯ã€ã‚¨ãƒŸãƒ¥ãƒ¬ãƒ¼ã‚¿ã‚’å†èµ·å‹•ã™ã‚‹ã¾ã§æœ‰åŠ¹ã«ãªã‚Šã¾ã›ã‚“。 - + - Player %1 of %2 - プレーヤー %1 of %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &ファイル (&F) - + Load &ROM... ROMをロード... - + Load ROM in archive... アーカイブã«ROMをロード... - + Add folder to library... ライブラリーã«ãƒ•ã‚©ãƒ«ãƒ€ã‚’追加... - + Load &patch... パッãƒã‚’ロード... (&P) - + Boot BIOS BIOSã‚’èµ·å‹• - + Replace ROM... ROMを交æ›... - + Scan e-Reader dotcodes... カードeをスキャン... - + ROM &info... ROM情報... (&I) - + Recent 最近開ã„ãŸROM - + Make portable ãƒãƒ¼ã‚¿ãƒ–ル化 - + &Load state ステートをロード (&L) - + Report bug... ãƒã‚°å ±å‘Š - + About... ãƒãƒ¼ã‚¸ãƒ§ãƒ³æƒ…å ±... - + Record GIF/WebP/APNG... GIF/WebP/APNGを記録 - + Game Pak sensors... カートリッジセンサー... - + Clear 消去 - + Load state file... ステートファイルをロード... - + Save games (%1) セーブデータ (%1) - + Select save game セーブデータをé¸æŠž - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Convert e-Reader card image to raw... - + &Save state ステートをセーブ (&S) - + Save state file... ステートファイルをセーブ... - + Quick load クイックロード - + Quick save クイックセーブ - + Load recent 最後ã«ä½¿ã£ãŸã‚¯ã‚¤ãƒƒã‚¯ã‚¹ãƒ­ãƒƒãƒˆã‹ã‚‰ãƒ­ãƒ¼ãƒ‰ - + Save recent 最後ã«ä½¿ã£ãŸã‚¯ã‚¤ãƒƒã‚¯ã‚¹ãƒ­ãƒƒãƒˆã«ã‚»ãƒ¼ãƒ– - + Undo load state クイックロードを元ã«æˆ»ã™ - + Undo save state クイックセーブを元ã«æˆ»ã™ - - + + State &%1 クイックスロット &%1 - + Load camera image... カメラ画åƒã‚’ロード... - + Convert save game... セーブデータを変æ›... - + GameShark saves (*.gsv *.sps *.xps) - + Import GameShark Save... GameSharkスナップショットを読ã¿è¾¼ã‚€ - + Export GameShark Save... GameSharkスナップショットを書ã出㙠- + New multiplayer window æ–°ã—ã„ウィンドウ(マルãƒãƒ—レイ) - + Connect to Dolphin... Dolphinã«æŽ¥ç¶š... - + E&xit 終了 (&X) - + &Emulation エミュレーション (&E) - + &Reset リセット (&R) - + Sh&utdown é–‰ã˜ã‚‹ (&U) - + Yank game pak カートリッジを抜ã - + &Pause 一時åœæ­¢ (&P) - + &Next frame 次ã®ãƒ•ãƒ¬ãƒ¼ãƒ  (&N) - + Fast forward (held) æ—©é€ã‚Š(押ã—) - + &Fast forward æ—©é€ã‚Š (&F) - + Fast forward speed æ—©é€ã‚Šé€Ÿåº¦ - + Unbounded 制é™ãªã— - + %0x %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) 巻戻ã—(押ã—) - + Re&wind 巻戻㗠(&R) - + Step backwards 1フレーム巻ã戻㙠- + Solar sensor 太陽センサー - + Increase solar level 明るã•ã‚’上ã’ã‚‹ - + Decrease solar level 明るã•ã‚’下ã’ã‚‹ - + Brightest solar level 明るã•æœ€é«˜ - + Darkest solar level 明るã•æœ€ä½Ž - + Brightness %1 明る㕠%1 - + Audio/&Video オーディオ/ビデオ (&V) - + Frame size ç”»é¢ã‚µã‚¤ã‚º - + Toggle fullscreen 全画é¢è¡¨ç¤º - + &Lock frame size - + Lock aspect ratio 縦横比を固定 - + Force integer scaling 整数スケーリングを強制 - + Bilinear filtering ãƒã‚¤ãƒªãƒ‹ã‚¢ãƒ•ã‚£ãƒ«ã‚¿ãƒªãƒ³ã‚° - + Frame&skip フレームスキップ (&S) - + Mute ミュート - + FPS target FPS - + Native (59.7275) ãƒã‚¤ãƒ†ã‚£ãƒ–(59.7275) - + Take &screenshot スクリーンショット (&S) - + F12 F12 - + Game Boy Printer... ãƒã‚±ãƒƒãƒˆãƒ—リンタ... - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games セーブデータ - + Automatically determine - + Use player %0 save game - + BattleChip Gate... ãƒãƒˆãƒ«ãƒãƒƒãƒ—ゲート... - + %1× %1× - + Interframe blending ãƒ•ãƒ¬ãƒ¼ãƒ é–“æ··åˆ - + Record A/V... ビデオ録画... - + Video layers ビデオレイヤー - + Audio channels オーディオãƒãƒ£ãƒ³ãƒãƒ« - + Adjust layer placement... レイヤーã®é…置を調整... - + &Tools ツール (&T) - + View &logs... ログビューアー... (&L) - + Game &overrides... ゲーム別設定... (&O) - + &Cheats... ãƒãƒ¼ãƒˆ... (&C) - + Settings... 設定... - + Open debugger console... デãƒãƒƒã‚¬ã‚³ãƒ³ã‚½ãƒ¼ãƒ«ã‚’é–‹ã... - + Start &GDB server... GDBサーãƒã‚’èµ·å‹•... (&G) - + Scripting... - + Create forwarder... - + Game state views - + View &palette... パレットビューアー... (&P) - + View &sprites... スプライトビューアー... (&S) - + View &tiles... タイルビューアー... (&T) - + View &map... マップビューアー... (&M) - + &Frame inspector... フレームインスペクタ... (&F) - + View memory... メモリビューアー... - + Search memory... メモリ検索... - + View &I/O registers... IOビューアー... (&I) - + Log memory &accesses... - + Record debug video log... デãƒãƒƒã‚°ãƒ“デオログ... - + Stop debug video log デãƒãƒƒã‚°ãƒ“デオログをåœæ­¢ - + Exit fullscreen 全画é¢è¡¨ç¤ºã‚’終了 - + GameShark Button (held) GameSharkボタン(押ã—) - + Autofire 連打 - + Autofire A 連打 A - + Autofire B 連打 B - + Autofire L 連打 L - + Autofire R 連打 R - + Autofire Start 連打 Start - + Autofire Select 連打 Select - + Autofire Up 連打 上 - + Autofire Right 連打 å³ - + Autofire Down 連打 下 - + Autofire Left 連打 å·¦ diff --git a/src/platform/qt/ts/mgba-ko.ts b/src/platform/qt/ts/mgba-ko.ts index 2e5bdd0aafd..e6363dd4915 100644 --- a/src/platform/qt/ts/mgba-ko.ts +++ b/src/platform/qt/ts/mgba-ko.ts @@ -480,7 +480,7 @@ Download size: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... OpenGL 3 컨í…스트를 만들 수 없습니다. ì´ì „ 스타ì¼ì„ ì‹œë„ ì¤‘ìž…ë‹ˆë‹¤... @@ -3015,7 +3015,7 @@ Download size: %3 QGBA::KeyEditor - + --- --- @@ -3822,17 +3822,27 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached ì—°ê²°ë˜ì§€ ì•Šì€ ë©€í‹°í”Œë ˆì´ì–´ 플레ì´ì–´ë¥¼ 분리하려고 함 - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached ì—°ê²°ë˜ì§€ ì•Šì€ ë©€í‹°í”Œë ˆì´ì–´ 플레ì´ì–´ì˜ 플레ì´ì–´ ID를 가져오려고 함 - + Trying to get save ID for a multiplayer player that's not attached ì—°ê²°ë˜ì§€ ì•Šì€ ë©€í‹°í”Œë ˆì´ì–´ 플레ì´ì–´ì˜ 저장 ID를 얻으려고 함 @@ -4331,21 +4341,21 @@ Download size: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (미확ì¸) - + bytes ë°”ì´íŠ¸ - + (no database present) (ë°ì´í„°ë² ì´ìŠ¤ ì—†ìŒ) @@ -4355,42 +4365,57 @@ Download size: %3 롬 ì •ë³´ - + + File information + + + + Game name: 게임 ì´ë¦„: - + + MD5 + + + + + ROM header + + + + Internal name: 내부 ì´ë¦„: - + Game ID: 게임 ID: - + Maker Code: ë©”ì´ì»¤ 코드: - + Revision: 리비전: - + File size: íŒŒì¼ í¬ê¸°: - + CRC32: CRC32: - + Save file: 저장 파ì¼: @@ -4823,65 +4848,74 @@ Download size: %3 컨트롤러 - + Shortcuts 단축키 - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders ì‰ì´ë” - + Select BIOS ë°”ì´ì˜¤ìŠ¤ ì„ íƒ - + Select directory 디렉토리 ì„ íƒ - + Select image ì´ë¯¸ì§€ ì„ íƒ - + Image file (*.png *.jpg *.jpeg) ì´ë¯¸ì§€ íŒŒì¼ (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never 절대 - + Just now 방금 - + Less than an hour ago 1시간 미만 ì „ - + %n hour(s) ago %n 시간 ì „ - + %n day(s) ago %n ì¼ ì „ @@ -5617,33 +5651,48 @@ Download size: %3 QGBA::ShaderSelector - + No shader active 활성 ì…°ì´ë” ì—†ìŒ - - + + Load shader ì‰ì´ë” 로드 - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded ë¡œë“œëœ ì‰ì´ë” ì—†ìŒ - + by %1 %1ì— ì˜í•´ - + Preprocessing 전처리 - + Pass %1 %1 패스 @@ -5949,95 +5998,95 @@ Download size: %3 QGBA::Window - + Archives (%1) ì•„ì¹´ì´ë¸Œ (%1) - - - + + + Select ROM 롬 ì„ íƒ - - + + Select save 저장 íŒŒì¼ ì„ íƒ - + Select patch 패치 ì„ íƒ - + Patches (*.ips *.ups *.bps) 패치 (*.ips *.ups *.bps) - + Select e-Reader dotcode e-ë¦¬ë” ë„트코드 ì„ íƒ - + e-Reader card (*.raw *.bin *.bmp) e-ë¦¬ë” ì¹´ë“œ (*.raw *.bin *.bmp) - + Select e-Reader card images e-ë¦¬ë” ì¹´ë“œ ì´ë¯¸ì§€ ì„ íƒ - + Image file (*.png *.jpg *.jpeg) ì´ë¯¸ì§€ íŒŒì¼ (*.png *.jpg *.jpeg) - + Conversion finished 변환 완료 - + %1 of %2 e-Reader cards converted successfully. %2 e-ë¦¬ë” ì¹´ë“œ 중 %1ì´(ê°€) 성공ì ìœ¼ë¡œ 변환ë˜ì—ˆìŠµë‹ˆë‹¤. - + Select image ì´ë¯¸ì§€ ì„ íƒ - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) ì´ë¯¸ì§€ íŒŒì¼ (*.png *.gif *.jpg *.jpeg);;모든 íŒŒì¼ (*) - + GameShark saves (*.sps *.xps) ê²Œìž„ìƒ¤í¬ ì €ìž¥ íŒŒì¼ (*.sps *.xps) - + Select video log 비디오 로그 ì„ íƒ - + Video logs (*.mvl) 비디오 로그 (*.mvl) - + Crash 치명ì ì¸ 오류 - + The game has crashed with the following error: %1 @@ -6046,694 +6095,694 @@ Download size: %3 %1 - + Unimplemented BIOS call 구현ë˜ì§€ ì•Šì€ ë°”ì´ì˜¤ìŠ¤ 호출 - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. ì´ ê²Œìž„ì€ êµ¬í˜„ë˜ì§€ ì•Šì€ ë°”ì´ì˜¤ìŠ¤ í˜¸ì¶œì„ ì‚¬ìš©í•©ë‹ˆë‹¤. 최ìƒì˜ ì„±ëŠ¥ì„ ì–»ìœ¼ë ¤ë©´ ê³µì‹ ë°”ì´ì˜¤ìŠ¤ë¥¼ 사용하십시오. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. ì ì ˆí•œ ë””ìŠ¤í”Œë ˆì´ ìž¥ì¹˜ë¥¼ ìƒì„±í•˜ì§€ 못했습니다. 소프트웨어 디스플레ì´ë¡œ ëŒì•„갑니다. 특히 í° ì°½ì—서는 ê²Œìž„ì´ ëŠë¦¬ê²Œ ì‹¤í–‰ë  ìˆ˜ 있습니다. - + Really make portable? ì •ë§ë¡œ íœ´ëŒ€ìš©ì„ ë§Œë“­ë‹ˆê¹Œ? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? ì´ë ‡ê²Œí•˜ë©´ ì—뮬레ì´í„°ê°€ 실행 파ì¼ê³¼ ë™ì¼í•œ 디렉토리ì—ì„œ êµ¬ì„±ì„ ë¡œë“œí•˜ê²Œë©ë‹ˆë‹¤. ê³„ì† í•˜ì‹œê² ìŠµë‹ˆê¹Œ? - + Restart needed 재시작 í•„ìš” - + Some changes will not take effect until the emulator is restarted. ì¼ë¶€ 변경 ì‚¬í•­ì€ ì—뮬레ì´í„°ê°€ 다시 ì‹œìž‘ë  ë•Œê¹Œì§€ ì ìš©ë˜ì§€ 않습니다. - + Reset needed 재설정 í•„ìš” - + Some changes will not take effect until the game is reset. ì¼ë¶€ 변경 ì‚¬í•­ì€ ê²Œìž„ì´ ìž¬ì„¤ì •ë  ë•Œê¹Œì§€ ì ìš©ë˜ì§€ 않습니다. - + - Player %1 of %2 - 플레ì´ì–´ %1 ì˜ %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &íŒŒì¼ - + Load &ROM... 로드 &롬... - + Load ROM in archive... ë¡¬ì„ ì•„ì¹´ì´ë¸Œì— 로드... - + Save games 게임 저장 - + Automatically determine ìžë™ìœ¼ë¡œ ê²°ì • - + Use player %0 save game 플레ì´ì–´ %0 저장 게임 사용 - + Load &patch... 로드 &패치... - + Boot BIOS BIOS 부팅 - + Replace ROM... 롬 êµì²´... - + Scan e-Reader dotcodes... e-ë¦¬ë” ë„트코드 스캔... - + Game state views 게임 ìƒíƒœ 보기 - + Convert e-Reader card image to raw... e-ë¦¬ë” ì¹´ë“œ ì´ë¯¸ì§€ë¥¼ ì›ì‹œ ë°ì´í„°ë¡œ 변환... - + ROM &info... 롬 &ì •ë³´... - + Recent 최근 실행 - + Make portable 휴대용 만들기 - + &Load state &로드 íŒŒì¼ ìƒíƒœ - + &Save state &저장 íŒŒì¼ ìƒíƒœ - + Quick load 빠른 로드 - + Quick save 빠른 저장 - + Load recent 최근 실행 로드 - + Save recent 최근 실행 저장 - + Undo load state 로드 íŒŒì¼ ìƒíƒœ ë³µì› - + Undo save state 저장 íŒŒì¼ ìƒíƒœ ë³µì› - - + + State &%1 ìƒíƒœ &%1 - + Load camera image... ì¹´ë©”ë¼ ì´ë¯¸ì§€ 로드... - + Convert save game... 저장 게임 변환... - + GameShark saves (*.gsv *.sps *.xps) ê²Œìž„ìƒ¤í¬ ì €ìž¥ (*.gsv *.sps *.xps) - + New multiplayer window 새로운 멀티 플레ì´ì–´ ì°½ - + Connect to Dolphin... ëŒí•€ì— ì—°ê²°... - + E&xit 종&료 - + &Emulation &ì—뮬레ì´ì…˜ - + &Reset &재설정 - + Sh&utdown 종&료 - + Yank game pak 양키 게임 팩 - + &Pause &정지 - + &Next frame &ë‹¤ìŒ í”„ë ˆìž„ - + Fast forward (held) 빨리 ê°ê¸° (누름) - + &Fast forward &빨리 ê°ê¸° - + Fast forward speed 빨리 ê°ê¸° ì†ë„ - + Unbounded 무제한 - + %0x %0x - + Increase fast forward speed 빨리 ê°ê¸° ì†ë„ í–¥ìƒ - + Decrease fast forward speed 빨리 ê°ê¸° ì†ë„ 줄ì´ê¸° - + Rewind (held) ë˜ê¹€ê¸° (누름) - + Re&wind 리&와ì¸ë“œ - + Step backwards ëŒì•„가기 - + Brightest solar level 가장 ë°ì€ 태양 수준 - + Darkest solar level 가장 ì–´ë‘ìš´ 태양 수준 - + Brightness %1 ë°ê¸° %1 - + Audio/&Video 오디오/&비디오 - + Frame size 프레임 í¬ê¸° - + Toggle fullscreen 전체화면 전환 - + &Lock frame size 프레임 í¬ê¸° 잠금 (&L) - + Lock aspect ratio 화면비 잠금 - + Frame&skip 프레임&건너뛰기 - + Mute ë¬´ìŒ - + FPS target FPS ëŒ€ìƒ - + Take &screenshot 스í¬ë¦°ìƒ· &ì°ê¸° - + F12 F12 - + Video layers 비디오 ë ˆì´ì–´ - + Audio channels 오디오 ì±„ë„ - + &Tools &ë„구 - + View &logs... 로그 &보기... - + Game &overrides... 게임 &오버ë¼ì´ë“œ... - + &Cheats... &치트.. - + Create forwarder... ì „ë‹¬ìž ìƒì„±... - + Open debugger console... 디버거 콘솔 열기... - + Start &GDB server... GDB 서버 &시작... - + Settings... 설정... - + Select folder í´ë” ì„ íƒ - + Couldn't Start 시작할 수 ì—†ìŒ - + Could not start game. ê²Œìž„ì„ ì‹œìž‘í•  수 없습니다. - + Add folder to library... ë¼ì´ë¸ŒëŸ¬ë¦¬ì— í´ë” 추가... - + Load state file... ìƒíƒœ íŒŒì¼ ë¡œë“œ... - + Save state file... ìƒíƒœ íŒŒì¼ ì €ìž¥... - + Import GameShark Save... ê²Œìž„ìƒ¤í¬ ì €ìž¥ 가져오기... - + Export GameShark Save... ê²Œìž„ìƒ¤í¬ ì €ìž¥ 내보내기... - + Report bug... 버그를 제보하기... - + About... ì •ë³´... - + Solar sensor 태양광 센서 - + Increase solar level 태양광 레벨 ì¦ê°€ - + Decrease solar level 태양광 레벨 ê°ì†Œ - + Force integer scaling 정수 스케ì¼ë§ ê°•ì œ 수행 - + Bilinear filtering ì´ì¤‘선형 í•„í„°ë§ - + Game Boy Printer... 게임 ë³´ì´ í”„ë¦°í„°... - + Save games (%1) 게임 (%1) 저장 - + Select save game 저장 게임 ì„ íƒ - + mGBA save state files (%1) mGBA 저장 ìƒíƒœ íŒŒì¼ (%1) - - + + Select save state 저장 ìƒíƒœ ì„ íƒ - + Load alternate save game... 대체 저장 게임 로드... - + Load temporary save game... ìž„ì‹œ 저장 게임 로드... - + BattleChip Gate... 배틀칩 게ì´íŠ¸... - + %1× %1× - + Interframe blending 프레임간 ì¡°í•© - + Native (59.7275) 실기 (59.7275) - + Record A/V... A/V 녹화... - + Record GIF/WebP/APNG... GIF/WebP/APNG 녹화... - + Adjust layer placement... ë ˆì´ì–´ 배치 ì¡°ì •... - + Game Pak sensors... 게임 팩 센서... - + Scripting... 스í¬ë¦½íŒ…... - + View &palette... 팔레트 &보기... - + View &sprites... 스프ë¼ì´íŠ¸ &보기... - + View &tiles... íƒ€ì¼ &보기... - + View &map... ì§€ë„ &보기... - + &Frame inspector... 프레임 검사기 (&F)... - + View memory... 메모리 보기... - + Search memory... 메모리 검색... - + View &I/O registers... I/O 레지스터 &보기... - + Log memory &accesses... 메모리 ë° ì ‘ì† ê¸°ë¡... - + Record debug video log... 디버그 비디오 로그 녹화... - + Stop debug video log 디버그 비디오 로그 중지 - + Exit fullscreen 전체화면 종료 - + GameShark Button (held) ê²Œìž„ìƒ¤í¬ ë²„íŠ¼ (누름) - + Autofire 연사 - + Autofire A 연사 A - + Autofire B 연사 B - + Autofire L 연사 L - + Autofire R 연사 R - + Autofire Start 연사 시작 - + Autofire Select 연사 ì„ íƒ - + Clear 지움 - + Autofire Up 연사 위쪽 - + Autofire Right 연사 오른쪽 - + Autofire Down 연사 아래쪽 - + Autofire Left 연사 왼쪽 diff --git a/src/platform/qt/ts/mgba-ms.ts b/src/platform/qt/ts/mgba-ms.ts index e606a3a9670..d8b2f9b0961 100644 --- a/src/platform/qt/ts/mgba-ms.ts +++ b/src/platform/qt/ts/mgba-ms.ts @@ -474,7 +474,7 @@ Download size: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3009,7 +3009,7 @@ Download size: %3 QGBA::KeyEditor - + --- --- @@ -3816,17 +3816,27 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4325,21 +4335,21 @@ Download size: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (tidak diketahui) - + bytes bait - + (no database present) (tiada pangkalan data hadir) @@ -4349,42 +4359,57 @@ Download size: %3 Perihal ROM - + + File information + + + + Game name: Nama permainan: - + + MD5 + + + + + ROM header + + + + Internal name: Nama dalaman: - + Game ID: ID Permainan: - + Maker Code: - + Revision: - + File size: Saiz fail: - + CRC32: CRC32: - + Save file: @@ -4817,65 +4842,74 @@ Download size: %3 Pengawal - + Shortcuts Pintas - - - Shaders + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + Shaders + + + + Select BIOS Pilih BIOS - + Select directory Pilih direktori - + Select image Pilih gambar - + Image file (*.png *.jpg *.jpeg) Fail gambar (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago - + %n day(s) ago @@ -5611,33 +5645,48 @@ Download size: %3 QGBA::ShaderSelector - + No shader active - - + + Load shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded - + by %1 - + Preprocessing - + Pass %1 @@ -5943,80 +5992,80 @@ Download size: %3 QGBA::Window - + Archives (%1) Arkib (%1) - - - + + + Select ROM Pilih ROM - + Select folder Pilih folder - - + + Select save - + Select patch - + Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) - + Select image Pilih gambar - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Fail gambar (*.png *.gif *.jpg *.jpeg);;Semua fail (*) - + GameShark saves (*.sps *.xps) Simpanan GameShark (*.sps *.xps) - + Select video log Pilih log video - + Video logs (*.mvl) Log video (*.mvl) - + Crash Nahas - + The game has crashed with the following error: %1 @@ -6025,709 +6074,709 @@ Download size: %3 %1 - + Couldn't Start Tidak dapat memula - + Could not start game. Permainan tidak dapat bermula. - + Unimplemented BIOS call Panggilan BIOS yg belum dilaksanakan - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Permainan ini menggunakan panggilan BIOS yang belum dilaksanakan. Sila pakai BIOS rasmi untuk pengalaman yang lebih baik. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Gagal mencipta peranti paparan yang sesuai, berbalik ke paparan perisian. Permainan mungkin menjadi lembap, terutamanya dengan tetingkap besar. - + Really make portable? Betulkah mahu buat jadi mudah alih? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Ini akan menetapkan pelagak untuk muat konfigurasi dari direktori yang sama dengan fail bolehlakunya. Teruskan? - + Restart needed Mula semula diperlukan - + Some changes will not take effect until the emulator is restarted. Beberapa perubahan tidak akan dilaksanakan sehingga pelagak dimula semula. - + - Player %1 of %2 - Pemain %1 dari %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &File - + Load &ROM... Muat %ROM... - + Load ROM in archive... Muat ROM daripada arkib... - + Add folder to library... Tambah folder ke perpustakaan... - + Save games (%1) Simpanan permainan (%1) - + Select save game Pilih simpanan permainan - + mGBA save state files (%1) mGBA fail keadaan tersimpan (%1) - - + + Select save state Pilih keadaan tersimpan - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) Fail gambar (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... Muat simpanan permainan alternatif... - + Load temporary save game... Muat simpanan permainan sementara... - + Load &patch... - + Boot BIOS But BIOS - + Replace ROM... Ganti ROM... - + Scan e-Reader dotcodes... - + Convert e-Reader card image to raw... - + ROM &info... &Perihal ROM... - + Recent Terkini - + Make portable Buat jadi mudah alih - + &Load state &Muat keadaan - + Load state file... Muat fail keadaan... - + &Save state &Simpan keadaan - + Save state file... Simpan fail keadaan... - + Quick load - + Quick save - + Load recent Muat terkini - + Save recent Simpan terkini - + Undo load state Buat asal keadaan termuat - + Undo save state Buat asal keadaan tersimpan - - + + State &%1 Keadaan &%1 - + Load camera image... Muat gambar kamera... - + Convert save game... Tukar simpanan permainan... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games Simpanan permainan - + Import GameShark Save... Import Simpanan GameShark... - + Export GameShark Save... Eksport Simpanan GameShark... - + Automatically determine - + Use player %0 save game - + New multiplayer window Tetingkap multipemain baru - + Connect to Dolphin... Sambung ke Dolphin... - + Report bug... Laporkan pepijat... - + About... Perihal... - + E&xit &Keluar - + &Emulation Pe&lagak - + &Reset - + Sh&utdown &Matikan - + Yank game pak Alih keluar Game Pak - + &Pause &Jeda - + &Next frame Bingkai se&terusnya - + Fast forward (held) Mundar laju (pegang) - + &Fast forward Mundar &laju - + Fast forward speed Kelajuan mundar laju - + Unbounded Tidak terbatas - + %0x %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) Putar balik (pegang) - + Re&wind Ma&ndir - + Step backwards Langkah belakang - + Solar sensor Pengesan suria - + Increase solar level Meningkatkan aras suria - + Decrease solar level Mengurangkan aras suria - + Brightest solar level Aras suria paling terang - + Darkest solar level Aras suria paling gelap - + Brightness %1 Kecerahan %1 - + Game Boy Printer... Pencetak Game Boy... - + BattleChip Gate... BattleChip Gate... - + Audio/&Video Audio/&Video - + Frame size Saiz bingkai - + %1× %1× - + Toggle fullscreen Togol skrinpenuh - + &Lock frame size - + Lock aspect ratio Kekalkan nisbah aspek - + Force integer scaling Paksa skala integer - + Interframe blending Persebatian antarabingkai - + Bilinear filtering Penapisan bilinear - + Frame&skip Langkauan &bingkai - + Mute Senyap - + FPS target Sasaran FPS - + Native (59.7275) Asal (59.7275) - + Take &screenshot Ambil &cekupan skrin - + F12 F12 - + Record A/V... Rakam A/V... - + Record GIF/WebP/APNG... Rakam GIF/WebP/APNG... - + Video layers Lapisan video - + Audio channels Saluran audio - + Adjust layer placement... Melaras peletakan lapisan... - + &Tools &Alat - + View &logs... Lihat &log... - + Game &overrides... - + Game Pak sensors... Pengesan Game Pak... - + &Cheats... &Tipu... - + Create forwarder... - + Settings... Tetapan... - + Open debugger console... Buka konsol penyahpepijat... - + Start &GDB server... Mula pelayan &GDB... - + Scripting... - + Game state views - + View &palette... Pelihat &palet... - + View &sprites... - + View &tiles... Pelihat &jubin... - + View &map... Pelihat pe&ta... - + &Frame inspector... Periksa &bingkai... - + View memory... Lihat ingatan... - + Search memory... Cari ingatan... - + View &I/O registers... Lihat daftar &I/O... - + Log memory &accesses... - + Record debug video log... Rakam log video nyahpepijat... - + Stop debug video log Henti log video nyahpepijat - + Exit fullscreen Keluar skrinpenuh - + GameShark Button (held) Butang GameShark (pegang) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear Kosongkan diff --git a/src/platform/qt/ts/mgba-nb_NO.ts b/src/platform/qt/ts/mgba-nb_NO.ts index 789faa1f0c2..f62f3793aca 100644 --- a/src/platform/qt/ts/mgba-nb_NO.ts +++ b/src/platform/qt/ts/mgba-nb_NO.ts @@ -478,7 +478,7 @@ Nedlastningsstørrelse: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3013,7 +3013,7 @@ Nedlastningsstørrelse: %3 QGBA::KeyEditor - + --- --- @@ -3820,17 +3820,27 @@ Nedlastningsstørrelse: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4329,21 +4339,21 @@ Nedlastningsstørrelse: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (ukjent) - + bytes byte - + (no database present) (ingen database forefinnes) @@ -4353,42 +4363,57 @@ Nedlastningsstørrelse: %3 ROM-info - + + File information + + + + Game name: Spillets navn: - + + MD5 + + + + + ROM header + + + + Internal name: Internt navn: - + Game ID: Spill-ID: - + Maker Code: - + Revision: - + File size: Filstørrelse: - + CRC32: CRC32: - + Save file: @@ -4821,58 +4846,67 @@ Nedlastningsstørrelse: %3 Kontrollere - + Shortcuts Snarveier - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Skyggeleggere - + Select BIOS Velg BIOS - + Select directory Velg mappe - + Select image Velg bilde - + Image file (*.png *.jpg *.jpeg) Bildefil (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Aldri - + Just now Akkurat nÃ¥ - + Less than an hour ago Mindre enn én time siden - + %n hour(s) ago @@ -4880,7 +4914,7 @@ Nedlastningsstørrelse: %3 - + %n day(s) ago @@ -5617,33 +5651,48 @@ Nedlastningsstørrelse: %3 QGBA::ShaderSelector - + No shader active Ingen aktive skyggeleggere - - + + Load shader Last inn skyggelegger - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded - + by %1 av %1 - + Preprocessing - + Pass %1 @@ -5949,789 +5998,789 @@ Nedlastningsstørrelse: %3 QGBA::Window - + Archives (%1) Arkiv (%1) - - - + + + Select ROM Velg ROM - + Select folder Velg mappe - - + + Select save Velg lagrefil - + Select patch Velg feilfiks - + Patches (*.ips *.ups *.bps) Feilfikser (*.ips *.ups *.bps) - + Select e-Reader dotcode Velg e-Reader-punktkode - + e-Reader card (*.raw *.bin *.bmp) e-Reader-kort (*.raw *.bin *.bmp) - + Select image Velg bilde - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Bildefil (*.png *.gif *.jpg *.jpeg);;All filer (*) - + GameShark saves (*.sps *.xps) - + Select video log - + Video logs (*.mvl) Videologgføringer (*.mvl) - + Crash Krasj - + The game has crashed with the following error: %1 - + Couldn't Start Klarte ikke Ã¥ starte opp - + Could not start game. Klarte ikke Ã¥ starte opp spillet. - + Unimplemented BIOS call - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + Really make portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + Restart needed Gjennomfør omstart - + Some changes will not take effect until the emulator is restarted. - + - Player %1 of %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File &Fil - + Load &ROM... Last inn &ROM... - + Load ROM in archive... - + Add folder to library... - + Save games (%1) Lagrefiler (%1) - + Select save game Velg lagrefil - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images Velg e-Reader-kortavbildninger - + Image file (*.png *.jpg *.jpeg) Bildefil (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Load &patch... - + Boot BIOS Oppstarts-BIOS - + Replace ROM... Bytt ROM.... - + Scan e-Reader dotcodes... Skann e-Reader-punktkoder... - + Convert e-Reader card image to raw... - + ROM &info... ROM-&info ... - + Recent Nylig - + Make portable - + &Load state &Last inn tilstand - + Load state file... - + &Save state &Lagre en tilstand - + Save state file... - + Quick load Hurtiginnlasting - + Quick save Hurtiglagring - + Load recent - + Save recent - + Undo load state - + Undo save state - - + + State &%1 - + Load camera image... - + Convert save game... - + GameShark saves (*.gsv *.sps *.xps) GameShark-lagrefiler (*.gsv *.sps *.xps) - + Reset needed Tilbakestilling kreves - + Some changes will not take effect until the game is reset. - + Save games Lagrefiler - + Import GameShark Save... - + Export GameShark Save... - + Automatically determine - + Use player %0 save game - + New multiplayer window Nytt flerspillervindu - + Connect to Dolphin... Koble til Dolphin... - + Report bug... Rapporter inn feil... - + About... Om … - + E&xit A&vslutt - + &Emulation &Emulering - + &Reset &Omstart - + Sh&utdown Skr&u av - + Yank game pak Dra ut spillkassetten - + &Pause &Pause - + &Next frame - + Fast forward (held) - + &Fast forward - + Fast forward speed - + Unbounded - + %0x %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) Spol tilbake (holdt) - + Re&wind Spol ti&lbake - + Step backwards - + Solar sensor Solsensor - + Increase solar level Øke solnivÃ¥et - + Decrease solar level Reduser solnivÃ¥et - + Brightest solar level Lyseste solnivÃ¥ - + Darkest solar level Mørkeste solnivÃ¥ - + Brightness %1 Lysstyrke %1 - + Game Boy Printer... Game Boy Printer... - + BattleChip Gate... - + Audio/&Video Lyd/&Video - + Frame size Rammestørrelse - + %1× %1× - + Toggle fullscreen Skru pÃ¥/av fullskjerm - + &Lock frame size - + Lock aspect ratio LÃ¥s visningsforhold - + Force integer scaling - + Interframe blending - + Bilinear filtering Bilineær filtrering - + Frame&skip - + Mute Demp lyd - + FPS target - + Native (59.7275) Systemstandard (59.7275) - + Take &screenshot Ta &skjermbilde - + F12 F12 - + Record A/V... - + Record GIF/WebP/APNG... - + Video layers - + Audio channels Lydkanaler - + Adjust layer placement... - + &Tools Verk&tøy - + View &logs... - + Game &overrides... Spilloverstyringer ... - + Game Pak sensors... Game Pak-sensorer ... - + &Cheats... - + Create forwarder... - + Settings... Innstillinger… - + Open debugger console... - + Start &GDB server... - + Scripting... - + Game state views - + View &palette... Vis &palett ... - + View &sprites... - + View &tiles... - + View &map... Vis &kart … - + &Frame inspector... - + View memory... Vis minne ... - + Search memory... Søk i minne ... - + View &I/O registers... - + Log memory &accesses... - + Record debug video log... - + Stop debug video log - + Exit fullscreen GÃ¥ ut av fullskjerm - + GameShark Button (held) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear Tøm diff --git a/src/platform/qt/ts/mgba-pl.ts b/src/platform/qt/ts/mgba-pl.ts index 12ce3446223..e4b19160865 100644 --- a/src/platform/qt/ts/mgba-pl.ts +++ b/src/platform/qt/ts/mgba-pl.ts @@ -480,7 +480,7 @@ Rozmiar pobierania: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3015,7 +3015,7 @@ Rozmiar pobierania: %3 QGBA::KeyEditor - + --- --- @@ -3822,17 +3822,27 @@ Rozmiar pobierania: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached Próba odÅ‚Ä…czenia gracza multiplayer, który nie jest doÅ‚Ä…czony - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached Próba uzyskania ID gracza w trybie wieloosobowym, który nie jest poÅ‚Ä…czony - + Trying to get save ID for a multiplayer player that's not attached Próba uzyskania identyfikatora zapisu dla gracza multiplayer, który nie jest poÅ‚Ä…czony @@ -4331,21 +4341,21 @@ Rozmiar pobierania: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (nieznany) - + bytes bajty - + (no database present) (brak bazy danych) @@ -4355,42 +4365,57 @@ Rozmiar pobierania: %3 Informacje o pamiÄ™ci ROM - + + File information + + + + Game name: Nazwa gry: - + + MD5 + + + + + ROM header + + + + Internal name: Nazwa wewnÄ™trzna: - + Game ID: ID gry: - + Maker Code: - + Revision: - + File size: Rozmiar pliku: - + CRC32: CRC32: - + Save file: Zapisz plik: @@ -4823,58 +4848,67 @@ Rozmiar pobierania: %3 Kontrolery - + Shortcuts Skróty - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Shadery - + Select BIOS Wybierz BIOS - + Select directory Wybierz katalog - + Select image Wybierz obraz - + Image file (*.png *.jpg *.jpeg) Plik graficzny (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Nigdy - + Just now WÅ‚aÅ›nie teraz - + Less than an hour ago Mniej niż godzinÄ™ temu - + %n hour(s) ago %n godzinÄ™ temu @@ -4883,7 +4917,7 @@ Rozmiar pobierania: %3 - + %n day(s) ago %n dzieÅ„ temu @@ -5621,33 +5655,48 @@ Rozmiar pobierania: %3 QGBA::ShaderSelector - + No shader active Brak aktywnych shaderów - - + + Load shader ZaÅ‚aduj shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded Nie zaÅ‚adowano shadera - + by %1 autorstwa %1 - + Preprocessing Przetwarzanie wstÄ™pne - + Pass %1 PrzejÅ›cie %1 @@ -5953,80 +6002,80 @@ Rozmiar pobierania: %3 QGBA::Window - + Archives (%1) Archiwa (%1) - - - + + + Select ROM Wybierz ROM - + Select folder Wybierz katalog - - + + Select save Wybierz zapis - + Select patch Wybierz Å‚atkÄ™ - + Patches (*.ips *.ups *.bps) Åatki (*.ips *.ups *.bps) - + Select e-Reader dotcode Wybierz kod kropki e-Reader - + e-Reader card (*.raw *.bin *.bmp) Karta e-Reader (*.raw *.bin *.bmp) - + Select image Wybierz obraz - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Plik obrazu (*.png *.gif *.jpg *.jpeg);;Wszystkie pliki (*) - + GameShark saves (*.sps *.xps) Zapisy GameShark (*.sps *.xps) - + Select video log Wybierz dziennik wideo - + Video logs (*.mvl) Dzienniki wideo (*.mvl) - + Crash Crash - + The game has crashed with the following error: %1 @@ -6035,709 +6084,709 @@ Rozmiar pobierania: %3 %1 - + Couldn't Start Nie udaÅ‚o siÄ™ uruchomić - + Could not start game. Nie udaÅ‚o siÄ™ rozpocząć gry. - + Unimplemented BIOS call Niewdrożone wywoÅ‚anie BIOS - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Ta gra używa wywoÅ‚ania BIOS, które nie jest zaimplementowane. Aby uzyskać najlepsze wrażenia, użyj oficjalnego BIOS. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Nie udaÅ‚o siÄ™ utworzyć odpowiedniego urzÄ…dzenia wyÅ›wietlajÄ…cego, powracam do wyÅ›wietlania programowego. Gry mogÄ… dziaÅ‚ać wolno, zwÅ‚aszcza w przypadku wiÄ™kszych okien. - + Really make portable? NaprawdÄ™ stworzyć wersjÄ™ portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? To sprawi, że emulator zaÅ‚aduje swojÄ… konfiguracjÄ™ z tego samego katalogu, co plik wykonywalny. Czy chcesz kontynuować? - + Restart needed Wymagane ponowne uruchomienie - + Some changes will not take effect until the emulator is restarted. Niektóre zmiany nie zacznÄ… obowiÄ…zywać, dopóki emulator nie zostanie ponownie uruchomiony. - + - Player %1 of %2 - Gracz %1 z %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 FPS) - %4 - + &File &Plik - + Load &ROM... ZaÅ‚aduj &ROM... - + Load ROM in archive... ZaÅ‚aduj ROM w archiwum... - + Add folder to library... Dodaj folder do biblioteki... - + Save games (%1) Zapisane gry (%1) - + Select save game Wybierz zapis gry - + mGBA save state files (%1) Pliki stanu gry mGBA (%1) - - + + Select save state Wybierz stan - + Select e-Reader card images Wybierz obrazy kart e-Reader - + Image file (*.png *.jpg *.jpeg) Plik graficzny (*.png *.jpg *.jpeg) - + Conversion finished Konwersja zakoÅ„czona - + %1 of %2 e-Reader cards converted successfully. %1 z %2 kart czytnika e-Reader zostaÅ‚o pomyÅ›lnie przekonwertowanych. - + Load alternate save game... ZaÅ‚aduj alternatywny zapis gry... - + Load temporary save game... ZaÅ‚aduj tymczasowy zapis gry... - + Load &patch... Wczytaj &poprawkÄ™... - + Boot BIOS BIOS startowy - + Replace ROM... WymieÅ„ ROM... - + Scan e-Reader dotcodes... Skanuj kody kropkowe czytnika e-Reader... - + Convert e-Reader card image to raw... Konwertuj obraz karty czytnika e-Reader na surowy... - + ROM &info... &Informacje o pamiÄ™ci ROM... - + Recent Ostatnie - + Make portable Stwórz wersjÄ™ portable - + &Load state &ZaÅ‚aduj stan - + Load state file... ZaÅ‚aduj plik stanu… - + &Save state &Zapisz stan - + Save state file... Zapisz plik stanu... - + Quick load Szybkie zaÅ‚adowanie - + Quick save Szybki zapis - + Load recent ZaÅ‚aduj ostatnie - + Save recent Zapisz ostatnie - + Undo load state Cofnij zaÅ‚adowanie stanu - + Undo save state Cofnij zapisanie stanu - - + + State &%1 Stan &%1 - + Load camera image... ZaÅ‚aduj obraz do kamery... - + Convert save game... Konwertuj zapisanÄ… grÄ™... - + GameShark saves (*.gsv *.sps *.xps) Zapisy GameShark (*.gsv *.sps *.xps) - + Reset needed Wymagane zresetowanie - + Some changes will not take effect until the game is reset. Niektóre zmiany nie zacznÄ… obowiÄ…zywać, dopóki gra nie zostanie zresetowana. - + Save games Zapisy gry - + Import GameShark Save... Importuj Zapis GameShark... - + Export GameShark Save... Eksportuj Zapis GameShark... - + Automatically determine Wykryj automatycznie - + Use player %0 save game Użyj zapis gry gracza %0 - + New multiplayer window Nowe okno dla wielu graczy - + Connect to Dolphin... PoÅ‚Ä…cz z Dolphinem... - + Report bug... ZgÅ‚oÅ› bÅ‚Ä…d... - + About... O Aplikacji... - + E&xit Z&akoÅ„cz - + &Emulation &Emulacja - + &Reset &Resetuj - + Sh&utdown Za&mknij - + Yank game pak WyciÄ…gnij Game Pak - + &Pause &Pauza - + &Next frame &NastÄ™pna klatka - + Fast forward (held) Przewijanie (przytrzymaj) - + &Fast forward &Przewijanie do przodu - + Fast forward speed PrÄ™dkość przewijania do przodu - + Unbounded Bez ograniczeÅ„ - + %0x %0x - + Increase fast forward speed ZwiÄ™kszenie prÄ™dkoÅ›ci przewijania do przodu - + Decrease fast forward speed Zmiejszenie prÄ™dkoÅ›ci przewijania do przodu - + Rewind (held) Przewijanie (przytrzymaj) - + Re&wind Pr&zewijanie - + Step backwards Krok w tyÅ‚ - + Solar sensor Czujnik sÅ‚oneczny - + Increase solar level ZwiÄ™ksz poziom energii sÅ‚onecznej - + Decrease solar level Zmniejsz poziom energii sÅ‚onecznej - + Brightest solar level NajjaÅ›niejszy poziom energii sÅ‚onecznej - + Darkest solar level Najciemniejszy poziom energii sÅ‚onecznej - + Brightness %1 Jasność %1 - + Game Boy Printer... Game Boy Printer... - + BattleChip Gate... BattleChip Gate... - + Audio/&Video DźwiÄ™k/&Wideo - + Frame size Rozmiar klatki - + %1× %1× - + Toggle fullscreen PrzeÅ‚Ä…cz tryb peÅ‚noekranowy - + &Lock frame size - + Lock aspect ratio Zablokuj proporcje - + Force integer scaling WymuÅ› skalowanie caÅ‚kowite - + Interframe blending Blendowanie miÄ™dzyklatkowe - + Bilinear filtering Filtrowanie dwuliniowe - + Frame&skip Klatko&wanie - + Mute Wycisz - + FPS target Cel KL./S - + Native (59.7275) Natywny (59.7275) - + Take &screenshot Wykonaj &zrzut ekranu - + F12 F12 - + Record A/V... Nagraj A/W... - + Record GIF/WebP/APNG... Nagraj GIF/WebP/APNG... - + Video layers Warstwy wideo - + Audio channels KanaÅ‚y audio - + Adjust layer placement... Dostosuj poÅ‚ożenie warstw... - + &Tools &NarzÄ™dzia - + View &logs... WyÅ›wietl &logi... - + Game &overrides... Nadpisania &ustawieÅ„ gry... - + Game Pak sensors... Czujniki Game Pak... - + &Cheats... &Kody... - + Create forwarder... Utwórz forwarder... - + Settings... Ustawienia... - + Open debugger console... Otwórz konsolÄ™ debugera... - + Start &GDB server... Uruchom serwer &GDB... - + Scripting... Skrypty... - + Game state views Widoki stanu gry - + View &palette... WyÅ›wietl &paletÄ™... - + View &sprites... WyÅ›wietl &sprite'y... - + View &tiles... WyÅ›wietl &kafelki... - + View &map... WyÅ›wietl &mapÄ™... - + &Frame inspector... Inspektor &klatek... - + View memory... WyÅ›wietl pamięć... - + Search memory... Przeszukaj pamięć... - + View &I/O registers... WyÅ›wietl rejestry &we/wy... - + Log memory &accesses... - + Record debug video log... Nagraj dziennik wideo debugowania... - + Stop debug video log Zatrzymaj dziennik wideo debugowania - + Exit fullscreen WyÅ‚Ä…czyć tryb peÅ‚noekranowy - + GameShark Button (held) Przycisk GameShark (przytrzymany) - + Autofire Turbo - + Autofire A Turbo A - + Autofire B Turbo B - + Autofire L Turbo L - + Autofire R Turbo R - + Autofire Start Turbo Start - + Autofire Select Turbo Select - + Autofire Up Turbo Góra - + Autofire Right Turbo Prawo - + Autofire Down Turbo Dół - + Autofire Left Turbo Lewo - + Clear Wyczyść diff --git a/src/platform/qt/ts/mgba-pt_BR.ts b/src/platform/qt/ts/mgba-pt_BR.ts index 3326cfcdead..e132eaeb380 100644 --- a/src/platform/qt/ts/mgba-pt_BR.ts +++ b/src/platform/qt/ts/mgba-pt_BR.ts @@ -480,7 +480,7 @@ Tamanho do download: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... Falhou em criar um contexto do OpenGL 3, tentando o estilo antigo... @@ -3015,7 +3015,7 @@ Tamanho do download: %3 QGBA::KeyEditor - + --- --- @@ -3822,17 +3822,27 @@ Tamanho do download: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached Tentando desconectar um jogador multiplayer que não está conectado - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached Tentando obter a ID do jogador pra um jogador multiplayer que não está conectado - + Trying to get save ID for a multiplayer player that's not attached Tentando obter a ID salva pra um jogador multiplayer que não está conectado @@ -4331,21 +4341,21 @@ Tamanho do download: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (desconhecido) - + bytes bytes - + (no database present) (nenhum banco de dados presente) @@ -4355,42 +4365,57 @@ Tamanho do download: %3 Informações da ROM - + + File information + + + + Game name: Nome do jogo: - + + MD5 + + + + + ROM header + + + + Internal name: Nome interno: - + Game ID: ID do Jogo: - + Maker Code: Código do Criador: - + Revision: Revisão: - + File size: Tamanho do arquivo: - + CRC32: CRC32: - + Save file: Arquivo do save: @@ -4823,58 +4848,67 @@ Tamanho do download: %3 Controles - + Shortcuts Atalhos - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Shaders - + Select BIOS Selecionar BIOS - + Select directory Selecione o diretório - + Select image Selecionar imagem - + Image file (*.png *.jpg *.jpeg) Arquivo da imagem (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Nunca - + Just now Aconteceu agora - + Less than an hour ago Menos do que a uma hora atrás - + %n hour(s) ago %n hora atrás @@ -4882,7 +4916,7 @@ Tamanho do download: %3 - + %n day(s) ago %n dia atrás @@ -5619,33 +5653,48 @@ Tamanho do download: %3 QGBA::ShaderSelector - + No shader active Nenhum shader ativo - - + + Load shader Carregar shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded Nenhum shader carregado - + by %1 por %1 - + Preprocessing Pré-processamento - + Pass %1 Passe %1 @@ -5951,80 +6000,80 @@ Tamanho do download: %3 QGBA::Window - + Archives (%1) Arquivos Compactados (%1) - - - + + + Select ROM Selecionar ROM - + Select folder Selecionar pasta - - + + Select save Selecionar save - + Select patch Selecionar patch - + Patches (*.ips *.ups *.bps) Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode Selecionar o dotcode do e-Reader - + e-Reader card (*.raw *.bin *.bmp) Cartão do e-Reader (*.raw *.bin *.bmp) - + Select image Selecionar imagem - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Arquivo de imagem (*.png *.gif *.jpg *.jpeg);;Todos os arquivos (*) - + GameShark saves (*.sps *.xps) Saves do GameShark (*.sps *.xps) - + Select video log Selecionar registro do vídeo - + Video logs (*.mvl) Registros do vídeo (*.mvl) - + Crash Crash - + The game has crashed with the following error: %1 @@ -6033,709 +6082,709 @@ Tamanho do download: %3 %1 - + Unimplemented BIOS call Chamada da BIOS não implementada - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Este jogo usa uma chamada de BIOS que não está implementada. Por favor use a BIOS oficial pra uma melhor experiência. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Falhou em criar um dispositivo de exibição apropriado, voltando a exibição por software. Os jogos podem executar lentamente, especialmente com janelas maiores. - + Really make portable? Realmente tornar portátil? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Isto fará o emulador carregar sua configuração do mesmo diretório que o executável. Você quer continuar? - + Restart needed Reiniciar é necessário - + Some changes will not take effect until the emulator is restarted. Algumas mudanças não terão efeito até o emulador ser reiniciado. - + - Player %1 of %2 - Jogador %1 de %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &Arquivo - + Load &ROM... Carregar &ROM... - + Load ROM in archive... Carregar a ROM no arquivo compactado... - + Add folder to library... Adicionar a pasta a biblioteca... - + Save games Saves dos jogos - + Automatically determine Determinar automaticamente - + Use player %0 save game Usar o save do jogo %0 do jogador - + Load &patch... Carregar &patch... - + Boot BIOS Inicializar a BIOS - + Replace ROM... Substituir a ROM... - + ROM &info... Informações da &ROM... - + Recent Recentes - + Make portable Tornar portátil - + &Load state &Carregar state - + Report bug... Reportar bug... - + About... Sobre... - + Game Pak sensors... Sensores do Game Pak... - + Clear Limpar - + Load state file... Carregar o arquivo do state... - + Save games (%1) Saves dos jogos (%1) - + Select save game Selecione o save do jogo - + mGBA save state files (%1) Arquivos do save state do mGBA (%1) - - + + Select save state Selecione um save state - + Select e-Reader card images Selecionar as imagens do cartão do e-Reader - + Image file (*.png *.jpg *.jpeg) Arquivo da imagem (*.png *.jpg *.jpeg) - + Conversion finished Conversão concluída - + %1 of %2 e-Reader cards converted successfully. %1 de %2 cartões do e-Reader convertidos com sucesso. - + Load alternate save game... Carregar save alternativo do jogo... - + Load temporary save game... Carregar save temporário do jogo... - + Convert e-Reader card image to raw... Converter a imagem do cartão do e-Reader pro natural... - + &Save state &Salvar o state - + Save state file... Arquivo do save state... - + Quick load Carregamento rápido - + Quick save Salvamento rápido - + Load recent Carregar recentes - + Save recent Salvar recentes - + Undo load state Desfazer o carregamento do state - + Undo save state Desfazer o save state - - + + State &%1 State &%1 - + Load camera image... Carregar a imagem da câmera... - + Convert save game... Converter o save do jogo... - + GameShark saves (*.gsv *.sps *.xps) Saves do GameShark (*.gsv *.sps *.xps) - + Reset needed Um reset é necessário - + Some changes will not take effect until the game is reset. Algumas mudanças não terão efeito até o jogo ser resetado. - + New multiplayer window Nova janela multi-jogador - + Connect to Dolphin... Conectar ao Dolphin... - + E&xit S&air - + &Emulation &Emulação - + &Reset &Resetar - + Sh&utdown De&sligar - + Yank game pak Arrancar o game pak - + &Pause &Pausar - + &Next frame &Próximo frame - + Fast forward (held) Avanço rápido (pressionado) - + &Fast forward &Avanço rápido - + Fast forward speed Velocidade do avanço rápido - + Unbounded Ilimitado - + %0x %0x - + Increase fast forward speed Aumentar a velocidade do avanço rápido - + Decrease fast forward speed Diminuir a velocidade do avanço rápido - + Rewind (held) Retroceder (pressionado) - + Re&wind Re&troceder - + Step backwards Voltar um passo - + Solar sensor Sensor solar - + Increase solar level Aumentar o nível solar - + Decrease solar level Diminuir o nível solar - + Brightest solar level Nível solar mais brilhante - + Darkest solar level Nível solar mais escuro - + Brightness %1 Brilho %1 - + Audio/&Video Ãudio/&Vídeo - + Frame size Tamanho do frame - + Toggle fullscreen Alternar tela cheia - + &Lock frame size &Travar o tamanho do frame - + Lock aspect ratio Travar a proporção do aspecto - + Force integer scaling Forçar o dimensionamento do inteiro - + Bilinear filtering Filtragem bilinear - + Frame&skip Frame&skip - + Mute Mudo - + FPS target FPS alvo - + Native (59.7275) Nativo (59,7275) - + Take &screenshot Tirar &screenshot - + F12 F12 - + Game Boy Printer... Impressora do Game Boy... - + BattleChip Gate... Portal do BattleChip... - + %1× %1× - + Interframe blending Mistura do interframe - + Record A/V... Gravar A/V... - + Video layers Camadas do vídeo - + Audio channels Canais de áudio - + Adjust layer placement... Ajustar o posicionamento da camada... - + &Tools &Ferramentas - + View &logs... Visualizar &registros... - + Game &overrides... Substituições &do jogo... - + Couldn't Start Não Pôde Iniciar - + Could not start game. Não pôde iniciar o jogo. - + Scan e-Reader dotcodes... Escanear os dotcodes do e-Reader... - + Import GameShark Save... Importar Save do GameShark... - + Export GameShark Save... Exportar Save do GameShark... - + Record GIF/WebP/APNG... Gravar GIF/WebP/APNG... - + &Cheats... &Trapaças... - + Settings... Configurações... - + Open debugger console... Abrir o console do debugger... - + Start &GDB server... Iniciar servidor do &GDB... - + Scripting... Scripting... - + Create forwarder... Criar encaminhador... - + Game state views Visualizações do estado do jogo - + View &palette... Visualizar &paleta... - + View &sprites... Visualizar &imagens móveis... - + View &tiles... Visualizar &mosaicos... - + View &map... Visualizar &mapa... - + &Frame inspector... Inspetor dos &frames... - + View memory... Visualizar memória... - + Search memory... Procurar na memória... - + View &I/O registers... Visualizar registros de &E/S... - + Log memory &accesses... Registrar os acessos a &memória... - + Record debug video log... Gravar registro do vídeo de debug... - + Stop debug video log Parar o registro do vídeo de debug - + Exit fullscreen Sair da tela cheia - + GameShark Button (held) Botão do GameShark (pressionado) - + Autofire Auto-disparar - + Autofire A Auto-disparar A - + Autofire B Auto-disparar B - + Autofire L Auto-disparar L - + Autofire R Auto-disparar R - + Autofire Start Auto-disparar Start - + Autofire Select Auto-disparar Select - + Autofire Up Auto-disparar Pra Cima - + Autofire Right Auto-disparar Direita - + Autofire Down Auto-disparar Pra Baixo - + Autofire Left Auto-disparar Esquerda diff --git a/src/platform/qt/ts/mgba-pt_PT.ts b/src/platform/qt/ts/mgba-pt_PT.ts index f6c819d37d5..5f4a2e76ff0 100644 --- a/src/platform/qt/ts/mgba-pt_PT.ts +++ b/src/platform/qt/ts/mgba-pt_PT.ts @@ -480,7 +480,7 @@ Tamanho da descarga: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3015,7 +3015,7 @@ Tamanho da descarga: %3 QGBA::KeyEditor - + --- --- @@ -3822,17 +3822,27 @@ Tamanho da descarga: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached A tentar desconectar um jogador multiplayer que não está conectado - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached A tentar obter a ID do jogador para um jogador multiplayer que não está conectado - + Trying to get save ID for a multiplayer player that's not attached A tentar obter a ID gravada para um jogador multiplayer que não está conectado @@ -4331,21 +4341,21 @@ Tamanho da descarga: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (desconhecido) - + bytes bytes - + (no database present) (nenhum banco de dados presente) @@ -4355,42 +4365,57 @@ Tamanho da descarga: %3 Informações da ROM - + + File information + + + + Game name: Nome do jogo: - + + MD5 + + + + + ROM header + + + + Internal name: Nome interno: - + Game ID: ID do Jogo: - + Maker Code: - + Revision: - + File size: Tamanho do ficheiro: - + CRC32: CRC32: - + Save file: Ficheiro do save: @@ -4823,58 +4848,67 @@ Tamanho da descarga: %3 Controles - + Shortcuts Atalhos - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Shaders - + Select BIOS Selecionar BIOS - + Select directory Selecione o diretório - + Select image Selecionar imagem - + Image file (*.png *.jpg *.jpeg) Ficheiro da imagem (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Nunca - + Just now Aconteceu agora - + Less than an hour ago Menos do que uma hora atrás - + %n hour(s) ago %n hora atrás @@ -4882,7 +4916,7 @@ Tamanho da descarga: %3 - + %n day(s) ago %n dia atrás @@ -5619,33 +5653,48 @@ Tamanho da descarga: %3 QGBA::ShaderSelector - + No shader active Nenhum shader ativo - - + + Load shader Carregar shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded Nenhum shader carregado - + by %1 por %1 - + Preprocessing Pré-processamento - + Pass %1 Passe %1 @@ -5951,80 +6000,80 @@ Tamanho da descarga: %3 QGBA::Window - + Archives (%1) Ficheiros Compactados (%1) - - - + + + Select ROM Selecionar ROM - + Select folder Selecionar pasta - - + + Select save Selecionar save - + Select patch Selecionar patch - + Patches (*.ips *.ups *.bps) Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode Selecionar dotcode do e-Reader - + e-Reader card (*.raw *.bin *.bmp) Cartão do e-Reader (*.raw *.bin *.bmp) - + Select image Selecionar imagem - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Ficheiro de imagem (*.png *.gif *.jpg *.jpeg);;Todos os ficheiros (*) - + GameShark saves (*.sps *.xps) Saves do GameShark (*.sps *.xps) - + Select video log Selecionar registo do vídeo - + Video logs (*.mvl) Registos do vídeo (*.mvl) - + Crash Crash - + The game has crashed with the following error: %1 @@ -6033,709 +6082,709 @@ Tamanho da descarga: %3 %1 - + Couldn't Start Não Pôde Iniciar - + Could not start game. Não pôde iniciar o jogo. - + Unimplemented BIOS call Chamada da BIOS não implementada - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Este jogo usa uma chamada de BIOS que não está implementada. Por favor use a BIOS oficial para uma melhor experiência. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Falhou em criar um aparelho de exibição apropriado, voltando a exibição por software. Os jogos podem executar lentamente, especialmente com janelas maiores. - + Really make portable? Realmente tornar portátil? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Isto fará o emulador carregar a configuração dele do mesmo diretório que o executável. Quer continuar? - + Restart needed Reiniciar é necessário - + Some changes will not take effect until the emulator is restarted. Algumas mudanças não terão efeito até o emulador ser reiniciado. - + - Player %1 of %2 - Jogador %1 de %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File &Ficheiro - + Load &ROM... Carregar &ROM... - + Load ROM in archive... Carregar ROM no arquivo... - + Add folder to library... Adicionar pasta a biblioteca... - + Save games (%1) Saves dos jogos (%1) - + Select save game Selecione save do jogo - + mGBA save state files (%1) Ficheiro do save state do mGBA (%1) - - + + Select save state Selecione um save state - + Select e-Reader card images Selecionar imagens do cartão do e-Reader - + Image file (*.png *.jpg *.jpeg) Ficheiro da imagem (*.png *.jpg *.jpeg) - + Conversion finished Conversão concluída - + %1 of %2 e-Reader cards converted successfully. %1 de %2 cartões do e-Reader convertidos com sucesso. - + Load alternate save game... Carregar save alternativo do jogo... - + Load temporary save game... Carregar save temporário do jogo... - + Load &patch... Carregar &patch... - + Boot BIOS Dar Boot na BIOS - + Replace ROM... Substituir a ROM... - + Scan e-Reader dotcodes... Escanear dotcodes do e-Reader... - + Convert e-Reader card image to raw... Converter imagem do cartão do e-Reader para natural... - + ROM &info... Informações da &ROM... - + Recent Recentes - + Make portable Tornar portátil - + &Load state &Carregar state - + Load state file... Carregar ficheiro do state... - + &Save state &Gravar o state - + Save state file... Ficheiro do save state... - + Quick load Carregamento rápido - + Quick save Salvamento rápido - + Load recent Carregar recentes - + Save recent Gravar recentes - + Undo load state Desfazer o carregamento do state - + Undo save state Desfazer o save state - - + + State &%1 State &%1 - + Load camera image... Carregar a imagem da câmara... - + Convert save game... Converter o save do jogo... - + GameShark saves (*.gsv *.sps *.xps) Saves do GameShark (*.gsv *.sps *.xps) - + Reset needed É necessário resetar - + Some changes will not take effect until the game is reset. Algumas mudanças não terão efeito até o jogo ser resetado. - + Save games Saves dos jogos - + Import GameShark Save... Importar Save do GameShark... - + Export GameShark Save... Exportar Save do GameShark... - + Automatically determine Determinar automaticamente - + Use player %0 save game Usar o save do jogo %0 do jogador - + New multiplayer window Nova janela multi-jogador - + Connect to Dolphin... Conectar ao Dolphin... - + Report bug... Reportar bug... - + About... Sobre... - + E&xit S&air - + &Emulation &Emulação - + &Reset &Resetar - + Sh&utdown De&sligar - + Yank game pak Arrancar o game pak - + &Pause &Pausar - + &Next frame &Próximo frame - + Fast forward (held) Avanço rápido (segurado) - + &Fast forward &Avanço rápido - + Fast forward speed Velocidade do avanço rápido - + Unbounded Ilimitado - + %0x %0x - + Increase fast forward speed Aumentar a velocidade do avanço rápido - + Decrease fast forward speed Diminuir a velocidade do avanço rápido - + Rewind (held) Retroceder (segurado) - + Re&wind Re&troceder - + Step backwards Voltar um passo - + Solar sensor Sensor solar - + Increase solar level Aumentar nível solar - + Decrease solar level Diminuir nível solar - + Brightest solar level Nível solar mais brilhante - + Darkest solar level Nível solar mais escuro - + Brightness %1 Brilho %1 - + Game Boy Printer... Impressora do Game Boy... - + BattleChip Gate... Portal do BattleChip... - + Audio/&Video Ãudio/&Vídeo - + Frame size Tamanho do frame - + %1× %1× - + Toggle fullscreen Alternar ecrã inteiro - + &Lock frame size - + Lock aspect ratio Travar a proporção do aspeto - + Force integer scaling Forçar o dimensionamento do inteiro - + Interframe blending Mistura do interframe - + Bilinear filtering Filtragem bilinear - + Frame&skip Frame&skip - + Mute Mudo - + FPS target FPS alvo - + Native (59.7275) Nativo (59,7275) - + Take &screenshot Tirar &screenshot - + F12 F12 - + Record A/V... Gravar A/V... - + Record GIF/WebP/APNG... Gravar GIF/WebP/APNG... - + Video layers Camadas do vídeo - + Audio channels Canais de áudio - + Adjust layer placement... Ajustar posicionamento da camada... - + &Tools &Ferramentas - + View &logs... Visualizar &registos... - + Game &overrides... Substituições &do jogo... - + Game Pak sensors... Sensores do Game Pak... - + &Cheats... &Trapaças... - + Create forwarder... Criar encaminhador... - + Settings... Configurações... - + Open debugger console... Abrir console do debugger... - + Start &GDB server... Iniciar servidor do &GDB... - + Scripting... Scripting... - + Game state views Visualizações do estado do jogo - + View &palette... Visualizar &paleta... - + View &sprites... Visualizar &imagens móveis... - + View &tiles... Visualizar &ladrilhos... - + View &map... Visualizar &mapa... - + &Frame inspector... Inspetor dos &frames... - + View memory... Visualizar memória... - + Search memory... Procurar na memória... - + View &I/O registers... Visualizar registos de &E/S... - + Log memory &accesses... - + Record debug video log... Gravar registo do vídeo de debug... - + Stop debug video log Parar o registo do vídeo de debug - + Exit fullscreen Sair do ecrã inteiro - + GameShark Button (held) Botão do GameShark (segurado) - + Autofire Auto-disparar - + Autofire A Auto-disparar A - + Autofire B Auto-disparar B - + Autofire L Auto-disparar L - + Autofire R Auto-disparar R - + Autofire Start Auto-disparar Start - + Autofire Select Auto-disparar Select - + Autofire Up Auto-disparar Para Cima - + Autofire Right Auto-disparar Direita - + Autofire Down Auto-disparar Para Baixo - + Autofire Left Auto-disparar Esquerda - + Clear Limpar diff --git a/src/platform/qt/ts/mgba-ru.ts b/src/platform/qt/ts/mgba-ru.ts index 5f130f18ed2..35b3f0ecb65 100644 --- a/src/platform/qt/ts/mgba-ru.ts +++ b/src/platform/qt/ts/mgba-ru.ts @@ -480,7 +480,7 @@ Download size: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3015,7 +3015,7 @@ Download size: %3 QGBA::KeyEditor - + --- --- @@ -3822,17 +3822,27 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4331,21 +4341,21 @@ Download size: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (неизвеÑтно) - + bytes байт - + (no database present) (нет в базе данных) @@ -4355,42 +4365,57 @@ Download size: %3 Ð˜Ð½Ñ„Ð¾Ñ€Ð¼Ð°Ñ†Ð¸Ñ Ð¾ ROM - + + File information + + + + Game name: Ðазвание игры: - + + MD5 + + + + + ROM header + + + + Internal name: Внутреннее наименование: - + Game ID: ID игры: - + Maker Code: - + Revision: - + File size: Размер файла: - + CRC32: CRC32: - + Save file: @@ -4823,58 +4848,67 @@ Download size: %3 Контроллеры - + Shortcuts Ð¡Ð¾Ñ‡ÐµÑ‚Ð°Ð½Ð¸Ñ ÐºÐ»Ð°Ð²Ð¸Ñˆ - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Шейдеры - + Select BIOS Выбор BIOS - + Select directory Выбор папки - + Select image Выбор Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ - + Image file (*.png *.jpg *.jpeg) Файл Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Ðикогда - + Just now Только ÑÐµÐ¹Ñ‡Ð°Ñ - + Less than an hour ago Менее чаÑа назад - + %n hour(s) ago %n Ñ‡Ð°Ñ Ð½Ð°Ð·Ð°Ð´ @@ -4883,7 +4917,7 @@ Download size: %3 - + %n day(s) ago %n день назад @@ -5621,33 +5655,48 @@ Download size: %3 QGBA::ShaderSelector - + No shader active Ðет активных шейдеров - - + + Load shader Загрузка шейдера - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded Ðет загруженных шейдеров - + by %1 автор %1 - + Preprocessing Предобработка - + Pass %1 Проход %1 @@ -5953,80 +6002,80 @@ Download size: %3 QGBA::Window - + Archives (%1) Ðрхивы (%1) - - - + + + Select ROM Выбор игры - + Select folder Выбор папки - - + + Select save Выбор ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ - + Select patch Выбор патча - + Patches (*.ips *.ups *.bps) Патчи (*.ips *.ups *.bps) - + Select e-Reader dotcode Выбор карточки e-Reader - + e-Reader card (*.raw *.bin *.bmp) Карточка e-Reader (*.raw *.bin *.bmp) - + Select image Выбор Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Файл Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) Ð¡Ð¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ GameShark (*.sps *.xps) - + Select video log Выбор видеолога - + Video logs (*.mvl) Видеологи (*.mvl) - + Crash Сбой - + The game has crashed with the following error: %1 @@ -6035,709 +6084,709 @@ Download size: %3 %1 - + Couldn't Start ЗапуÑк не удалÑÑ - + Could not start game. Ðе удалоÑÑŒ запуÑтить игру. - + Unimplemented BIOS call ÐеизвеÑтный вызов BIOS - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Игра иÑпользует нереализованный вызов BIOS. ПожалуйÑта, воÑпользуйтеÑÑŒ официальным BIOS Ð´Ð»Ñ Ð»ÑƒÑ‡ÑˆÐµÐ¹ ÑовмеÑтимоÑти. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Ðе удалоÑÑŒ Ñоздать уÑтройÑтво отображениÑ, возврат к программному режиму. Игры могут идти медленнее, оÑобенно в окнах больших размеров. - + Really make portable? Перейти в портативный режим? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? ПоÑле Ñтого ÑмулÑтор будет загружать конфигурацию из папки Ñ Ð¸ÑполнÑемым файлом. Продолжить? - + Restart needed ТребуетÑÑ Ð¿ÐµÑ€ÐµÐ·Ð°Ð¿ÑƒÑк - + Some changes will not take effect until the emulator is restarted. Ð”Ð»Ñ Ð¿Ñ€Ð¸Ð¼ÐµÐ½ÐµÐ½Ð¸Ñ Ð½ÐµÐºÐ¾Ñ‚Ð¾Ñ€Ñ‹Ñ… изменений требуетÑÑ Ð¿ÐµÑ€ÐµÐ·Ð°Ð¿ÑƒÑтить ÑмулÑтор. - + - Player %1 of %2 - Игрок %1 из %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File &Файл - + Load &ROM... Загрузить &ROM... - + Load ROM in archive... Загрузить игру из архива... - + Add folder to library... Добавить папку в библиотеку... - + Save games (%1) Игровые ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ (%1) - + Select save game Выбор игрового ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ - + mGBA save state files (%1) Файл ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ ÑоÑтоÑÐ½Ð¸Ñ mGBA (%1) - - + + Select save state Выбор ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ ÑоÑтоÑÐ½Ð¸Ñ - + Select e-Reader card images Выбор Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ ÐºÐ°Ñ€Ñ‚Ð¾Ñ‡ÐºÐ¸ e-Reader - + Image file (*.png *.jpg *.jpeg) Файл Ð¸Ð·Ð¾Ð±Ñ€Ð°Ð¶ÐµÐ½Ð¸Ñ (*.png *.jpg *.jpeg) - + Conversion finished ÐšÐ¾Ð½Ð²ÐµÑ€Ñ‚Ð°Ñ†Ð¸Ñ Ð·Ð°Ð²ÐµÑ€ÑˆÐµÐ½Ð° - + %1 of %2 e-Reader cards converted successfully. %1 из %2 карточек e-Reader уÑпешно Ñконвертировано. - + Load alternate save game... Загрузить альтернативное Ñохранение... - + Load temporary save game... Загрузить временное Ñохранение... - + Load &patch... Загрузить &патч... - + Boot BIOS ЗагрузитьÑÑ Ð² BIOS - + Replace ROM... Заменить ROM... - + Scan e-Reader dotcodes... Сканировать dot-коды e-Reader... - + Convert e-Reader card image to raw... Конвертировать карту e-Reader в raw... - + ROM &info... Ð˜Ð½Ñ„Ð¾Ñ€Ð¼Ð°Ñ†Ð¸Ñ Ð¾Ð± &игре... - + Recent Ðедавние - + Make portable Портативный режим - + &Load state &Загрузить ÑоÑтоÑние - + Load state file... Загрузить ÑоÑтоÑние из файла... - + &Save state &Сохранить ÑоÑтоÑние - + Save state file... Сохранить ÑоÑтоÑние в файл... - + Quick load БыÑÑ‚Ñ€Ð°Ñ Ð·Ð°Ð³Ñ€ÑƒÐ·ÐºÐ° - + Quick save БыÑтрое Ñохранение - + Load recent Загрузить недавнее - + Save recent Сохранить в недавнее - + Undo load state Отмена загрузки ÑоÑтоÑÐ½Ð¸Ñ - + Undo save state Отмена ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ ÑоÑтоÑÐ½Ð¸Ñ - - + + State &%1 Слот &%1 - + Load camera image... Загрузить изображение Ñ ÐºÐ°Ð¼ÐµÑ€Ñ‹... - + Convert save game... Конвертировать игровое Ñохранение... - + GameShark saves (*.gsv *.sps *.xps) Ð¡Ð¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ GameShark (*.gsv *.sps *.xps) - + Reset needed Ðеобходима перезагрузка - + Some changes will not take effect until the game is reset. Ðекоторые Ð¸Ð·Ð¼ÐµÐ½ÐµÐ½Ð¸Ñ Ð½Ðµ войдут в Ñилу, пока игра не перезагружена. - + Save games Ð¡Ð¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ - + Import GameShark Save... Импорт ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ GameShark... - + Export GameShark Save... ЭкÑпорт ÑÐ¾Ñ…Ñ€Ð°Ð½ÐµÐ½Ð¸Ñ GameShark... - + Automatically determine Определить автоматичеÑки - + Use player %0 save game ИÑпользовать Ñохранение игрока %0 - + New multiplayer window Ðовое окно мультиплеера - + Connect to Dolphin... Соединение Ñ Dolphin... - + Report bug... Сообщить об ошибке... - + About... О программе... - + E&xit &Выход - + &Emulation &ЭмулÑÑ†Ð¸Ñ - + &Reset Перезагрузить (&R/&К) - + Sh&utdown Выключить (&U/&Г) - + Yank game pak Пнуть картридж - + &Pause Пау&за - + &Next frame Следующий кадр (&N/&Т) - + Fast forward (held) Перемотка (удержание) - + &Fast forward Перемотк&а - + Fast forward speed СкороÑÑ‚ÑŒ перемотки - + Unbounded ÐÐµÐ¾Ð³Ñ€Ð°Ð½Ð¸Ñ‡ÐµÐ½Ð½Ð°Ñ - + %0x %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) ÐžÐ±Ñ€Ð°Ñ‚Ð½Ð°Ñ Ð¿ÐµÑ€ÐµÐ¼Ð¾Ñ‚ÐºÐ° (удержание) - + Re&wind ÐžÐ±Ñ€Ð°Ñ‚Ð½Ð°Ñ Ð¿ÐµÑ€ÐµÐ¼Ð¾Ñ‚ÐºÐ° (&W/&Ц) - + Step backwards Шаг назад - + Solar sensor Датчик Ñолнца - + Increase solar level УÑилить Ñолнечный Ñвет - + Decrease solar level ОÑлабить Ñолнечный Ñвет - + Brightest solar level Ярчайшее Ñолнце - + Darkest solar level ТуÑклейшее Ñолнце - + Brightness %1 ЯркоÑÑ‚ÑŒ %1 - + Game Boy Printer... - + BattleChip Gate... - + Audio/&Video Ðудио/Видео (&V/&Ðœ) - + Frame size Размер кадра - + %1× %1× - + Toggle fullscreen Переключить полноÑкранный режим - + &Lock frame size - + Lock aspect ratio ЗафикÑировать Ñоотношение Ñторон - + Force integer scaling Принудительное целочиÑленное маÑштабирование - + Interframe blending Межкадровое Ñмешение - + Bilinear filtering Ð‘Ð¸Ð»Ð¸Ð½ÐµÐ¹Ð½Ð°Ñ Ñ„Ð¸Ð»ÑŒÑ‚Ñ€Ð°Ñ†Ð¸Ñ - + Frame&skip ПропуÑк кадров (&S/&Ы) - + Mute Выключить звук - + FPS target Целевой FPS - + Native (59.7275) Родной (59.7275) - + Take &screenshot СнÑÑ‚ÑŒ Ñкриншот (&S/&Ы) - + F12 F12 - + Record A/V... ЗапиÑать аудио/видео... - + Record GIF/WebP/APNG... ЗапиÑать GIF/WebP/APNG... - + Video layers ВидеоÑлои - + Audio channels Ðудиоканалы - + Adjust layer placement... ÐаÑтроить раÑположение Ñлоёв... - + &Tools ИнÑтрум&енты - + View &logs... ПоÑмотреть в журнал... (&L/&Д) - + Game &overrides... ÐŸÐµÑ€ÐµÐ¾Ð¿Ñ€ÐµÐ´ÐµÐ»ÐµÐ½Ð¸Ñ Ð´Ð»Ñ Ñтой игры... (&О/&Щ) - + Game Pak sensors... Датчики в Game Pak... - + &Cheats... Читы... (&C/&С) - + Create forwarder... - + Settings... ÐаÑтройки... - + Open debugger console... Открыть конÑоль отладки... - + Start &GDB server... ЗапуÑтить Ñервер &GDB... - + Scripting... Скрипты... - + Game state views ПроÑмотр ÑоÑтоÑÐ½Ð¸Ñ Ð¸Ð³Ñ€Ñ‹ - + View &palette... ПроÑмотр палитры... (&P/&З) - + View &sprites... ПроÑмотр Ñпрайтов... (&S/&Ы) - + View &tiles... ПроÑмотр тайлов... (&T/&Е) - + View &map... ПроÑмотр карты... (&M/&Ь) - + &Frame inspector... Изучение фрейм&а... - + View memory... ПроÑмотр памÑти... - + Search memory... ПоиÑк в памÑти... - + View &I/O registers... ПроÑмотр региÑтров &I/O... - + Log memory &accesses... - + Record debug video log... ЗапиÑÑŒ отладочного видеожурнала... - + Stop debug video log Закончить запиÑÑŒ отладочного видеожурнала - + Exit fullscreen Выйти из полноÑкранного режима - + GameShark Button (held) Кнопка GameShark (удерживаетÑÑ) - + Autofire ÐвтоÑтрельба - + Autofire A A (автоÑтрельба) - + Autofire B B (автоÑтрельба) - + Autofire L L (автоÑтрельба) - + Autofire R R (автоÑтрельба) - + Autofire Start Start (автоÑтрельба) - + Autofire Select Select (автоÑтрельба) - + Autofire Up Вверх (автоÑтрельба) - + Autofire Right Вправо (автоÑтрельба) - + Autofire Down Вниз (автоÑтрельба) - + Autofire Left Влево (автоÑтрельба) - + Clear ОчиÑтить diff --git a/src/platform/qt/ts/mgba-sv.ts b/src/platform/qt/ts/mgba-sv.ts index 6f6d30651cf..b0ddef6a8f1 100644 --- a/src/platform/qt/ts/mgba-sv.ts +++ b/src/platform/qt/ts/mgba-sv.ts @@ -480,7 +480,7 @@ Hämtningsstorlek: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... Misslyckades med att skapa en OpenGL 3-kontext, provar old-style... @@ -3015,7 +3015,7 @@ Hämtningsstorlek: %3 QGBA::KeyEditor - + --- --- @@ -3348,7 +3348,7 @@ Hämtningsstorlek: %3 Offset - + Förskjut @@ -3822,17 +3822,27 @@ Hämtningsstorlek: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4331,21 +4341,21 @@ Hämtningsstorlek: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (okänt) - + bytes bytes - + (no database present) (finns ingen databas) @@ -4355,42 +4365,57 @@ Hämtningsstorlek: %3 ROM-info - + + File information + + + + Game name: Spelnamn: - + + MD5 + + + + + ROM header + + + + Internal name: Internt namn: - + Game ID: Spel-ID: - + Maker Code: Tillverkarkod: - + Revision: Revision: - + File size: Filstorlek: - + CRC32: CRC32: - + Save file: Sparad fil: @@ -4823,58 +4848,67 @@ Hämtningsstorlek: %3 Handkontroller - + Shortcuts Genvägar - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Shaders - + Select BIOS Välj BIOS - + Select directory Välj katalog - + Select image Välj bild - + Image file (*.png *.jpg *.jpeg) Bildfil (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never Aldrig - + Just now Just nyss - + Less than an hour ago Mindre än en timme sedan - + %n hour(s) ago %n timme sedan @@ -4882,7 +4916,7 @@ Hämtningsstorlek: %3 - + %n day(s) ago %n dag sedan @@ -5347,7 +5381,7 @@ Hämtningsstorlek: %3 Unbounded - + Obunden @@ -5619,33 +5653,48 @@ Hämtningsstorlek: %3 QGBA::ShaderSelector - + No shader active Ingen shader aktiv - - + + Load shader Läs in shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded Ingen shader inläst - + by %1 av %1 - + Preprocessing Förbehandling - + Pass %1 Pass %1 @@ -5951,80 +6000,80 @@ Hämtningsstorlek: %3 QGBA::Window - + Archives (%1) Arkiv (%1) - - - + + + Select ROM Välj ROM - + Select folder Välj mapp - - + + Select save Välj sparning - + Select patch Välj patch - + Patches (*.ips *.ups *.bps) Patchar (*.ips *.ups *.bps) - + Select e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) e-Reader-kort (*.raw *.bin *.bmp) - + Select image Välj bild - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Bildfil (*.png *.gif *.jpg *.jpeg);;Alla filer (*) - + GameShark saves (*.sps *.xps) GameShark-sparningar (*.sps *.xps) - + Select video log Välj videologg - + Video logs (*.mvl) Videologgar (*.mvl) - + Crash Krasch - + The game has crashed with the following error: %1 @@ -6033,709 +6082,709 @@ Hämtningsstorlek: %3 %1 - + Couldn't Start Kunde inte starta - + Could not start game. Kunde inte starta spel. - + Unimplemented BIOS call - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + Really make portable? Verkligen göra portabel? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Detta komma att göra att emulatorn läser in sin konfiguration frÃ¥n samma katalog som den körbara filen. Vill du fortsätta? - + Restart needed Omstart krävs - + Some changes will not take effect until the emulator is restarted. Vissa ändringar kommer inte ge effekt tills emulatorn har startats om. - + - Player %1 of %2 - Spelare %1 av %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 bilder/s) - %4 - + &File &Arkiv - + Load &ROM... Läs in &ROM... - + Load ROM in archive... Läs in ROM i arkiv... - + Add folder to library... Lägg till mapp till bibliotek... - + Save games (%1) Sparade spel (%1) - + Select save game Välj sparat spel - + mGBA save state files (%1) mGBA-filer för sparat tillstÃ¥nd (%1) - - + + Select save state Välj sparat tillstÃ¥nd - + Select e-Reader card images Välj e-Reader-kortavbilder - + Image file (*.png *.jpg *.jpeg) Bildfil (*.png *.jpg *.jpeg) - + Conversion finished Konvertering färdig - + %1 of %2 e-Reader cards converted successfully. %1 av %2 e-Reader-kort konverterades. - + Load alternate save game... Läs in alternativt sparat spel... - + Load temporary save game... Läs in temporärt sparat spel... - + Load &patch... Läs in &patch... - + Boot BIOS Starta upp BIOS - + Replace ROM... Ersätt ROM... - + Scan e-Reader dotcodes... Skanna e-Reader-punktkoder... - + Convert e-Reader card image to raw... Konvertera e-Reader-kortavbilder till raw... - + ROM &info... ROM-&info... - + Recent Senaste - + Make portable Gör den portabel - + &Load state &Läs in tillstÃ¥nd - + Load state file... Läs in tillstÃ¥ndsfil... - + &Save state &Spara tillstÃ¥nd - + Save state file... Spara tillstÃ¥ndsfil... - + Quick load Snabbinläsning - + Quick save Snabbsparning - + Load recent Läs in senaste - + Save recent Spara senaste - + Undo load state Ã…ngra inläst tillstÃ¥nd - + Undo save state Ã…ngra sparat tillstÃ¥nd - - + + State &%1 TillstÃ¥nd &%1 - + Load camera image... Läs in kamerabild... - + Convert save game... Konvertera sparat spel... - + GameShark saves (*.gsv *.sps *.xps) GameShark-sparningar (*.gsv *.sps *.xps) - + Reset needed Omstart krävs - + Some changes will not take effect until the game is reset. Vissa ändringar kommer inte bli effektiva tills spelet har startats om. - + Save games Sparade spel - + Import GameShark Save... Importera GameShark-sparning... - + Export GameShark Save... Exportera GameShark-sparning... - + Automatically determine Bestäm automatiskt - + Use player %0 save game - + New multiplayer window Nytt flerspelarfönster - + Connect to Dolphin... Anslut till Dolphin... - + Report bug... Rapportera fel... - + About... Om... - + E&xit A&vsluta - + &Emulation &Emulering - + &Reset Starta &om - + Sh&utdown Stäng &ner - + Yank game pak - + &Pause &Paus - + &Next frame &Nästa bildruta - + Fast forward (held) Snabbspolning (hÃ¥ll) - + &Fast forward Snabbs&pola - + Fast forward speed Snabbspolningshastighet - + Unbounded Obunden - + %0x %0x - + Increase fast forward speed Öka snabbspolningshastighet - + Decrease fast forward speed Sänk snabbspolningshastighet - + Rewind (held) Spola tillbaka (hÃ¥ll) - + Re&wind Spola ti&llbaka - + Step backwards Stega bakÃ¥t - + Solar sensor Solsensor - + Increase solar level Öka solnivÃ¥ - + Decrease solar level Sänk solnivÃ¥ - + Brightest solar level Starkaste solnivÃ¥n - + Darkest solar level Mörkaste solnivÃ¥n - + Brightness %1 Ljusstyrka %1 - + Game Boy Printer... Game Boy-skrivare... - + BattleChip Gate... - + Audio/&Video Ljud/&Video - + Frame size Bildrutestorlek - + %1× %1× - + Toggle fullscreen Växla helskärm - + &Lock frame size &LÃ¥s bildrutestorlek - + Lock aspect ratio LÃ¥s bildförhÃ¥llande - + Force integer scaling Tvinga heltalsskalning - + Interframe blending - + Bilinear filtering Bilinjär filtrering - + Frame&skip - + Mute Tyst - + FPS target - + Native (59.7275) Inbyggd (59.7275) - + Take &screenshot Ta s&kärmbild - + F12 F12 - + Record A/V... Spela in ljud/bild... - + Record GIF/WebP/APNG... Spela in GIF/WebP/APNG... - + Video layers Videolager - + Audio channels Ljudkanaler - + Adjust layer placement... Justera lagerplacering... - + &Tools Ver&ktyg - + View &logs... Visa &loggar... - + Game &overrides... - + Game Pak sensors... Game Pak-sensorer... - + &Cheats... &Fusk... - + Create forwarder... - + Settings... Inställningar... - + Open debugger console... Öppna felsökningskonsoll... - + Start &GDB server... Starta &GDB-server... - + Scripting... Skriptning... - + Game state views - + View &palette... Visa &palett... - + View &sprites... Visa &sprites... - + View &tiles... Visa &brickor... - + View &map... Visa &karta... - + &Frame inspector... Inspektera bi&ldrutor... - + View memory... Visa minne... - + Search memory... Sök i minnet... - + View &I/O registers... Visa I/&O-register... - + Log memory &accesses... Logga minnesÃ¥&tkomster... - + Record debug video log... Spela in felsökningsvideologg... - + Stop debug video log Stoppa felsökningsvideologg - + Exit fullscreen Avsluta helskärm - + GameShark Button (held) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear Töm diff --git a/src/platform/qt/ts/mgba-template.ts b/src/platform/qt/ts/mgba-template.ts index 8cd293d9b85..0155d9c068b 100644 --- a/src/platform/qt/ts/mgba-template.ts +++ b/src/platform/qt/ts/mgba-template.ts @@ -474,7 +474,7 @@ Download size: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3009,7 +3009,7 @@ Download size: %3 QGBA::KeyEditor - + --- @@ -3816,17 +3816,27 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4325,21 +4335,21 @@ Download size: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) - + bytes - + (no database present) @@ -4349,42 +4359,57 @@ Download size: %3 - + + File information + + + + Game name: - + + MD5 + + + + + ROM header + + + + Internal name: - + Game ID: - + Maker Code: - + Revision: - + File size: - + CRC32: - + Save file: @@ -4817,65 +4842,74 @@ Download size: %3 - + Shortcuts - - - Shaders + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + Shaders + + + + Select BIOS - + Select directory - + Select image - + Image file (*.png *.jpg *.jpeg) - + (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago - + %n day(s) ago @@ -5611,33 +5645,48 @@ Download size: %3 QGBA::ShaderSelector - + No shader active - - + + Load shader - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded - + by %1 - + Preprocessing - + Pass %1 @@ -5943,789 +5992,789 @@ Download size: %3 QGBA::Window - + Archives (%1) - - - + + + Select ROM - + Select folder - - + + Select save - + Select patch - + Patches (*.ips *.ups *.bps) - + Select e-Reader dotcode - + e-Reader card (*.raw *.bin *.bmp) - + Select image - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) - + Select video log - + Video logs (*.mvl) - + Crash - + The game has crashed with the following error: %1 - + Couldn't Start - + Could not start game. - + Unimplemented BIOS call - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - + Really make portable? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - + Restart needed - + Some changes will not take effect until the emulator is restarted. - + - Player %1 of %2 - + %1 - %2 - + %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File - + Load &ROM... - + Load ROM in archive... - + Add folder to library... - + Save games (%1) - + Select save game - + mGBA save state files (%1) - - + + Select save state - + Select e-Reader card images - + Image file (*.png *.jpg *.jpeg) - + Conversion finished - + %1 of %2 e-Reader cards converted successfully. - + Load alternate save game... - + Load temporary save game... - + Load &patch... - + Boot BIOS - + Replace ROM... - + Scan e-Reader dotcodes... - + Convert e-Reader card image to raw... - + ROM &info... - + Recent - + Make portable - + &Load state - + Load state file... - + &Save state - + Save state file... - + Quick load - + Quick save - + Load recent - + Save recent - + Undo load state - + Undo save state - - + + State &%1 - + Load camera image... - + Convert save game... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + Save games - + Import GameShark Save... - + Export GameShark Save... - + Automatically determine - + Use player %0 save game - + New multiplayer window - + Connect to Dolphin... - + Report bug... - + About... - + E&xit - + &Emulation - + &Reset - + Sh&utdown - + Yank game pak - + &Pause - + &Next frame - + Fast forward (held) - + &Fast forward - + Fast forward speed - + Unbounded - + %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) - + Re&wind - + Step backwards - + Solar sensor - + Increase solar level - + Decrease solar level - + Brightest solar level - + Darkest solar level - + Brightness %1 - + Game Boy Printer... - + BattleChip Gate... - + Audio/&Video - + Frame size - + %1× - + Toggle fullscreen - + &Lock frame size - + Lock aspect ratio - + Force integer scaling - + Interframe blending - + Bilinear filtering - + Frame&skip - + Mute - + FPS target - + Native (59.7275) - + Take &screenshot - + F12 - + Record A/V... - + Record GIF/WebP/APNG... - + Video layers - + Audio channels - + Adjust layer placement... - + &Tools - + View &logs... - + Game &overrides... - + Game Pak sensors... - + &Cheats... - + Create forwarder... - + Settings... - + Open debugger console... - + Start &GDB server... - + Scripting... - + Game state views - + View &palette... - + View &sprites... - + View &tiles... - + View &map... - + &Frame inspector... - + View memory... - + Search memory... - + View &I/O registers... - + Log memory &accesses... - + Record debug video log... - + Stop debug video log - + Exit fullscreen - + GameShark Button (held) - + Autofire - + Autofire A - + Autofire B - + Autofire L - + Autofire R - + Autofire Start - + Autofire Select - + Autofire Up - + Autofire Right - + Autofire Down - + Autofire Left - + Clear diff --git a/src/platform/qt/ts/mgba-tr.ts b/src/platform/qt/ts/mgba-tr.ts index 59e0855316f..aaafaf98821 100644 --- a/src/platform/qt/ts/mgba-tr.ts +++ b/src/platform/qt/ts/mgba-tr.ts @@ -480,7 +480,7 @@ Yeni sürüm: %2 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... @@ -3015,7 +3015,7 @@ Yeni sürüm: %2 QGBA::KeyEditor - + --- @@ -3822,17 +3822,27 @@ Yeni sürüm: %2 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached - + Trying to get save ID for a multiplayer player that's not attached @@ -4331,21 +4341,21 @@ Yeni sürüm: %2 QGBA::ROMInfo - - - - - + + + + + (unknown) (bilinmeyen) - + bytes - + (no database present) (veritabanı yok) @@ -4355,42 +4365,57 @@ Yeni sürüm: %2 ROM bilgisi - + + File information + + + + Game name: Oyun adı: - + + MD5 + + + + + ROM header + + + + Internal name: Dahili Ä°sim: - + Game ID: - + Maker Code: - + Revision: - + File size: Dosya boyutu: - + CRC32: - + Save file: @@ -4823,65 +4848,74 @@ Yeni sürüm: %2 - + Shortcuts Kısayollar - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders Gölgelendiricler - + Select BIOS BIOS seç - + Select directory Yolu seç - + Select image Resim seç - + Image file (*.png *.jpg *.jpeg) Görüntü dosyası (*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never - + Just now - + Less than an hour ago - + %n hour(s) ago - + %n day(s) ago @@ -5617,33 +5651,48 @@ Yeni sürüm: %2 QGBA::ShaderSelector - + No shader active Hiçbir Gölgelendirici aktif deÄŸil - - + + Load shader Gölgelendirici yükle - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded Gölgelendirici yüklenmedi - + by %1 - + Preprocessing Ä°ÅŸleniyor - + Pass %1 @@ -5949,100 +5998,100 @@ Yeni sürüm: %2 QGBA::Window - + Archives (%1) ArÅŸivler (%1) - - - + + + Select ROM ROM seç - + Select folder Klasör seç - - + + Select save Kayıt seç - + Select patch Yama seç - + Patches (*.ips *.ups *.bps) Yamalar (*.ips *.ups *.bps) - + Select e-Reader dotcode e-Okuyucu nokta kodunu seç - + e-Reader card (*.raw *.bin *.bmp) e-Okuyucu kart (*.raw *.bin *.bmp) - + Select e-Reader card images e-Okuyucu kartından görüntüleri seç - + Image file (*.png *.jpg *.jpeg) Görüntü dosyası (*.png *.jpg *.jpeg) - + Conversion finished Dönüştürme tamamlandı - + %1 of %2 e-Reader cards converted successfully. %1 / %2 e-Okuyucu kartları dönüştürme tamamlandı. - + Select image Resim seç - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) Resim dosyası (*.png *.gif *.jpg *.jpeg);;All files (*) - + GameShark saves (*.sps *.xps) GameShark kayıtları (*.sps *.xps) - + Select video log Video günlüğü seç - + Video logs (*.mvl) Video günlükleri (*.mvl) - + Crash Çökme - + The game has crashed with the following error: %1 @@ -6051,689 +6100,689 @@ Yeni sürüm: %2 %1 - + Unimplemented BIOS call Uygulanmamış BIOS giriÅŸi - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. Oyun BIOS dosyasına ihtiyacı var. Lütfen en iyi deneyim için resmi BIOS'u kullanın. - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. Uygun görüntü cihazı oluÅŸturma baÅŸarısız, yazılım ekranına dönülüyor. Oyunlar özellikle daha büyük ekranlarda yavaÅŸ çalışabilir. - + Really make portable? Taşınabilir yapılsın mı? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? Öyküncünün yapılandırmasını yürütülebilir dosya ile aynı dizinden yüklemesini saÄŸlar. Devam etmek istiyor musunuz? - + Restart needed Yeniden baÅŸlatma gerekli - + Some changes will not take effect until the emulator is restarted. Bazı deÄŸiÅŸiklikler öyküncü yeniden baÅŸlatılıncaya kadar etkili olmaz. - + - Player %1 of %2 - + %1 - %2 - + %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 - + &File - + Load &ROM... &ROM yükle... - + Load ROM in archive... ROM'u arÅŸivden yükle ... - + Add folder to library... Kütüphaneye klasör ekle ... - + Save games Oyunları kaydet - + Automatically determine - + Use player %0 save game - + Load &patch... &Patch yükle... - + Boot BIOS BIOS boot et - + Replace ROM... ROM deÄŸiÅŸti... - + Create forwarder... - + Game state views - + Log memory &accesses... - + Convert e-Reader card image to raw... e-Okuyucu kart resimlerini rawa dönüştür... - + ROM &info... ROM &info... - + Recent Son kullanılanlar - + Make portable Portatif yap - + &Load state &KaydedilmiÅŸ konum yükle - + Load state file... KaydedilmiÅŸ konum dosyası yükle... - + &Save state &Konumu kaydet - + Save state file... Konum dosyasını kaydet... - + Quick load Hızlı Yükle - + Quick save Hızlı kaydet - + Load recent En son yükle - + Save recent Hızlı kaydet - + Undo load state Kaydedilen konum yüklemeyi geri al - + Undo save state Konum kaydetmeyi geri al - - + + State &%1 Konum &%1 - + Load camera image... Kamera resmini yükle ... - + Convert save game... Kayıtlı oyun dömnüştürülüyor... - + GameShark saves (*.gsv *.sps *.xps) - + Reset needed - + Some changes will not take effect until the game is reset. - + New multiplayer window Yeni çokoyunculu ekranı - + Connect to Dolphin... Dolphin'e BaÄŸlan... - + Report bug... Hata rapor et... - + About... Hakkında... - + E&xit Çıkış - + &Emulation Emülasyon - + &Reset &Reset - + Sh&utdown Kapat - + Yank game pak - + &Pause &Durdur - + &Next frame &Sonraki kare - + Fast forward (held) Ä°leriye sar(basılı tutun) - + &Fast forward &Ä°leriye sar - + Fast forward speed Ä°leriye sarma hızı - + Unbounded - + %0x - + Increase fast forward speed - + Decrease fast forward speed - + Rewind (held) Geri sar (basılı tutun) - + Re&wind Geri sar - + Step backwards Geriye doÄŸru adım - + Solar sensor - + Increase solar level Solar seviyesini arttır - + Decrease solar level Solar seviyesini düşür - + Brightest solar level En parlak solar seviyesi - + Darkest solar level En karanlık solar seviyesi - + Brightness %1 Parlaklık:%1 - + Game Boy Printer... Game Boy yazıcısı... - + BattleChip Gate... - + Audio/&Video Ses/&Video - + Frame size Çerçeve boyutu - + Toggle fullscreen Tamekranı aç/kapa - + &Lock frame size - + Lock aspect ratio En boy oranını kilitle - + Force integer scaling Tamsayılı ölçeklendirmeyi zorla - + Bilinear filtering Bilinear filtreleme - + Frame&skip Kare atlama - + Mute Sessiz - + FPS target FPS hedefi - + Native (59.7275) - + Take &screenshot Ekran görüntüsü al - + F12 - + Video layers - + Audio channels Ses kanalları - + Adjust layer placement... Katman yerleÅŸimini ayarlayın... - + &Tools &Araçlar - + View &logs... Kayıtları görüntüle... - + Game &overrides... & Oyunun üzerine yazılanlar... - + Couldn't Start BaÅŸlatılamadı - + Save games (%1) Kayıtlı oyunlar (%1) - + Select save game Kayıtlı oyun seç - + mGBA save state files (%1) mGBA kayıt durum dosyası (%1) - - + + Select save state Kayıt durumu seç - + Could not start game. Oyun baÅŸlatılamadı. - + Load alternate save game... Alternatif kayıtlı oyun yükle... - + Load temporary save game... Geçici kayıtlı oyunu yükle... - + Scan e-Reader dotcodes... e-Okuyucu noktakodları tara... - + Import GameShark Save... GameShark kaydını içeri aktar... - + Export GameShark Save... GameShark kaydını dışarı aktar... - + %1× %1× - + Interframe blending Kareler-arası Karıştırma - + Record A/V... A/V Kayıt... - + Record GIF/WebP/APNG... GIF/WebP/APNG Kayıt... - + Game Pak sensors... Oyun KartuÅŸ sensörleri... - + &Cheats... &Hileler... - + Settings... Ayarlar... - + Open debugger console... Hata ayıklayıcı konsolunu aç ... - + Start &GDB server... &GDB sunucusunu baÅŸlat... - + Scripting... - + View &palette... &Renk Paletini gör... - + View &sprites... &Spriteları gör... - + View &tiles... &Desenleri gör... - + View &map... &Haritayı gör - + &Frame inspector... &Kare denetçisi... - + View memory... Hafıza gör... - + Search memory... Hafızada ara... - + View &I/O registers... &I/O kayıtlarını görüntüle - + Record debug video log... Hata ayıklama video günlüğünü kaydet... - + Stop debug video log Hata ayıklama video günlüğünü durdur - + Exit fullscreen Tam ekrandan çık - + GameShark Button (held) GameShark Butonu (basılı tutun) - + Autofire Otomatik basma - + Autofire A Otomatik basma A - + Autofire B Otomatik basma B - + Autofire L Otomatik basma L - + Autofire R Otomatik basma R - + Autofire Start Otomatik basma Start - + Autofire Select Otomatik basma Select - + Autofire Up Otomatik basma Up - + Autofire Right Otomatik basma Right - + Autofire Down Otomatik basma Down - + Autofire Left Otomatik basma Sol - + Clear Temizle diff --git a/src/platform/qt/ts/mgba-zh_CN.ts b/src/platform/qt/ts/mgba-zh_CN.ts index be19fdd1444..a051d76fbed 100644 --- a/src/platform/qt/ts/mgba-zh_CN.ts +++ b/src/platform/qt/ts/mgba-zh_CN.ts @@ -480,7 +480,7 @@ Download size: %3 QGBA::DisplayGL - + Failed to create an OpenGL 3 context, trying old-style... 创建OpenGL3环境失败,请å°è¯•æ—§å½¢å¼... @@ -3015,7 +3015,7 @@ Download size: %3 QGBA::KeyEditor - + --- --- @@ -3822,17 +3822,27 @@ Download size: %3 QGBA::MultiplayerController - + Trying to detach a multiplayer player that's not attached å°è¯•æ–­å¼€ä¸Žæœªè¿žæŽ¥çš„多人玩家的连接 - + + Clearing invalid save ID + + + + + Clearing invalid preferred ID + + + + Trying to get player ID for a multiplayer player that's not attached å°è¯•èŽ·å–未连接的多人玩家的 ID - + Trying to get save ID for a multiplayer player that's not attached å°è¯•èŽ·å–未连接的多人玩家的存档 ID @@ -4331,21 +4341,21 @@ Download size: %3 QGBA::ROMInfo - - - - - + + + + + (unknown) (未知) - + bytes 字节 - + (no database present) (无现存数æ®åº“) @@ -4355,42 +4365,57 @@ Download size: %3 ROM ä¿¡æ¯ - + + File information + + + + Game name: 游æˆå称: - + + MD5 + + + + + ROM header + + + + Internal name: 内部å称: - + Game ID: æ¸¸æˆ ID: - + Maker Code: 创建者代ç ï¼š - + Revision: 修订: - + File size: 文件大å°: - + CRC32: CRC32: - + Save file: ä¿å­˜æ–‡ä»¶: @@ -4823,65 +4848,74 @@ Download size: %3 控制器 - + Shortcuts å¿«æ·é”® - - + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + + + + + + + Shaders ç€è‰²å™¨ - + Select BIOS 选择 BIOS - + Select directory 选择目录 - + Select image 选择图片 - + Image file (*.png *.jpg *.jpeg) 图åƒæ–‡ä»¶ï¼ˆ*.png *.jpg *.jpeg) - + (%1×%2) (%1×%2) - + Never ä»Žä¸ - + Just now 刚刚 - + Less than an hour ago ä¸åˆ°ä¸€å°æ—¶å‰ - + %n hour(s) ago %n å°æ—¶å‰ - + %n day(s) ago %n å¤©å‰ @@ -5617,33 +5651,48 @@ Download size: %3 QGBA::ShaderSelector - + No shader active 无激活的ç€è‰²å™¨ - - + + Load shader 载入ç€è‰²å™¨ - + + mGBA Shaders + + + + + Error loading shader + + + + + The shader "%1" could not be loaded successfully. + + + + No shader loaded ä¸è½½å…¥ç€è‰²å™¨ - + by %1 ç”± %1 - + Preprocessing é¢„å¤„ç† - + Pass %1 é€šé“ %1 @@ -5949,80 +5998,80 @@ Download size: %3 QGBA::Window - + Archives (%1) 压缩文件 (%1) - - - + + + Select ROM 选择 ROM - + Select folder 选择文件夹 - - + + Select save 选择存档 - + Select patch é€‰æ‹©è¡¥ä¸ - + Patches (*.ips *.ups *.bps) è¡¥ä¸ (*.ips *.ups *.bps) - + Select e-Reader dotcode 选择 e-Reader ç‚¹ç  - + e-Reader card (*.raw *.bin *.bmp) e-Reader å¡ (*.raw *.bin *.bmp) - + Select image 选择图片 - + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) 图åƒæ–‡ä»¶ (*.png *.gif *.jpg *.jpeg);;所有文件 (*) - + GameShark saves (*.sps *.xps) GameShark 存档 (*.sps *.xps) - + Select video log 选择视频日志 - + Video logs (*.mvl) 视频日志文件 (*.mvl) - + Crash 崩溃 - + The game has crashed with the following error: %1 @@ -6031,709 +6080,709 @@ Download size: %3 %1 - + Couldn't Start 无法å¯åŠ¨ - + Could not start game. 无法å¯åŠ¨æ¸¸æˆã€‚ - + Unimplemented BIOS call 未实现的 BIOS 调用 - + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. 此游æˆä½¿ç”¨å°šæœªå®žçŽ°çš„ BIOS 调用。请使用官方 BIOS 以获得最佳体验。 - + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. 无法创建适åˆçš„显示设备,正在回滚到软件显示。游æˆçš„è¿è¡Œé€Ÿåº¦ï¼ˆç‰¹åˆ«åœ¨å¤§çª—å£çš„情况下)å¯èƒ½ä¼šå˜æ…¢ã€‚ - + Really make portable? 确定进行程åºä¾¿æºåŒ–? - + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? 进行此æ“作åŽï¼Œæ¨¡æ‹Ÿå™¨å°†ä»Žå…¶å¯æ‰§è¡Œæ–‡ä»¶æ‰€åœ¨ç›®å½•ä¸­è½½å…¥æ¨¡æ‹Ÿå™¨é…置。您想继续å—? - + Restart needed 需è¦é‡æ–°å¯åŠ¨ - + Some changes will not take effect until the emulator is restarted. 更改将在模拟器下次é‡æ–°å¯åŠ¨æ—¶ç”Ÿæ•ˆã€‚ - + - Player %1 of %2 - 玩家 %1 å…± %2 - + %1 - %2 %1 - %2 - + %1 - %2 - %3 %1 - %2 - %3 - + %1 - %2 (%3 fps) - %4 %1 - %2 (%3 fps) - %4 - + &File 文件(&F) - + Load &ROM... 载入 ROM(&R)... - + Load ROM in archive... 从压缩文件中载入 ROM... - + Add folder to library... 将文件夹添加到库中... - + Save games (%1) ä¿å­˜æ¸¸æˆ (%1) - + Select save game 选择ä¿å­˜æ¸¸æˆ - + mGBA save state files (%1) mGBA å³æ—¶å­˜æ¡£æ–‡ä»¶ (%1) - - + + Select save state 选择å³æ—¶å­˜æ¡£ - + Select e-Reader card images 选择 e-Reader å¡ç‰‡å›¾åƒ - + Image file (*.png *.jpg *.jpeg) 图åƒæ–‡ä»¶ï¼ˆ*.png *.jpg *.jpeg) - + Conversion finished 转æ¢å®Œæˆ - + %1 of %2 e-Reader cards converted successfully. æˆåŠŸè½¬æ¢äº† %1 张(共 %2 张)e-Reader å¡ç‰‡ã€‚ - + Load alternate save game... 加载备用ä¿å­˜æ¸¸æˆ... - + Load temporary save game... 加载临时ä¿å­˜æ¸¸æˆ... - + Load &patch... 载入补ä¸(&P)... - + Boot BIOS 引导 BIOS - + Replace ROM... æ›¿æ¢ ROM... - + Scan e-Reader dotcodes... 扫æ e-Reader 点ç ... - + Convert e-Reader card image to raw... å°† e-Reader å¡ç‰‡å›¾åƒè½¬æ¢ä¸ºåŽŸå§‹æ•°æ®... - + ROM &info... ROM ä¿¡æ¯(&I)... - + Recent 最近打开 - + Make portable 程åºä¾¿æºåŒ– - + &Load state 载入å³æ—¶å­˜æ¡£(&L) - + Load state file... 载入å³æ—¶å­˜æ¡£æ–‡ä»¶... - + &Save state ä¿å­˜å³æ—¶å­˜æ¡£(&S) - + Save state file... ä¿å­˜å³æ—¶å­˜æ¡£æ–‡ä»¶... - + Quick load 快速读档 - + Quick save 快速存档 - + Load recent 载入最近存档 - + Save recent ä¿å­˜æœ€è¿‘存档 - + Undo load state 撤消读档 - + Undo save state 撤消存档 - - + + State &%1 å³æ—¶å­˜æ¡£ (&%1) - + Load camera image... 载入相机图片... - + Convert save game... 转æ¢ä¿å­˜æ¸¸æˆ... - + GameShark saves (*.gsv *.sps *.xps) GameShark 存档 (*.gsv *.sps *.xps) - + Reset needed 需è¦é‡å¯ - + Some changes will not take effect until the game is reset. æŸäº›æ”¹åŠ¨éœ€è¦é‡æ–°å¯åŠ¨æ‰ä¼šç”Ÿæ•ˆã€‚ - + Save games 游æˆå­˜æ¡£ - + Import GameShark Save... 导入 GameShark 存档... - + Export GameShark Save... 导出 GameShark 存档... - + Automatically determine 自动终止 - + Use player %0 save game 使用玩家 %0 存档 - + New multiplayer window 新建多人游æˆçª—å£ - + Connect to Dolphin... 连接到 Dolphin... - + Report bug... 报告错误... - + About... 关于... - + E&xit 退出(&X) - + &Emulation 模拟(&E) - + &Reset é‡ç½®(&R) - + Sh&utdown 关机(&U) - + Yank game pak 快速抽出游æˆå¡å¸¦ - + &Pause æš‚åœ(&P) - + &Next frame 下一帧(&N) - + Fast forward (held) å¿«è¿› (长按) - + &Fast forward å¿«è¿›(&F) - + Fast forward speed 快进速度 - + Unbounded ä¸é™åˆ¶ - + %0x %0x - + Increase fast forward speed 加快快进速度 - + Decrease fast forward speed é™ä½Žå¿«è¿›é€Ÿåº¦ - + Rewind (held) 倒带 (长按) - + Re&wind 倒带(&W) - + Step backwards 步退 - + Solar sensor 太阳光传感器 - + Increase solar level 增加太阳光等级 - + Decrease solar level é™ä½Žå¤ªé˜³å…‰ç­‰çº§ - + Brightest solar level 太阳光等级为最亮 - + Darkest solar level 太阳光等级为最暗 - + Brightness %1 亮度 %1 - + Game Boy Printer... Game Boy 打å°æœº... - + BattleChip Gate... BattleChip Gate... - + Audio/&Video 音频/视频(&V) - + Frame size ç”»é¢å¤§å° - + %1× %1× - + Toggle fullscreen 切æ¢å…¨å± - + &Lock frame size é”定帧大å°(&L) - + Lock aspect ratio é”定纵横比 - + Force integer scaling 强制整数缩放 - + Interframe blending å¸§é—´æ··åˆ - + Bilinear filtering åŒçº¿æ€§è¿‡æ»¤ - + Frame&skip 跳帧(&S) - + Mute é™éŸ³ - + FPS target 目标 FPS - + Native (59.7275) 原生 (59.7275) - + Take &screenshot 截图(&S) - + F12 F12 - + Record A/V... 录制音频/视频... - + Record GIF/WebP/APNG... 录制 GIF/WebP/APNG... - + Video layers 视频图层 - + Audio channels éŸ³é¢‘å£°é“ - + Adjust layer placement... 调整图层布局... - + &Tools 工具(&T) - + View &logs... 查看日志(&L)... - + Game &overrides... 覆写游æˆ(&O)... - + Game Pak sensors... 游æˆå¡å¸¦ä¼ æ„Ÿå™¨... - + &Cheats... 作弊ç (&C)... - + Create forwarder... 创建转å‘器... - + Settings... 设置... - + Open debugger console... 打开调试器控制å°... - + Start &GDB server... 打开 GDB æœåŠ¡å™¨(&G)... - + Scripting... 脚本... - + Game state views 游æˆçŠ¶æ€è§†å›¾ - + View &palette... 查看调色æ¿(&P)... - + View &sprites... 查看精çµå›¾(&S)... - + View &tiles... 查看图å—(&T)... - + View &map... 查看映射(&M)... - + &Frame inspector... 帧检查器(&F)... - + View memory... 查看内存... - + Search memory... æœç´¢å†…å­˜... - + View &I/O registers... 查看 I/O 寄存器(&I)... - + Log memory &accesses... 记录内存访问(&a)... - + Record debug video log... 记录调试视频日志... - + Stop debug video log åœæ­¢è®°å½•è°ƒè¯•è§†é¢‘日志 - + Exit fullscreen é€€å‡ºå…¨å± - + GameShark Button (held) GameShark é”® (长按) - + Autofire è¿žå‘ - + Autofire A è¿žå‘ A - + Autofire B è¿žå‘ B - + Autofire L è¿žå‘ L - + Autofire R è¿žå‘ R - + Autofire Start è¿žå‘ Start - + Autofire Select è¿žå‘ Select - + Autofire Up è¿žå‘ ä¸Š - + Autofire Right è¿žå‘ å³ - + Autofire Down è¿žå‘ ä¸‹ - + Autofire Left è¿žå‘ å·¦ - + Clear 清除 diff --git a/src/platform/qt/ts/mgba-zh_Hant.ts b/src/platform/qt/ts/mgba-zh_Hant.ts index 279452fe565..8cbb231b5e0 100644 --- a/src/platform/qt/ts/mgba-zh_Hant.ts +++ b/src/platform/qt/ts/mgba-zh_Hant.ts @@ -1,6182 +1,6861 @@ - + - AboutScreen + QGBA + + + Game Boy Advance ROMs (%1) + Game Boy Advance ROMs (%1) + + + + Game Boy ROMs (%1) + Game Boy ROMs (%1) + + + + All ROMs (%1) + 所有 ROMs (%1) + + + + %1 Video Logs (*.mvl) + %1 影片記錄檔 (*.mvl) + + + + QGBA::AboutScreen About - 關於 + 關於 <a href="http://mgba.io/">Website</a> • <a href="https://forums.mgba.io/">Forums / Support</a> • <a href="https://patreon.com/mgba">Donate</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">Source</a> - <a href="http://mgba.io/">網站</a> • <a href="https://forums.mgba.io/">論壇ã€å–å¾—å”助</a> • <a href="https://patreon.com/mgba">贊助</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">原始碼</a> + <a href="http://mgba.io/">網站</a> • <a href="https://forums.mgba.io/">論壇ã€å–å¾—å”助</a> • <a href="https://patreon.com/mgba">贊助</a> • <a href="https://github.com/mgba-emu/mgba/tree/{gitBranch}">原始碼</a> Branch: <tt>{gitBranch}</tt><br/>Revision: <tt>{gitCommit}</tt> - 分支: <tt>{gitBranch}</tt><br/>修訂版: <tt>{gitCommit}</tt> + 分支: <tt>{gitBranch}</tt><br/>修訂版: <tt>{gitCommit}</tt> {projectName} would like to thank the following patrons from Patreon: - {projectName} æ„Ÿè¬ä»¥ä¸‹ Patreon 贊助者: + {projectName} æ„Ÿè¬ä»¥ä¸‹ Patreon 贊助者: © 2013 – {year} Jeffrey Pfau, licensed under the Mozilla Public License, version 2.0 Game Boy Advance is a registered trademark of Nintendo Co., Ltd. - © 2013 – {year} Jeffrey Pfau,基於 Mozilla 公共許å¯è­‰ï¼ˆç‰ˆæœ¬ 2.0)授權 + © 2013 – {year} Jeffrey Pfau,基於 Mozilla 公共許å¯è­‰ï¼ˆç‰ˆæœ¬ 2.0)授權 Game Boy Advance 是任天堂有é™å…¬å¸ï¼ˆNintendo Co., Ltd.)的註冊商標。 {projectName} is an open-source Game Boy Advance emulator - {projectName} 是開æºçš„ Game Boy Advance 模擬器 + {projectName} 是開æºçš„ Game Boy Advance 模擬器 - ApplicationUpdatePrompt + QGBA::ApplicationUpdatePrompt + + + An update to %1 is available. + + %1 有å¯ç”¨çš„更新。 + + + + + +Do you want to download and install it now? You will need to restart the emulator when the download is complete. + +您想è¦ç«‹å³ä¸‹è¼‰ä¸¦å®‰è£å—Žï¼Ÿä¸‹è¼‰å®Œæˆå¾Œï¼Œæ‚¨éœ€è¦é‡æ–°å•Ÿå‹•æ¨¡æ“¬å™¨ã€‚ + + + + +Auto-update is not available on this platform. If you wish to update you will need to do it manually. + +此平å°ä¸æ”¯æ´è‡ªå‹•æ›´æ–°ã€‚若您希望更新則必須手動進行。 + + + + Current version: %1 +New version: %2 +Download size: %3 + ç¾åœ¨ç‰ˆæœ¬: %1 +新版本: %2 +下載的檔案大å°: %3 + + + + Downloading update... + 正在下載更新... + + + + Downloading failed. Please update manually. + 下載失敗。請手動更新。 + + + + Downloading done. Press OK to restart %1 and install the update. + 下載完æˆã€‚按下 OK é‡æ–°å•Ÿå‹• %1 並安è£æ›´æ–°ã€‚ + An update is available - 有å¯ç”¨çš„æ›´æ–° + 有å¯ç”¨çš„æ›´æ–° + + + + QGBA::ApplicationUpdater + + + Stable + 穩定版本 + + + + Development + 開發版本 + + + + Unknown + 未知 + + + + (None) + (ç„¡) - ArchiveInspector + QGBA::ArchiveInspector Open in archive... - 在壓縮文件中打開... + 在壓縮文件中打開... Loading... - 正在載入... + 正在載入... - AssetTile + QGBA::AssetTile + + + + + 0x%0 (%1) + 0x%0 (%1) + Tile # - 圖塊 # + 圖塊 # Palette # - 調色盤 # + 調色盤 # Address - ä½å€ + ä½å€ Red - ç´… + ç´… Green - 綠 + 綠 Blue - è— + è— + + + + QGBA::AudioDevice + + + Can't set format of context-less audio device + + + + + Audio device is missing its core + + + + + Writing data to read-only audio device + + + + + QGBA::AudioProcessorQt + + + Can't start an audio processor without input + + + + + QGBA::AudioProcessorSDL + + + Can't start an audio processor without input + - BattleChipView + QGBA::BattleChipView BattleChip Gate - 戰鬥晶片閘 + 戰鬥晶片閘 Chip name - 晶片å稱 + 晶片å稱 Insert - æ’å…¥ + æ’å…¥ Save - 存檔 + Load - è®€å– + Add - 加入 + 加入 Remove - 移除 + 移除 Gate type - 閘門類別 + 閘門類別 Inserted - å·²æ’å…¥ + å·²æ’å…¥ Chip ID - 晶片ID + 晶片ID Update Chip data - 更新晶片資料 + 更新晶片資料 Show advanced - 顯示進階é¸é … + 顯示進階é¸é … + + + + BattleChip data missing + + + + + BattleChip data is missing. BattleChip Gates will still work, but some graphics will be missing. Would you like to download the data now? + + + + + + Select deck file + + + + + Incompatible deck + + + + + The selected deck is not compatible with this Chip Gate + + + + + QGBA::CheatsModel + + + (untitled) + (無標題) + + + + Failed to open cheats file: %1 + 金手指開啟失敗: %1 - CheatsView + QGBA::CheatsView + + + + Autodetect (recommended) + 自動åµæ¸¬ (建議) + + + + + Select cheats file + é¸æ“‡é‡‘手指 + + + + Some cheats could not be added. Please ensure they're formatted correctly and/or try other cheat types. + + Cheats - 金手指 + 金手指 Add New Code - 新增金手指 + 新增金手指 + + + + Load + + + + + Save + Remove - 移除 + 移除 + + + + Enter codes here... + 在此輸入代碼... Add Lines - 新增一行 + 新增一行 Code type - 代碼類型 + 代碼類型 + + + QGBA::CoreController - - Save - 儲存 + + Reset r%1-%2 %3 + - - Load - 載入 + + + Rewinding not currently enabled + - - Enter codes here... - 在此輸入代碼... + + Reset the game? + + + + + Most games will require a reset to load the new save. Do you want to reset now? + + + + + Failed to open save file: %1 + 存檔開啟失敗: %1 + + + + Failed to open game file: %1 + éŠæˆ²é–‹å•Ÿå¤±æ•—: %1 + + + + Can't yank pack in unexpected platform! + 無法在é æ–™å¤–çš„å¹³å°æ‹”除å¡å¸¶ï¼ + + + + Failed to open snapshot file for reading: %1 + 讀å–快照失敗: %1 + + + + Failed to open snapshot file for writing: %1 + 寫入快照失敗: %1 - DebuggerConsole + QGBA::CoreManager + + + Failed to open game file: %1 + éŠæˆ²é–‹å•Ÿå¤±æ•—: %1 + + + + Could not load game. Are you sure it's in the correct format? + 無法讀å–éŠæˆ²ã€‚您確定格å¼æ­£ç¢ºå—Žï¼Ÿ + + + + Failed to open save file; in-game saves cannot be updated. Please ensure the save directory is writable without additional privileges (e.g. UAC on Windows). + 無法開啟存檔;éŠæˆ²å…§å­˜æª”無法更新。請確定存檔路徑的寫入ä¸éœ€è¦é¡å¤–æ¬Šé™ (å³ Windows çš„ UAC)。 + + + + QGBA::DebuggerConsole Debugger - 除錯器 + 除錯器 Enter command (try `help` for more info) - 輸入指令 (更多資訊請見「幫助ã€) + 輸入指令 (更多資訊請見「幫助ã€) Break - 中斷 + 中斷 - DolphinConnector + QGBA::DebuggerConsoleController + + + Could not open CLI history for writing + + + + + QGBA::DisplayGL + + + Failed to create an OpenGL 3 context, trying old-style... + + + + + QGBA::DolphinConnector Connect to Dolphin - 連接 Dolphin + 連接 Dolphin Local computer - å€åŸŸé›»è…¦ + å€åŸŸé›»è…¦ IP address - IPä½å€ + IPä½å€ Connect - 連接 + 連接 Disconnect - 中斷連接 + 中斷連接 Close - 關閉 + 關閉 Reset on connect - 連接後é‡æ–°å•Ÿå‹• + 連接後é‡æ–°å•Ÿå‹• + + + + Couldn't Connect + + + + + Could not connect to Dolphin. + - FrameView + QGBA::ForwarderGenerator - - Inspect frame - 檢查畫格 + + 3DS + - - Magnification - 放大 + + Vita + + + + QGBA::ForwarderGenerator3DS - - Freeze frame - æš«åœç•«æ ¼ + + Icon + - - Backdrop color - 背景é¡è‰² + + Banner + + + + QGBA::ForwarderGeneratorVita - - Disable scanline effects - åœç”¨æŽƒæ線特效 + + Bubble + - - Export - 匯出 + + Background + 背景 - - Reset - é‡æ–°å•Ÿå‹• + + Startup + - GIFView + QGBA::ForwarderView - - Record GIF/WebP/APNG - 錄製 GIF/WebP/APNG + + Create forwarder + - - Loop - 循環 + + Files + - - Start - 開始 + + ROM file: + - - Stop - åœæ­¢ + + + + Browse + ç€è¦½ - - Select File - é¸æ“‡æª”案 + + Output filename: + - - APNG - APNG + + Forwarder base: + - - GIF - GIF + + Latest stable version + - - WebP - WebP + + Latest development build + - - Frameskip - è·³éŽç•«æ ¼ + + Specific file + - - - IOViewer - - I/O Viewer - I/O 檢視器 + + Base file: + - - 0x0000 - 0x0000 + + System + - - B - B + + 3DS + - - - LibraryTree - - Name - å稱 + + Vita + - - Location - ä½ç½® + + Presentation + - - Platform - å¹³å° + + Title: + - - Size - å¤§å° + + Images: + - - CRC32 - CRC32 + + Use default image + - - - LoadSaveState - - - %1 State - %1 å³æ™‚存檔 + + Preferred size: + - - - - - - - - - - No Save - 無存檔 + + Select image file + - - 5 - 5 + + Select ROM file + - - 6 - 6 + + Select output filename + - - 8 - 8 + + Select base file + - - 4 - 4 + + Build finished + - - 1 - 1 + + Forwarder finished building + - - 3 - 3 + + Build failed + - - 7 - 7 + + Failed to build forwarder + - - 9 - 9 + + %1 installable package (*.%2) + - - 2 - 2 + + Select an image + - - Cancel - å–消 + + Image files (*.png *.jpg *.bmp) + - LogView + QGBA::FrameView - - Logs - 記錄 + + Export frame + 匯出畫格 - - Enabled Levels - å·²å•Ÿç”¨çš„é—œå¡ + + Portable Network Graphics (*.png) + å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) - - Debug - 除錯 + + None + ç„¡ - - Stub - æ¸¬è©¦æ¨ + + Background + 背景 - - Info - 資訊 + + Window + 視窗 - - Warning - 警告 + + Objwin + Objwin - - Error - 錯誤 + + Sprite + 角色圖 - - Fatal - åš´é‡ + + Backdrop + 背景 - - Game Error - éŠæˆ²éŒ¯èª¤ + + Frame + ç•«æ ¼ - - Advanced settings - 進階設定 + + %1 %2 + %1 %2 - - Clear - 清除 + + Inspect frame + 檢查畫格 - - Max Lines - 最大行數 + + Magnification + 放大 - - - MapView - - Maps - 映射 + + Freeze frame + æš«åœç•«æ ¼ - - Magnification - 放大 + + Backdrop color + 背景é¡è‰² - + + Disable scanline effects + åœç”¨æŽƒæ線特效 + + + Export - 匯出 + 匯出 - - Copy - 複製 + + Reset + é‡æ–°å•Ÿå‹• - MemoryDump + QGBA::GBAApp - - Save Memory Range - è¨˜æ†¶é«”å„²å­˜ç¯„åœ + + Enable Discord Rich Presence + 啟用 Discord Rich Presence + + + QGBA::GBAKeyEditor - - Start Address: - 起始ä½å€: + + Clear Button + 清除按鈕 - - Byte Count: - ä½å…ƒçµ„數: + + Clear Analog + 清除類比輸入 - - Dump across banks - è·¨è¨˜æ†¶åº«å‚¾å° + + Refresh + é‡æ–°æ•´ç† + + + + Set all + 設定全部 - MemorySearch + QGBA::GDBWindow - - Memory Search - æœå°‹è¨˜æ†¶é«” + + Server settings + 伺æœå™¨è¨­å®š - - Address - ä½å€ + + Local port + å€åŸŸåŸ  - - Current Value - ç›®å‰çš„值 + + Bind address + ç¶å®šä½å€ - - - Type - 型別 + + Write watchpoints behavior + - - Value - 值 + + Standard GDB + - - Numeric - 數字 + + Internal change detection + - - Text - 文字 + + Break on all writes + - - Width - 寬度 + + Break + 中斷 - - - Guess - é æ¸¬ + + Stop + åœæ­¢ - - 1 Byte (8-bit) - 1 ä½å…ƒçµ„ (8 ä½å…ƒ) + + Start + 開始 - - 2 Bytes (16-bit) - 2 ä½å…ƒçµ„ (16 ä½å…ƒ) + + Crash + 當機 - - 4 Bytes (32-bit) - 4 ä½å…ƒçµ„ (32 ä½å…ƒ) + + Could not start GDB server + 無法啟動 GDB 伺æœå™¨ + + + QGBA::GIFView - - Number type - 數字型別 + + Failed to open output file: %1 + 輸出檔案開啟失敗: %1 - - Decimal - åé€²ä½ + + Select output file + é¸æ“‡è¼¸å‡ºçš„檔案 - - Hexadecimal - åå…­é€²ä½ + + Graphics Interchange Format (*.gif);;WebP ( *.webp);;Animated Portable Network Graphics (*.png *.apng) + 圖形互æ›æ ¼å¼ (*.gif);;WebP ( *.webp);;å‹•æ…‹å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png *.apng) - - Search type - æœå°‹åž‹åˆ¥ + + Record GIF/WebP/APNG + 錄製 GIF/WebP/APNG - - Equal to value - 等於值 + + Loop + 循環 - - Greater than value - 大於值 + + Start + - - Less than value - å°æ–¼å€¼ + + Stop + åœæ­¢ - - Unknown/changed - 未知/已變更 + + Select File + é¸æ“‡æª”案 - - Changed by value - 數值變更 + + APNG + APNG - - Unchanged - 未變更 + + GIF + GIF - - Increased - 增加 + + WebP + WebP - - Decreased - 減少 + + Frameskip + è·³éŽç•«æ ¼ + + + QGBA::GameBoy - - Search ROM - æœå°‹ ROM - - - - New Search - æ–°çš„æœå°‹ + + + Autodetect + 自動åµæ¸¬ - - Search Within - 在...裡æœå°‹ + + Game Boy (DMG) + - - Open in Memory Viewer - 在記憶體檢視器中打開 + + Game Boy Pocket (MGB) + - - Refresh - é‡æ–°æ•´ç† + + Super Game Boy (SGB) + - - - MemoryView - - Memory - 記憶體 + + Super Game Boy 2 (SGB) + - - Inspect Address: - 檢查ä½å€: + + Game Boy Color (CGB) + - - Set Alignment: - 資料å°é½Šè¨­å®š: + + Game Boy Advance (AGB) + - - &1 Byte - 1 ä½å…ƒçµ„ (&1) + + Super Game Boy Color (SGB + CGB) + - - &2 Bytes - 2 ä½å…ƒçµ„ (&2) + + ROM Only + - - &4 Bytes - 4 ä½å…ƒçµ„ (&4) + + MBC1 + - - Unsigned Integer: - 無符號整數: + + MBC2 + - - Signed Integer: - 有符號整數: + + MBC3 + - - String: - 字串: + + MBC3 + RTC + - - Load TBL - è®€å– TBL + + MBC5 + - - Copy Selection - è¤‡è£½æ‰€é¸ + + MBC5 + Rumble + - - Paste - 貼上 + + MBC6 + - - Save Selection - å„²å­˜æ‰€é¸ + + MBC7 (Tilt) + - - Save Range - å„²å­˜ç¯„åœ + + MMM01 + - - Load - è®€å– + + HuC-1 + - - - ObjView - - Sprites - 角色圖 + + HuC-3 + - - Address - ä½å€ + + Pocket Cam + - - Copy - 複製 + + TAMA5 + TAMA5 - - Magnification - 放大 + + Wisdom Tree + - - Geometry - 幾何 + + NT (old 1) + - - Position - ä½ç½® + + NT (old 2) + - - , - , + + NT (new) + - - Dimensions - 維度 + + Pokémon Jade/Diamond + - - × - × + + BBD + - - Matrix - 矩陣 + + Hitek + - - Export - 匯出 + + GGB-81 + - - Attributes - 屬性 + + Li Cheng + - - Transform - è®Šæ› + + Sachen (MMC1) + - - Off - é—œ + + Sachen (MMC2) + + + + QGBA::IOViewer - - Palette - 調色盤 + + Background mode + èƒŒæ™¯æ¨¡å¼ - - Double Size - å…©å€å¤§å° + + Mode 0: 4 tile layers + æ¨¡å¼ 0: 4 個圖塊層 - - - - Return, Ctrl+R - 返回,Ctrl+R + + Mode 1: 2 tile layers + 1 rotated/scaled tile layer + æ¨¡å¼ 1:2 個圖塊層 + 1 個å¯æ—‹è½‰/縮放圖塊層 - - Flipped - 已翻轉 + + Mode 2: 2 rotated/scaled tile layers + æ¨¡å¼ 2:2 個å¯æ—‹è½‰/縮放圖塊層 - - H - Short for horizontal - H + + Mode 3: Full 15-bit bitmap + æ¨¡å¼ 3: 完全 15 ä½å…ƒé»žé™£ - - V - Short for vertical - V + + Mode 4: Full 8-bit bitmap + æ¨¡å¼ 4: 完全 8 ä½å…ƒé»žé™£ - - Mode - æ¨¡å¼ + + Mode 5: Small 15-bit bitmap + æ¨¡å¼ 5: 15 ä½å…ƒç´°å°é»žé™£ - - Normal - 正常 + + CGB Mode + CGB æ¨¡å¼ - - Mosaic - 馬賽克 + + Frame select + ç•«æ ¼é¸æ“‡ - - Enabled - 已啟用 + + Unlocked HBlank + 解鎖的 HBlank - - Priority - 優先度 + + Linear OBJ tile mapping + 線性 OBJ 圖塊映射 - - Tile - 圖塊 + + Force blank screen + 強制清空螢幕 - - - OverrideView - - Game Overrides - éŠæˆ²æ›¿ä»£ + + Enable background 0 + 啟用背景 0 - - Game Boy Advance - Game Boy Advance + + Enable background 1 + 啟用背景 1 - - - - - Autodetect - 自動åµæ¸¬ + + Enable background 2 + 啟用背景 2 - - Realtime clock - 實時計時器 + + Enable background 3 + 啟用背景 3 - - Gyroscope - 陀螺儀 + + Enable OBJ + 啟用 OBJ - - Tilt - 傾斜 + + Enable Window 0 + 啟用視窗 0 - - Light sensor - 光感測器 + + Enable Window 1 + 啟用視窗 1 - - Rumble - 震動 + + Enable OBJ Window + 啟用 OBJ 視窗 - - Save type - 存檔類型 + + Swap green components + 替æ›ç¶ è‰²çµ„件 - - None - ç„¡ + + Currently in VBlank + ç›®å‰ VBlank 值 - - SRAM - SRAM + + Currently in HBlank + ç›®å‰ HBlank 值 - - Flash 512kb - Flash 512kb + + Currently in VCounter + ç›®å‰ VCounter 值 - - Flash 1Mb - Flash 1Mb + + Enable VBlank IRQ generation + å…許 VBlank 生æˆä¸­æ–·è«‹æ±‚ (IRQ) - - EEPROM 8kB - EEPROM 8kB + + Enable HBlank IRQ generation + å…許 HBlank 生æˆä¸­æ–·è«‹æ±‚ (IRQ) - - EEPROM 512 bytes - EEPROM 512 bytes + + Enable VCounter IRQ generation + å…許 VCounter 生æˆä¸­æ–·è«‹æ±‚ (IRQ) - - SRAM 64kB (bootlegs only) - SRAM 64kB (僅用於盜版å¡å¸¶) + + VCounter scanline + VCounter 掃æç·š - - Idle loop - 閒置迴圈 + + Current scanline + ç›®å‰çš„掃æç·š - - Game Boy Player features - Game Boy Player 特性 + + + + + Priority + 優先度 - - VBA bug compatibility mode - VBA éŒ¯èª¤ç›¸å®¹æ€§æ¨¡å¼ + + + + + Tile data base (* 16kB) + 圖塊資料基底 (* 16kB) - - Game Boy - Game Boy + + + + + Enable mosaic + 啟用馬賽克 - - Game Boy model - Game Boy 型號 + + + + + Enable 256-color + 啟用 256 色 - - Memory bank controller - 記憶庫控制器 + + + + + Tile map base (* 2kB) + 圖塊映射基底 (* 2kB) - - Background Colors - 背景é¡è‰² + + + + + Background dimensions + 背景維度 - - Sprite Colors 1 - 角色圖é¡è‰² 1 + + + Overflow wraps + 溢ä½å›žç¹ž - - Sprite Colors 2 - 角色圖é¡è‰² 2 + + + + + + + Horizontal offset + æ°´å¹³åç§»é‡ - - Palette preset - é è¨­èª¿è‰²ç›¤ + + + + + + + Vertical offset + åž‚ç›´åç§»é‡ - - - PaletteView - - Palette - 調色盤 + + + + + + + + + + + + + Fractional part + 分數部分 - - Background - 背景 + + + + + + + + + Integer part + 整數部分 - - Objects - 物件 + + + + + Integer part (low) + 整數部分 (低ä½) - - Selection - é¸å– + + + + + Integer part (high) + 整數部分 (高ä½) - - Red - ç´… + + + End x + 最終 x - - Green - 綠 + + + Start x + 起始 x - - Blue - è— + + + End y + 最終 y - - 16-bit value - 16 ä½å…ƒæ•¸å€¼ + + + Start y + 起始 y - - Hex code - å六進ä½ç¢¼ + + Window 0 enable BG 0 + 視窗 0 啟用 BG 0 - - Palette index - 調色盤索引值 + + Window 0 enable BG 1 + 視窗 0 啟用 BG 1 - - Export BG - 匯出背景 + + Window 0 enable BG 2 + 視窗 0 啟用 BG 2 - - Export OBJ - 匯出 OBJ + + Window 0 enable BG 3 + 視窗 0 啟用 BG 3 - - - PlacementControl - - Adjust placement - 調整ä½ç½® + + Window 0 enable OBJ + 視窗 0 啟用 OBJ - - All - 全部 + + Window 0 enable blend + 視窗 0 å•Ÿç”¨æ··åˆ - - Offset - åç§»é‡ + + Window 1 enable BG 0 + 視窗 1 啟用 BG 0 - - X - X + + Window 1 enable BG 1 + 視窗 1 啟用 BG 1 - - Y - Y + + Window 1 enable BG 2 + 視窗 1 啟用 BG 2 - - - PrinterView - - Game Boy Printer - Game Boy Printer + + Window 1 enable BG 3 + 視窗 1 啟用 BG 3 - - Hurry up! - å¿«ä¸€é»žï¼ + + Window 1 enable OBJ + 視窗 1 啟用 OBJ - - Tear off - 撕裂 + + Window 1 enable blend + 視窗 1 å•Ÿç”¨æ··åˆ - - Magnification - 放大 + + Outside window enable BG 0 + 外å´è¦–窗啟用 BG 0 - - Copy - 複製 + + Outside window enable BG 1 + 外å´è¦–窗啟用 BG 1 - - - QGBA::AboutScreen - - 2021 - 2021 + + Outside window enable BG 2 + 外å´è¦–窗啟用 BG 2 - - - QGBA::ApplicationUpdatePrompt - - An update to %1 is available. - - %1 有å¯ç”¨çš„更新。 - + + Outside window enable BG 3 + 外å´è¦–窗啟用 BG 3 - - -Do you want to download and install it now? You will need to restart the emulator when the download is complete. - -您想è¦ç«‹å³ä¸‹è¼‰ä¸¦å®‰è£å—Žï¼Ÿä¸‹è¼‰å®Œæˆå¾Œï¼Œæ‚¨éœ€è¦é‡æ–°å•Ÿå‹•æ¨¡æ“¬å™¨ã€‚ + + Outside window enable OBJ + 外å´è¦–窗啟用 OBJ - - -Auto-update is not available on this platform. If you wish to update you will need to do it manually. - -此平å°ä¸æ”¯æ´è‡ªå‹•æ›´æ–°ã€‚若您希望更新則必須手動進行。 + + Outside window enable blend + 外å´è¦–çª—å•Ÿç”¨æ··åˆ - - Current version: %1 -New version: %2 -Download size: %3 - ç¾åœ¨ç‰ˆæœ¬: %1 -新版本: %2 -下載的檔案大å°: %3 + + OBJ window enable BG 0 + OBJ 視窗啟用 BG 0 - - Downloading update... - 正在下載更新... + + OBJ window enable BG 1 + OBJ 視窗啟用 BG 1 - - Downloading failed. Please update manually. - 下載失敗。請手動更新。 + + OBJ window enable BG 2 + OBJ 視窗啟用 BG 2 - - Downloading done. Press OK to restart %1 and install the update. - 下載完æˆã€‚按下 OK é‡æ–°å•Ÿå‹• %1 並安è£æ›´æ–°ã€‚ + + OBJ window enable BG 3 + OBJ 視窗啟用 BG 3 - - - QGBA::ApplicationUpdater - - Stable - 穩定版本 + + OBJ window enable OBJ + OBJ 視窗啟用 OBJ - - Development - 開發版本 + + OBJ window enable blend + OBJ è¦–çª—å•Ÿç”¨æ··åˆ - - Unknown - 未知 + + Background mosaic size vertical + èƒŒæ™¯é¦¬è³½å…‹åž‚ç›´å¤§å° - - (None) - (ç„¡) + + Background mosaic size horizontal + èƒŒæ™¯é¦¬è³½å…‹æ°´å¹³å¤§å° - - - QGBA::AssetTile - - %0%1%2 - %0%1%2 + + Object mosaic size vertical + ç‰©ä»¶é¦¬è³½å…‹åž‚ç›´å¤§å° - - - - 0x%0 (%1) - 0x%0 (%1) + + Object mosaic size horizontal + ç‰©ä»¶é¦¬è³½å…‹æ°´å¹³å¤§å° - - - QGBA::CheatsModel - - (untitled) - (無標題) + + BG 0 target 1 + BG 0 目標 1 - - Failed to open cheats file: %1 - 金手指開啟失敗: %1 + + BG 1 target 1 + BG 1 目標 1 - - - QGBA::CheatsView - - - Autodetect (recommended) - 自動åµæ¸¬ (建議) + + BG 2 target 1 + BG 2 目標 1 - - - Select cheats file - é¸æ“‡é‡‘手指 + + BG 3 target 1 + BG 3 目標 1 - - - QGBA::CoreController - - Failed to open save file: %1 - 存檔開啟失敗: %1 + + OBJ target 1 + OBJ 目標 1 - - Failed to open game file: %1 - éŠæˆ²é–‹å•Ÿå¤±æ•—: %1 + + Backdrop target 1 + 背景目標 1 - - Can't yank pack in unexpected platform! - 無法在é æ–™å¤–çš„å¹³å°æ‹”除å¡å¸¶ï¼ + + Blend mode + æ··åˆæ¨¡å¼ - - Failed to open snapshot file for reading: %1 - 讀å–快照失敗: %1 + + Disabled + å·²åœç”¨ - - Failed to open snapshot file for writing: %1 - 寫入快照失敗: %1 + + Additive blending + åŠ ç®—æ··åˆ - - - QGBA::CoreManager - - Failed to open game file: %1 - éŠæˆ²é–‹å•Ÿå¤±æ•—: %1 + + Brighten + 增亮 - - Could not load game. Are you sure it's in the correct format? - 無法讀å–éŠæˆ²ã€‚您確定格å¼æ­£ç¢ºå—Žï¼Ÿ + + Darken + 變暗 - - Failed to open save file; in-game saves cannot be updated. Please ensure the save directory is writable without additional privileges (e.g. UAC on Windows). - 無法開啟存檔;éŠæˆ²å…§å­˜æª”無法更新。請確定存檔路徑的寫入ä¸éœ€è¦é¡å¤–æ¬Šé™ (å³ Windows çš„ UAC)。 + + BG 0 target 2 + BG 0 目標 2 - - - QGBA::FrameView - - Export frame - 匯出畫格 + + BG 1 target 2 + BG 1 目標 2 - - Portable Network Graphics (*.png) - å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) + + BG 2 target 2 + BG 2 目標 2 - - None - ç„¡ + + BG 3 target 2 + BG 3 目標 2 - - Background - 背景 + + OBJ target 2 + OBJ 目標 2 - - Window - 視窗 + + Backdrop target 2 + 背景目標 2 - - Objwin - Objwin + + Blend A (target 1) + æ··åˆ A (目標 1) - - Sprite - 角色圖 + + Blend B (target 2) + æ··åˆ B (目標 2) - - Backdrop - 背景 + + Blend Y + æ··åˆ Y - - Frame - ç•«æ ¼ + + + Sweep shifts + 掃æä½ç§» - - %1 %2 - %1 %2 + + + Sweep subtract + 掃æ相減 - - - QGBA::GBAApp - - Enable Discord Rich Presence - 啟用 Discord Rich Presence + + + Sweep time (in 1/128s) + 掃æ時間 (1/128 秒) - - - QGBA::GBAKeyEditor - - Clear Button - 清除按鈕 + + + + + + + + + Sound length + è²éŸ³é•·åº¦ - - Clear Analog - 清除類比輸入 + + + + + Duty cycle + 工作週期 - - Refresh - é‡æ–°æ•´ç† + + + + + + + Envelope step time + 包å°æ­¥é€²æ™‚é–“ - - Set all - 設定全部 + + + + + + + Envelope increase + å¢žåŠ åŒ…å° - - - QGBA::GDBWindow - - Server settings - 伺æœå™¨è¨­å®š + + + + + + + Initial volume + åˆå§‹éŸ³é‡ - - Local port - å€åŸŸåŸ  + + + + Sound frequency + è²éŸ³é »çŽ‡ - - Bind address - ç¶å®šä½å€ + + + + + + + + + Timed + 已排定時間 - - Break - 中斷 - - - - Stop - åœæ­¢ + + + + + + + + + Reset + é‡æ–°å•Ÿå‹• - - Start - 開始 + + Double-size wave table + é›™å€å°ºå¯¸æ³¢å½¢è¡¨ - - Crash - 當機 + + Active wave table + 使用中的波形表 - - Could not start GDB server - 無法啟動 GDB 伺æœå™¨ + + + Enable channel 3 + å•Ÿç”¨é »é“ 3 - - - QGBA::GIFView - - Failed to open output file: %1 - 輸出檔案開啟失敗: %1 + + + Volume + éŸ³é‡ - - Select output file - é¸æ“‡è¼¸å‡ºçš„檔案 + + + 0% + 0% - - Graphics Interchange Format (*.gif);;WebP ( *.webp);;Animated Portable Network Graphics (*.png *.apng) - 圖形互æ›æ ¼å¼ (*.gif);;WebP ( *.webp);;å‹•æ…‹å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png *.apng) + + + + 100% + 100% - - - QGBA::IOViewer - - Background mode - èƒŒæ™¯æ¨¡å¼ + + + + 50% + 50% - - Mode 0: 4 tile layers - æ¨¡å¼ 0: 4 個圖塊層 + + + + 25% + 25% - - Mode 1: 2 tile layers + 1 rotated/scaled tile layer - æ¨¡å¼ 1:2 個圖塊層 + 1 個å¯æ—‹è½‰/縮放圖塊層 + + + + + 75% + 75% - - Mode 2: 2 rotated/scaled tile layers - æ¨¡å¼ 2:2 個å¯æ—‹è½‰/縮放圖塊層 + + + Clock divider + 時é˜åˆ†é »å™¨ - - Mode 3: Full 15-bit bitmap - æ¨¡å¼ 3: 完全 15 ä½å…ƒé»žé™£ + + + Register stages + 暫存器階段 - - Mode 4: Full 8-bit bitmap - æ¨¡å¼ 4: 完全 8 ä½å…ƒé»žé™£ + + + 15 + 15 - - Mode 5: Small 15-bit bitmap - æ¨¡å¼ 5: 15 ä½å…ƒç´°å°é»žé™£ + + + 7 + 7 - - CGB Mode - CGB æ¨¡å¼ + + + Shifter frequency + 移ä½å™¨é »çŽ‡ - - Frame select - ç•«æ ¼é¸æ“‡ + + PSG volume right + å¯ç¨‹å¼åŒ–發è²å™¨éŸ³é‡ï¼Žå³ - - Unlocked HBlank - 解鎖的 HBlank + + PSG volume left + å¯ç¨‹å¼åŒ–發è²å™¨éŸ³é‡ï¼Žå·¦ - - Linear OBJ tile mapping - 線性 OBJ 圖塊映射 + + + Enable channel 1 right + 啟用å³å´é »é“ 1 - - Force blank screen - 強制清空螢幕 + + + Enable channel 2 right + 啟用å³å´é »é“ 2 - - Enable background 0 - 啟用背景 0 + + + Enable channel 3 right + 啟用å³å´é »é“ 3 - - Enable background 1 - 啟用背景 1 + + + Enable channel 4 right + 啟用å³å´é »é“ 4 - - Enable background 2 - 啟用背景 2 + + + Enable channel 1 left + 啟用左å´é »é“ 1 - - Enable background 3 - 啟用背景 3 + + + Enable channel 2 left + 啟用左å´é »é“ 2 - - Enable OBJ - 啟用 OBJ + + + Enable channel 3 left + 啟用左å´é »é“ 3 - - Enable Window 0 - 啟用視窗 0 + + + Enable channel 4 left + 啟用左å´é »é“ 4 - - Enable Window 1 - 啟用視窗 1 + + PSG master volume + å¯ç¨‹å¼åŒ–發è²å™¨ç¸½éŸ³é‡ - - Enable OBJ Window - 啟用 OBJ 視窗 + + Loud channel A + æšè²é »é“ A - - Swap green components - 替æ›ç¶ è‰²çµ„件 + + Loud channel B + æšè²é »é“ B - - Currently in VBlank - ç›®å‰ VBlank 值 + + Enable channel A right + 啟用å³å´é »é“ A - - Currently in HBlank - ç›®å‰ HBlank 值 + + Enable channel A left + 啟用左å´é »é“ A - - Currently in VCounter - ç›®å‰ VCounter 值 + + Channel A timer + é »é“ A 計時器 - - Enable VBlank IRQ generation - å…許 VBlank 生æˆä¸­æ–·è«‹æ±‚ (IRQ) + + + 0 + 0 - - Enable HBlank IRQ generation - å…許 HBlank 生æˆä¸­æ–·è«‹æ±‚ (IRQ) + + + + + + + + + + 1 + 1 - - Enable VCounter IRQ generation - å…許 VCounter 生æˆä¸­æ–·è«‹æ±‚ (IRQ) + + Channel A reset + é »é“ A é‡è¨­ - - VCounter scanline - VCounter 掃æç·š + + Enable channel B right + 啟用å³å´é »é“ B - - Current scanline - ç›®å‰çš„掃æç·š + + Enable channel B left + 啟用左å´é »é“ B + + + + Channel B timer + é »é“ B 計時器 + + + + Channel B reset + é »é“ B é‡è¨­ + + + + + Active channel 1 + ä½¿ç”¨ä¸­çš„é »é“ 1 + + + + + Active channel 2 + ä½¿ç”¨ä¸­çš„é »é“ 2 + + + + + Active channel 3 + ä½¿ç”¨ä¸­çš„é »é“ 3 + + + + + Active channel 4 + ä½¿ç”¨ä¸­çš„é »é“ 4 + + + + + Enable audio + 啟用音訊 + + + + Bias + å移 + + + + Resolution + 解æžåº¦ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Sample + å–樣 + + + + + + + + + + + Address (low) + ä½å€ (低) + + + + + + + + + + + Address (high) + ä½å€ (高) + + + + + + Sound frequency (low) + è²éŸ³é »çŽ‡ (低) + + + + + + Sound frequency (high) + è²éŸ³é »çŽ‡ (高) + + + + Source (high) + ä¾†æº (高) + + + + Source (low) + ä¾†æº (低) + + + + Destination (high) + 目的地 (高) + + + + Destination (low) + 目的地 (低) + + + + + Green (low) + 綠 (低) + + + + + Green (high) + 綠 (高) + + + + + + + Word count + 字數 + + + + + + + Destination offset + 目的地åç§»é‡ + + + + + + + + + + + Increment + éžå¢ž + + + + + + + + + + + Decrement + éžæ¸› + + + + + + + + + + + Fixed + 固定 + + + + + + + Increment and reload + éžå¢žä¸¦é‡æ–°è®€å– + + + + + + + Source offset + 來æºåç§»é‡ + + + + + + + Repeat + é‡è¤‡ + + + + + + + 32-bit + 32 ä½å…ƒ + + + + + + + Start timing + 開始時間 + + + + + + + + Immediate + ç«‹å³ + + + + + + + + + + + VBlank + VBlank + + + + + + + + + + HBlank + HBlank + + + + + + + + + + + + IRQ + 中斷請求 (IRQ) + + + + + + + + + + + + + + Enable + 啟用 + + + + + + Audio FIFO + 音訊先進先出 + + + + Video Capture + è¦–è¨Šæ“·å– + + + + DRQ + 資料請求 (DRQ) + + + + + + + + + + + Value + 值 + + + + + + + Scale + 比例 + + + + + + + + 1/64 + 1/64 + + + + + + + + 1/256 + 1/256 + + + + + + + + 1/1024 + 1/1024 + + + + + + Cascade + ä¸²è¯ + + + + + A + A + + + + I/O Viewer + I/O 檢視器 + + + + 0x0000 + 0x0000 + + + + + + B + B + + + + + Select + Select + + + + + Start + Start + + + + + Right + å³ + + + + + Left + å·¦ + + + + + Up + 上 + + + + + Down + 下 + + + + + R + R + + + + + L + L + + + + Condition + Condition + + + + SC + SC + + + + SD + SD + + + + SI + SI + + + + SO + SO + + + + + VCounter + VCounter + + + + + Timer 0 + Timer 0 + + + + + Timer 1 + Timer 1 + + + + + Timer 2 + Timer 2 + + + + + Timer 3 + Timer 3 + + + + + SIO + SIO + + + + + DMA 0 + DMA 0 + + + + + DMA 1 + DMA 1 + + + + + DMA 2 + DMA 2 + + + + + DMA 3 + DMA 3 + + + + + Keypad + éµç›¤ - - - - - Priority - 優先度 + + + Gamepak + éŠæˆ²å¡å¸¶ - - - - - Tile data base (* 16kB) - 圖塊資料基底 (* 16kB) + + SRAM wait + SRAM 等候 - - - - - Enable mosaic - 啟用馬賽克 + + + + + + 4 + 4 - - - - - Enable 256-color - 啟用 256 色 + + + + + 3 + 3 - - - - - Tile map base (* 2kB) - 圖塊映射基底 (* 2kB) + + + + + + 2 + 2 - - - - - Background dimensions - 背景維度 + + + + + + 8 + 8 - - - Overflow wraps - 溢ä½å›žç¹ž + + Cart 0 non-sequential + å¡å¸¶ 0 (éžæŒ‰åº) - - - - - - - Horizontal offset - æ°´å¹³åç§»é‡ + + Cart 0 sequential + å¡å¸¶ 0 (按åº) - - - - - - - Vertical offset - åž‚ç›´åç§»é‡ + + Cart 1 non-sequential + å¡å¸¶ 1 (éžæŒ‰åº) - - - - - - - - - - - - - Fractional part - 分數部分 + + Cart 1 sequential + å¡å¸¶ 1 (按åº) - - - - - - - - - Integer part - 整數部分 + + Cart 2 non-sequential + å¡å¸¶ 2 (éžæŒ‰åº) - - - - - Integer part (low) - 整數部分 (低ä½) + + Cart 2 sequential + å¡å¸¶ 2 (按åº) - - - - - Integer part (high) - 整數部分 (高ä½) + + PHI terminal + PHI 終端 - - - End x - 最終 x + + + Disable + åœç”¨ - - - Start x - 起始 x + + 4.19MHz + 4.19MHz - - - End y - 最終 y + + 8.38MHz + 8.38MHz - - - Start y - 起始 y + + 16.78MHz + 16.78MHz - - Window 0 enable BG 0 - 視窗 0 啟用 BG 0 + + Gamepak prefetch + éŠæˆ²å¡å¸¶é è®€ - - Window 0 enable BG 1 - 視窗 0 啟用 BG 1 + + Enable IRQs + 啟用中斷請求 (IRQ) - - Window 0 enable BG 2 - 視窗 0 啟用 BG 2 + + Right/A + å³/A - - Window 0 enable BG 3 - 視窗 0 啟用 BG 3 + + Left/B + å·¦/B - - Window 0 enable OBJ - 視窗 0 啟用 OBJ + + Up/Select + 上/Select - - Window 0 enable blend - 視窗 0 å•Ÿç”¨æ··åˆ + + Down/Start + 下/Start - - Window 1 enable BG 0 - 視窗 1 啟用 BG 0 + + Active D-pad + 使用中的åå­—éµ - - Window 1 enable BG 1 - 視窗 1 啟用 BG 1 + + Active face buttons + 使用中的正é¢æŒ‰éˆ• - - Window 1 enable BG 2 - 視窗 1 啟用 BG 2 + + Internal clock + å…§éƒ¨æ™‚é˜ - - Window 1 enable BG 3 - 視窗 1 啟用 BG 3 + + 32× clocking (CGB only) + 32 å€æ™‚脈 (僅 CGB é©ç”¨) - - Window 1 enable OBJ - 視窗 1 啟用 OBJ + + Transfer active + 傳é€ä½¿ç”¨ç‹€æ…‹ - - Window 1 enable blend - 視窗 1 å•Ÿç”¨æ··åˆ + + Divider + 除數 + + + + 1/16 + 1/16 - - Outside window enable BG 0 - 外å´è¦–窗啟用 BG 0 + + + LCD STAT + LCD STAT - - Outside window enable BG 1 - 外å´è¦–窗啟用 BG 1 + + + Timer + 計時器 - - Outside window enable BG 2 - 外å´è¦–窗啟用 BG 2 + + + Serial + 串列 - - Outside window enable BG 3 - 外å´è¦–窗啟用 BG 3 + + + Joypad + æ–æ¡¿ - - Outside window enable OBJ - 外å´è¦–窗啟用 OBJ + + Volume right + å³å´éŸ³é‡ - - Outside window enable blend - 外å´è¦–çª—å•Ÿç”¨æ··åˆ + + Output right + å³å´è¼¸å‡º - - OBJ window enable BG 0 - OBJ 視窗啟用 BG 0 + + Volume left + å·¦å´éŸ³é‡ - - OBJ window enable BG 1 - OBJ 視窗啟用 BG 1 + + Output left + å·¦å´è¼¸å‡º - - OBJ window enable BG 2 - OBJ 視窗啟用 BG 2 + + Background enable/priority + 背景啟用/優先度 - - OBJ window enable BG 3 - OBJ 視窗啟用 BG 3 + + Enable sprites + 啟用角色圖 - - OBJ window enable OBJ - OBJ 視窗啟用 OBJ + + Double-height sprites + å…©å€é«˜åº¦è§’色圖 - - OBJ window enable blend - OBJ è¦–çª—å•Ÿç”¨æ··åˆ + + Background tile map + 背景圖塊映射 - - Background mosaic size vertical - èƒŒæ™¯é¦¬è³½å…‹åž‚ç›´å¤§å° + + + 0x9800 – 0x9BFF + 0x9800 – 0x9BFF - - Background mosaic size horizontal - èƒŒæ™¯é¦¬è³½å…‹æ°´å¹³å¤§å° + + + 0x9C00 – 0x9FFF + 0x9C00 – 0x9FFF - - Object mosaic size vertical - ç‰©ä»¶é¦¬è³½å…‹åž‚ç›´å¤§å° + + Background tile data + 背景圖塊資料 - - Object mosaic size horizontal - ç‰©ä»¶é¦¬è³½å…‹æ°´å¹³å¤§å° + + 0x8800 – 0x87FF + 0x8800 – 0x87FF - - BG 0 target 1 - BG 0 目標 1 + + 0x8000 – 0x8FFF + 0x8000 – 0x8FFF - - BG 1 target 1 - BG 1 目標 1 + + Enable window + 啟用視窗 - - BG 2 target 1 - BG 2 目標 1 + + Window tile map + 視窗圖塊映射 - - BG 3 target 1 - BG 3 目標 1 + + Enable LCD + 啟用 LCD - - OBJ target 1 - OBJ 目標 1 + + Mode + æ¨¡å¼ - - Backdrop target 1 - 背景目標 1 + + 0: HBlank + 0: HBlank - - Blend mode - æ··åˆæ¨¡å¼ + + 1: VBlank + 1: VBlank - - Disabled - å·²åœç”¨ + + 2: OAM scan + 2: 掃æ OAM - - Additive blending - åŠ ç®—æ··åˆ + + 3: HDraw + 3: HDraw - - Brighten - 增亮 + + In LYC + æ–¼ LYC - - Darken - 變暗 + + Enable HBlank (mode 0) IRQ + 啟用 HBlank (æ¨¡å¼ 0) 中斷請求 (IRQ) - - BG 0 target 2 - BG 0 目標 2 + + Enable VBlank (mode 1) IRQ + 啟用 VBlank (æ¨¡å¼ 1) 中斷請求 (IRQ) - - BG 1 target 2 - BG 1 目標 2 + + Enable OAM (mode 2) IRQ + 啟用 OAM (æ¨¡å¼ 2) 中斷請求 (IRQ) - - BG 2 target 2 - BG 2 目標 2 + + Enable LYC IRQ + 啟用 LYC 中斷請求 (IRQ) - - BG 3 target 2 - BG 3 目標 2 + + Current Y coordinate + ç¾åœ¨ Y 座標 - - OBJ target 2 - OBJ 目標 2 + + Comparison Y coordinate + å°ç…§ Y 座標 - - Backdrop target 2 - 背景目標 2 + + Start upper byte + 起始高ä½å…ƒçµ„ - - Blend A (target 1) - æ··åˆ A (目標 1) + + + + Color 0 shade + 色彩 0 é™°å½± - - Blend B (target 2) - æ··åˆ B (目標 2) + + + + Color 1 shade + 色彩 1 é™°å½± - - Blend Y - æ··åˆ Y + + + + Color 2 shade + 色彩 2 é™°å½± - - - Sweep shifts - 掃æä½ç§» + + + + Color 3 shade + 色彩 3 é™°å½± - - - Sweep subtract - 掃æ相減 + + Prepare to switch speed + 準備切æ›é€Ÿåº¦ - - - Sweep time (in 1/128s) - 掃æ時間 (1/128 秒) + + Double speed + é›™å€é€Ÿåº¦ + + + + VRAM bank + VRAM bank - - - - - - - - - Sound length - è²éŸ³é•·åº¦ + + Length + 長度 - - - - - Duty cycle - 工作週期 + + Timing + 時間點 - - - - - - - Envelope step time - 包å°æ­¥é€²æ™‚é–“ + + Write bit + 寫入ä½å…ƒ - - - - - - - Envelope increase - å¢žåŠ åŒ…å° + + Read bit + 讀å–ä½å…ƒ - - - - - - - Initial volume - åˆå§‹éŸ³é‡ + + + Unknown + 未知 - - - - Sound frequency - è²éŸ³é »çŽ‡ + + + Current index + ç¾åœ¨ç´¢å¼•å€¼ - - - - - - - - - Timed - 已排定時間 + + + Auto-increment + 自動éžå¢ž - - - - - - - - - Reset - é‡æ–°å•Ÿå‹• + + + Red + ç´… - - Double-size wave table - é›™å€å°ºå¯¸æ³¢å½¢è¡¨ + + + Blue + è— - - Active wave table - 使用中的波形表 + + Sprite ordering + è§’è‰²åœ–é †åº - - - Enable channel 3 - å•Ÿç”¨é »é“ 3 + + OAM order + OAM é †åº - - - Volume - éŸ³é‡ + + x coordinate sorting + X åº§æ¨™æŽ’åº - - - 0% - 0% + + WRAM bank + WRAM bank + + + + QGBA::KeyEditor + + + + --- + --- + + + QGBA::LibraryTree - - - - 100% - 100% + + Name + å稱 - - - - 50% - 50% + + Location + ä½ç½® - - - - 25% - 25% + + Platform + å¹³å° - - - - - 75% - 75% + + Size + å¤§å° - - - Clock divider - 時é˜åˆ†é »å™¨ + + CRC32 + CRC32 + + + QGBA::LoadSaveState - - - Register stages - 暫存器階段 + + Load State + 讀å–å³æ™‚存檔 - - - 15 - 15 + + Save State + 儲存å³æ™‚存檔 - - - 7 - 7 + + Empty + 空 - - - Shifter frequency - 移ä½å™¨é »çŽ‡ + + Corrupted + æ毀 - - PSG volume right - å¯ç¨‹å¼åŒ–發è²å™¨éŸ³é‡ï¼Žå³ + + Slot %1 + 儲存槽 %1 - - PSG volume left - å¯ç¨‹å¼åŒ–發è²å™¨éŸ³é‡ï¼Žå·¦ + + + %1 State + %1 å³æ™‚存檔 - - - Enable channel 1 right - 啟用å³å´é »é“ 1 + + + + + + + + + + No Save + 無存檔 - - - Enable channel 2 right - 啟用å³å´é »é“ 2 + + 5 + 5 - - - Enable channel 3 right - 啟用å³å´é »é“ 3 + + 6 + 6 - - - Enable channel 4 right - 啟用å³å´é »é“ 4 + + 8 + 8 - - - Enable channel 1 left - 啟用左å´é »é“ 1 + + 4 + 4 - - - Enable channel 2 left - 啟用左å´é »é“ 2 + + 1 + 1 - - - Enable channel 3 left - 啟用左å´é »é“ 3 + + 3 + 3 - - - Enable channel 4 left - 啟用左å´é »é“ 4 + + 7 + 7 - - PSG master volume - å¯ç¨‹å¼åŒ–發è²å™¨ç¸½éŸ³é‡ + + 9 + 9 - - Loud channel A - æšè²é »é“ A + + 2 + 2 - - Loud channel B - æšè²é »é“ B + + Cancel + å–消 + + + QGBA::LogConfigModel - - Enable channel A right - 啟用å³å´é »é“ A + + + Default + é è¨­ - - Enable channel A left - 啟用左å´é »é“ A + + Fatal + åš´é‡ - - Channel A timer - é »é“ A 計時器 + + Error + 錯誤 - - - 0 - 0 + + Warning + 警告 - - - - - - - - - - 1 - 1 + + Info + 資訊 - - Channel A reset - é »é“ A é‡è¨­ + + Debug + 除錯 - - Enable channel B right - 啟用å³å´é »é“ B + + Stub + æ¸¬è©¦æ¨ - - Enable channel B left - 啟用左å´é »é“ B + + Game Error + éŠæˆ²éŒ¯èª¤ + + + QGBA::LogController - - Channel B timer - é »é“ B 計時器 + + [%1] %2: %3 + [%1] %2: %3 - - Channel B reset - é »é“ B é‡è¨­ + + An error occurred + 錯誤發生 - - - Active channel 1 - ä½¿ç”¨ä¸­çš„é »é“ 1 + + DEBUG + DEBUG - - - Active channel 2 - ä½¿ç”¨ä¸­çš„é »é“ 2 + + STUB + STUB - - - Active channel 3 - ä½¿ç”¨ä¸­çš„é »é“ 3 + + INFO + INFO - - - Active channel 4 - ä½¿ç”¨ä¸­çš„é »é“ 4 + + WARN + WARN - - - Enable audio - 啟用音訊 + + ERROR + ERROR - - Bias - å移 + + FATAL + FATAL - - Resolution - 解æžåº¦ + + GAME ERROR + GAME ERROR + + + QGBA::LogView - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Sample - å–樣 + + Logs + 記錄 - - - - - - - - - Address (low) - ä½å€ (低) + + Enabled Levels + å·²å•Ÿç”¨çš„é—œå¡ - - - - - - - - - Address (high) - ä½å€ (高) + + Debug + 除錯 - - - - Sound frequency (low) - è²éŸ³é »çŽ‡ (低) + + Stub + æ¸¬è©¦æ¨ - - - - Sound frequency (high) - è²éŸ³é »çŽ‡ (高) + + Info + 資訊 - - Source (high) - ä¾†æº (高) + + Warning + 警告 - - Source (low) - ä¾†æº (低) + + Error + 錯誤 - - Destination (high) - 目的地 (高) + + Fatal + åš´é‡ - - Destination (low) - 目的地 (低) + + Game Error + éŠæˆ²éŒ¯èª¤ - - - Green (low) - 綠 (低) + + Advanced settings + 進階設定 - - - Green (high) - 綠 (高) + + Clear + 清除 - - - - - Word count - 字數 + + Max Lines + 最大行數 + + + QGBA::MapView - - - - - Destination offset - 目的地åç§»é‡ + + Priority + 優先度 - - - - - - - - - Increment - éžå¢ž + + + Map base + 映射基底 - - - - - - - - - Decrement - éžæ¸› + + + Tile base + 圖塊基底 - - - - - - - - - Fixed - 固定 + + Size + å¤§å° - - - - - Increment and reload - éžå¢žä¸¦é‡æ–°è®€å– + + + Offset + åç§»é‡ - - - - - Source offset - 來æºåç§»é‡ + + Xform + Xform - - - - - Repeat - é‡è¤‡ + + Map Addr. + 映射ä½å€ - - - - - 32-bit - 32 ä½å…ƒ + + Mirror + é¡åƒ - - - - - Start timing - 開始時間 + + None + ç„¡ - - - - - - Immediate - ç«‹å³ + + Both + 兩者 - - - - - - - - - VBlank - VBlank + + Horizontal + æ°´å¹³ - - - - - - - - HBlank - HBlank + + Vertical + åž‚ç›´ - - - - - - - - - - IRQ - 中斷請求 (IRQ) + + + + N/A + N/A - - - - - - - - - - - - Enable - 啟用 + + Export map + 匯出映射 - - - - Audio FIFO - 音訊先進先出 + + Portable Network Graphics (*.png) + å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) - - Video Capture - è¦–è¨Šæ“·å– + + Maps + 映射 - - DRQ - 資料請求 (DRQ) + + Magnification + 放大 - - - - - - - - - Value - 值 + + Export + 匯出 - - - - - Scale - 比例 + + Copy + 複製 + + + QGBA::MemoryAccessLogView - - - - - - 1/64 - 1/64 + + Memory access logging + - - - - - - 1/256 - 1/256 + + Log file + - - - - - - 1/1024 - 1/1024 + + Browse + ç€è¦½ - - - - Cascade - ä¸²è¯ + + Log additional information (uses 3× space) + - - - A - A + + Load existing file if present + - - - B - B + + Regions + - - - Select - Select + + Export ROM snapshot + - - + Start - Start + - - - Right - å³ + + Stop + åœæ­¢ - - - Left - å·¦ + + Failed to open memory log file + - - - Up - 上 + + + Select access log file + - - - Down - 下 + + Memory access logs (*.mal) + + + + QGBA::MemoryDump - - - R - R + + Save memory region + 儲存記憶體å€åŸŸ - - - L - L + + Failed to open output file: %1 + 輸出檔案開啟失敗: %1 - - Condition - Condition + + Save Memory Range + è¨˜æ†¶é«”å„²å­˜ç¯„åœ - - SC - SC + + Start Address: + 起始ä½å€: - - SD - SD + + Byte Count: + ä½å…ƒçµ„數: - - SI - SI + + Dump across banks + è·¨è¨˜æ†¶åº«å‚¾å° + + + QGBA::MemoryModel - - SO - SO + + Copy selection + è¤‡è£½æ‰€é¸ - - - VCounter - VCounter + + Save selection + å„²å­˜æ‰€é¸ - - - Timer 0 - Timer 0 + + Paste + 貼上 - - - Timer 1 - Timer 1 + + Load + è®€å– - - - Timer 2 - Timer 2 + + All + 全部 - - - Timer 3 - Timer 3 + + Load TBL + è®€å– TBL - - - SIO - SIO + + Save selected memory + 儲存é¸å–的記憶體 - - - DMA 0 - DMA 0 + + Failed to open output file: %1 + 輸出檔案開啟失敗: %1 - - - DMA 1 - DMA 1 + + Load memory + 讀å–記憶體 - - - DMA 2 - DMA 2 + + Failed to open input file: %1 + 輸入檔案開啟失敗: %1 - - - DMA 3 - DMA 3 + + TBL + TBL - - - Keypad - éµç›¤ + + ISO-8859-1 + ISO-8859-1 + + + QGBA::MemorySearch - - - Gamepak - éŠæˆ²å¡å¸¶ + + (%0/%1×) + (%0/%1×) - - SRAM wait - SRAM 等候 + + (â…Ÿ%0×) + (â…Ÿ%0×) - - - - - - 4 - 4 + + (%0×) + (%0×) - - - - - 3 - 3 + + %1 byte%2 + %1 ä½å…ƒçµ„%2 - - - - - - 2 - 2 + + Memory Search + æœå°‹è¨˜æ†¶é«” - - - - - - 8 - 8 + + Address + ä½å€ - - Cart 0 non-sequential - å¡å¸¶ 0 (éžæŒ‰åº) + + Current Value + ç›®å‰çš„值 - - Cart 0 sequential - å¡å¸¶ 0 (按åº) + + + Type + 型別 - - Cart 1 non-sequential - å¡å¸¶ 1 (éžæŒ‰åº) + + Value + 值 - - Cart 1 sequential - å¡å¸¶ 1 (按åº) + + Numeric + 數字 - - Cart 2 non-sequential - å¡å¸¶ 2 (éžæŒ‰åº) + + Text + 文字 - - Cart 2 sequential - å¡å¸¶ 2 (按åº) + + Width + 寬度 - - PHI terminal - PHI 終端 + + + Guess + é æ¸¬ - - - Disable - åœç”¨ + + 1 Byte (8-bit) + 1 ä½å…ƒçµ„ (8 ä½å…ƒ) + + + + 2 Bytes (16-bit) + 2 ä½å…ƒçµ„ (16 ä½å…ƒ) + + + + 4 Bytes (32-bit) + 4 ä½å…ƒçµ„ (32 ä½å…ƒ) + + + + Number type + 數字型別 - - 4.19MHz - 4.19MHz + + Decimal + åé€²ä½ - - 8.38MHz - 8.38MHz + + Hexadecimal + åå…­é€²ä½ - - 16.78MHz - 16.78MHz + + Search type + æœå°‹åž‹åˆ¥ - - Gamepak prefetch - éŠæˆ²å¡å¸¶é è®€ + + Equal to value + 等於值 - - Enable IRQs - 啟用中斷請求 (IRQ) + + Greater than value + 大於值 - - Right/A - å³/A + + Less than value + å°æ–¼å€¼ - - Left/B - å·¦/B + + Unknown/changed + 未知/已變更 - - Up/Select - 上/Select + + Changed by value + 數值變更 - - Down/Start - 下/Start + + Unchanged + 未變更 - - Active D-pad - 使用中的åå­—éµ + + Increased + 增加 - - Active face buttons - 使用中的正é¢æŒ‰éˆ• + + Decreased + 減少 - - Internal clock - å…§éƒ¨æ™‚é˜ + + Search ROM + æœå°‹ ROM - - 32× clocking (CGB only) - 32 å€æ™‚脈 (僅 CGB é©ç”¨) + + New Search + æ–°çš„æœå°‹ - - Transfer active - 傳é€ä½¿ç”¨ç‹€æ…‹ + + Search Within + 在...裡æœå°‹ - - Divider - 除數 + + Open in Memory Viewer + 在記憶體檢視器中打開 - - 1/16 - 1/16 + + Refresh + é‡æ–°æ•´ç† + + + QGBA::MemoryView - - - LCD STAT - LCD STAT + + Memory + 記憶體 - - - Timer - 計時器 + + Inspect Address: + 檢查ä½å€: - - - Serial - 串列 + + Set Alignment: + 資料å°é½Šè¨­å®š: - - - Joypad - æ–æ¡¿ + + &1 Byte + 1 ä½å…ƒçµ„ (&1) - - Volume right - å³å´éŸ³é‡ + + &2 Bytes + 2 ä½å…ƒçµ„ (&2) - - Output right - å³å´è¼¸å‡º + + &4 Bytes + 4 ä½å…ƒçµ„ (&4) - - Volume left - å·¦å´éŸ³é‡ + + Unsigned Integer: + 無符號整數: - - Output left - å·¦å´è¼¸å‡º + + Signed Integer: + 有符號整數: - - Background enable/priority - 背景啟用/優先度 + + String: + 字串: - - Enable sprites - 啟用角色圖 + + Load TBL + è®€å– TBL - - Double-height sprites - å…©å€é«˜åº¦è§’色圖 + + Copy Selection + è¤‡è£½æ‰€é¸ - - Background tile map - 背景圖塊映射 + + Paste + 貼上 - - - 0x9800 – 0x9BFF - 0x9800 – 0x9BFF + + Save Selection + å„²å­˜æ‰€é¸ - - - 0x9C00 – 0x9FFF - 0x9C00 – 0x9FFF + + Save Range + å„²å­˜ç¯„åœ - - Background tile data - 背景圖塊資料 + + Load + + + + QGBA::MessagePainter - - 0x8800 – 0x87FF - 0x8800 – 0x87FF + + Frame %1 + + + + QGBA::MultiplayerController - - 0x8000 – 0x8FFF - 0x8000 – 0x8FFF + + Trying to detach a multiplayer player that's not attached + - - Enable window - 啟用視窗 + + Clearing invalid save ID + - - Window tile map - 視窗圖塊映射 + + Clearing invalid preferred ID + - - Enable LCD - 啟用 LCD + + Trying to get player ID for a multiplayer player that's not attached + - - Mode - æ¨¡å¼ + + Trying to get save ID for a multiplayer player that's not attached + + + + QGBA::ObjView - - 0: HBlank - 0: HBlank + + + 0x%0 + 0x%0 - - 1: VBlank - 1: VBlank + + Sprites + 角色圖 - - 2: OAM scan - 2: 掃æ OAM + + Address + ä½å€ - - 3: HDraw - 3: HDraw + + Copy + 複製 - - In LYC - æ–¼ LYC + + Magnification + 放大 - - Enable HBlank (mode 0) IRQ - 啟用 HBlank (æ¨¡å¼ 0) 中斷請求 (IRQ) + + Geometry + 幾何 - - Enable VBlank (mode 1) IRQ - 啟用 VBlank (æ¨¡å¼ 1) 中斷請求 (IRQ) + + Position + ä½ç½® - - Enable OAM (mode 2) IRQ - 啟用 OAM (æ¨¡å¼ 2) 中斷請求 (IRQ) + + Dimensions + 維度 - - Enable LYC IRQ - 啟用 LYC 中斷請求 (IRQ) + + Matrix + 矩陣 - - Current Y coordinate - ç¾åœ¨ Y 座標 + + Export + 匯出 - - Comparison Y coordinate - å°ç…§ Y 座標 + + Attributes + 屬性 - - Start upper byte - 起始高ä½å…ƒçµ„ + + Transform + è®Šæ› - - - - Color 0 shade - 色彩 0 é™°å½± + + + Off + é—œ - - - - Color 1 shade - 色彩 1 é™°å½± + + Palette + 調色盤 - - - - Color 2 shade - 色彩 2 é™°å½± + + Double Size + å…©å€å¤§å° - - - - Color 3 shade - 色彩 3 é™°å½± + + Flipped + 已翻轉 - - Prepare to switch speed - 準備切æ›é€Ÿåº¦ + + H + Short for horizontal + H - - Double speed - é›™å€é€Ÿåº¦ + + + + Return, Ctrl+R + 返回,Ctrl+R - - VRAM bank - VRAM bank + + V + Short for vertical + V - - Length - 長度 + + Mode + æ¨¡å¼ - - Timing - 時間點 + + Mosaic + 馬賽克 - - Write bit - 寫入ä½å…ƒ + + Enabled + 已啟用 - - Read bit - 讀å–ä½å…ƒ + + Priority + 優先度 - - - Unknown - 未知 + + Tile + 圖塊 - - - Current index - ç¾åœ¨ç´¢å¼•å€¼ + + + + + + + + + --- + --- - - - Auto-increment - 自動éžå¢ž + + + Normal + 正常 - - - Red - ç´… + + Trans + Trans - - - Blue - è— + + OBJWIN + OBJWIN - - Sprite ordering - è§’è‰²åœ–é †åº + + Invalid + 無效 - - OAM order - OAM é †åº + + + N/A + N/A - - x coordinate sorting - X åº§æ¨™æŽ’åº + + Export sprite + 匯出角色圖 - - WRAM bank - WRAM bank + + Portable Network Graphics (*.png) + å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) - QGBA::KeyEditor + QGBA::OverrideView - - - --- - --- + + Official MBCs + 官方記憶庫控制器 (MBC) - - Super (L) - Super (L) + + Licensed MBCs + 已授權的記憶庫控制器 (MBC) - - Super (R) - Super (R) + + Unlicensed MBCs + 未授權的記憶庫控制器 (MBC) - - Menu - é¸å–® + + Game Overrides + éŠæˆ²æ›¿ä»£ - - - QGBA::LoadSaveState - - Load State - 讀å–å³æ™‚存檔 + + Game Boy Advance + Game Boy Advance - - Save State - 儲存å³æ™‚存檔 + + + + + Autodetect + 自動åµæ¸¬ - - Empty - 空 + + Realtime clock + 實時計時器 - - Corrupted - æ毀 + + Gyroscope + 陀螺儀 - - Slot %1 - 儲存槽 %1 + + Tilt + 傾斜 - - - QGBA::LogConfigModel - - - Default - é è¨­ + + Light sensor + 光感測器 - - Fatal - åš´é‡ + + Rumble + 震動 - - Error - 錯誤 + + Save type + 存檔類型 - - Warning - 警告 + + None + ç„¡ - - Info - 資訊 + + SRAM + SRAM - - Debug - 除錯 + + Flash 512kb + Flash 512kb - - Stub - æ¸¬è©¦æ¨ + + Flash 1Mb + Flash 1Mb - - Game Error - éŠæˆ²éŒ¯èª¤ + + EEPROM 8kB + EEPROM 8kB - - - QGBA::LogController - - [%1] %2: %3 - [%1] %2: %3 + + EEPROM 512 bytes + EEPROM 512 bytes - - An error occurred - 錯誤發生 + + SRAM 64kB (bootlegs only) + SRAM 64kB (僅用於盜版å¡å¸¶) - - DEBUG - DEBUG + + Idle loop + 閒置迴圈 - - STUB - STUB + + Game Boy Player features + Game Boy Player 特性 - - INFO - INFO + + VBA bug compatibility mode + VBA éŒ¯èª¤ç›¸å®¹æ€§æ¨¡å¼ - - WARN - WARN + + Game Boy + Game Boy - - ERROR - ERROR + + Game Boy model + Game Boy 型號 - - FATAL - FATAL + + Memory bank controller + 記憶庫控制器 + + + + Background Colors + 背景é¡è‰² + + + + Sprite Colors 1 + 角色圖é¡è‰² 1 + + + + Sprite Colors 2 + 角色圖é¡è‰² 2 - - GAME ERROR - GAME ERROR + + Palette preset + é è¨­èª¿è‰²ç›¤ - QGBA::MapView + QGBA::PaletteView - - Priority - 優先度 + + #%0 + #%0 - - - Map base - 映射基底 + + 0x%0 + 0x%0 - - - Tile base - 圖塊基底 + + + + + 0x%0 (%1) + 0x%0 (%1) - - Size - å¤§å° + + Export palette + 匯出調色盤 - - - Offset - åç§»é‡ + + Windows PAL (*.pal);;Adobe Color Table (*.act) + Windows PAL (*.pal);;Adobe Color Table (*.act) - - Xform - Xform + + Failed to open output palette file: %1 + 輸出調色盤開啟失敗: %1 - - Map Addr. - 映射ä½å€ + + Palette + 調色盤 - - Mirror - é¡åƒ + + Background + 背景 - - None - ç„¡ + + Objects + 物件 - - Both - 兩者 + + Selection + é¸å– - - Horizontal - æ°´å¹³ + + Red + ç´… - - Vertical - åž‚ç›´ + + Green + 綠 - - - - N/A - N/A + + Blue + è— - - Export map - 匯出映射 + + 16-bit value + 16 ä½å…ƒæ•¸å€¼ - - Portable Network Graphics (*.png) - å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) + + Hex code + å六進ä½ç¢¼ - - - QGBA::MemoryDump - - Save memory region - 儲存記憶體å€åŸŸ + + Palette index + 調色盤索引值 - - Failed to open output file: %1 - 輸出檔案開啟失敗: %1 + + Export BG + 匯出背景 + + + + Export OBJ + 匯出 OBJ - QGBA::MemoryModel + QGBA::PlacementControl - - Copy selection - è¤‡è£½æ‰€é¸ + + Adjust placement + 調整ä½ç½® - - Save selection - å„²å­˜æ‰€é¸ + + All + 全部 - - Paste - 貼上 + + Offset + åç§»é‡ - - Load - è®€å– + + X + X - - All - 全部 + + Y + Y + + + QGBA::PrinterView - - Load TBL - è®€å– TBL + + Game Boy Printer + Game Boy Printer - - Save selected memory - 儲存é¸å–的記憶體 + + Hurry up! + å¿«ä¸€é»žï¼ - - Failed to open output file: %1 - 輸出檔案開啟失敗: %1 + + Tear off + 撕裂 - - Load memory - 讀å–記憶體 + + Magnification + 放大 - - Failed to open input file: %1 - 輸入檔案開啟失敗: %1 + + Copy + 複製 - - TBL - TBL + + Save Printout + - - ISO-8859-1 - ISO-8859-1 + + Portable Network Graphics (*.png) + å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) - QGBA::MemorySearch - - - (%0/%1×) - (%0/%1×) - - - - (â…Ÿ%0×) - (â…Ÿ%0×) - + QGBA::ROMInfo - - (%0×) - (%0×) + + + + + + (unknown) + (未知) - - %1 byte%2 - %1 ä½å…ƒçµ„%2 + + bytes + ä½å…ƒçµ„ - - - QGBA::ObjView - - - 0x%0 - 0x%0 + + (no database present) + (無資料庫存在) - - Off - é—œ + + ROM Info + ROM 資訊 - - - - - - - - - --- - --- + + File information + - - Normal - 正常 + + Game name: + éŠæˆ²å稱: - - Trans - Trans + + File size: + 檔案大å°: - - OBJWIN - OBJWIN + + CRC32: + CRC32: - - Invalid - 無效 + + MD5 + - - - N/A - N/A + + Save file: + - - Export sprite - 匯出角色圖 + + ROM header + - - Portable Network Graphics (*.png) - å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) + + Internal name: + 內部å稱: - - - QGBA::OverrideView - - Official MBCs - 官方記憶庫控制器 (MBC) + + Game ID: + éŠæˆ² ID - - Licensed MBCs - 已授權的記憶庫控制器 (MBC) + + Maker Code: + - - Unlicensed MBCs - 未授權的記憶庫控制器 (MBC) + + Revision: + - QGBA::PaletteView - - - #%0 - #%0 - - - - 0x%0 - 0x%0 - - - - - - - 0x%0 (%1) - 0x%0 (%1) - + QGBA::ReportView - - Export palette - 匯出調色盤 + + Bug report archive + 錯誤回報記錄 - - Windows PAL (*.pal);;Adobe Color Table (*.act) - Windows PAL (*.pal);;Adobe Color Table (*.act) + + ZIP archive (*.zip) + ZIP 壓縮檔 (*.zip) - - Failed to open output palette file: %1 - 輸出調色盤開啟失敗: %1 + + Generate Bug Report + 產生錯誤報告 - - - QGBA::ROMInfo - - - - - - (unknown) - (未知) + + <html><head/><body><p>To file a bug report, please first generate a report file to attach to the bug report you're about to file. It is recommended that you include the save files, as these often help with debugging issues. This will collect some information about the version of {projectName} you're running, your configuration, your computer, and the game you currently have open (if any). Once this collection is completed you can review all of the information gathered below and save it to a zip file. The collection will automatically attempt to redact any personal information, such as your username if it's in any of the paths gathered, but just in case you can edit it afterwards. After you have generated and saved it, please click the button below or go to <a href="https://mgba.io/i/"><span style=" text-decoration: underline; color:#2980b9;">mgba.io/i</span></a> to file the bug report on GitHub. Make sure to attach the report you generated!</p></body></html> + <html><head/><body><p>è‹¥è¦æ出錯誤報告,請先產生一份報告檔,å†å°‡å ±å‘Šæª”附加到è¦æ出的錯誤報告中。建議您附上存檔,因為存檔通常å°é™¤éŒ¯å¾ˆæœ‰å¹«åŠ©ã€‚錯誤報告會收集以下資料:正在執行的 {projectName} 版本ã€è¨­å®šã€é›»è…¦è³‡è¨Šã€ç›®å‰é–‹å•Ÿçš„éŠæˆ² (若有的話)。在資料收集完æˆå¾Œï¼Œæ‚¨å¯ä»¥æª¢æŸ¥æ‰€æœ‰æ”¶é›†çš„è³‡æ–™ï¼Œä¸¦å„²å­˜æˆ zip 壓縮檔。錯誤報告會嘗試自動塗銷所有個人資訊,例如路徑包å«çš„使用者å稱。以防è¬ä¸€æ‚¨é‚„是å¯ä»¥åœ¨é€™ä¹‹å¾Œè‡ªè¡Œç·¨è¼¯ã€‚生æˆä¸¦å„²å­˜å ±å‘Šä¹‹å¾Œï¼Œè«‹é»žæ“Šä¸‹æ–¹æŒ‰éˆ•ï¼Œæˆ–å‰å¾€ <a href="https://mgba.io/i/"><span style=" text-decoration: underline; color:#2980b9;">mgba.io/i</span></a> 以在 GitHub 上æ出報告。請確定附上產生的報告ï¼</p></body></html> - - - bytes - ä½å…ƒçµ„ + + Generate report + 產生報告 - - (no database present) - (無資料庫存在) + + Save + - - - QGBA::ReportView - - Bug report archive - 錯誤回報記錄 + + Open issue list in browser + 在ç€è¦½å™¨ä¸­æ‰“é–‹å•é¡Œæ¸…å–® - - ZIP archive (*.zip) - ZIP 壓縮檔 (*.zip) + + Include save file + 附加存檔 + + + + Create and include savestate + 建立並加入å³æ™‚存檔 QGBA::SaveConverter - + Save games and save states (%1) 儲存éŠæˆ²ä¸¦å„²å­˜å³æ™‚存檔 (%1) - + Select save game or save state é¸æ“‡éŠæˆ²å­˜æª”或å³æ™‚存檔 - + Save games (%1) éŠæˆ²å­˜æª” (%1) - + Select save game é¸æ“‡éŠæˆ²å­˜æª” - + Conversion failed 轉檔失敗 - + Failed to convert the save game. This is probably a bug. 存檔轉æ›å¤±æ•—。這å¯èƒ½æ˜¯å€‹ bug。 - + No file selected 未é¸å–檔案 - + Could not open file 無法開啟檔案 - + No valid formats found 找ä¸åˆ°æœ‰æ•ˆçš„æ ¼å¼ - + Please select a valid input file è«‹é¸æ“‡æœ‰æ•ˆçš„輸入檔 - + No valid conversions found 找ä¸åˆ°æœ‰æ•ˆçš„轉æ›æ–¹æ³• - - Cannot convert save games between platforms - 無法在ä¸åŒå¹³å°é–“轉æ›å­˜æª” + + %1 %2 save game + %1 %2 éŠæˆ²å­˜æª” - - - QGBA::SettingsView - - - Qt Multimedia - Qt 多媒體 + + little endian + ä½å…ƒçµ„ç”±å°åˆ°å¤§ - - SDL - SDL + + big endian + ä½å…ƒçµ„ç”±å¤§åˆ°å° - - Software (Qt) - 軟體 (Qt) + + SRAM + SRAM - - OpenGL - OpenGL + + %1 flash + %1 flash - - OpenGL (force version 1.x) - OpenGL (強制使用 1.x 版) + + %1 EEPROM + %1 EEPROM - - None - ç„¡ + + + RTC + - - None (Still Image) - ç„¡ (éœæ…‹å½±åƒ) + + %1 SRAM + RTC + %1 SRAM + RTC - - Keyboard - éµç›¤ + + %1 SRAM + %1 SRAM - - Controllers - 控制器 + + packed MBC2 + åŒ…è£ MBC2 - - Shortcuts - å¿«æ·éµ + + unpacked MBC2 + æœªåŒ…è£ MBC2 - - - Shaders - 著色器 + + MBC6 flash + MBC6 flash - - Select BIOS - é¸æ“‡ BIOS + + MBC6 combined SRAM + flash + MBC6 åˆä½µ SRAM + flash - - Select directory - é¸æ“‡è³‡æ–™å¤¾ + + MBC6 SRAM + MBC6 SRAM - - (%1×%2) - (%1×%2) + + TAMA5 + TAMA5 - - Never - æ°¸ä¸ + + %1 (%2) + %1 (%2) - - Just now - 剛剛 + + %1 save state with embedded %2 save game + %1 å³æ™‚存檔與嵌入的 %2 éŠæˆ²å­˜æª” - - Less than an hour ago - 一å°æ™‚å…§ + + %1 SharkPort %2 save game + %1 SharkPort %2 存檔 - - - %n hour(s) ago - - %n å°æ™‚å‰ - + + + %1 GameShark Advance SP %2 save game + %1 GameShark Advance SP %2 存檔 - - - %n day(s) ago - - %n æ—¥å‰ - + + + Cannot convert save games between platforms + 無法在ä¸åŒå¹³å°é–“轉æ›å­˜æª” + + + + Convert/Extract Save Game + 轉æ›/æ“·å–存檔 + + + + Input file + 輸入檔案 + + + + + Browse + ç€è¦½ + + + + Output file + 輸出檔案 - QGBA::ShaderSelector + QGBA::ScriptingTextBuffer - - No shader active - 無使用中的著色器 + + Untitled buffer + + + + QGBA::ScriptingView - - Load shader - 讀å–著色器 + + Scripting + - - No shader loaded - 未讀å–著色器 + + Run + - - by %1 - ç”± %1 + + File + - - Preprocessing - é è™•ç† + + Load recent script + - - Pass %1 - é€šé“ %1 + + Load script... + - - - QGBA::ShortcutModel - - Action - 動作 + + &Load most recent + - - Keyboard - éµç›¤ + + &Reset + é‡æ–°å•Ÿå‹• (&R) - - Gamepad - éŠæˆ²æ‰‹æŠŠ + + 0 + 0 - - - QGBA::TileView - - Export tiles - 匯出圖塊 + + Select script to load + - - - Portable Network Graphics (*.png) - å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) + + Lua scripts (*.lua) + - - Export tile - 匯出圖塊 + + All files (*.*) + - QGBA::VideoView + QGBA::SensorView - - Failed to open output video file: %1 - 輸出影片開啟失敗: %1 + + Sensors + 感測器 - - Native (%0x%1) - 原始畫質 (%0x%1) + + Realtime clock + 實時計時器 - - Select output file - é¸æ“‡è¼¸å‡ºçš„檔案 + + System time + 系統時間 - - - QGBA::Window - - Game Boy Advance ROMs (%1) - Game Boy Advance ROMs (%1) + + Fixed time + 固定時間 - - Game Boy ROMs (%1) - Game Boy ROMs (%1) + + Now + ç¾åœ¨ - - All ROMs (%1) - 所有 ROMs (%1) + + Offset time + - - %1 Video Logs (*.mvl) - %1 影片記錄檔 (*.mvl) + + sec + - - Archives (%1) - 壓縮檔 (%1) + + Start time at + 開始時間於 - - - - Select ROM - é¸æ“‡ ROM + + MM/dd/yy hh:mm:ss AP + yy/MM/dd hh:mm:ss AP - - Select folder - é¸æ“‡è³‡æ–™å¤¾ + + Light sensor + 光感測器 - - - Select save - é¸æ“‡å­˜æª” + + Brightness + 亮度 - - Select patch - é¸æ“‡ä¿®è£œæª” + + Tilt sensor + 傾斜感測器 - - Patches (*.ips *.ups *.bps) - 修補檔 (*.ips *.ups *.bps) + + + Set Y + 設定 Y - - Select e-Reader dotcode - é¸æ“‡ e-Reader 點碼 + + + Set X + 設定 X - - e-Reader card (*.raw *.bin *.bmp) - e-Reader å¡ç‰‡ (*.raw *.bin *.bmp) + + Gyroscope + 陀螺儀 - - Select image - é¸æ“‡åœ–片 + + Sensitivity + éˆæ•åº¦ + + + QGBA::SettingsView - - Image file (*.png *.gif *.jpg *.jpeg);;All files (*) - 圖檔 (*.png *.gif *.jpg *.jpeg);;所有檔案 (*) + + + Qt Multimedia + Qt 多媒體 - - GameShark saves (*.sps *.xps) - GameShark 存檔 (*.sps *.xps) + + SDL + SDL - - Select video log - é¸æ“‡å½±ç‰‡è¨˜éŒ„檔 + + Software (Qt) + 軟體 (Qt) - - Video logs (*.mvl) - 影片記錄檔 (*.mvl) + + Settings + 設定 - - Crash - 當機 + + Audio/Video + 音訊/視訊 - - The game has crashed with the following error: - -%1 - éŠæˆ²å› ä»¥ä¸‹éŒ¯èª¤ç•¶æ©Ÿ: - -%1 + + Gameplay + - - Couldn't Start - 無法啟動 + + Interface + ä»‹é¢ - - Could not start game. - 無法啟動éŠæˆ²ã€‚ + + Update + æ›´æ–° - - Unimplemented BIOS call - 未實è£çš„ BIOS å‘¼å« + + Emulation + 模擬 - - This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. - æ­¤éŠæˆ²ä½¿ç”¨äº†æœªå¯¦è£çš„ BIOS 呼å«ã€‚為了ç²å¾—最佳體驗,請使用官方 BIOS。 + + Enhancements + 增強 - - Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. - 建立é©ç•¶çš„顯示è£ç½®å¤±æ•—,回歸到軟體顯示。éŠæˆ²å¯èƒ½æœƒè·‘得很慢,尤其在使用大螢幕的時候。 + + BIOS + BIOS - - Really make portable? - 這真的å¯æ”œï¼Ÿ + + Paths + 路徑 - - This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? - 模擬器會從執行檔所在的資料夾讀å–設定檔。確定è¦ç¹¼çºŒå—Žï¼Ÿ + + Logging + 記錄 - - Restart needed - 需è¦é‡æ–°å•Ÿå‹• + + Game Boy + Game Boy - - Some changes will not take effect until the emulator is restarted. - 有些變更在模擬器é‡æ–°å•Ÿå‹•å‰ä¸æœƒç”Ÿæ•ˆã€‚ + + + Audio + 音訊 - - - Player %1 of %2 - - Player %1 of %2 + + Audio driver: + 音訊驅動: - - %1 - %2 - %1 - %2 + + Audio buffer: + 音訊緩è¡: - - %1 - %2 - %3 - %1 - %2 - %3 + + + 1536 + 1536 - - %1 - %2 (%3 fps) - %4 - %1 - %2 (%3 fps) - %4 + + 512 + 512 - - &File - 檔案 (&F) + + 768 + 768 - - Load &ROM... - è®€å– ROM (&R) ... + + 1024 + 1024 - - Load ROM in archive... - 從壓縮檔讀å–ROM... + + 2048 + 2048 - - Add folder to library... - 加入資料夾至收è—... + + 3072 + 3072 - - Save games (%1) - éŠæˆ²å­˜æª” (%1) + + 4096 + 4096 - - Select save game - é¸æ“‡å­˜æª” + + samples + å–樣 - - mGBA save state files (%1) - mGBA å³æ™‚存檔 (%1) + + Sample rate: + å–樣率: - - - Select save state - é¸æ“‡å³æ™‚存檔 + + + 44100 + 44100 - - Select e-Reader card images - é¸å– e-Reader å¡ç‰‡åœ–檔 + + 22050 + 22050 - - Image file (*.png *.jpg *.jpeg) - 圖檔 (*.png *.jpg *.jpeg) + + 32000 + 32000 - - Conversion finished - è½‰æª”å®Œæˆ + + 48000 + 48000 - - %1 of %2 e-Reader cards converted successfully. - %1 å¼µ e-Reader å¡ç‰‡è½‰æ›æˆåŠŸã€‚ (å…± %2 å¼µ) + + Hz + Hz - - Load alternate save game... - 讀å–å¦ä¸€ä»½å­˜æª”... + + Volume: + 音é‡: - - Load temporary save game... - 讀å–暫時存檔... + + + + + Mute + éœéŸ³ - - Load &patch... - 讀å–並修補 (&P) ... + + Fast forward volume: + 快轉音é‡: - - Boot BIOS - å•Ÿå‹• BIOS + + Audio in multiplayer: + 多人éŠæˆ²éŸ³è¨Š: - - Replace ROM... - å–代 ROM... + + All windows + 所有視窗 - - Scan e-Reader dotcodes... - 掃æ e-Reader 點碼 + + Player 1 window only + 僅玩家 1 視窗 - - Convert e-Reader card image to raw... - è½‰æ› e-Reader å¡ç‰‡åœ–檔為原始資料 + + Currently active player window + ç¾åœ¨ä½¿ç”¨ä¸­çš„玩家視窗 - - ROM &info... - ROM 資訊 (&I) + + + Video + 視訊 - - Recent - 最近使用 + + Display driver: + 顯示驅動: - - Make portable - å¯æ”œåŒ– + + Frameskip: + è·³éŽç•«æ ¼: - - &Load state - 讀å–å³æ™‚存檔 (&L) + + Skip every + æ¯éš” N ç•«æ ¼è·³éŽ - - Load state file... - 讀å–å³æ™‚存檔... + + + frames + ç•«æ ¼ - - &Save state - 儲存å³æ™‚存檔 (&S) + + Lock aspect ratio + 鎖定長寬比 - - Save state file... - 儲存å³æ™‚存檔... + + Force integer scaling + 強制整數å€æ”¾å¤§ - - Quick load - å¿«é€Ÿè®€å– + + Interframe blending + ç•«æ ¼é–“æ··åˆ - - Quick save - 快速儲存 + + Bilinear filtering + 雙線性éŽæ¿¾ - - Load recent - 讀å–最近存檔 + + FPS target: + FPS 目標: - - Save recent - 儲存最近存檔 + + frames per second + æ¯ç§’畫格數 (FPS) - - Undo load state - å–消讀å–å³æ™‚存檔 + + Native (59.7275) + 原生 (59.7275) - - Undo save state - å–消儲存å³æ™‚存檔 + + Sync: + åŒæ­¥: - - - State &%1 - å³æ™‚存檔 (&%1) + + On loading a game: + - - Load camera image... - 讀å–相機影åƒ... + + Load last state + - - Convert save game... - 轉æ›å­˜æª”... + + Load cheats + - - GameShark saves (*.gsv *.sps *.xps) - GameShark 存檔 (*.gsv *.sps *.xps) + + Periodically autosave state + - - Import GameShark Save... - 匯入 GameShark 存檔 + + Save entered cheats + - - Export GameShark Save... - 匯出 GameShark 存檔 + + Save state extra data: + 儲存å³æ™‚存檔é¡å¤–資料: - - New multiplayer window - 新增多人éŠæˆ²è¦–窗 + + + Screenshot + 螢幕截圖 - - Connect to Dolphin... - 連接 Dolphin... + + + Save game + 儲存éŠæˆ² - - Report bug... - 回報錯誤... + + + Cheat codes + 金手指代碼 - - About... - 關於... + + Load state extra data: + 讀å–å³æ™‚存檔é¡å¤–資料: - - E&xit - 離開 (&E) + + Enable Discord Rich Presence + 啟用 Discord Rich Presence - - &Emulation - 模擬 (&E) + + Language + 語言 - - &Reset - é‡æ–°å•Ÿå‹• (&R) + + Library: + 資料庫: - - Sh&utdown - 關機 (&S) + + List view + 清單顯示 - - Yank game pak - 拔除éŠæˆ²å¡å¸¶ + + Tree view + 樹狀顯示 - - &Pause - æš«åœ (&P) + + Show when no game open + ç„¡éŠæˆ²å•Ÿå‹•æ™‚顯示 - - &Next frame - 下一畫格 (&N) + + Show filename instead of ROM name in library view + - - Fast forward (held) - 快轉 (長按) + + Clear cache + æ¸…é™¤å¿«å– - - &Fast forward - 快轉 (&F) + + Allow opposing input directions + å…許相åæ–¹å‘輸入 - - Fast forward speed - 快轉速率 + + Suspend screensaver + æš«åœèž¢å¹•ä¿è­·ç¨‹å¼ - - Unbounded - ç„¡é™åˆ¶ + + When inactive: + 閒置時: - - %0x - %0x + + + Pause + æš«åœ - - Rewind (held) - 倒轉 (長按) + + When minimized: + 最å°åŒ–時: - - Re&wind - 倒轉 (&R) + + Dynamically update window title + 動態更新視窗標題 - - Step backwards - é€æ ¼å€’轉 + + Show FPS in title bar + 標題顯示 FPS - - Sync to &video - 與畫é¢åŒæ­¥ (&V) + + Show filename instead of ROM name in title bar + 標題顯示檔案åç¨±è€Œéž ROM å稱 - - Sync to &audio - 與音訊åŒæ­¥ (&A) + + Show OSD messages + 顯示 OSD è¨Šæ¯ - - Solar sensor - 日光感測器 + + Show frame count in OSD + - - Increase solar level - 增加日光等級 + + Show emulation info on reset + - - Decrease solar level - é™ä½Žæ—¥å…‰ç­‰ç´š + + + + + + + + + + + Browse + ç€è¦½ - - Brightest solar level - 最大日光等級 + + Custom border: + - - Darkest solar level - 最å°æ—¥å…‰ç­‰ç´š + + Current channel: + ç›®å‰é »é“: - - Brightness %1 - 亮度 %1 + + Current version: + ç¾åœ¨ç‰ˆæœ¬: - - Game Boy Printer... - Game Boy Printer... + + Update channel: + æ›´æ–°é »é“: - - BattleChip Gate... - 戰鬥晶片閘... + + Available version: + å¯ç”¨ç‰ˆæœ¬: - - Audio/&Video - 音訊/視訊 (&V) + + (Unknown) + (未知) - - Frame size - ç•«æ ¼å¤§å° + + Last checked: + 上次檢查時間: - - %1× - %1× + + Automatically check on start + 啟動時自動檢查 - - Toggle fullscreen - 切æ›å…¨èž¢å¹• + + Check now + ç¾åœ¨æª¢æŸ¥ - - Lock aspect ratio - 鎖定長寬比 + + Fast forward speed: + 快轉速率: - - Force integer scaling - 強制整數å€æ”¾å¤§ + + + Unbounded + ç„¡é™åˆ¶ - - Interframe blending - ç•«æ ¼é–“æ··åˆ + + Fast forward (held) speed: + 快轉 (長按) 速率: - - Bilinear filtering - 雙線性éŽæ¿¾ + + Autofire interval: + 自動連射間隔: - - Frame&skip - è·³éŽç•«æ ¼ (&S) + + Enable rewind + 啟用倒轉 - - Mute - éœéŸ³ + + Rewind history: + 倒轉歷å²: - - FPS target - FPS 目標 + + Rewind speed: + - - Native (59.7275) - 原生 (59.7275) + + Idle loops: + 閒置迴圈: - - Take &screenshot - 螢幕截圖 (&S) + + Run all + 執行全部 - - F12 - F12 + + Remove known + 移除已知 - - Record A/V... - 錄製音訊/å½±åƒ... + + Detect and remove + åµæ¸¬ä¸¦ç§»é™¤ - - Record GIF/WebP/APNG... - 錄製 GIF/WebP/APNG... + + Preload entire ROM into memory + é å…ˆè®€å–整個 ROM 至記憶體中 - - Video layers - 視訊圖層 + + Enable Game Boy Player features by default + é è¨­å•Ÿç”¨ Game Boy Player 功能 - - Audio channels - éŸ³è¨Šé€šé“ + + Enable VBA bug compatibility in ROM hacks + ROM 修改啟用 VBA 錯誤相容性 - - Adjust layer placement... - 調整圖層ä½ç½®... + + Video renderer: + 渲染器: - - &Tools - 工具 (&T) + + Software + 軟體 - - View &logs... - 查看記錄檔 (&L) + + + OpenGL + OpenGL - - Game &overrides... - éŠæˆ²æ›¿ä»£ (&O) + + OpenGL enhancements + OpenGL 增強 - - Game Pak sensors... - éŠæˆ²å¡å¸¶æ„Ÿæ¸¬å™¨... + + High-resolution scale: + 高畫質比例: - - &Cheats... - 金手指 (&C) + + (240×160) + (240×160) - - Settings... - 設定... + + GB BIOS file: + GB BIOS 檔案: - - Open debugger console... - 打開除錯器控制å°... + + SGB BIOS file: + SGB BIOS 檔案: - - Start &GDB server... - å•Ÿå‹• GDB 伺æœå™¨ (&G) + + GBC BIOS file: + GBC BIOS 檔案: - - View &palette... - 檢視調色盤 (&P) + + GBA BIOS file: + GBA BIOS 檔案: - - View &sprites... - 檢視角色圖 (&S) + + Use BIOS file if found + 若存在,使用 BIOS 檔案 - - View &tiles... - 檢視圖塊 (&T) + + Skip BIOS intro + è·³éŽ BIOS é–‹é ­ç•«é¢ - - View &map... - 檢視映射 (&M) + + Save games + éŠæˆ²å­˜æª” - - &Frame inspector... - 畫格檢視器 (&F) + + + + + + Same directory as the ROM + 與 ROM åŒç›®éŒ„ - - View memory... - 檢視記憶體... + + Save states + å³æ™‚存檔 - - Search memory... - æœå°‹è¨˜æ†¶é«”... + + Screenshots + 螢幕截圖 - - View &I/O registers... - 檢視 I/O 暫存器 (&I) + + Patches + 修補檔 - - Record debug video log... - 錄製除錯影片記錄檔。 + + Cheats + 金手指 - - Stop debug video log - åœæ­¢é™¤éŒ¯å½±ç‰‡è¨˜éŒ„檔 + + Log to file + 記錄到檔案 - - Exit fullscreen - 離開全螢幕 + + Log to console + è¨˜éŒ„åˆ°æŽ§åˆ¶å° - - GameShark Button (held) - Gameshark 按鈕 (長按) + + Select Log File + é¸æ“‡è¨˜éŒ„檔 - - Autofire - 自動連射 + + Models + 模型 - - Autofire A - 自動連射 A + + GB only: + 僅 GB: - - Autofire B - 自動連射 B + + SGB compatible: + SGB 相容: - - Autofire L - 自動連射 L + + GBC only: + 僅 GBC: - - Autofire R - 自動連射 R + + GBC compatible: + GBC 相容: - - Autofire Start - 自動連射 Start + + SGB and GBC compatible: + SGB & GBC 相容: - - Autofire Select - 自動連射 Select + + Super Game Boy borders + Super Game Boy é‚Šç•Œ - - Autofire Up - 自動連射 上 + + Game Boy palette + Game Boy 調色盤 - - Autofire Right - 自動連射 å³ + + Preset: + é è¨­: - - Autofire Down - 自動連射 下 + + Default BG colors: + é è¨­ BG é¡è‰²çµ„: - - Autofire Left - 自動連射 å·¦ + + Default sprite colors 1: + é è¨­è§’色圖é¡è‰²çµ„ 1 - - Clear - 清除 + + Default sprite colors 2: + é è¨­è§’色圖é¡è‰²çµ„ 2 - - - QObject - - %1 byte - %1 ä½å…ƒçµ„ + + SGB color palette if available + è‹¥å¯ç”¨ï¼Œä½¿ç”¨SGB調色盤 - - %1 kiB - %1 kiB + + Default color palette only + 僅使用é è¨­èª¿è‰²ç›¤ - - %1 MiB - %1 MiB + + GBC color palette if available + è‹¥å¯ç”¨ï¼Œä½¿ç”¨GBC調色盤 - - GBA - GBA + + SGB (preferred) or GBC color palette if available + è‹¥å¯ç”¨ï¼Œä½¿ç”¨ SGB (優先) 或 GBC調色盤 - - GB - GB + + Game Boy Camera + Game Boy Camera - - ? - ? + + Driver: + é©…å‹•: - - - QShortcut - - Shift - Shift + + Source: + 來æº: - - Control - Control + + OpenGL (force version 1.x) + OpenGL (強制使用 1.x 版) - - Alt - Alt + + None + ç„¡ - - Meta - Meta + + None (Still Image) + ç„¡ (éœæ…‹å½±åƒ) - - - ROMInfo - - ROM Info - ROM 資訊 + + Keyboard + éµç›¤ - - Game name: - éŠæˆ²å稱: + + Controllers + 控制器 - - Internal name: - 內部å稱: + + Shortcuts + å¿«æ·éµ - - Game ID: - éŠæˆ² ID + + Shaders are not supported when the display driver is not OpenGL. + +If it is set to OpenGL and you still see this, your graphics card or drivers may be too old. + - - File size: - 檔案大å°: + + + + + Shaders + 著色器 - - CRC32: - CRC32: + + Select BIOS + é¸æ“‡ BIOS - - - ReportView - - Generate Bug Report - 產生錯誤報告 + + Select directory + é¸æ“‡è³‡æ–™å¤¾ - - <html><head/><body><p>To file a bug report, please first generate a report file to attach to the bug report you're about to file. It is recommended that you include the save files, as these often help with debugging issues. This will collect some information about the version of {projectName} you're running, your configuration, your computer, and the game you currently have open (if any). Once this collection is completed you can review all of the information gathered below and save it to a zip file. The collection will automatically attempt to redact any personal information, such as your username if it's in any of the paths gathered, but just in case you can edit it afterwards. After you have generated and saved it, please click the button below or go to <a href="https://mgba.io/i/"><span style=" text-decoration: underline; color:#2980b9;">mgba.io/i</span></a> to file the bug report on GitHub. Make sure to attach the report you generated!</p></body></html> - <html><head/><body><p>è‹¥è¦æ出錯誤報告,請先產生一份報告檔,å†å°‡å ±å‘Šæª”附加到è¦æ出的錯誤報告中。建議您附上存檔,因為存檔通常å°é™¤éŒ¯å¾ˆæœ‰å¹«åŠ©ã€‚錯誤報告會收集以下資料:正在執行的 {projectName} 版本ã€è¨­å®šã€é›»è…¦è³‡è¨Šã€ç›®å‰é–‹å•Ÿçš„éŠæˆ² (若有的話)。在資料收集完æˆå¾Œï¼Œæ‚¨å¯ä»¥æª¢æŸ¥æ‰€æœ‰æ”¶é›†çš„è³‡æ–™ï¼Œä¸¦å„²å­˜æˆ zip 壓縮檔。錯誤報告會嘗試自動塗銷所有個人資訊,例如路徑包å«çš„使用者å稱。以防è¬ä¸€æ‚¨é‚„是å¯ä»¥åœ¨é€™ä¹‹å¾Œè‡ªè¡Œç·¨è¼¯ã€‚生æˆä¸¦å„²å­˜å ±å‘Šä¹‹å¾Œï¼Œè«‹é»žæ“Šä¸‹æ–¹æŒ‰éˆ•ï¼Œæˆ–å‰å¾€ <a href="https://mgba.io/i/"><span style=" text-decoration: underline; color:#2980b9;">mgba.io/i</span></a> 以在 GitHub 上æ出報告。請確定附上產生的報告ï¼</p></body></html> + + Select image + é¸æ“‡åœ–片 - - Generate report - 產生報告 + + Image file (*.png *.jpg *.jpeg) + 圖檔 (*.png *.jpg *.jpeg) - - Save - 儲存 + + (%1×%2) + (%1×%2) - - Open issue list in browser - 在ç€è¦½å™¨ä¸­æ‰“é–‹å•é¡Œæ¸…å–® + + Never + æ°¸ä¸ - - Include save file - 附加存檔 + + Just now + 剛剛 - - Create and include savestate - 建立並加入å³æ™‚存檔 + + Less than an hour ago + 一å°æ™‚å…§ + + + + %n hour(s) ago + + %n å°æ™‚å‰ + + + + + %n day(s) ago + + %n æ—¥å‰ + - SaveConverter + QGBA::ShaderSelector - - Convert/Extract Save Game - 轉æ›/æ“·å–存檔 + + No shader active + 無使用中的著色器 + + + + + Load shader + 讀å–著色器 - - Input file - 輸入檔案 + + mGBA Shaders + - - - Browse - ç€è¦½ + + Error loading shader + - - Output file - 輸出檔案 + + The shader "%1" could not be loaded successfully. + - - %1 %2 save game - %1 %2 éŠæˆ²å­˜æª” + + No shader loaded + 未讀å–著色器 - - little endian - ä½å…ƒçµ„ç”±å°åˆ°å¤§ + + by %1 + ç”± %1 - - big endian - ä½å…ƒçµ„ç”±å¤§åˆ°å° + + Preprocessing + é è™•ç† - - SRAM - SRAM + + Pass %1 + é€šé“ %1 - - %1 flash - %1 flash + + Shaders + 著色器 - - %1 EEPROM - %1 EEPROM + + Active Shader: + 使用中的著色器: - - %1 SRAM + RTC - %1 SRAM + RTC + + Name + å稱 - - %1 SRAM - %1 SRAM + + Author + 作者 - - packed MBC2 - åŒ…è£ MBC2 + + Description + æè¿° - - unpacked MBC2 - æœªåŒ…è£ MBC2 + + Unload Shader + å¸é™¤è‘—色器 - - MBC6 flash - MBC6 flash + + Load New Shader + 讀å–新著色器 + + + QGBA::ShortcutModel - - MBC6 combined SRAM + flash - MBC6 åˆä½µ SRAM + flash + + Action + 動作 - - MBC6 SRAM - MBC6 SRAM + + Keyboard + éµç›¤ - - TAMA5 - TAMA5 + + Gamepad + éŠæˆ²æ‰‹æŠŠ + + + QGBA::ShortcutView - - %1 (%2) - %1 (%2) + + Edit Shortcuts + 編輯快æ·éµ - - %1 save state with embedded %2 save game - %1 å³æ™‚存檔與嵌入的 %2 éŠæˆ²å­˜æª” + + Keyboard + éµç›¤ - - %1 SharkPort %2 save game - %1 SharkPort %2 存檔 + + Gamepad + éŠæˆ²æ‰‹æŠŠ - - %1 GameShark Advance SP %2 save game - %1 GameShark Advance SP %2 存檔 + + Clear + 清除 - SensorView + QGBA::TileView - - Sensors - 感測器 + + Export tiles + 匯出圖塊 - - Realtime clock - 實時計時器 + + + Portable Network Graphics (*.png) + å¯æ”œå¼ç¶²è·¯åœ–å½¢ (*.png) - - Fixed time - 固定時間 + + Export tile + 匯出圖塊 - - System time - 系統時間 + + Tiles + 圖塊 - - Start time at - 開始時間於 + + Palette + 調色盤 - - Now - ç¾åœ¨ + + 256 colors + 256 色 - - MM/dd/yy hh:mm:ss AP - yy/MM/dd hh:mm:ss AP + + Magnification + 放大 - - Light sensor - 光感測器 + + Tiles per row + æ¯è¡Œåœ–塊數 - - Brightness - 亮度 + + Fit to window + è²¼åˆè¦–窗 - - Tilt sensor - 傾斜感測器 + + Displayed tiles + - - - Set Y - 設定 Y + + Only BG tiles + - - - Set X - 設定 X + + Only OBJ tiles + - - Gyroscope - 陀螺儀 + + Both + 兩者 - - Sensitivity - éˆæ•åº¦ + + Copy Selected + 複製é¸å– + + + + Export Selected + åŒ¯å‡ºæ‰€é¸ + + + + Copy All + 複製全部 + + + + Export All + 匯出全部 - SettingsView + QGBA::VideoView - - Settings - 設定 + + Failed to open output video file: %1 + 輸出影片開啟失敗: %1 - - Audio/Video - 音訊/視訊 + + Native (%0x%1) + 原始畫質 (%0x%1) - - Interface - ä»‹é¢ + + Select output file + é¸æ“‡è¼¸å‡ºçš„檔案 - - Update - æ›´æ–° + + Record Video + 錄影 - - Emulation - 模擬 + + Start + - - Enhancements - 增強 + + Stop + åœæ­¢ - - BIOS - BIOS + + Select File + é¸æ“‡æª”案 - - Paths - 路徑 + + Presets + é è¨­ - - Logging - 記錄 + + High &Quality + 高畫質 (&Q) - - Game Boy - Game Boy + + &YouTube + YouTube (&Y) - - Audio driver: - 音訊驅動: + + WebM + WebM - - Audio buffer: - 音訊緩è¡: + + MP4 + MP4 - - - 1536 - 1536 + + &Lossless + ç„¡æå“質 (&L) - - 512 - 512 + + 4K + 4K - - 768 - 768 + + &1080p + 1080p (&1) - - 1024 - 1024 + + &720p + 720p (&7) - - 2048 - 2048 + + &480p + 480p (&4) - - 3072 - 3072 + + &Native + 原始畫質 (&N) - - 4096 - 4096 + + Format + æ ¼å¼ - - samples - å–樣 + + Bitrate (kbps) + ä½å…ƒçŽ‡ (kbps) - - Sample rate: - å–樣率: + + ABR + ABR - - - 44100 - 44100 + + VBR + VBR - - 22050 - 22050 + + CRF + CRF - - 32000 - 32000 + + Dimensions + 維度 - - 48000 - 48000 + + Lock aspect ratio + 鎖定長寬比 - - Hz - Hz + + Show advanced + 顯示進階é¸é … + + + QGBA::Window - - Volume: - 音é‡: + + Archives (%1) + 壓縮檔 (%1) - - - - - Mute - éœéŸ³ + + + + Select ROM + é¸æ“‡ ROM - - Fast forward volume: - 快轉音é‡: + + Select folder + é¸æ“‡è³‡æ–™å¤¾ - - Audio in multiplayer: - 多人éŠæˆ²éŸ³è¨Š: + + + Select save + é¸æ“‡å­˜æª” - - All windows - 所有視窗 + + Select patch + é¸æ“‡ä¿®è£œæª” - - Player 1 window only - 僅玩家 1 視窗 + + Patches (*.ips *.ups *.bps) + 修補檔 (*.ips *.ups *.bps) - - Currently active player window - ç¾åœ¨ä½¿ç”¨ä¸­çš„玩家視窗 + + Select e-Reader dotcode + é¸æ“‡ e-Reader 點碼 - - Display driver: - 顯示驅動: + + e-Reader card (*.raw *.bin *.bmp) + e-Reader å¡ç‰‡ (*.raw *.bin *.bmp) - - Frameskip: - è·³éŽç•«æ ¼: + + Select image + é¸æ“‡åœ–片 - - Skip every - æ¯éš” N ç•«æ ¼è·³éŽ + + Image file (*.png *.gif *.jpg *.jpeg);;All files (*) + 圖檔 (*.png *.gif *.jpg *.jpeg);;所有檔案 (*) - - - frames - ç•«æ ¼ + + GameShark saves (*.sps *.xps) + GameShark 存檔 (*.sps *.xps) - - FPS target: - FPS 目標: + + Select video log + é¸æ“‡å½±ç‰‡è¨˜éŒ„檔 + + + + Video logs (*.mvl) + 影片記錄檔 (*.mvl) + + + + Crash + 當機 - - frames per second - æ¯ç§’畫格數 (FPS) + + The game has crashed with the following error: + +%1 + éŠæˆ²å› ä»¥ä¸‹éŒ¯èª¤ç•¶æ©Ÿ: + +%1 - - Sync: - åŒæ­¥: + + Couldn't Start + 無法啟動 - - Video - 視訊 + + Could not start game. + 無法啟動éŠæˆ²ã€‚ - - Audio - 音訊 + + Unimplemented BIOS call + 未實è£çš„ BIOS å‘¼å« - - Lock aspect ratio - 鎖定長寬比 + + This game uses a BIOS call that is not implemented. Please use the official BIOS for best experience. + æ­¤éŠæˆ²ä½¿ç”¨äº†æœªå¯¦è£çš„ BIOS 呼å«ã€‚為了ç²å¾—最佳體驗,請使用官方 BIOS。 - - Force integer scaling - 強制整數å€æ”¾å¤§ + + Failed to create an appropriate display device, falling back to software display. Games may run slowly, especially with larger windows. + 建立é©ç•¶çš„顯示è£ç½®å¤±æ•—,回歸到軟體顯示。éŠæˆ²å¯èƒ½æœƒè·‘得很慢,尤其在使用大螢幕的時候。 - - Bilinear filtering - 雙線性éŽæ¿¾ + + Really make portable? + 這真的å¯æ”œï¼Ÿ - - - Pause - æš«åœ + + This will make the emulator load its configuration from the same directory as the executable. Do you want to continue? + 模擬器會從執行檔所在的資料夾讀å–設定檔。確定è¦ç¹¼çºŒå—Žï¼Ÿ - - When inactive: - 閒置時: + + Restart needed + 需è¦é‡æ–°å•Ÿå‹• - - When minimized: - 最å°åŒ–時: + + Some changes will not take effect until the emulator is restarted. + 有些變更在模擬器é‡æ–°å•Ÿå‹•å‰ä¸æœƒç”Ÿæ•ˆã€‚ - - Current channel: - ç›®å‰é »é“: + + Reset needed + - - Current version: - ç¾åœ¨ç‰ˆæœ¬: + + Some changes will not take effect until the game is reset. + - - Update channel: - æ›´æ–°é »é“: + + - Player %1 of %2 + - Player %1 of %2 - - Available version: - å¯ç”¨ç‰ˆæœ¬: + + %1 - %2 + %1 - %2 - - (Unknown) - (未知) + + %1 - %2 - %3 + %1 - %2 - %3 - - Last checked: - 上次檢查時間: + + %1 - %2 (%3 fps) - %4 + %1 - %2 (%3 fps) - %4 - - Automatically check on start - 啟動時自動檢查 + + &File + 檔案 (&F) - - Check now - ç¾åœ¨æª¢æŸ¥ + + Load &ROM... + è®€å– ROM (&R) ... - - Default color palette only - 僅使用é è¨­èª¿è‰²ç›¤ + + Load ROM in archive... + 從壓縮檔讀å–ROM... - - SGB color palette if available - è‹¥å¯ç”¨ï¼Œä½¿ç”¨SGB調色盤 + + Add folder to library... + 加入資料夾至收è—... - - GBC color palette if available - è‹¥å¯ç”¨ï¼Œä½¿ç”¨GBC調色盤 + + Save games (%1) + éŠæˆ²å­˜æª” (%1) - - SGB (preferred) or GBC color palette if available - è‹¥å¯ç”¨ï¼Œä½¿ç”¨ SGB (優先) 或 GBC調色盤 + + Select save game + é¸æ“‡å­˜æª” - - Game Boy Camera - Game Boy Camera + + mGBA save state files (%1) + mGBA å³æ™‚存檔 (%1) - - Driver: - é©…å‹•: + + + Select save state + é¸æ“‡å³æ™‚存檔 - - Source: - 來æº: + + Select e-Reader card images + é¸å– e-Reader å¡ç‰‡åœ–檔 - - Native (59.7275) - 原生 (59.7275) + + Image file (*.png *.jpg *.jpeg) + 圖檔 (*.png *.jpg *.jpeg) - - Interframe blending - ç•«æ ¼é–“æ··åˆ + + Conversion finished + è½‰æª”å®Œæˆ - - Language - 語言 + + %1 of %2 e-Reader cards converted successfully. + %1 å¼µ e-Reader å¡ç‰‡è½‰æ›æˆåŠŸã€‚ (å…± %2 å¼µ) - - Library: - 資料庫: + + Load alternate save game... + 讀å–å¦ä¸€ä»½å­˜æª”... - - List view - 清單顯示 + + Load temporary save game... + 讀å–暫時存檔... - - Tree view - 樹狀顯示 + + Load &patch... + 讀å–並修補 (&P) ... - - Show when no game open - ç„¡éŠæˆ²å•Ÿå‹•æ™‚顯示 + + Boot BIOS + å•Ÿå‹• BIOS - - Clear cache - æ¸…é™¤å¿«å– + + Replace ROM... + å–代 ROM... - - Allow opposing input directions - å…許相åæ–¹å‘輸入 + + Scan e-Reader dotcodes... + 掃æ e-Reader 點碼 - - Suspend screensaver - æš«åœèž¢å¹•ä¿è­·ç¨‹å¼ + + Convert e-Reader card image to raw... + è½‰æ› e-Reader å¡ç‰‡åœ–檔為原始資料 - - Dynamically update window title - 動態更新視窗標題 + + ROM &info... + ROM 資訊 (&I) - - Show filename instead of ROM name in title bar - 標題顯示檔案åç¨±è€Œéž ROM å稱 + + Recent + 最近使用 - - Show OSD messages - 顯示 OSD è¨Šæ¯ + + Make portable + å¯æ”œåŒ– - - Enable Discord Rich Presence - 啟用 Discord Rich Presence + + &Load state + 讀å–å³æ™‚存檔 (&L) - - Automatically save state - 自動儲存å³æ™‚存檔 + + Load state file... + 讀å–å³æ™‚存檔... - - Automatically load state - 自動讀å–å³æ™‚存檔 + + &Save state + 儲存å³æ™‚存檔 (&S) - - Automatically save cheats - 自動儲存金手指 + + Save state file... + 儲存å³æ™‚存檔... - - Automatically load cheats - 自動讀å–金手指 + + Quick load + å¿«é€Ÿè®€å– - - Show FPS in title bar - 標題顯示 FPS + + Quick save + 快速儲存 - - Fast forward speed: - 快轉速率: + + Load recent + 讀å–最近存檔 - - - Unbounded - ç„¡é™åˆ¶ + + Save recent + 儲存最近存檔 - - Fast forward (held) speed: - 快轉 (長按) 速率: + + Undo load state + å–消讀å–å³æ™‚存檔 - - Autofire interval: - 自動連射間隔: + + Undo save state + å–消儲存å³æ™‚存檔 - - Enable rewind - 啟用倒轉 + + + State &%1 + å³æ™‚存檔 (&%1) - - Rewind history: - 倒轉歷å²: + + Load camera image... + 讀å–相機影åƒ... - - Idle loops: - 閒置迴圈: + + Convert save game... + 轉æ›å­˜æª”... - - Run all - 執行全部 + + GameShark saves (*.gsv *.sps *.xps) + GameShark 存檔 (*.gsv *.sps *.xps) - - Remove known - 移除已知 + + Save games + éŠæˆ²å­˜æª” - - Detect and remove - åµæ¸¬ä¸¦ç§»é™¤ + + Import GameShark Save... + 匯入 GameShark 存檔 - - Preload entire ROM into memory - é å…ˆè®€å–整個 ROM 至記憶體中 + + Export GameShark Save... + 匯出 GameShark 存檔 - - Save state extra data: - 儲存å³æ™‚存檔é¡å¤–資料: + + Automatically determine + - - - Save game - 儲存éŠæˆ² + + Use player %0 save game + - - Load state extra data: - 讀å–å³æ™‚存檔é¡å¤–資料: + + New multiplayer window + 新增多人éŠæˆ²è¦–窗 - - Models - 模型 + + Connect to Dolphin... + 連接 Dolphin... - - GB only: - 僅 GB: + + Report bug... + 回報錯誤... - - SGB compatible: - SGB 相容: + + About... + 關於... - - GBC only: - 僅 GBC: + + E&xit + 離開 (&E) - - GBC compatible: - GBC 相容: + + &Emulation + 模擬 (&E) - - SGB and GBC compatible: - SGB & GBC 相容: + + &Reset + é‡æ–°å•Ÿå‹• (&R) - - Game Boy palette - Game Boy 調色盤 + + Sh&utdown + 關機 (&S) - - Preset: - é è¨­: + + Yank game pak + 拔除éŠæˆ²å¡å¸¶ - - - Screenshot - 螢幕截圖 + + &Pause + æš«åœ (&P) - - - Cheat codes - 金手指代碼 + + &Next frame + 下一畫格 (&N) - - Enable Game Boy Player features by default - é è¨­å•Ÿç”¨ Game Boy Player 功能 + + Fast forward (held) + 快轉 (長按) - - Enable VBA bug compatibility in ROM hacks - ROM 修改啟用 VBA 錯誤相容性 + + &Fast forward + 快轉 (&F) - - Video renderer: - 渲染器: + + Fast forward speed + 快轉速率 - - Software - 軟體 + + Unbounded + ç„¡é™åˆ¶ - - OpenGL - OpenGL + + %0x + %0x - - OpenGL enhancements - OpenGL 增強 + + Increase fast forward speed + - - High-resolution scale: - 高畫質比例: + + Decrease fast forward speed + - - (240×160) - (240×160) + + Rewind (held) + 倒轉 (長按) - - XQ GBA audio (experimental) - XQ GBA 音訊 (測試版) + + Re&wind + 倒轉 (&R) - - GB BIOS file: - GB BIOS 檔案: - - - - - - - - - - - - Browse - ç€è¦½ + + Step backwards + é€æ ¼å€’轉 - - Use BIOS file if found - 若存在,使用 BIOS 檔案 + + Solar sensor + 日光感測器 - - Skip BIOS intro - è·³éŽ BIOS é–‹é ­ç•«é¢ + + Increase solar level + 增加日光等級 - - GBA BIOS file: - GBA BIOS 檔案: + + Decrease solar level + é™ä½Žæ—¥å…‰ç­‰ç´š - - GBC BIOS file: - GBC BIOS 檔案: + + Brightest solar level + 最大日光等級 - - SGB BIOS file: - SGB BIOS 檔案: + + Darkest solar level + 最å°æ—¥å…‰ç­‰ç´š - - Save games - éŠæˆ²å­˜æª” + + Brightness %1 + 亮度 %1 - - - - - - Same directory as the ROM - 與 ROM åŒç›®éŒ„ + + Game Boy Printer... + Game Boy Printer... - - Save states - å³æ™‚存檔 + + BattleChip Gate... + 戰鬥晶片閘... - - Screenshots - 螢幕截圖 + + Audio/&Video + 音訊/視訊 (&V) - - Patches - 修補檔 + + Frame size + ç•«æ ¼å¤§å° - - Cheats - 金手指 + + %1× + %1× - - Log to file - 記錄到檔案 + + Toggle fullscreen + 切æ›å…¨èž¢å¹• - - Log to console - è¨˜éŒ„åˆ°æŽ§åˆ¶å° + + &Lock frame size + - - Select Log File - é¸æ“‡è¨˜éŒ„檔 + + Lock aspect ratio + 鎖定長寬比 - - Default BG colors: - é è¨­ BG é¡è‰²çµ„: + + Force integer scaling + 強制整數å€æ”¾å¤§ - - Default sprite colors 1: - é è¨­è§’色圖é¡è‰²çµ„ 1 + + Interframe blending + ç•«æ ¼é–“æ··åˆ - - Default sprite colors 2: - é è¨­è§’色圖é¡è‰²çµ„ 2 + + Bilinear filtering + 雙線性éŽæ¿¾ - - Super Game Boy borders - Super Game Boy é‚Šç•Œ + + Frame&skip + è·³éŽç•«æ ¼ (&S) - - - ShaderSelector - - Shaders - 著色器 + + Mute + éœéŸ³ - - Active Shader: - 使用中的著色器: + + FPS target + FPS 目標 - - Name - å稱 + + Native (59.7275) + 原生 (59.7275) - - Author - 作者 + + Take &screenshot + 螢幕截圖 (&S) - - Description - æè¿° + + F12 + F12 - - Unload Shader - å¸é™¤è‘—色器 + + Record A/V... + 錄製音訊/å½±åƒ... - - Load New Shader - 讀å–新著色器 + + Record GIF/WebP/APNG... + 錄製 GIF/WebP/APNG... - - - ShortcutView - - Edit Shortcuts - 編輯快æ·éµ + + Video layers + 視訊圖層 - - Keyboard - éµç›¤ + + Audio channels + éŸ³è¨Šé€šé“ - - Gamepad - éŠæˆ²æ‰‹æŠŠ + + Adjust layer placement... + 調整圖層ä½ç½®... - - Clear - 清除 + + &Tools + 工具 (&T) - - - TileView - - Tiles - 圖塊 + + View &logs... + 查看記錄檔 (&L) - - Export Selected - åŒ¯å‡ºæ‰€é¸ + + Game &overrides... + éŠæˆ²æ›¿ä»£ (&O) - - Export All - 匯出全部 + + Game Pak sensors... + éŠæˆ²å¡å¸¶æ„Ÿæ¸¬å™¨... - - 256 colors - 256 色 + + &Cheats... + 金手指 (&C) - - Magnification - 放大 + + Scripting... + - - Tiles per row - æ¯è¡Œåœ–塊數 + + Create forwarder... + - - Fit to window - è²¼åˆè¦–窗 + + Settings... + 設定... - - Copy Selected - 複製é¸å– + + Open debugger console... + 打開除錯器控制å°... - - Copy All - 複製全部 + + Start &GDB server... + å•Ÿå‹• GDB 伺æœå™¨ (&G) - - - VideoView - - Record Video - 錄影 + + Game state views + - - Start - Start + + View &palette... + 檢視調色盤 (&P) - - Stop - åœæ­¢ + + View &sprites... + 檢視角色圖 (&S) - - Select File - é¸æ“‡æª”案 + + View &tiles... + 檢視圖塊 (&T) - - Presets - é è¨­ + + View &map... + 檢視映射 (&M) - - High &Quality - 高畫質 (&Q) + + &Frame inspector... + 畫格檢視器 (&F) - - &YouTube - YouTube (&Y) + + View memory... + 檢視記憶體... - - - WebM - WebM + + Search memory... + æœå°‹è¨˜æ†¶é«”... - - - MP4 - MP4 + + View &I/O registers... + 檢視 I/O 暫存器 (&I) - - &Lossless - ç„¡æå“質 (&L) + + Log memory &accesses... + - - 4K - 4K + + Record debug video log... + 錄製除錯影片記錄檔。 - - &1080p - 1080p (&1) + + Stop debug video log + åœæ­¢é™¤éŒ¯å½±ç‰‡è¨˜éŒ„檔 - - &720p - 720p (&7) + + Exit fullscreen + 離開全螢幕 - - &480p - 480p (&4) + + GameShark Button (held) + Gameshark 按鈕 (長按) - - &Native - 原始畫質 (&N) + + Autofire + 自動連射 - - Format - æ ¼å¼ + + Autofire A + 自動連射 A - - MKV - MKV + + Autofire B + 自動連射 B - - AVI - AVI + + Autofire L + 自動連射 L - - HEVC - HEVC + + Autofire R + 自動連射 R - - HEVC (NVENC) - HEVC (NVENC) + + Autofire Start + 自動連射 Start - - VP8 - VP8 + + Autofire Select + 自動連射 Select - - VP9 - VP9 + + Autofire Up + 自動連射 上 - - FFV1 - FFV1 + + Autofire Right + 自動連射 å³ - - - None - ç„¡ + + Autofire Down + 自動連射 下 - - FLAC - FLAC + + Autofire Left + 自動連射 å·¦ - - Opus - Opus + + Clear + 清除 + + + QObject - - Vorbis - Vorbis + + %1 byte + %1 ä½å…ƒçµ„ - - MP3 - MP3 + + %1 kiB + %1 kiB - - AAC - AAC + + %1 MiB + %1 MiB - - Uncompressed - 未壓縮 + + GBA + GBA - - Bitrate (kbps) - ä½å…ƒçŽ‡ (kbps) + + GB + GB - - ABR - ABR + + ? + ? - - H.264 - H.264 + + Super (L) + Super (L) - - H.264 (NVENC) - H.264 (NVENC) + + Super (R) + Super (R) - - VBR - VBR + + Menu + é¸å–® + + + QShortcut - - CRF - CRF + + Shift + Shift - - Dimensions - 維度 + + Control + Control - - Lock aspect ratio - 鎖定長寬比 + + Alt + Alt - - Show advanced - 顯示進階é¸é … + + Meta + Meta From fb0fed21aa53dd96def972289eed28358e178a27 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 13 Dec 2024 14:48:27 -0800 Subject: [PATCH 313/338] Qt: Skip processing QLocale::C if present --- src/platform/qt/SettingsView.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/platform/qt/SettingsView.cpp b/src/platform/qt/SettingsView.cpp index a72bf0d7bb8..f4eea01dbc4 100644 --- a/src/platform/qt/SettingsView.cpp +++ b/src/platform/qt/SettingsView.cpp @@ -364,7 +364,7 @@ SettingsView::SettingsView(ConfigController* controller, InputController* inputC continue; } QLocale locale(name.remove(QString("%0-").arg(binaryName)).remove(".qm")); - if (locale.language() == QLocale::English) { + if (locale.language() == QLocale::English || locale.language() == QLocale::C) { continue; } QString endonym = locale.nativeLanguageName(); From 1983d0f42cb39dd06114d3aa8941dbf21ed62e1f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 14 Dec 2024 22:28:08 -0800 Subject: [PATCH 314/338] GBA Core: Fix booting into BIOS when skip BIOS is enabled --- CHANGES | 3 ++- src/gba/core.c | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/CHANGES b/CHANGES index f3a8cc53984..42fea400eb9 100644 --- a/CHANGES +++ b/CHANGES @@ -19,8 +19,9 @@ Other fixes: - Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963) - Debugger: Fix writing to specific segment in command-line debugger - GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1 - - GBA Hardware: Fix loading states unconditionally overwriting GPIO memory - GBA: Fix getting game info for multiboot ROMs + - GBA Core: Fix booting into BIOS when skip BIOS is enabled + - GBA Hardware: Fix loading states unconditionally overwriting GPIO memory - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) - Qt: Fix potential crash when configuring shortcuts Misc: diff --git a/src/gba/core.c b/src/gba/core.c index 1d3fffb9ef0..da782d06cfb 100644 --- a/src/gba/core.c +++ b/src/gba/core.c @@ -801,7 +801,7 @@ static void _GBACoreReset(struct mCore* core) { #endif ARMReset(core->cpu); - bool forceSkip = gba->mbVf || core->opts.skipBios; + bool forceSkip = gba->mbVf || (core->opts.skipBios && (gba->romVf || gba->memory.rom)); if (!forceSkip && (gba->romVf || gba->memory.rom) && gba->pristineRomSize >= 0xA0 && gba->biosVf) { uint32_t crc = doCrc32(&gba->memory.rom[1], 0x9C); if (crc != LOGO_CRC32) { From 39ab641953e8c6e977b893527fd260858c3a6402 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Fri, 20 Dec 2024 02:14:23 -0800 Subject: [PATCH 315/338] GBA Savedata: Demote savegme time offset message to DEBUG level --- src/gba/savedata.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gba/savedata.c b/src/gba/savedata.c index c0d2c889a52..50d2be3818a 100644 --- a/src/gba/savedata.c +++ b/src/gba/savedata.c @@ -702,7 +702,7 @@ void GBASavedataRTCRead(struct GBASavedata* savedata) { savedata->gpio->rtc.offset = savedata->gpio->rtc.lastLatch - rtcTime; - mLOG(GBA_SAVE, ERROR, "Savegame time offset set to %li", savedata->gpio->rtc.offset); + mLOG(GBA_SAVE, DEBUG, "Savegame time offset set to %li", savedata->gpio->rtc.offset); } void GBASavedataSerialize(const struct GBASavedata* savedata, struct GBASerializedState* state) { From 08430fc058c4a4ef57ddd40006bb356c1e3024a2 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 22 Dec 2024 04:50:46 -0800 Subject: [PATCH 316/338] mGUI: Load parent directory if last used directory is missing (fixes #3379) --- CHANGES | 1 + include/mgba-util/gui/menu.h | 3 +++ src/util/gui/file-select.c | 11 ++++++++++- src/util/gui/menu.c | 2 ++ 4 files changed, 16 insertions(+), 1 deletion(-) diff --git a/CHANGES b/CHANGES index 42fea400eb9..847865d2637 100644 --- a/CHANGES +++ b/CHANGES @@ -22,6 +22,7 @@ Other fixes: - GBA: Fix getting game info for multiboot ROMs - GBA Core: Fix booting into BIOS when skip BIOS is enabled - GBA Hardware: Fix loading states unconditionally overwriting GPIO memory + - mGUI: Load parent directory if last used directory is missing (fixes mgba.io/i/3379) - Qt: Fix savestate preview sizes with different scales (fixes mgba.io/i/2560) - Qt: Fix potential crash when configuring shortcuts Misc: diff --git a/include/mgba-util/gui/menu.h b/include/mgba-util/gui/menu.h index 399ddd8c3b4..4a1c3651abf 100644 --- a/include/mgba-util/gui/menu.h +++ b/include/mgba-util/gui/menu.h @@ -10,9 +10,12 @@ CXX_GUARD_START +#include #include #include +mLOG_DECLARE_CATEGORY(GUI_MENU); + #define GUI_V_V (struct GUIVariant) { .type = GUI_VARIANT_VOID } #define GUI_V_U(U) (struct GUIVariant) { .type = GUI_VARIANT_UNSIGNED, .v.u = (U) } #define GUI_V_I(I) (struct GUIVariant) { .type = GUI_VARIANT_INT, .v.i = (I) } diff --git a/src/util/gui/file-select.c b/src/util/gui/file-select.c index 0cdfba35d77..f13668c3fc9 100644 --- a/src/util/gui/file-select.c +++ b/src/util/gui/file-select.c @@ -163,7 +163,16 @@ bool GUISelectFile(struct GUIParams* params, char* outPath, size_t outLen, bool .subtitle = params->currentPath, }; GUIMenuItemListInit(&menu.items, 0); - _refreshDirectory(params, params->currentPath, &menu.items, filterName, filterContents, preselect); + while (true) { + if (_refreshDirectory(params, params->currentPath, &menu.items, filterName, filterContents, preselect)) { + break; + } + if (strncmp(params->currentPath, params->basePath, PATH_MAX) == 0 || !params->currentPath[0]) { + mLOG(GUI_MENU, ERROR, "Failed to load base directory"); + return false; + } + _upDirectory(params->currentPath); + } menu.index = params->fileIndex; while (true) { diff --git a/src/util/gui/menu.c b/src/util/gui/menu.c index f0c624f1715..2109bf8e114 100644 --- a/src/util/gui/menu.c +++ b/src/util/gui/menu.c @@ -17,6 +17,8 @@ DEFINE_VECTOR(GUIMenuItemList, struct GUIMenuItem); DEFINE_VECTOR(GUIMenuSavedList, struct GUIMenuSavedState); +mLOG_DEFINE_CATEGORY(GUI_MENU, "GUI Menu", "gui.menu"); + void _itemNext(struct GUIMenuItem* item, bool wrap) { if (wrap || item->state < item->nStates - 1) { unsigned oldState = item->state; From d82fc3dec1001dc5fd83e30c4e75e21ff8c69e59 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 24 Dec 2024 18:54:10 -0800 Subject: [PATCH 317/338] FFmpeg: Fix failing to record videos with CRF video (fixes #3368) --- CHANGES | 1 + src/feature/ffmpeg/ffmpeg-encoder.c | 4 +++- 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/CHANGES b/CHANGES index 847865d2637..62f51060ce4 100644 --- a/CHANGES +++ b/CHANGES @@ -18,6 +18,7 @@ Emulation fixes: Other fixes: - Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963) - Debugger: Fix writing to specific segment in command-line debugger + - FFmpeg: Fix failing to record videos with CRF video (fixes mgba.io/i/3368) - GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1 - GBA: Fix getting game info for multiboot ROMs - GBA Core: Fix booting into BIOS when skip BIOS is enabled diff --git a/src/feature/ffmpeg/ffmpeg-encoder.c b/src/feature/ffmpeg/ffmpeg-encoder.c index 6202e0fcdce..e83aa680c51 100644 --- a/src/feature/ffmpeg/ffmpeg-encoder.c +++ b/src/feature/ffmpeg/ffmpeg-encoder.c @@ -384,7 +384,9 @@ bool FFmpegEncoderOpen(struct FFmpegEncoder* encoder, const char* outfile) { encoder->videoStream = avformat_new_stream(encoder->context, vcodec); encoder->video = encoder->videoStream->codec; #endif - encoder->video->bit_rate = encoder->videoBitrate; + if (encoder->videoBitrate >= 0) { + encoder->video->bit_rate = encoder->videoBitrate; + } encoder->video->width = encoder->width; encoder->video->height = encoder->height; encoder->video->time_base = (AVRational) { encoder->frameCycles * encoder->frameskip, encoder->cycles }; From ad0d3972a695e9eddfb45be0072eb94961382e4b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sat, 28 Dec 2024 22:45:39 -0800 Subject: [PATCH 318/338] Updater: Fix rewriting folders and files on Windows (fixes #3384) --- CHANGES | 1 + src/tools/updater-main.c | 20 ++++++++++++-------- 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/CHANGES b/CHANGES index 62f51060ce4..b5b2f4fe1c7 100644 --- a/CHANGES +++ b/CHANGES @@ -48,6 +48,7 @@ Misc: - Qt: Show a dummy shader settings tab if shaders aren't supported - Res: Port NSO-gba-colors shader (closes mgba.io/i/2834) - Scripting: Add `callbacks:oneshot` for single-call callbacks + - Updater: Fix rewriting folders and files on Windows (fixes mgba.io/i/3384) 0.10.4: (2024-12-07) Emulation fixes: diff --git a/src/tools/updater-main.c b/src/tools/updater-main.c index a27a07a08a3..b536e320802 100644 --- a/src/tools/updater-main.c +++ b/src/tools/updater-main.c @@ -133,14 +133,11 @@ bool extractArchive(struct VDir* archive, const char* root, bool prefix) { errno = 0; vfOut = VFileOpen(path, O_WRONLY | O_CREAT | O_TRUNC); if (!vfOut) { - if (errno == EACCES) { -#ifdef _WIN32 - Sleep(1000); -#else - sleep(1); -#endif - vfOut = VFileOpen(path, O_WRONLY | O_CREAT | O_TRUNC); - } else if (errno == EISDIR) { + int error = errno; + struct stat st; + if (error == EISDIR || (stat(path, &st) >= 0 && S_ISDIR(st.st_mode))) { + // Windows maps STATUS_FILE_IS_A_DIRECTORY to ERROR_ACCESS_DENIED, + // which then gets mapped to EACCESS, because everything is awful fprintf(logfile, "rm -r %s\n", path); if (!rmdirRecursive(VDirOpen(path))) { return false; @@ -151,6 +148,13 @@ bool extractArchive(struct VDir* archive, const char* root, bool prefix) { RemoveDirectoryW(wpath); #else rmdir(path); +#endif + vfOut = VFileOpen(path, O_WRONLY | O_CREAT | O_TRUNC); + } else if (error == EACCES || error == ETXTBSY) { +#ifdef _WIN32 + Sleep(1000); +#else + sleep(1); #endif vfOut = VFileOpen(path, O_WRONLY | O_CREAT | O_TRUNC); } From 4007e19736706fb320cec5724fec3abf6391021c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Sun, 29 Dec 2024 17:38:14 -0800 Subject: [PATCH 319/338] CMake: Fix entitlements plist filename --- src/platform/qt/CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/platform/qt/CMakeLists.txt b/src/platform/qt/CMakeLists.txt index 3134512f26c..a5fe5b8a857 100644 --- a/src/platform/qt/CMakeLists.txt +++ b/src/platform/qt/CMakeLists.txt @@ -517,7 +517,7 @@ if(APPLE) set(DEPLOY_OPTIONS ${DEPLOY_OPTIONS} -R "${CROSS_ROOT}") endif() if($ENV{CODESIGN_IDENTITY}) - set(DEPLOY_OPTIONS ${DEPLOY_OPTIONS} -s "$ENV{CODESIGN_IDENTITY}" -E "${PROJECT_SOURCE_DIR}/res/entitlements.xml") + set(DEPLOY_OPTIONS ${DEPLOY_OPTIONS} -s "$ENV{CODESIGN_IDENTITY}" -E "${PROJECT_SOURCE_DIR}/res/entitlements.plist") endif() install(CODE "execute_process(COMMAND \"${PROJECT_SOURCE_DIR}/tools/deploy-mac.py\" -v ${DEPLOY_OPTIONS} \"\$ENV{DESTDIR}\${CMAKE_INSTALL_PREFIX}/${APPDIR}/${PROJECT_NAME}.app\")") endif() From 6b5638efda0e615ddae0091c02ba1ad041bbd5b5 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 31 Dec 2024 01:35:49 -0800 Subject: [PATCH 320/338] Core: Improve PNG deserialization logging --- src/core/serialize.c | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/src/core/serialize.c b/src/core/serialize.c index 4f7c07a4afe..7e3426a597a 100644 --- a/src/core/serialize.c +++ b/src/core/serialize.c @@ -249,9 +249,16 @@ static int _loadPNGChunkHandler(png_structp png, png_unknown_chunkp chunk) { } const uint8_t* data = chunk->data; data += sizeof(uint32_t) * 2; - uncompress((Bytef*) item.data, &len, data, chunk->size); - item.size = len; - mStateExtdataPut(extdata, tag, &item); + if (uncompress((Bytef*) item.data, &len, data, chunk->size) == Z_OK) { + if (item.size != len) { + mLOG(SAVESTATE, WARN, "Mismatched decompressed extdata %i size (%"PRIz"u vs %"PRIz"u)", tag, item.size, (size_t) len); + item.size = len; + } + mStateExtdataPut(extdata, tag, &item); + } else { + mLOG(SAVESTATE, WARN, "Failed to decompress extdata chunk"); + free(item.data); + } return 1; } return 0; @@ -320,7 +327,7 @@ static void* _loadPNGState(struct mCore* core, struct VFile* vf, struct mStateEx return state; } -static bool _loadPNGExtadata(struct VFile* vf, struct mStateExtdata* extdata) { +static bool _loadPNGExtdata(struct VFile* vf, struct mStateExtdata* extdata) { png_structp png = PNGReadOpen(vf, PNG_HEADER_BYTES); png_infop info = png_create_info_struct(png); png_infop end = png_create_info_struct(png); @@ -511,7 +518,7 @@ void* mCoreExtractState(struct mCore* core, struct VFile* vf, struct mStateExtda bool mCoreExtractExtdata(struct mCore* core, struct VFile* vf, struct mStateExtdata* extdata) { #ifdef USE_PNG if (isPNG(vf)) { - return _loadPNGExtadata(vf, extdata); + return _loadPNGExtdata(vf, extdata); } #endif if (!core) { From abb9bec571ebb511486bd756049cfa3327168f5b Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 31 Dec 2024 01:45:03 -0800 Subject: [PATCH 321/338] GB Core: Fix cloning savedata when backing file is outdated (fixes #3388) --- CHANGES | 1 + src/gb/core.c | 35 ++++++++++++++++++++++++----------- 2 files changed, 25 insertions(+), 11 deletions(-) diff --git a/CHANGES b/CHANGES index b5b2f4fe1c7..595943d3d6e 100644 --- a/CHANGES +++ b/CHANGES @@ -19,6 +19,7 @@ Other fixes: - Core: Fix inconsistencies with setting game-specific overrides (fixes mgba.io/i/2963) - Debugger: Fix writing to specific segment in command-line debugger - FFmpeg: Fix failing to record videos with CRF video (fixes mgba.io/i/3368) + - GB Core: Fix cloning savedata when backing file is outdated (fixes mgba.io/i/3388) - GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1 - GBA: Fix getting game info for multiboot ROMs - GBA Core: Fix booting into BIOS when skip BIOS is enabled diff --git a/src/gb/core.c b/src/gb/core.c index b97e1ee255a..f71b570e0e9 100644 --- a/src/gb/core.c +++ b/src/gb/core.c @@ -1167,19 +1167,32 @@ static struct mCheatDevice* _GBCoreCheatDevice(struct mCore* core) { static size_t _GBCoreSavedataClone(struct mCore* core, void** sram) { struct GB* gb = core->board; - struct VFile* vf = gb->sramVf; - if (vf) { - *sram = malloc(vf->size(vf)); - vf->seek(vf, 0, SEEK_SET); - return vf->read(vf, *sram, vf->size(vf)); + size_t sramSize = gb->sramSize; + size_t vfSize = 0; + size_t size = sramSize; + uint8_t* view = NULL; + + if (gb->sramVf) { + vfSize = gb->sramVf->size(gb->sramVf); + if (vfSize > size) { + size = vfSize; + } + } + if (!size) { + *sram = NULL; + return 0; + } + + view = malloc(size); + if (sramSize) { + memcpy(view, gb->memory.sram, gb->sramSize); } - if (gb->sramSize) { - *sram = malloc(gb->sramSize); - memcpy(*sram, gb->memory.sram, gb->sramSize); - return gb->sramSize; + if (vfSize > sramSize) { + gb->sramVf->seek(gb->sramVf, sramSize, SEEK_SET); + gb->sramVf->read(gb->sramVf, &view[sramSize], vfSize - sramSize); } - *sram = NULL; - return 0; + *sram = view; + return size; } static bool _GBCoreSavedataRestore(struct mCore* core, const void* sram, size_t size, bool writeback) { From d55ee872e3464bcc89d023de14adefafd35fcf85 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 31 Dec 2024 01:48:05 -0800 Subject: [PATCH 322/338] CHANGES: Remove duplicated line --- CHANGES | 1 - 1 file changed, 1 deletion(-) diff --git a/CHANGES b/CHANGES index 595943d3d6e..b87501580da 100644 --- a/CHANGES +++ b/CHANGES @@ -20,7 +20,6 @@ Other fixes: - Debugger: Fix writing to specific segment in command-line debugger - FFmpeg: Fix failing to record videos with CRF video (fixes mgba.io/i/3368) - GB Core: Fix cloning savedata when backing file is outdated (fixes mgba.io/i/3388) - - GB Serialize: Prevent loading invalid states where LY >= 144 in modes other than 1 - GBA: Fix getting game info for multiboot ROMs - GBA Core: Fix booting into BIOS when skip BIOS is enabled - GBA Hardware: Fix loading states unconditionally overwriting GPIO memory From 72ee6f9840362f5327ae3e9e8a627b77f749645c Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 31 Dec 2024 02:53:14 -0800 Subject: [PATCH 323/338] Scripting: Expose info table to breakpoint/watchpoint callbacks (closes #3369) --- src/core/scripting.c | 31 +++++++++- src/core/test/scripting.c | 115 ++++++++++++++++++++++++++++++++++---- 2 files changed, 134 insertions(+), 12 deletions(-) diff --git a/src/core/scripting.c b/src/core/scripting.c index 9e46b619c8f..012a739bc9f 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -769,7 +769,7 @@ static int64_t _addCallbackToBreakpoint(struct mScriptDebugger* debugger, struct return cbid; } -static void _runCallbacks(struct mScriptDebugger* debugger, struct mScriptBreakpoint* point) { +static void _runCallbacks(struct mScriptDebugger* debugger, struct mScriptBreakpoint* point, struct mScriptValue* info) { struct TableIterator iter; if (!HashTableIteratorStart(&point->callbacks, &iter)) { return; @@ -778,6 +778,7 @@ static void _runCallbacks(struct mScriptDebugger* debugger, struct mScriptBreakp struct mScriptValue* fn = HashTableIteratorGetValue(&point->callbacks, &iter); struct mScriptFrame frame; mScriptFrameInit(&frame); + mSCRIPT_PUSH(&frame.stack, WTABLE, info); mScriptContextInvoke(debugger->p->context, fn, &frame); mScriptFrameDeinit(&frame); } while (HashTableIteratorNext(&point->callbacks, &iter)); @@ -826,7 +827,33 @@ static void _scriptDebuggerEntered(struct mDebuggerModule* debugger, enum mDebug return; } - _runCallbacks(scriptDebugger, point); + struct mScriptValue cbInfo = { + .refs = mSCRIPT_VALUE_UNREF, + .flags = 0, + .type = mSCRIPT_TYPE_MS_TABLE, + }; + cbInfo.type->alloc(&cbInfo); + + // TODO: Intern strings + mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("address"), mScriptValueCreateFromUInt(info->address)); + if (info->width > 0) { + mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("width"), mScriptValueCreateFromSInt(info->width)); + } + if (info->segment >= 0) { + mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("segment"), mScriptValueCreateFromSInt(info->segment)); + } + + if (reason == DEBUGGER_ENTER_WATCHPOINT) { + mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("oldValue"), mScriptValueCreateFromSInt(info->type.wp.oldValue)); + if (info->type.wp.accessType != WATCHPOINT_READ) { + mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("newValue"), mScriptValueCreateFromSInt(info->type.wp.newValue)); + } + mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("accessType"), mScriptValueCreateFromSInt(info->type.wp.accessType)); + } + + _runCallbacks(scriptDebugger, point, &cbInfo); + + cbInfo.type->free(&cbInfo); debugger->isPaused = false; } diff --git a/src/core/test/scripting.c b/src/core/test/scripting.c index 63927effed1..16692fc145e 100644 --- a/src/core/test/scripting.c +++ b/src/core/test/scripting.c @@ -365,8 +365,10 @@ M_TEST_DEFINE(basicBreakpointGBA) { TEST_PROGRAM( "hit = 0\n" - "function bkpt()\n" + "address = nil\n" + "function bkpt(info)\n" " hit = hit + 1\n" + " address = info.address\n" "end" ); TEST_PROGRAM("cbid = emu:setBreakpoint(bkpt, 0x020000C4)"); @@ -379,6 +381,7 @@ M_TEST_DEFINE(basicBreakpointGBA) { assert_int_equal(debugger.state, DEBUGGER_RUNNING); TEST_PROGRAM("assert(hit >= 1)"); + TEST_PROGRAM("assert(address == 0x020000C4)"); mScriptContextDeinit(&context); TEARDOWN_CORE; @@ -404,8 +407,10 @@ M_TEST_DEFINE(basicBreakpointGB) { TEST_PROGRAM( "hit = 0\n" - "function bkpt()\n" + "address = nil\n" + "function bkpt(info)\n" " hit = hit + 1\n" + " address = info.address\n" "end" ); TEST_PROGRAM("cbid = emu:setBreakpoint(bkpt, 0xF0)"); @@ -418,6 +423,7 @@ M_TEST_DEFINE(basicBreakpointGB) { assert_int_equal(debugger.state, DEBUGGER_RUNNING); TEST_PROGRAM("assert(hit >= 1)"); + TEST_PROGRAM("assert(address == 0xF0)"); mScriptContextDeinit(&context); TEARDOWN_CORE; @@ -441,11 +447,22 @@ M_TEST_DEFINE(multipleBreakpoint) { TEST_PROGRAM( "hit = 0\n" - "function bkpt1()\n" + "address = nil\n" + "function bkpt1(info)\n" " hit = hit + 1\n" + " if address then\n" + " address = (address + info.address) / 2\n" + " else\n" + " address = info.address\n" + " end\n" "end\n" - "function bkpt2()\n" + "function bkpt2(info)\n" " hit = hit + 100\n" + " if address then\n" + " address = (address + info.address) / 2\n" + " else\n" + " address = info.address\n" + " end\n" "end" ); #ifdef M_CORE_GBA @@ -465,6 +482,13 @@ M_TEST_DEFINE(multipleBreakpoint) { assert_int_equal(debugger.state, DEBUGGER_RUNNING); TEST_PROGRAM("assert(hit >= 101)"); +#ifdef M_CORE_GBA + TEST_PROGRAM("assert(address >= 0x020000C4)"); + TEST_PROGRAM("assert(address <= 0x020000C8)"); +#else + TEST_PROGRAM("assert(address >= 0xF0)"); + TEST_PROGRAM("assert(address <= 0xF1)"); +#endif mScriptContextDeinit(&context); TEARDOWN_CORE; @@ -479,13 +503,28 @@ M_TEST_DEFINE(basicWatchpoint) { core->reset(core); mScriptContextAttachCore(&context, core); + int i; + for (i = 0; i < 4; ++i) { + core->busWrite8(core, RAM_BASE + i, i + 1); + } + mDebuggerInit(&debugger); mDebuggerAttach(&debugger, core); TEST_PROGRAM( "hit = 0\n" - "function bkpt()\n" + "address = nil\n" + "width = nil\n" + "oldValue = nil\n" + "newValue = nil\n" + "accessType = nil\n" + "function bkpt(info)\n" " hit = hit + 1\n" + " address = info.address\n" + " width = info.width\n" + " oldValue = info.oldValue\n" + " newValue = info.newValue\n" + " accessType = info.accessType\n" "end" ); struct mScriptValue base = mSCRIPT_MAKE_S32(RAM_BASE); @@ -499,7 +538,13 @@ M_TEST_DEFINE(basicWatchpoint) { uint8_t value; // Read - TEST_PROGRAM("hit = 0"); + TEST_PROGRAM( + "hit = 0\n" + "address = nil\n" + "width = nil\n" + "oldValue = nil\n" + "newValue = nil\n" + "accessType = nil\n"); value = core->rawRead8(core, RAM_BASE, -1); TEST_PROGRAM("assert(hit == 0)"); core->busRead8(core, RAM_BASE); @@ -508,31 +553,71 @@ M_TEST_DEFINE(basicWatchpoint) { TEST_PROGRAM("assert(hit == 1)"); core->busWrite8(core, RAM_BASE, ~value); TEST_PROGRAM("assert(hit == 1)"); + TEST_PROGRAM("assert(address == base)"); + TEST_PROGRAM("assert(width == 1)"); + TEST_PROGRAM("assert(oldValue == 1)"); + TEST_PROGRAM("assert(newValue == nil)"); + TEST_PROGRAM("assert(accessType == C.WATCHPOINT_TYPE.READ)"); // Write - TEST_PROGRAM("hit = 0"); + TEST_PROGRAM( + "hit = 0\n" + "address = nil\n" + "width = nil\n" + "oldValue = nil\n" + "newValue = nil\n" + "accessType = nil\n"); value = core->rawRead8(core, RAM_BASE + 1, -1); TEST_PROGRAM("assert(hit == 0)"); core->busRead8(core, RAM_BASE + 1); TEST_PROGRAM("assert(hit == 0)"); core->busWrite8(core, RAM_BASE + 1, value); TEST_PROGRAM("assert(hit == 1)"); + TEST_PROGRAM("assert(oldValue == 2)"); + TEST_PROGRAM("assert(newValue == 2)"); core->busWrite8(core, RAM_BASE + 1, ~value); TEST_PROGRAM("assert(hit == 2)"); + TEST_PROGRAM("assert(address == base + 1)"); + TEST_PROGRAM("assert(width == 1)"); + TEST_PROGRAM("assert(oldValue == 2)"); + TEST_PROGRAM("assert(newValue == -3)"); + TEST_PROGRAM("assert(accessType == C.WATCHPOINT_TYPE.WRITE)"); // RW - TEST_PROGRAM("hit = 0"); + TEST_PROGRAM( + "hit = 0\n" + "address = nil\n" + "width = nil\n" + "oldValue = nil\n" + "newValue = nil\n" + "accessType = nil\n"); value = core->rawRead8(core, RAM_BASE + 2, -1); TEST_PROGRAM("assert(hit == 0)"); core->busRead8(core, RAM_BASE + 2); + TEST_PROGRAM("assert(accessType == C.WATCHPOINT_TYPE.READ)"); TEST_PROGRAM("assert(hit == 1)"); + TEST_PROGRAM("assert(oldValue == 3)"); + TEST_PROGRAM("assert(newValue == nil)"); core->busWrite8(core, RAM_BASE + 2, value); TEST_PROGRAM("assert(hit == 2)"); + TEST_PROGRAM("assert(oldValue == 3)"); + TEST_PROGRAM("assert(newValue == 3)"); core->busWrite8(core, RAM_BASE + 2, ~value); TEST_PROGRAM("assert(hit == 3)"); + TEST_PROGRAM("assert(address == base + 2)"); + TEST_PROGRAM("assert(width == 1)"); + TEST_PROGRAM("assert(oldValue == 3)"); + TEST_PROGRAM("assert(newValue == -4)"); + TEST_PROGRAM("assert(accessType == C.WATCHPOINT_TYPE.WRITE)"); // Change - TEST_PROGRAM("hit = 0"); + TEST_PROGRAM( + "hit = 0\n" + "address = nil\n" + "width = nil\n" + "oldValue = nil\n" + "newValue = nil\n" + "accessType = nil\n"); value = core->rawRead8(core, RAM_BASE + 3, -1); TEST_PROGRAM("assert(hit == 0)"); core->busRead8(core, RAM_BASE + 3); @@ -541,6 +626,11 @@ M_TEST_DEFINE(basicWatchpoint) { TEST_PROGRAM("assert(hit == 0)"); core->busWrite8(core, RAM_BASE + 3, ~value); TEST_PROGRAM("assert(hit == 1)"); + TEST_PROGRAM("assert(address == base + 3)"); + TEST_PROGRAM("assert(width == 1)"); + TEST_PROGRAM("assert(oldValue == 4)"); + TEST_PROGRAM("assert(newValue == -5)"); + TEST_PROGRAM("assert(accessType == C.WATCHPOINT_TYPE.WRITE)"); mScriptContextDeinit(&context); TEARDOWN_CORE; @@ -728,8 +818,10 @@ M_TEST_DEFINE(rangeWatchpoint) { TEST_PROGRAM( "hit = 0\n" - "function bkpt()\n" + "address = nil\n" + "function bkpt(info)\n" " hit = hit + 1\n" + " address = info.address\n" "end" ); struct mScriptValue base = mSCRIPT_MAKE_S32(RAM_BASE); @@ -741,10 +833,13 @@ M_TEST_DEFINE(rangeWatchpoint) { TEST_PROGRAM("assert(hit == 0)"); core->busRead8(core, RAM_BASE); TEST_PROGRAM("assert(hit == 1)"); + TEST_PROGRAM("assert(address == base)"); core->busRead8(core, RAM_BASE + 1); TEST_PROGRAM("assert(hit == 3)"); + TEST_PROGRAM("assert(address == base + 1)"); core->busRead8(core, RAM_BASE + 2); TEST_PROGRAM("assert(hit == 4)"); + TEST_PROGRAM("assert(address == base + 2)"); mScriptContextDeinit(&context); TEARDOWN_CORE; From 23531e24b8b95966bb8711ac05749f8b8c45e102 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 31 Dec 2024 03:11:31 -0800 Subject: [PATCH 324/338] Scripting: Remove needless heap allocations --- src/core/scripting.c | 31 ++++++++++++++++++++++++------- 1 file changed, 24 insertions(+), 7 deletions(-) diff --git a/src/core/scripting.c b/src/core/scripting.c index 012a739bc9f..3b331b5b73e 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -834,21 +834,38 @@ static void _scriptDebuggerEntered(struct mDebuggerModule* debugger, enum mDebug }; cbInfo.type->alloc(&cbInfo); - // TODO: Intern strings - mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("address"), mScriptValueCreateFromUInt(info->address)); + static struct mScriptValue keyAddress = mSCRIPT_MAKE_CHARP("address"); + static struct mScriptValue keyWidth = mSCRIPT_MAKE_CHARP("width"); + static struct mScriptValue keySegment = mSCRIPT_MAKE_CHARP("segment"); + static struct mScriptValue keyOldValue = mSCRIPT_MAKE_CHARP("oldValue"); + static struct mScriptValue keyNewValue = mSCRIPT_MAKE_CHARP("newValue"); + static struct mScriptValue keyAccessType = mSCRIPT_MAKE_CHARP("accessType"); + + struct mScriptValue valAddress = mSCRIPT_MAKE_U32(info->address); + struct mScriptValue valWidth = mSCRIPT_MAKE_S32(info->width); + struct mScriptValue valSegment = mSCRIPT_MAKE_S32(info->segment); + struct mScriptValue valOldValue; + struct mScriptValue valNewValue; + struct mScriptValue valAccessType; + + mScriptTableInsert(&cbInfo, &keyAddress, &valAddress); if (info->width > 0) { - mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("width"), mScriptValueCreateFromSInt(info->width)); + mScriptTableInsert(&cbInfo, &keyWidth, &valWidth); } if (info->segment >= 0) { - mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("segment"), mScriptValueCreateFromSInt(info->segment)); + mScriptTableInsert(&cbInfo, &keySegment, &valSegment); } if (reason == DEBUGGER_ENTER_WATCHPOINT) { - mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("oldValue"), mScriptValueCreateFromSInt(info->type.wp.oldValue)); + valOldValue = mSCRIPT_MAKE_S32(info->type.wp.oldValue); + valNewValue = mSCRIPT_MAKE_S32(info->type.wp.newValue); + valAccessType = mSCRIPT_MAKE_S32(info->type.wp.accessType); + + mScriptTableInsert(&cbInfo, &keyOldValue, &valOldValue); if (info->type.wp.accessType != WATCHPOINT_READ) { - mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("newValue"), mScriptValueCreateFromSInt(info->type.wp.newValue)); + mScriptTableInsert(&cbInfo, &keyNewValue, &valNewValue); } - mScriptTableInsert(&cbInfo, mScriptStringCreateFromASCII("accessType"), mScriptValueCreateFromSInt(info->type.wp.accessType)); + mScriptTableInsert(&cbInfo, &keyAccessType, &valAccessType); } _runCallbacks(scriptDebugger, point, &cbInfo); From 132293449de246bb19abf453fde06fcfa22fe402 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 31 Dec 2024 16:51:50 -0800 Subject: [PATCH 325/338] Scripting: Attempt to fix Windows build --- src/core/scripting.c | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/core/scripting.c b/src/core/scripting.c index 3b331b5b73e..f409b4782e7 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -834,12 +834,12 @@ static void _scriptDebuggerEntered(struct mDebuggerModule* debugger, enum mDebug }; cbInfo.type->alloc(&cbInfo); - static struct mScriptValue keyAddress = mSCRIPT_MAKE_CHARP("address"); - static struct mScriptValue keyWidth = mSCRIPT_MAKE_CHARP("width"); - static struct mScriptValue keySegment = mSCRIPT_MAKE_CHARP("segment"); - static struct mScriptValue keyOldValue = mSCRIPT_MAKE_CHARP("oldValue"); - static struct mScriptValue keyNewValue = mSCRIPT_MAKE_CHARP("newValue"); - static struct mScriptValue keyAccessType = mSCRIPT_MAKE_CHARP("accessType"); + static struct mScriptValue keyAddress = mSCRIPT_CHARP("address"); + static struct mScriptValue keyWidth = mSCRIPT_CHARP("width"); + static struct mScriptValue keySegment = mSCRIPT_CHARP("segment"); + static struct mScriptValue keyOldValue = mSCRIPT_CHARP("oldValue"); + static struct mScriptValue keyNewValue = mSCRIPT_CHARP("newValue"); + static struct mScriptValue keyAccessType = mSCRIPT_CHARP("accessType"); struct mScriptValue valAddress = mSCRIPT_MAKE_U32(info->address); struct mScriptValue valWidth = mSCRIPT_MAKE_S32(info->width); From 39ced7dd81a11e8bf1ec8d72a8e332075e69db4f Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 31 Dec 2024 16:52:34 -0800 Subject: [PATCH 326/338] Windows: Don't redefine WIN32_LEAN_AND_MEAN if already defined --- include/mgba-util/common.h | 2 ++ 1 file changed, 2 insertions(+) diff --git a/include/mgba-util/common.h b/include/mgba-util/common.h index c5008e01fab..04018faf498 100644 --- a/include/mgba-util/common.h +++ b/include/mgba-util/common.h @@ -17,7 +17,9 @@ CXX_GUARD_START #ifdef _WIN32 +#ifndef WIN32_LEAN_AND_MEAN #define WIN32_LEAN_AND_MEAN +#endif // Require Windows 7 or newer #ifndef _WIN32_WINNT #define _WIN32_WINNT 0x0601 From 9f5c2aa00cc470bd20c0c29c5bfcb7a8451704c4 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Tue, 31 Dec 2024 17:04:52 -0800 Subject: [PATCH 327/338] Scripting: Expose MD5 checksum --- src/core/scripting.c | 3 +++ src/script/stdlib.c | 1 + 2 files changed, 4 insertions(+) diff --git a/src/core/scripting.c b/src/core/scripting.c index f409b4782e7..b36a91412c9 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -350,6 +350,9 @@ static struct mScriptValue* _mScriptCoreChecksum(const struct mCore* core, int t case mCHECKSUM_CRC32: size = 4; break; + case mCHECKSUM_MD5: + size = 16; + break; } if (!size) { return &mScriptValueNull; diff --git a/src/script/stdlib.c b/src/script/stdlib.c index 6e81cfd8634..8fc1b14044f 100644 --- a/src/script/stdlib.c +++ b/src/script/stdlib.c @@ -130,6 +130,7 @@ void mScriptContextAttachStdlib(struct mScriptContext* context) { }); mScriptContextExportConstants(context, "CHECKSUM", (struct mScriptKVPair[]) { mSCRIPT_CONSTANT_PAIR(mCHECKSUM, CRC32), + mSCRIPT_CONSTANT_PAIR(mCHECKSUM, MD5), mSCRIPT_KV_SENTINEL }); #ifdef M_CORE_GBA From 4eb1dbca3617893deb3bfe161f42982e375b1668 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Wed, 1 Jan 2025 01:22:08 -0800 Subject: [PATCH 328/338] Core: Quash some warnings --- src/core/serialize.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/core/serialize.c b/src/core/serialize.c index 7e3426a597a..90f066b8524 100644 --- a/src/core/serialize.c +++ b/src/core/serialize.c @@ -250,8 +250,8 @@ static int _loadPNGChunkHandler(png_structp png, png_unknown_chunkp chunk) { const uint8_t* data = chunk->data; data += sizeof(uint32_t) * 2; if (uncompress((Bytef*) item.data, &len, data, chunk->size) == Z_OK) { - if (item.size != len) { - mLOG(SAVESTATE, WARN, "Mismatched decompressed extdata %i size (%"PRIz"u vs %"PRIz"u)", tag, item.size, (size_t) len); + if ((uLongf) item.size != len) { + mLOG(SAVESTATE, WARN, "Mismatched decompressed extdata %i size (%d vs %u)", tag, item.size, (uint32_t) len); item.size = len; } mStateExtdataPut(extdata, tag, &item); From e29b5ac047358d54bd4a299cc190487a1aa46e53 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 2 Jan 2025 00:11:04 -0800 Subject: [PATCH 329/338] FFmpeg: Use avcodec_get_supported_config when present --- src/feature/ffmpeg/ffmpeg-common.h | 4 ++ src/feature/ffmpeg/ffmpeg-encoder.c | 57 ++++++++++++++++++++++------- 2 files changed, 47 insertions(+), 14 deletions(-) diff --git a/src/feature/ffmpeg/ffmpeg-common.h b/src/feature/ffmpeg/ffmpeg-common.h index 299d5167d0e..2476ea575c4 100644 --- a/src/feature/ffmpeg/ffmpeg-common.h +++ b/src/feature/ffmpeg/ffmpeg-common.h @@ -38,6 +38,10 @@ CXX_GUARD_START #define FFMPEG_USE_NEW_CH_LAYOUT #endif +#if LIBAVCODEC_VERSION_INT >= AV_VERSION_INT(61, 13, 100) +#define FFMPEG_USE_GET_SUPPORTED_CONFIG +#endif + static inline enum AVPixelFormat mColorFormatToFFmpegPixFmt(enum mColorFormat format) { switch (format) { #ifndef USE_LIBAV diff --git a/src/feature/ffmpeg/ffmpeg-encoder.c b/src/feature/ffmpeg/ffmpeg-encoder.c index e83aa680c51..96c5e5bea8b 100644 --- a/src/feature/ffmpeg/ffmpeg-encoder.c +++ b/src/feature/ffmpeg/ffmpeg-encoder.c @@ -134,18 +134,28 @@ bool FFmpegEncoderSetAudio(struct FFmpegEncoder* encoder, const char* acodec, un return false; } - if (!codec->sample_fmts) { + const enum AVSampleFormat* formats = NULL; +#ifdef FFMPEG_USE_GET_SUPPORTED_CONFIG + if (avcodec_get_supported_config(NULL, codec, AV_CODEC_CONFIG_SAMPLE_FORMAT, 0, (const void**) &formats, NULL) < 0) { return false; } +#else + formats = codec->sample_fmts; +#endif + + if (!formats) { + return false; + } + size_t i; size_t j; int priority = INT_MAX; encoder->sampleFormat = AV_SAMPLE_FMT_NONE; - for (i = 0; codec->sample_fmts[i] != AV_SAMPLE_FMT_NONE; ++i) { + for (i = 0; formats[i] != AV_SAMPLE_FMT_NONE; ++i) { for (j = 0; j < sizeof(priorities) / sizeof(*priorities); ++j) { - if (codec->sample_fmts[i] == priorities[j].format && priority > priorities[j].priority) { + if (formats[i] == priorities[j].format && priority > priorities[j].priority) { priority = priorities[j].priority; - encoder->sampleFormat = codec->sample_fmts[i]; + encoder->sampleFormat = formats[i]; } } } @@ -153,18 +163,29 @@ bool FFmpegEncoderSetAudio(struct FFmpegEncoder* encoder, const char* acodec, un return false; } encoder->sampleRate = encoder->isampleRate; - if (codec->supported_samplerates) { + + + + const int* sampleRates = NULL; +#ifdef FFMPEG_USE_GET_SUPPORTED_CONFIG + if (avcodec_get_supported_config(NULL, codec, AV_CODEC_CONFIG_SAMPLE_RATE, 0, (const void**) &sampleRates, NULL) < 0) { + return false; + } +#else + sampleRates = codec->sample_rates; +#endif + if (sampleRates) { bool gotSampleRate = false; int highestSampleRate = 0; - for (i = 0; codec->supported_samplerates[i]; ++i) { - if (codec->supported_samplerates[i] > highestSampleRate) { - highestSampleRate = codec->supported_samplerates[i]; + for (i = 0; sampleRates[i]; ++i) { + if (sampleRates[i] > highestSampleRate) { + highestSampleRate = sampleRates[i]; } - if (codec->supported_samplerates[i] < encoder->isampleRate) { + if (sampleRates[i] < encoder->isampleRate) { continue; } - if (!gotSampleRate || encoder->sampleRate > codec->supported_samplerates[i]) { - encoder->sampleRate = codec->supported_samplerates[i]; + if (!gotSampleRate || encoder->sampleRate > sampleRates[i]) { + encoder->sampleRate = sampleRates[i]; gotSampleRate = true; } } @@ -231,11 +252,19 @@ bool FFmpegEncoderSetVideo(struct FFmpegEncoder* encoder, const char* vcodec, in size_t j; int priority = INT_MAX; encoder->pixFormat = AV_PIX_FMT_NONE; - for (i = 0; codec->pix_fmts[i] != AV_PIX_FMT_NONE; ++i) { + const enum AVPixelFormat* formats; +#ifdef FFMPEG_USE_GET_SUPPORTED_CONFIG + if (avcodec_get_supported_config(NULL, codec, AV_CODEC_CONFIG_PIX_FORMAT, 0, (const void**) &formats, NULL) < 0) { + return false; + } +#else + formats = codec->pix_fmts; +#endif + for (i = 0; formats[i] != AV_PIX_FMT_NONE; ++i) { for (j = 0; j < sizeof(priorities) / sizeof(*priorities); ++j) { - if (codec->pix_fmts[i] == priorities[j].format && priority > priorities[j].priority) { + if (formats[i] == priorities[j].format && priority > priorities[j].priority) { priority = priorities[j].priority; - encoder->pixFormat = codec->pix_fmts[i]; + encoder->pixFormat = formats[i]; } } } From 3c59429d96e47e192fedc9f479ae1a60360de975 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 2 Jan 2025 00:15:46 -0800 Subject: [PATCH 330/338] FFmpeg: Fix build --- src/feature/ffmpeg/ffmpeg-encoder.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/feature/ffmpeg/ffmpeg-encoder.c b/src/feature/ffmpeg/ffmpeg-encoder.c index 96c5e5bea8b..0286b6eebbf 100644 --- a/src/feature/ffmpeg/ffmpeg-encoder.c +++ b/src/feature/ffmpeg/ffmpeg-encoder.c @@ -172,7 +172,7 @@ bool FFmpegEncoderSetAudio(struct FFmpegEncoder* encoder, const char* acodec, un return false; } #else - sampleRates = codec->sample_rates; + sampleRates = codec->supported_samplerates; #endif if (sampleRates) { bool gotSampleRate = false; From eb5fc371ff8e5efa93ad0ee6a4c82c604bbf5de1 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 2 Jan 2025 01:14:11 -0800 Subject: [PATCH 331/338] Scripting: Let mScriptContextAttachLogger take NULL for logger --- src/script/console.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/script/console.c b/src/script/console.c index d908534f66c..c6324452cc1 100644 --- a/src/script/console.c +++ b/src/script/console.c @@ -82,7 +82,7 @@ static struct mScriptConsole* _ensureConsole(struct mScriptContext* context) { void mScriptContextAttachLogger(struct mScriptContext* context, struct mLogger* logger) { struct mScriptConsole* console = _ensureConsole(context); - console->logger = logger; + console->logger = logger ? logger : mLogGetContext(); } void mScriptContextDetachLogger(struct mScriptContext* context) { From ee21e43bdb022cc9cd649aa1d85e4041b130b1b4 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 2 Jan 2025 01:21:20 -0800 Subject: [PATCH 332/338] Scripting: Install callbacks in mScriptContextAttachCore instead of mCoreThread --- src/core/scripting.c | 30 +++++++++++++++++++++++ src/core/thread.c | 58 +++----------------------------------------- 2 files changed, 33 insertions(+), 55 deletions(-) diff --git a/src/core/scripting.c b/src/core/scripting.c index b36a91412c9..20659f0bcc9 100644 --- a/src/core/scripting.c +++ b/src/core/scripting.c @@ -1343,6 +1343,24 @@ static uint8_t _readLuminance(struct GBALuminanceSource* luminance) { } #endif +#define CALLBACK(NAME) _mScriptCoreCallback ## NAME +#define DEFINE_CALLBACK(NAME) \ + void CALLBACK(NAME) (void* context) { \ + struct mScriptContext* scriptContext = context; \ + if (!scriptContext) { \ + return; \ + } \ + mScriptContextTriggerCallback(scriptContext, #NAME, NULL); \ + } + +DEFINE_CALLBACK(frame) +DEFINE_CALLBACK(crashed) +DEFINE_CALLBACK(sleep) +DEFINE_CALLBACK(stop) +DEFINE_CALLBACK(keysRead) +DEFINE_CALLBACK(savedataUpdated) +DEFINE_CALLBACK(alarm) + void mScriptContextAttachCore(struct mScriptContext* context, struct mCore* core) { struct mScriptValue* coreValue = mScriptValueAlloc(mSCRIPT_TYPE_MS_S(mScriptCoreAdapter)); struct mScriptCoreAdapter* adapter = calloc(1, sizeof(*adapter)); @@ -1375,6 +1393,18 @@ void mScriptContextAttachCore(struct mScriptContext* context, struct mCore* core } #endif + struct mCoreCallbacks callbacks = { + .videoFrameEnded = CALLBACK(frame), + .coreCrashed = CALLBACK(crashed), + .sleep = CALLBACK(sleep), + .shutdown = CALLBACK(stop), + .keysRead = CALLBACK(keysRead), + .savedataUpdated = CALLBACK(savedataUpdated), + .alarm = CALLBACK(alarm), + .context = context + }; + core->addCoreCallbacks(core, &callbacks); + _rebuildMemoryMap(context, adapter); coreValue->value.opaque = adapter; diff --git a/src/core/thread.c b/src/core/thread.c index 2b16a03c7ba..988ce0848a1 100644 --- a/src/core/thread.c +++ b/src/core/thread.c @@ -198,42 +198,6 @@ void _coreShutdown(void* context) { MutexUnlock(&thread->impl->stateMutex); } -#ifdef ENABLE_SCRIPTING -#define ADD_CALLBACK(NAME) \ -void _script_ ## NAME(void* context) { \ - struct mCoreThread* threadContext = context; \ - if (!threadContext->scriptContext) { \ - return; \ - } \ - mScriptContextTriggerCallback(threadContext->scriptContext, #NAME, NULL); \ -} - -ADD_CALLBACK(frame) -ADD_CALLBACK(crashed) -ADD_CALLBACK(sleep) -ADD_CALLBACK(stop) -ADD_CALLBACK(keysRead) -ADD_CALLBACK(savedataUpdated) -ADD_CALLBACK(alarm) - -#undef ADD_CALLBACK -#define SCRIPT(NAME) _script_ ## NAME - -static void _mCoreThreadAddCallbacks(struct mCoreThread* threadContext) { - struct mCoreCallbacks callbacks = { - .videoFrameEnded = SCRIPT(frame), - .coreCrashed = SCRIPT(crashed), - .sleep = SCRIPT(sleep), - .shutdown = SCRIPT(stop), - .keysRead = SCRIPT(keysRead), - .savedataUpdated = SCRIPT(savedataUpdated), - .alarm = SCRIPT(alarm), - .context = threadContext - }; - threadContext->core->addCoreCallbacks(threadContext->core, &callbacks); -} -#endif - static THREAD_ENTRY _mCoreThreadRun(void* context) { struct mCoreThread* threadContext = context; #ifdef USE_PTHREADS @@ -279,7 +243,6 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { struct mScriptContext* scriptContext = threadContext->scriptContext; if (scriptContext) { mScriptContextAttachCore(scriptContext, core); - _mCoreThreadAddCallbacks(threadContext); } #endif @@ -289,12 +252,7 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { } #ifdef ENABLE_SCRIPTING // startCallback could add a script context - if (scriptContext != threadContext->scriptContext) { - scriptContext = threadContext->scriptContext; - if (scriptContext) { - _mCoreThreadAddCallbacks(threadContext); - } - } + scriptContext = threadContext->scriptContext; if (scriptContext) { mScriptContextTriggerCallback(scriptContext, "start", NULL); } @@ -312,12 +270,7 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { #ifdef ENABLE_SCRIPTING // resetCallback could add a script context - if (scriptContext != threadContext->scriptContext) { - scriptContext = threadContext->scriptContext; - if (scriptContext) { - _mCoreThreadAddCallbacks(threadContext); - } - } + scriptContext = threadContext->scriptContext; if (scriptContext) { mScriptContextTriggerCallback(scriptContext, "reset", NULL); } @@ -372,12 +325,7 @@ static THREAD_ENTRY _mCoreThreadRun(void* context) { } } #ifdef ENABLE_SCRIPTING - if (scriptContext != threadContext->scriptContext) { - scriptContext = threadContext->scriptContext; - if (scriptContext) { - _mCoreThreadAddCallbacks(threadContext); - } - } + scriptContext = threadContext->scriptContext; #endif if (wasPaused && !(impl->requested & mTHREAD_REQ_PAUSE)) { break; From fe37fa2ab2ddc3ff275d69cf10b5b0a31cd05aaa Mon Sep 17 00:00:00 2001 From: Johan Mattsson <39247600+j-mattsson@users.noreply.github.com> Date: Wed, 1 Jan 2025 15:04:14 +0100 Subject: [PATCH 333/338] Fix potential index out of bounds in DisplayQt.cpp --- src/platform/qt/DisplayQt.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/platform/qt/DisplayQt.cpp b/src/platform/qt/DisplayQt.cpp index b71147c43a1..3f46872f450 100644 --- a/src/platform/qt/DisplayQt.cpp +++ b/src/platform/qt/DisplayQt.cpp @@ -209,7 +209,7 @@ void DisplayQt::deinit(struct VideoBackend*) { void DisplayQt::setLayerDimensions(struct VideoBackend* v, enum VideoLayer layer, const struct mRectangle* dims) { DisplayQt* self = static_cast(v->user); - if (layer > self->m_layerDims.size()) { + if (layer >= self->m_layerDims.size()) { return; } self->m_layerDims[layer] = QRect(dims->x, dims->y, dims->width, dims->height); @@ -217,7 +217,7 @@ void DisplayQt::setLayerDimensions(struct VideoBackend* v, enum VideoLayer layer void DisplayQt::layerDimensions(const struct VideoBackend* v, enum VideoLayer layer, struct mRectangle* dims) { DisplayQt* self = static_cast(v->user); - if (layer > self->m_layerDims.size()) { + if (layer >= self->m_layerDims.size()) { return; } QRect rect = self->m_layerDims[layer]; @@ -238,7 +238,7 @@ void DisplayQt::contextResized(struct VideoBackend*, unsigned, unsigned, unsigne void DisplayQt::setImageSize(struct VideoBackend* v, enum VideoLayer layer, int w, int h) { DisplayQt* self = static_cast(v->user); - if (layer > self->m_layers.size()) { + if (layer >= self->m_layers.size()) { return; } self->m_layers[layer] = QImage(w, h, QImage::Format_ARGB32); @@ -246,7 +246,7 @@ void DisplayQt::setImageSize(struct VideoBackend* v, enum VideoLayer layer, int void DisplayQt::imageSize(struct VideoBackend* v, enum VideoLayer layer, int* w, int* h) { DisplayQt* self = static_cast(v->user); - if (layer > self->m_layers.size()) { + if (layer >= self->m_layers.size()) { return; } *w = self->m_layers[layer].width(); @@ -255,7 +255,7 @@ void DisplayQt::imageSize(struct VideoBackend* v, enum VideoLayer layer, int* w, void DisplayQt::setImage(struct VideoBackend* v, enum VideoLayer layer, const void* frame) { DisplayQt* self = static_cast(v->user); - if (layer > self->m_layers.size()) { + if (layer >= self->m_layers.size()) { return; } QImage& image = self->m_layers[layer]; From ef6659d5872e9e02f6d7b8656680ceb747a78a75 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 2 Jan 2025 01:43:21 -0800 Subject: [PATCH 334/338] Scripting: Make mScriptContextLoad run the script too --- src/script/context.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/script/context.c b/src/script/context.c index 0d770dfde22..fbed31862e3 100644 --- a/src/script/context.c +++ b/src/script/context.c @@ -421,7 +421,10 @@ bool mScriptContextLoadVF(struct mScriptContext* context, const char* name, stru if (!info.context) { return false; } - return info.context->load(info.context, name, vf); + if (!info.context->load(info.context, name, vf)) { + return false; + } + return info.context->run(info.context); } #ifdef ENABLE_VFS From 69ead6e3c9ff2b09348270c06a56b81623909d00 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 2 Jan 2025 01:44:54 -0800 Subject: [PATCH 335/338] ROM Tester: Add script running --- src/platform/test/rom-test-main.c | 97 +++++++++++++++++++++++++++---- 1 file changed, 85 insertions(+), 12 deletions(-) diff --git a/src/platform/test/rom-test-main.c b/src/platform/test/rom-test-main.c index be9f36e8eb1..807f32ec146 100644 --- a/src/platform/test/rom-test-main.c +++ b/src/platform/test/rom-test-main.c @@ -17,26 +17,37 @@ #ifdef M_CORE_GB #include #endif +#ifdef ENABLE_SCRIPTING +#include +#include +#endif #include +#include #include #include #include #define ROM_TEST_OPTIONS "S:R:" -#define ROM_TEST_USAGE \ - "Additional options:\n" \ - " -S SWI Run until specified SWI call before exiting\n" \ - " -R REGISTER General purpose register to return as exit code\n" \ +static const char* const romTestUsage = + "Additional options:\n" + " -S SWI Run until specified SWI call before exiting\n" + " -R REGISTER General purpose register to return as exit code\n" +#ifdef ENABLE_SCRIPTING + " --script FILE Run a script on start. Can be passed multiple times\n" +#endif + ; struct RomTestOpts { int exitSwiImmediate; char* returnCodeRegister; + struct StringList scripts; }; static void _romTestShutdown(int signal); static bool _parseRomTestOpts(struct mSubParser* parser, int option, const char* arg); +static bool _parseLongRomTestOpts(struct mSubParser* parser, const char* option, const char* arg); static bool _parseSwi(const char* regStr, int* oSwi); static bool _romTestCheckResiger(void); @@ -62,11 +73,23 @@ void (*_armSwi32)(struct ARMCore* cpu, int immediate); int main(int argc, char * argv[]) { signal(SIGINT, _romTestShutdown); + bool cleanExit = false; + int uncleanExit = 1; + struct RomTestOpts romTestOpts = { 3, NULL }; + StringListInit(&romTestOpts.scripts, 0); struct mSubParser subparser = { - .usage = ROM_TEST_USAGE, + .usage = romTestUsage, .parse = _parseRomTestOpts, + .parseLong = _parseLongRomTestOpts, .extraOptions = ROM_TEST_OPTIONS, + .longOptions = (struct mOption[]) { + { + .name = "script", + .arg = true, + }, + {0} + }, .opts = &romTestOpts }; @@ -77,15 +100,17 @@ int main(int argc, char * argv[]) { } if (!parsed || args.showHelp) { usage(argv[0], NULL, NULL, &subparser, 1); - return !parsed; + uncleanExit = !parsed; + goto argsExit; } if (args.showVersion) { version(argv[0]); - return 0; + uncleanExit = 0; + goto argsExit; } core = mCoreFind(args.fname); if (!core) { - return 1; + goto argsExit; } core->init(core); mCoreInitConfig(core, "romTest"); @@ -99,7 +124,6 @@ int main(int argc, char * argv[]) { mStandardLoggerConfig(&_logger, &core->config); mLogSetDefaultLogger(&_logger.d); - bool cleanExit = false; struct mCoreCallbacks callbacks = {0}; _returnCodeRegister = romTestOpts.returnCodeRegister; @@ -166,6 +190,32 @@ int main(int argc, char * argv[]) { savestate->close(savestate); } +#ifdef ENABLE_SCRIPTING + struct mScriptContext scriptContext; + + if (StringListSize(&romTestOpts.scripts)) { + mScriptContextInit(&scriptContext); + mScriptContextAttachStdlib(&scriptContext); + mScriptContextAttachImage(&scriptContext); + mScriptContextAttachLogger(&scriptContext, NULL); + mScriptContextAttachSocket(&scriptContext); +#ifdef USE_JSON_C + mScriptContextAttachStorage(&scriptContext); +#endif + mScriptContextRegisterEngines(&scriptContext); + + mScriptContextAttachCore(&scriptContext, core); + + size_t i; + for (i = 0; i < StringListSize(&romTestOpts.scripts); ++i) { + if (!mScriptContextLoadFile(&scriptContext, *StringListGetPointer(&romTestOpts.scripts, i))) { + mLOG(STATUS, ERROR, "Failed to load script \"%s\"", *StringListGetPointer(&romTestOpts.scripts, i)); + goto scriptsError; + } + } + } +#endif + #ifdef ENABLE_DEBUGGERS if (hasDebugger) { do { @@ -176,19 +226,25 @@ int main(int argc, char * argv[]) { do { core->runLoop(core); } while (!_dispatchExiting); + cleanExit = true; +scriptsError: core->unloadROM(core); +#ifdef ENABLE_SCRIPTING + if (StringListSize(&romTestOpts.scripts)) { + mScriptContextDeinit(&scriptContext); + } +#endif + #ifdef ENABLE_DEBUGGERS if (hasDebugger) { core->detachDebugger(core); mDebuggerDeinit(&debugger); } #endif - cleanExit = true; loadError: - mArgumentsDeinit(&args); mStandardLoggerDeinit(&_logger); mCoreConfigDeinit(&core->config); core->deinit(core); @@ -196,7 +252,15 @@ int main(int argc, char * argv[]) { free(_returnCodeRegister); } - return cleanExit ? _exitCode : 1; +argsExit: + size_t i; + for (i = 0; i < StringListSize(&romTestOpts.scripts); ++i) { + free(*StringListGetPointer(&romTestOpts.scripts, i)); + } + StringListDeinit(&romTestOpts.scripts); + mArgumentsDeinit(&args); + + return cleanExit ? _exitCode : uncleanExit; } static void _romTestShutdown(int signal) { @@ -296,6 +360,15 @@ static bool _parseRomTestOpts(struct mSubParser* parser, int option, const char* } } +static bool _parseLongRomTestOpts(struct mSubParser* parser, const char* option, const char* arg) { + struct RomTestOpts* opts = parser->opts; + if (strcmp(option, "script") == 0) { + *StringListAppend(&opts->scripts) = strdup(arg); + return true; + } + return false; +} + static bool _parseSwi(const char* swiStr, int* oSwi) { char* parseEnd; long swi = strtol(swiStr, &parseEnd, 0); From d9aa7d5103e87f3ee480a8403a32152000ac62ab Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 2 Jan 2025 01:58:41 -0800 Subject: [PATCH 336/338] Headless: Rename mgba-rom-test to mgba-headless --- CMakeLists.txt | 12 ++- .../{test/rom-test-main.c => headless-main.c} | 86 +++++++++---------- src/platform/test/CMakeLists.txt | 7 -- 3 files changed, 53 insertions(+), 52 deletions(-) rename src/platform/{test/rom-test-main.c => headless-main.c} (76%) diff --git a/CMakeLists.txt b/CMakeLists.txt index 5daa78976d9..7f4737fddc6 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -72,7 +72,7 @@ if(NOT LIBMGBA_ONLY) set(BUILD_TEST OFF CACHE BOOL "Build testing harness") set(BUILD_SUITE OFF CACHE BOOL "Build test suite") set(BUILD_CINEMA OFF CACHE BOOL "Build video tests suite") - set(BUILD_ROM_TEST OFF CACHE BOOL "Build ROM test tool") + set(BUILD_HEADLESS OFF CACHE BOOL "Build headless tool") set(BUILD_EXAMPLE OFF CACHE BOOL "Build example frontends") set(BUILD_PYTHON OFF CACHE BOOL "Build Python bindings") set(BUILD_STATIC OFF CACHE BOOL "Build a static library") @@ -1037,6 +1037,13 @@ if(BUILD_QT) add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/src/platform/qt ${CMAKE_CURRENT_BINARY_DIR}/qt) endif() +if(BUILD_HEADLESS) + add_executable(${BINARY_NAME}-headless ${CMAKE_CURRENT_SOURCE_DIR}/src/platform/headless-main.c) + target_link_libraries(${BINARY_NAME}-headless ${BINARY_NAME}) + target_compile_definitions(${BINARY_NAME}-headless PRIVATE "${OS_DEFINES};${FEATURE_DEFINES};${FUNCTION_DEFINES}") + install(TARGETS ${BINARY_NAME}-headless DESTINATION ${CMAKE_INSTALL_BINDIR} COMPONENT ${BINARY_NAME}-headless) +endif() + if(NOT USE_CMOCKA) set(BUILD_SUITE OFF) endif() @@ -1213,6 +1220,7 @@ elseif(BUILD_STATIC) cpack_add_component(lib${BINARY_NAME} GROUP dev) endif() cpack_add_component(${BINARY_NAME}-dev GROUP dev) +cpack_add_component(${BINARY_NAME}-headless GROUP dev) if(3DS) cpack_add_component(${BINARY_NAME}-3ds GROUP base) @@ -1318,6 +1326,7 @@ if(NOT QUIET AND NOT LIBMGBA_ONLY) message(STATUS "Frontends:") message(STATUS " Qt: ${BUILD_QT}") message(STATUS " SDL (${SDL_VERSION}): ${BUILD_SDL}") + message(STATUS " Headless: ${BUILD_HEADLESS}") message(STATUS " Python bindings: ${BUILD_PYTHON}") message(STATUS " Examples: ${BUILD_EXAMPLE}") message(STATUS "Test tools:") @@ -1325,7 +1334,6 @@ if(NOT QUIET AND NOT LIBMGBA_ONLY) message(STATUS " Test harness: ${BUILD_TEST}") message(STATUS " Test suite: ${BUILD_SUITE}") message(STATUS " Video test suite: ${BUILD_CINEMA}") - message(STATUS " ROM tester: ${BUILD_ROM_TEST}") message(STATUS "Cores:") message(STATUS " Libretro core: ${BUILD_LIBRETRO}") message(STATUS "Libraries:") diff --git a/src/platform/test/rom-test-main.c b/src/platform/headless-main.c similarity index 76% rename from src/platform/test/rom-test-main.c rename to src/platform/headless-main.c index 807f32ec146..f501e52b244 100644 --- a/src/platform/test/rom-test-main.c +++ b/src/platform/headless-main.c @@ -29,8 +29,8 @@ #include #include -#define ROM_TEST_OPTIONS "S:R:" -static const char* const romTestUsage = +#define HEADLESS_OPTIONS "S:R:" +static const char* const headlessUsage = "Additional options:\n" " -S SWI Run until specified SWI call before exiting\n" " -R REGISTER General purpose register to return as exit code\n" @@ -39,18 +39,18 @@ static const char* const romTestUsage = #endif ; -struct RomTestOpts { +struct HeadlessOpts { int exitSwiImmediate; char* returnCodeRegister; struct StringList scripts; }; -static void _romTestShutdown(int signal); -static bool _parseRomTestOpts(struct mSubParser* parser, int option, const char* arg); -static bool _parseLongRomTestOpts(struct mSubParser* parser, const char* option, const char* arg); +static void _headlessShutdown(int signal); +static bool _parseHeadlessOpts(struct mSubParser* parser, int option, const char* arg); +static bool _parseLongHeadlessOpts(struct mSubParser* parser, const char* option, const char* arg); static bool _parseSwi(const char* regStr, int* oSwi); -static bool _romTestCheckResiger(void); +static bool _headlessCheckResiger(void); static struct mCore* core; @@ -58,10 +58,10 @@ static bool _dispatchExiting = false; static int _exitCode = 0; static struct mStandardLogger _logger; -static void _romTestCallback(void* context); +static void _headlessCallback(void* context); #ifdef M_CORE_GBA -static void _romTestSwi16(struct ARMCore* cpu, int immediate); -static void _romTestSwi32(struct ARMCore* cpu, int immediate); +static void _headlessSwi16(struct ARMCore* cpu, int immediate); +static void _headlessSwi32(struct ARMCore* cpu, int immediate); static int _exitSwiImmediate; static char* _returnCodeRegister; @@ -71,18 +71,18 @@ void (*_armSwi32)(struct ARMCore* cpu, int immediate); #endif int main(int argc, char * argv[]) { - signal(SIGINT, _romTestShutdown); + signal(SIGINT, _headlessShutdown); bool cleanExit = false; int uncleanExit = 1; - struct RomTestOpts romTestOpts = { 3, NULL }; - StringListInit(&romTestOpts.scripts, 0); + struct HeadlessOpts headlessOpts = { 3, NULL }; + StringListInit(&headlessOpts.scripts, 0); struct mSubParser subparser = { - .usage = romTestUsage, - .parse = _parseRomTestOpts, - .parseLong = _parseLongRomTestOpts, - .extraOptions = ROM_TEST_OPTIONS, + .usage = headlessUsage, + .parse = _parseHeadlessOpts, + .parseLong = _parseLongHeadlessOpts, + .extraOptions = HEADLESS_OPTIONS, .longOptions = (struct mOption[]) { { .name = "script", @@ -90,7 +90,7 @@ int main(int argc, char * argv[]) { }, {0} }, - .opts = &romTestOpts + .opts = &headlessOpts }; struct mArguments args; @@ -113,7 +113,7 @@ int main(int argc, char * argv[]) { goto argsExit; } core->init(core); - mCoreInitConfig(core, "romTest"); + mCoreInitConfig(core, "headless"); mArgumentsApply(&args, NULL, 0, &core->config); mCoreConfigSetDefaultValue(&core->config, "idleOptimization", "remove"); @@ -126,8 +126,8 @@ int main(int argc, char * argv[]) { struct mCoreCallbacks callbacks = {0}; - _returnCodeRegister = romTestOpts.returnCodeRegister; - if (!_romTestCheckResiger()) { + _returnCodeRegister = headlessOpts.returnCodeRegister; + if (!_headlessCheckResiger()) { goto loadError; } @@ -135,24 +135,24 @@ int main(int argc, char * argv[]) { #ifdef M_CORE_GBA case mPLATFORM_GBA: ((struct GBA*) core->board)->hardCrash = false; - _exitSwiImmediate = romTestOpts.exitSwiImmediate; + _exitSwiImmediate = headlessOpts.exitSwiImmediate; if (_exitSwiImmediate == 3) { // Hook into SWI 3 (shutdown) - callbacks.shutdown = _romTestCallback; + callbacks.shutdown = _headlessCallback; core->addCoreCallbacks(core, &callbacks); } else { // Custom SWI hooks _armSwi16 = ((struct GBA*) core->board)->cpu->irqh.swi16; - ((struct GBA*) core->board)->cpu->irqh.swi16 = _romTestSwi16; + ((struct GBA*) core->board)->cpu->irqh.swi16 = _headlessSwi16; _armSwi32 = ((struct GBA*) core->board)->cpu->irqh.swi32; - ((struct GBA*) core->board)->cpu->irqh.swi32 = _romTestSwi32; + ((struct GBA*) core->board)->cpu->irqh.swi32 = _headlessSwi32; } break; #endif #ifdef M_CORE_GB case mPLATFORM_GB: - callbacks.shutdown = _romTestCallback; + callbacks.shutdown = _headlessCallback; core->addCoreCallbacks(core, &callbacks); break; #endif @@ -193,7 +193,7 @@ int main(int argc, char * argv[]) { #ifdef ENABLE_SCRIPTING struct mScriptContext scriptContext; - if (StringListSize(&romTestOpts.scripts)) { + if (StringListSize(&headlessOpts.scripts)) { mScriptContextInit(&scriptContext); mScriptContextAttachStdlib(&scriptContext); mScriptContextAttachImage(&scriptContext); @@ -207,9 +207,9 @@ int main(int argc, char * argv[]) { mScriptContextAttachCore(&scriptContext, core); size_t i; - for (i = 0; i < StringListSize(&romTestOpts.scripts); ++i) { - if (!mScriptContextLoadFile(&scriptContext, *StringListGetPointer(&romTestOpts.scripts, i))) { - mLOG(STATUS, ERROR, "Failed to load script \"%s\"", *StringListGetPointer(&romTestOpts.scripts, i)); + for (i = 0; i < StringListSize(&headlessOpts.scripts); ++i) { + if (!mScriptContextLoadFile(&scriptContext, *StringListGetPointer(&headlessOpts.scripts, i))) { + mLOG(STATUS, ERROR, "Failed to load script \"%s\"", *StringListGetPointer(&headlessOpts.scripts, i)); goto scriptsError; } } @@ -232,7 +232,7 @@ int main(int argc, char * argv[]) { core->unloadROM(core); #ifdef ENABLE_SCRIPTING - if (StringListSize(&romTestOpts.scripts)) { + if (StringListSize(&headlessOpts.scripts)) { mScriptContextDeinit(&scriptContext); } #endif @@ -254,21 +254,21 @@ int main(int argc, char * argv[]) { argsExit: size_t i; - for (i = 0; i < StringListSize(&romTestOpts.scripts); ++i) { - free(*StringListGetPointer(&romTestOpts.scripts, i)); + for (i = 0; i < StringListSize(&headlessOpts.scripts); ++i) { + free(*StringListGetPointer(&headlessOpts.scripts, i)); } - StringListDeinit(&romTestOpts.scripts); + StringListDeinit(&headlessOpts.scripts); mArgumentsDeinit(&args); return cleanExit ? _exitCode : uncleanExit; } -static void _romTestShutdown(int signal) { +static void _headlessShutdown(int signal) { UNUSED(signal); _dispatchExiting = true; } -static bool _romTestCheckResiger(void) { +static bool _headlessCheckResiger(void) { if (!_returnCodeRegister) { return true; } @@ -314,7 +314,7 @@ static bool _romTestCheckResiger(void) { return true; } -static void _romTestCallback(void* context) { +static void _headlessCallback(void* context) { UNUSED(context); if (_returnCodeRegister) { core->readRegister(core, _returnCodeRegister, &_exitCode); @@ -323,7 +323,7 @@ static void _romTestCallback(void* context) { } #ifdef M_CORE_GBA -static void _romTestSwi16(struct ARMCore* cpu, int immediate) { +static void _headlessSwi16(struct ARMCore* cpu, int immediate) { if (immediate == _exitSwiImmediate) { if (_returnCodeRegister) { core->readRegister(core, _returnCodeRegister, &_exitCode); @@ -334,7 +334,7 @@ static void _romTestSwi16(struct ARMCore* cpu, int immediate) { _armSwi16(cpu, immediate); } -static void _romTestSwi32(struct ARMCore* cpu, int immediate) { +static void _headlessSwi32(struct ARMCore* cpu, int immediate) { if (immediate == _exitSwiImmediate) { if (_returnCodeRegister) { core->readRegister(core, _returnCodeRegister, &_exitCode); @@ -346,8 +346,8 @@ static void _romTestSwi32(struct ARMCore* cpu, int immediate) { } #endif -static bool _parseRomTestOpts(struct mSubParser* parser, int option, const char* arg) { - struct RomTestOpts* opts = parser->opts; +static bool _parseHeadlessOpts(struct mSubParser* parser, int option, const char* arg) { + struct HeadlessOpts* opts = parser->opts; errno = 0; switch (option) { case 'S': @@ -360,8 +360,8 @@ static bool _parseRomTestOpts(struct mSubParser* parser, int option, const char* } } -static bool _parseLongRomTestOpts(struct mSubParser* parser, const char* option, const char* arg) { - struct RomTestOpts* opts = parser->opts; +static bool _parseLongHeadlessOpts(struct mSubParser* parser, const char* option, const char* arg) { + struct HeadlessOpts* opts = parser->opts; if (strcmp(option, "script") == 0) { *StringListAppend(&opts->scripts) = strdup(arg); return true; diff --git a/src/platform/test/CMakeLists.txt b/src/platform/test/CMakeLists.txt index 3172c6c88a1..ce21f8cebef 100644 --- a/src/platform/test/CMakeLists.txt +++ b/src/platform/test/CMakeLists.txt @@ -46,10 +46,3 @@ if(BUILD_CINEMA) add_test(cinema ${BINARY_NAME}-cinema -v) install(TARGETS ${BINARY_NAME}-cinema DESTINATION ${CMAKE_INSTALL_BINDIR} COMPONENT ${BINARY_NAME}-test) endif() - -if(BUILD_ROM_TEST) - add_executable(${BINARY_NAME}-rom-test ${CMAKE_CURRENT_SOURCE_DIR}/rom-test-main.c) - target_link_libraries(${BINARY_NAME}-rom-test ${BINARY_NAME}) - target_compile_definitions(${BINARY_NAME}-rom-test PRIVATE "${OS_DEFINES};${FEATURE_DEFINES};${FUNCTION_DEFINES}") - install(TARGETS ${BINARY_NAME}-rom-test DESTINATION ${CMAKE_INSTALL_BINDIR} COMPONENT ${BINARY_NAME}-test) -endif() From 0ccd3c84dc9f84b75d0aa09203bf7bc3d70df385 Mon Sep 17 00:00:00 2001 From: Vicki Pfau Date: Thu, 2 Jan 2025 02:07:04 -0800 Subject: [PATCH 337/338] Qt: Make --script explanation match headless explanation --- src/platform/qt/ConfigController.cpp | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/platform/qt/ConfigController.cpp b/src/platform/qt/ConfigController.cpp index 819b2479d0b..ed000ab3b07 100644 --- a/src/platform/qt/ConfigController.cpp +++ b/src/platform/qt/ConfigController.cpp @@ -158,8 +158,7 @@ ConfigController::ConfigController(QObject* parent) " Can be passed multiple times for multiple cards\n" " --mb FILE Boot a multiboot image with FILE inserted into the ROM slot" #ifdef ENABLE_SCRIPTING - "\n --script FILE Script file to load on start\n" - " Can be passed multiple times\n" + "\n --script FILE Run a script on start. Can be passed multiple times\n" #endif ; From 43243c1dc5f55ad5dbccd7556badc12a09caa8df Mon Sep 17 00:00:00 2001 From: Eric Warmenhoven Date: Fri, 3 Jan 2025 15:12:44 -0500 Subject: [PATCH 338/338] post-merge fixes --- Makefile.libretro | 2 +- libretro-build/Makefile.common | 9 ++- src/platform/3ds/3ds-vfs.c | 6 ++ src/platform/libretro/libretro.c | 116 +++++++++++++++---------------- src/platform/psp2/sce-vfs.c | 6 ++ src/util/vfs.c | 4 +- 6 files changed, 79 insertions(+), 64 deletions(-) diff --git a/Makefile.libretro b/Makefile.libretro index 895cb42449b..24e5dced21f 100644 --- a/Makefile.libretro +++ b/Makefile.libretro @@ -318,7 +318,7 @@ else ifeq ($(platform), ctr) CFLAGS += -I$(CTRULIB)/include DEFINES += -std=c99 - PLATFORM_DEFINES += -DUSE_VFS_3DS + PLATFORM_DEFINES += -DENABLE_VFS_3DS STATIC_LINKING = 1 # Xbox 360 diff --git a/libretro-build/Makefile.common b/libretro-build/Makefile.common index 258fc4de268..8007d01371c 100644 --- a/libretro-build/Makefile.common +++ b/libretro-build/Makefile.common @@ -23,7 +23,7 @@ ifneq ($(DEBUG), 1) endif ifneq ($(HAVE_VFS_FD),1) -RETRODEFS += -DUSE_VFS_FILE +RETRODEFS += -DENABLE_VFS_FILE endif ifeq (,$(findstring win,$(platform))) @@ -91,6 +91,7 @@ SOURCES_C := $(CORE_DIR)/src/arm/arm.c \ $(CORE_DIR)/src/gba/gba.c \ $(CORE_DIR)/src/gba/cart/gpio.c \ $(CORE_DIR)/src/gba/cart/ereader.c \ + $(CORE_DIR)/src/gba/cart/unlicensed.c \ $(CORE_DIR)/src/gba/hle-bios.c \ $(CORE_DIR)/src/gba/input.c \ $(CORE_DIR)/src/gba/io.c \ @@ -114,13 +115,16 @@ SOURCES_C := $(CORE_DIR)/src/arm/arm.c \ $(CORE_DIR)/src/platform/libretro/libretro.c \ $(CORE_DIR)/src/sm83/isa-sm83.c \ $(CORE_DIR)/src/sm83/sm83.c \ - $(CORE_DIR)/src/third-party/blip_buf/blip_buf.c \ $(CORE_DIR)/src/third-party/inih/ini.c \ + $(CORE_DIR)/src/util/audio-buffer.c \ $(CORE_DIR)/src/util/circle-buffer.c \ $(CORE_DIR)/src/util/configuration.c \ $(CORE_DIR)/src/util/formatting.c \ $(CORE_DIR)/src/util/gbk-table.c \ + $(CORE_DIR)/src/util/geometry.c \ $(CORE_DIR)/src/util/hash.c \ + $(CORE_DIR)/src/util/image.c \ + $(CORE_DIR)/src/util/md5.c \ $(CORE_DIR)/src/util/patch.c \ $(CORE_DIR)/src/util/patch-ips.c \ $(CORE_DIR)/src/util/patch-ups.c \ @@ -136,6 +140,7 @@ RETRODEFS += -DHAVE_CRC32 endif ifeq ($(HAVE_VFS_FD),1) +RETRODEFS += -DENABLE_VFS_FD ifeq ($(platform), vita) SOURCES_C += $(CORE_DIR)/src/platform/psp2/sce-vfs.c else ifeq ($(platform), ctr) diff --git a/src/platform/3ds/3ds-vfs.c b/src/platform/3ds/3ds-vfs.c index 88297e9cd1d..c4346811c25 100644 --- a/src/platform/3ds/3ds-vfs.c +++ b/src/platform/3ds/3ds-vfs.c @@ -18,6 +18,7 @@ struct VFile3DS { u64 offset; }; +#ifdef ENABLE_VFS struct VDirEntry3DS { struct VDirEntry d; FS_DirectoryEntry ent[MAX_ENT]; @@ -33,6 +34,7 @@ struct VDir3DS { Handle handle; struct VDirEntry3DS vde; }; +#endif static bool _vf3dClose(struct VFile* vf); static off_t _vf3dSeek(struct VFile* vf, off_t offset, int whence); @@ -44,6 +46,7 @@ static void _vf3dTruncate(struct VFile* vf, size_t size); static ssize_t _vf3dSize(struct VFile* vf); static bool _vf3dSync(struct VFile* vf, void* buffer, size_t size); +#ifdef ENABLE_VFS static bool _vd3dClose(struct VDir* vd); static void _vd3dRewind(struct VDir* vd); static struct VDirEntry* _vd3dListNext(struct VDir* vd); @@ -53,6 +56,7 @@ static bool _vd3dDeleteFile(struct VDir* vd, const char* path); static const char* _vd3deName(struct VDirEntry* vde); static enum VFSType _vd3deType(struct VDirEntry* vde); +#endif struct VFile* VFileOpen3DS(FS_Archive* archive, const char* path, int flags) { struct VFile3DS* vf3d = malloc(sizeof(struct VFile3DS)); @@ -178,6 +182,7 @@ static bool _vf3dSync(struct VFile* vf, void* buffer, size_t size) { return true; } +#ifdef ENABLE_VFS struct VDir* VDirOpen(const char* path) { struct VDir3DS* vd3d = malloc(sizeof(struct VDir3DS)); if (!vd3d) { @@ -326,3 +331,4 @@ bool VDirCreate(const char* path) { return R_SUCCEEDED(rc) || rc == 0xC82044BE; } #endif +#endif diff --git a/src/platform/libretro/libretro.c b/src/platform/libretro/libretro.c index eb8c0bae4d5..55549449089 100644 --- a/src/platform/libretro/libretro.c +++ b/src/platform/libretro/libretro.c @@ -353,7 +353,7 @@ static void _loadAudioLowPassFilterSettings(void) { #define GBA_CC_BG 0.21f #define GBA_CC_GAMMA_ADJ 1.0f -static color_t* ccLUT = NULL; +static mColor* ccLUT = NULL; static unsigned ccType = 0; static bool colorCorrectionEnabled = false; @@ -456,7 +456,7 @@ static void _initColorCorrection(void) { /* Allocate look-up table buffer, if required */ if (!ccLUT) { - size_t lutSize = 65536 * sizeof(color_t); + size_t lutSize = 65536 * sizeof(mColor); ccLUT = malloc(lutSize); if (!ccLUT) { return; @@ -553,17 +553,17 @@ enum frame_blend_method static enum frame_blend_method frameBlendType = FRAME_BLEND_NONE; static bool frameBlendEnabled = false; -static color_t* outputBufferPrev1 = NULL; -static color_t* outputBufferPrev2 = NULL; -static color_t* outputBufferPrev3 = NULL; -static color_t* outputBufferPrev4 = NULL; +static mColor* outputBufferPrev1 = NULL; +static mColor* outputBufferPrev2 = NULL; +static mColor* outputBufferPrev3 = NULL; +static mColor* outputBufferPrev4 = NULL; static float* outputBufferAccR = NULL; static float* outputBufferAccG = NULL; static float* outputBufferAccB = NULL; static float frameBlendResponse[4] = {0.0f}; static bool frameBlendResponseSet = false; -static bool _allocateOutputBufferPrev(color_t** buf) { +static bool _allocateOutputBufferPrev(mColor** buf) { if (!*buf) { *buf = malloc(VIDEO_BUFF_SIZE); if (!*buf) { @@ -721,7 +721,7 @@ static void _loadFrameBlendSettings(void) { } /* General post processing buffers/functions */ -static color_t* ppOutputBuffer = NULL; +static mColor* ppOutputBuffer = NULL; static void (*videoPostProcess)(unsigned width, unsigned height) = NULL; @@ -732,8 +732,8 @@ static void (*videoPostProcess)(unsigned width, unsigned height) = NULL; * minimise logic in the inner loops where possible */ static void videoPostProcessCc(unsigned width, unsigned height) { - color_t *src = outputBuffer; - color_t *dst = ppOutputBuffer; + mColor *src = outputBuffer; + mColor *dst = ppOutputBuffer; size_t x, y; for (y = 0; y < height; y++) { @@ -747,25 +747,25 @@ static void videoPostProcessCc(unsigned width, unsigned height) { static void videoPostProcessMix(unsigned width, unsigned height) { - color_t *srcCurr = outputBuffer; - color_t *srcPrev = outputBufferPrev1; - color_t *dst = ppOutputBuffer; + mColor *srcCurr = outputBuffer; + mColor *srcPrev = outputBufferPrev1; + mColor *dst = ppOutputBuffer; size_t x, y; for (y = 0; y < height; y++) { for (x = 0; x < width; x++) { /* Get colours from current + previous frames */ - color_t rgbCurr = *(srcCurr + x); - color_t rgbPrev = *(srcPrev + x); + mColor rgbCurr = *(srcCurr + x); + mColor rgbPrev = *(srcPrev + x); /* Store colours for next frame */ - *(srcPrev + x) = rgbCurr; + *(srcPrev + x) = rgbCurr; /* Mix colours * > "Mixing Packed RGB Pixels Efficiently" * http://blargg.8bitalley.com/info/rgb_mixing.html */ - color_t rgbMix = (rgbCurr + rgbPrev + ((rgbCurr ^ rgbPrev) & 0x821)) >> 1; + mColor rgbMix = (rgbCurr + rgbPrev + ((rgbCurr ^ rgbPrev) & 0x821)) >> 1; /* Assign colours for current frame */ *(dst + x) = colorCorrectionEnabled ? @@ -779,21 +779,21 @@ static void videoPostProcessMix(unsigned width, unsigned height) { static void videoPostProcessMixSmart(unsigned width, unsigned height) { - color_t *srcCurr = outputBuffer; - color_t *srcPrev1 = outputBufferPrev1; - color_t *srcPrev2 = outputBufferPrev2; - color_t *srcPrev3 = outputBufferPrev3; - color_t *dst = ppOutputBuffer; + mColor *srcCurr = outputBuffer; + mColor *srcPrev1 = outputBufferPrev1; + mColor *srcPrev2 = outputBufferPrev2; + mColor *srcPrev3 = outputBufferPrev3; + mColor *dst = ppOutputBuffer; size_t x, y; for (y = 0; y < height; y++) { for (x = 0; x < width; x++) { /* Get colours from current + previous frames */ - color_t rgbCurr = *(srcCurr + x); - color_t rgbPrev1 = *(srcPrev1 + x); - color_t rgbPrev2 = *(srcPrev2 + x); - color_t rgbPrev3 = *(srcPrev3 + x); + mColor rgbCurr = *(srcCurr + x); + mColor rgbPrev1 = *(srcPrev1 + x); + mColor rgbPrev2 = *(srcPrev2 + x); + mColor rgbPrev3 = *(srcPrev3 + x); /* Store colours for next frame */ *(srcPrev1 + x) = rgbCurr; @@ -811,7 +811,7 @@ static void videoPostProcessMixSmart(unsigned width, unsigned height) { /* Mix colours * > "Mixing Packed RGB Pixels Efficiently" * http://blargg.8bitalley.com/info/rgb_mixing.html */ - color_t rgbMix = (rgbCurr + rgbPrev1 + ((rgbCurr ^ rgbPrev1) & 0x821)) >> 1; + mColor rgbMix = (rgbCurr + rgbPrev1 + ((rgbCurr ^ rgbPrev1) & 0x821)) >> 1; /* Assign colours for current frame */ *(dst + x) = colorCorrectionEnabled ? @@ -833,24 +833,24 @@ static void videoPostProcessMixSmart(unsigned width, unsigned height) { static void videoPostProcessLcdGhost(unsigned width, unsigned height) { - color_t *srcCurr = outputBuffer; - color_t *srcPrev1 = outputBufferPrev1; - color_t *srcPrev2 = outputBufferPrev2; - color_t *srcPrev3 = outputBufferPrev3; - color_t *srcPrev4 = outputBufferPrev4; - color_t *dst = ppOutputBuffer; - float *response = frameBlendResponse; + mColor *srcCurr = outputBuffer; + mColor *srcPrev1 = outputBufferPrev1; + mColor *srcPrev2 = outputBufferPrev2; + mColor *srcPrev3 = outputBufferPrev3; + mColor *srcPrev4 = outputBufferPrev4; + mColor *dst = ppOutputBuffer; + float *response = frameBlendResponse; size_t x, y; for (y = 0; y < height; y++) { for (x = 0; x < width; x++) { /* Get colours from current + previous frames */ - color_t rgbCurr = *(srcCurr + x); - color_t rgbPrev1 = *(srcPrev1 + x); - color_t rgbPrev2 = *(srcPrev2 + x); - color_t rgbPrev3 = *(srcPrev3 + x); - color_t rgbPrev4 = *(srcPrev4 + x); + mColor rgbCurr = *(srcCurr + x); + mColor rgbPrev1 = *(srcPrev1 + x); + mColor rgbPrev2 = *(srcPrev2 + x); + mColor rgbPrev3 = *(srcPrev3 + x); + mColor rgbPrev4 = *(srcPrev4 + x); /* Store colours for next frame */ *(srcPrev1 + x) = rgbCurr; @@ -879,7 +879,7 @@ static void videoPostProcessLcdGhost(unsigned width, unsigned height) { float gPrev4 = (float)(rgbPrev4 >> 6 & 0x1F); float bPrev4 = (float)(rgbPrev4 & 0x1F); - /* Mix colours for current frame and convert back to color_t + /* Mix colours for current frame and convert back to mColor * > Response time effect implemented via an exponential * drop-off algorithm, taken from the 'Gameboy Classic Shader' * by Harlequin: @@ -888,19 +888,19 @@ static void videoPostProcessLcdGhost(unsigned width, unsigned height) { rCurr += (rPrev2 - rCurr) * *(response + 1); rCurr += (rPrev3 - rCurr) * *(response + 2); rCurr += (rPrev4 - rCurr) * *(response + 3); - color_t rMix = (color_t)(rCurr + 0.5f) & 0x1F; + mColor rMix = (mColor)(rCurr + 0.5f) & 0x1F; gCurr += (gPrev1 - gCurr) * *response; gCurr += (gPrev2 - gCurr) * *(response + 1); gCurr += (gPrev3 - gCurr) * *(response + 2); gCurr += (gPrev4 - gCurr) * *(response + 3); - color_t gMix = (color_t)(gCurr + 0.5f) & 0x1F; + mColor gMix = (mColor)(gCurr + 0.5f) & 0x1F; bCurr += (bPrev1 - bCurr) * *response; bCurr += (bPrev2 - bCurr) * *(response + 1); bCurr += (bPrev3 - bCurr) * *(response + 2); bCurr += (bPrev4 - bCurr) * *(response + 3); - color_t bMix = (color_t)(bCurr + 0.5f) & 0x1F; + mColor bMix = (mColor)(bCurr + 0.5f) & 0x1F; /* Repack colours for current frame */ *(dst + x) = colorCorrectionEnabled ? @@ -918,21 +918,21 @@ static void videoPostProcessLcdGhost(unsigned width, unsigned height) { static void videoPostProcessLcdGhostFast(unsigned width, unsigned height) { - color_t *srcCurr = outputBuffer; - float *srcPrevR = outputBufferAccR; - float *srcPrevG = outputBufferAccG; - float *srcPrevB = outputBufferAccB; - color_t *dst = ppOutputBuffer; + mColor *srcCurr = outputBuffer; + float *srcPrevR = outputBufferAccR; + float *srcPrevG = outputBufferAccG; + float *srcPrevB = outputBufferAccB; + mColor *dst = ppOutputBuffer; size_t x, y; for (y = 0; y < height; y++) { for (x = 0; x < width; x++) { /* Get colours from current + previous frames */ - color_t rgbCurr = *(srcCurr + x); - float rPrev = *(srcPrevR + x); - float gPrev = *(srcPrevG + x); - float bPrev = *(srcPrevB + x); + mColor rgbCurr = *(srcCurr + x); + float rPrev = *(srcPrevR + x); + float gPrev = *(srcPrevG + x); + float bPrev = *(srcPrevB + x); /* Unpack current colours and convert to float */ float rCurr = (float)(rgbCurr >> 11 & 0x1F); @@ -950,9 +950,9 @@ static void videoPostProcessLcdGhostFast(unsigned width, unsigned height) { *(srcPrevB + x) = bMix; /* Convert and repack current frame colours */ - color_t rgbMix = ((color_t)(rMix + 0.5f) & 0x1F) << 11 - | ((color_t)(gMix + 0.5f) & 0x1F) << 6 - | ((color_t)(bMix + 0.5f) & 0x1F); + mColor rgbMix = ((mColor)(rMix + 0.5f) & 0x1F) << 11 + | ((mColor)(gMix + 0.5f) & 0x1F) << 6 + | ((mColor)(bMix + 0.5f) & 0x1F); /* Assign colours for current frame */ *(dst + x) = colorCorrectionEnabled ? @@ -1682,12 +1682,12 @@ void retro_run(void) { #if defined(COLOR_16_BIT) && defined(COLOR_5_6_5) if (videoPostProcess) { videoPostProcess(width, height); - videoCallback(ppOutputBuffer, width, height, VIDEO_WIDTH_MAX * sizeof(color_t)); + videoCallback(ppOutputBuffer, width, height, VIDEO_WIDTH_MAX * sizeof(mColor)); } else #endif - videoCallback(outputBuffer, width, height, VIDEO_WIDTH_MAX * sizeof(color_t)); + videoCallback(outputBuffer, width, height, VIDEO_WIDTH_MAX * sizeof(mColor)); } else { - videoCallback(NULL, width, height, VIDEO_WIDTH_MAX * sizeof(color_t)); + videoCallback(NULL, width, height, VIDEO_WIDTH_MAX * sizeof(mColor)); } #ifdef M_CORE_GBA diff --git a/src/platform/psp2/sce-vfs.c b/src/platform/psp2/sce-vfs.c index a98e9943dc2..dd46f17ba40 100644 --- a/src/platform/psp2/sce-vfs.c +++ b/src/platform/psp2/sce-vfs.c @@ -21,6 +21,7 @@ struct VFileSce { SceUID fd; }; +#ifdef ENABLE_VFS struct VDirEntrySce { struct VDirEntry d; SceIoDirent ent; @@ -32,6 +33,7 @@ struct VDirSce { SceUID fd; char* path; }; +#endif static bool _vfsceClose(struct VFile* vf); static off_t _vfsceSeek(struct VFile* vf, off_t offset, int whence); @@ -43,6 +45,7 @@ static void _vfsceTruncate(struct VFile* vf, size_t size); static ssize_t _vfsceSize(struct VFile* vf); static bool _vfsceSync(struct VFile* vf, void* memory, size_t size); +#ifdef ENABLE_VFS static bool _vdsceClose(struct VDir* vd); static void _vdsceRewind(struct VDir* vd); static struct VDirEntry* _vdsceListNext(struct VDir* vd); @@ -62,6 +65,7 @@ static bool _vdlsceDeleteFile(struct VDir* vd, const char* path); static const char* _vdlesceName(struct VDirEntry* vde); static enum VFSType _vdlesceType(struct VDirEntry* vde); +#endif struct VFile* VFileOpenSce(const char* path, int flags, SceMode mode) { struct VFileSce* vfsce = malloc(sizeof(struct VFileSce)); @@ -161,6 +165,7 @@ bool _vfsceSync(struct VFile* vf, void* buffer, size_t size) { return sceIoSyncByFd(vfsce->fd, 0) >= 0; } +#ifdef ENABLE_VFS struct VDir* VDirOpen(const char* path) { if (!path || !path[0]) { return VDeviceList(); @@ -370,3 +375,4 @@ bool VDirCreate(const char* path) { sceIoMkdir(path, 0777); return true; } +#endif diff --git a/src/util/vfs.c b/src/util/vfs.c index f6242482138..f9ddd7048f7 100644 --- a/src/util/vfs.c +++ b/src/util/vfs.c @@ -215,7 +215,7 @@ void separatePath(const char* path, char* dirname, char* basename, char* extensi } } -#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2 +#ifdef ENABLE_VFS bool isAbsolute(const char* path) { // XXX: Is this robust? #ifdef _WIN32 @@ -250,9 +250,7 @@ void makeAbsolute(const char* path, const char* base, char* out) { #endif strncpy(out, buf, PATH_MAX); } -#endif -#ifdef ENABLE_VFS struct VFile* VDirFindFirst(struct VDir* dir, bool (*filter)(struct VFile*)) { dir->rewind(dir); struct VDirEntry* dirent = dir->listNext(dir);