Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

GBA hardware extensions #2251

Open
wants to merge 24 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
0051c82
Add .vscode to .gitignore
kaisermg5 Jun 30, 2021
cf6d9ef
Added a protoype protocol to use hardware extensions. Made an extensi…
kaisermg5 Jun 30, 2021
9831a24
Update with master.
kaisermg5 Jun 30, 2021
e563a36
Rewrote most of the extensions code to reorganize the IO and change t…
kaisermg5 Jul 4, 2021
7bba0eb
Hardware extensions code cleanup.
kaisermg5 Jul 4, 2021
acc10c3
Fixed bug that allowed to call disabled extensions.
kaisermg5 Jul 10, 2021
7a12e6a
Added command line arguments to enable extensions.
kaisermg5 Jul 10, 2021
36f5879
Added initial hardware extensions serialization support.
kaisermg5 Jul 11, 2021
71e4e6c
Organized hardware extensions code a bit.
kaisermg5 Jul 11, 2021
58450e6
Organized hardware extensions code a bit more...
kaisermg5 Jul 11, 2021
e3d7cad
Moved some hardcoded stuff to a hardware extensions header file.
kaisermg5 Jul 11, 2021
6223cd7
Designed hardware extensions Qt UI. Functionality missing.
kaisermg5 Jul 19, 2021
3b0b9c3
Fixed some bugs that happened after refactoring.
kaisermg5 Jul 19, 2021
77a0db9
Made each extension have its own config key. Made command line args t…
kaisermg5 Jul 19, 2021
cedf69f
Moved hardware extensions settings into enhancements and redesigned UI.
kaisermg5 Jul 20, 2021
b65493b
De-hardcoded some memory regions. And changed an enum to comply with …
kaisermg5 Jul 21, 2021
165e597
Merge branch 'master' of https://github.com/kaisermg5/mgba
kaisermg5 Jul 21, 2021
558a008
Merge branch 'master' into hardware-extensions
kaisermg5 Jul 21, 2021
ece8c5a
Multiple name changes, moved files and other small changes related to…
kaisermg5 Jul 22, 2021
97dac47
Convert spaces indentation to tabs in gab extensions files.
kaisermg5 Jul 22, 2021
274183e
Removed gba extensions command line args. Also removed their optiond …
kaisermg5 Jul 23, 2021
11a7413
Merged extensions-ids.h with extensions.h. And replaced mCore's exten…
kaisermg5 Jul 23, 2021
d89678a
Fixed error on GB, while attempting to deserialize extensions data.
kaisermg5 Jul 25, 2021
b2c2e55
Changes to dynamically alloc GBA extensions IO and extra RAM. Added t…
kaisermg5 Jul 25, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
/build
/build-*
/.vs
/.vscode

*.a
*.dylib
Expand Down
6 changes: 6 additions & 0 deletions include/mgba/core/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ CXX_GUARD_START

#include <mgba-util/configuration.h>

#include <mgba/internal/gba/hardware-extensions-ids.h>

struct mCoreConfig {
struct Configuration configTable;
struct Configuration defaultsTable;
Expand Down Expand Up @@ -58,6 +60,10 @@ struct mCoreOptions {

bool videoSync;
bool audioSync;

// Extensions
bool hwExtensions;
uint16_t hwExtensionsFlags[HWEX_FLAGS_REGISTERS_COUNT];
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These should not be in the core opts since they're specific to one core.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Removed them.

};

void mCoreConfigInit(struct mCoreConfig*, const char* port);
Expand Down
3 changes: 3 additions & 0 deletions include/mgba/core/core.h
Original file line number Diff line number Diff line change
Expand Up @@ -160,6 +160,9 @@ struct mCore {
void (*startVideoLog)(struct mCore*, struct mVideoLogContext*);
void (*endVideoLog)(struct mCore*);
#endif

size_t (*hwExtensionsSerialize)(struct mCore*, void** sram);
bool (*hwExtensionsDeserialize)(struct mCore*, const void* sram, size_t size);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would probably make more sense to have a "generic" extdata serialize that you specify via passing in an extdata flag.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed.

};

#if !defined(MINIMAL_CORE) || MINIMAL_CORE < 2
Expand Down
2 changes: 2 additions & 0 deletions include/mgba/core/serialize.h
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ enum mStateExtdataTag {
EXTDATA_SAVEDATA = 2,
EXTDATA_CHEATS = 3,
EXTDATA_RTC = 4,
EXTDATA_HW_EXTENSIONS = 5,
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Extensions should probably have a larger ID, I'm trying to reserve low IDs for things that are standard on systems. Maybe 0x80.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe 0x1F? To make it consistent with the SAVESTATE_HW_EXTENSIONS define.
Since flags in mCoreLoadStateNamed and mCoreSaveStateNamed are declared as int, so I shouldn't exceed 32 bits.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The SAVESTATE_HW_EXTENSIONS define is fine--note that there's one for metadata already, which is everything over 0x100, so you don't necessarily need to worry about this one exceeding that bit count.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed. Changed the enum to 0x80 and left the define as it was.

EXTDATA_META_TIME = 0x101,
EXTDATA_MAX
};
Expand All @@ -25,6 +26,7 @@ enum mStateExtdataTag {
#define SAVESTATE_CHEATS 4
#define SAVESTATE_RTC 8
#define SAVESTATE_METADATA 16
#define SAVESTATE_HW_EXTENSIONS 32

struct mStateExtdataItem {
int32_t size;
Expand Down
11 changes: 11 additions & 0 deletions include/mgba/feature/commandline.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,14 @@ CXX_GUARD_START

#include <mgba/debugger/debugger.h>

#include <mgba/internal/gba/hardware-extensions-ids.h>

enum HwExSettingsOverrides {
HWEX_DONT_OVERRIDE = 0,
HWEX_ENABLE = 1,
HWEX_DISABLE = 2,
};

struct mArguments {
char* fname;
char* patch;
Expand All @@ -29,6 +37,9 @@ struct mArguments {
bool debugAtStart;
bool showHelp;
bool showVersion;

char hwExtensions;
char hwExtensionsFlags[HWEX_EXTENSIONS_COUNT];
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See above about configuration. Passing in via a -C flag is probably a better idea, at least for now.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also removed this.

};

struct mCoreConfig;
Expand Down
3 changes: 3 additions & 0 deletions include/mgba/internal/gba/gba.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ CXX_GUARD_START
#include <mgba/internal/gba/audio.h>
#include <mgba/internal/gba/sio.h>
#include <mgba/internal/gba/timer.h>
#include <mgba/internal/gba/hardware-extensions.h>

#define GBA_ARM7TDMI_FREQUENCY 0x1000000U

Expand Down Expand Up @@ -123,6 +124,8 @@ struct GBA {
bool debug;
char debugString[0x100];
GBADebugFlags debugFlags;

struct GBAHardwareExtensions hwExtensions;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would probably group this with the other components closer to the beginning.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed. Moved it under the SIO.

};

struct GBACartridge {
Expand Down
16 changes: 16 additions & 0 deletions include/mgba/internal/gba/hardware-extensions-ids.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
/* Copyright (c) 2021 Jeffrey Pfau
endrift marked this conversation as resolved.
Show resolved Hide resolved
*
* 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 HARDWARE_EXTENSIONS_IDS_H
#define HARDWARE_EXTENSIONS_IDS_H

enum HARDWARE_EXTENSIONS_IDS {
HWEX_ID_MORE_RAM = 0,
HWEX_EXTENSIONS_COUNT
};

#define HWEX_FLAGS_REGISTERS_COUNT ((HWEX_EXTENSIONS_COUNT / 16) + (HWEX_EXTENSIONS_COUNT % 16 ? 1 : 0))

#endif
56 changes: 56 additions & 0 deletions include/mgba/internal/gba/hardware-extensions.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
/* Copyright (c) 2021 Jeffrey Pfau
endrift marked this conversation as resolved.
Show resolved Hide resolved
*
* 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 HARDWARE_EXTENSIONS_H
#define HARDWARE_EXTENSIONS_H
endrift marked this conversation as resolved.
Show resolved Hide resolved

#include <mgba-util/common.h>

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Needs the CXX_GUARD

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed.

#include <mgba/core/log.h>
#include <mgba/core/timing.h>

#include <mgba/internal/gba/io.h>
#include <mgba/internal/gba/hardware-extensions-ids.h>


Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Extraneous line.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't understand what you mean by extraneous... As in "strange" line? Or did you just mean to say there's an extra blank line?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There's an extra blank line, yes.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed.

#define REG_HWEX_VERSION_VALUE HWEX_EXTENSIONS_COUNT
#define HWEX_MORE_RAM_SIZE 0x100000 // 1 MB
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why is this specifically 1 MB? It seems arbitrary. Perhaps making it adjustable would be better.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No particular reason, it was easier to code at the moment. I added three more commands to the extension:

  • Init: to set the set the initial size of the extra RAM.
  • Resize: to change it. It will either truncate the data at the end or add more spece to the end.
  • Destroy: frees the extra RAM.
    Also added a max size clause of 64 MB. Don't think any gba game would need more than that, but it can be changed.


struct GBAHardwareExtensions {
bool enabled;
bool userEnabled;
uint16_t userEnabledFlags[HWEX_FLAGS_REGISTERS_COUNT];

// IO:
uint32_t memory[(REG_HWEX_END - REG_HWEX_ENABLE) / 2];
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// IO:
uint32_t memory[(REG_HWEX_END - REG_HWEX_ENABLE) / 2];
uint16_t io[(REG_HWEX_END - REG_HWEX_ENABLE) / 2];

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed.


// Other data
uint32_t moreRam[HWEX_MORE_RAM_SIZE / sizeof(uint32_t)];
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This needs to be on the heap (and only allocated when wanted).

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fixed.

};


struct GBAHardwareExtensionsState {
uint32_t enabled; // boolean
uint32_t version;

// IO:
uint32_t memory[128];

// Other data
uint32_t moreRam[HWEX_MORE_RAM_SIZE / sizeof(uint32_t)];
};


struct GBA;
void GBAHardwareExtensionsInit(struct GBAHardwareExtensions* hw);
uint16_t GBAHardwareExtensionsIORead(struct GBA* gba, uint32_t address);
uint32_t GBAHardwareExtensionsIORead32(struct GBA* gba, uint32_t address);
void GBAHardwareExtensionsIOWrite8(struct GBA* gba, uint32_t address, uint8_t value);
void GBAHardwareExtensionsIOWrite(struct GBA* gba, uint32_t address, uint16_t value);
void GBAHardwareExtensionsIOWrite32(struct GBA* gba, uint32_t address, uint32_t value);
bool GBAHardwareExtensionsSerialize(struct GBA* gba, struct GBAHardwareExtensionsState* state);
bool GBAHardwareExtensionsDeserialize(struct GBA* gba, const struct GBAHardwareExtensionsState* state, size_t size);

#endif
25 changes: 25 additions & 0 deletions include/mgba/internal/gba/io.h
Original file line number Diff line number Diff line change
Expand Up @@ -157,6 +157,31 @@ enum GBAIORegisters {
REG_DEBUG_STRING = 0xFFF600,
REG_DEBUG_FLAGS = 0xFFF700,
REG_DEBUG_ENABLE = 0xFFF780,

// Extensions
REG_HWEX_ENABLE = 0x400A00,
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This base seems arbitrary. How did you choose it?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I didn't know what to put, so I chose something in the middle. Didn't want to put it at the end so its easy to add more and also didn't want to put it close to the real registers. Any suggestions?

REG_HWEX_VERSION = 0x400A02,
REG_HWEX_ENABLE_FLAGS_0 = 0x400A04,
REG_HWEX_ENABLE_FLAGS_1 = 0x400A06,
REG_HWEX_ENABLE_FLAGS_2 = 0x400A08,
REG_HWEX_ENABLE_FLAGS_3 = 0x400A0A,
REG_HWEX_ENABLE_FLAGS_4 = 0x400A0C,
REG_HWEX_ENABLE_FLAGS_5 = 0x400A0E,

// More RAM
REG_HWEX0_CNT = 0x400A10,
REG_HWEX0_RET_CODE = 0x400A12,
REG_HWEX0_P0_LO = 0x400A14, // command
REG_HWEX0_P0_HI = 0x400A16,
REG_HWEX0_P1_LO = 0x400A18, // index
REG_HWEX0_P1_HI = 0x400A1A,
REG_HWEX0_P2_LO = 0x400A1C, // data pointer
REG_HWEX0_P2_HI = 0x400A1E,
REG_HWEX0_P3_LO = 0x400A20, // size
REG_HWEX0_P3_HI = 0x400A22,

REG_HWEX_END = 0x400A24,

};

mLOG_DECLARE_CATEGORY(GBA_IO);
Expand Down
38 changes: 38 additions & 0 deletions src/core/config.c
Original file line number Diff line number Diff line change
Expand Up @@ -440,6 +440,29 @@ void mCoreConfigMap(const struct mCoreConfig* config, struct mCoreOptions* opts)
_lookupCharValue(config, "screenshotPath", &opts->screenshotPath);
_lookupCharValue(config, "patchPath", &opts->patchPath);
_lookupCharValue(config, "cheatsPath", &opts->cheatsPath);

_lookupIntValue(config, "hwExtensions", &fakeBool);
opts->hwExtensions = fakeBool;

const char hexDigits[] = "0123456789ABCDEF";
char hwExtensionsFlagsKey[] = "hwExtensionsFlags_XXXX";
for (size_t index = 0; index <= (HWEX_EXTENSIONS_COUNT >> 4); index++) {
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 3] = hexDigits[index & 0xF];
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 4] = hexDigits[(index >> 4) & 0xF];
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 5] = hexDigits[(index >> 8) & 0xF];

for (size_t offset = 0; offset < 0x10 && ((index << 4) + offset) < HWEX_EXTENSIONS_COUNT; offset++) {
uint16_t bitFlag = (1 << offset);
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 2] = hexDigits[offset];
if (_lookupIntValue(config, hwExtensionsFlagsKey, &fakeBool)) {
if (fakeBool) {
opts->hwExtensionsFlags[index] |= bitFlag;
} else {
opts->hwExtensionsFlags[index] &= 0xFFFF ^ bitFlag;
}
}
}
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This doesn't belong in the core config.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also removed this.

}

void mCoreConfigLoadDefaults(struct mCoreConfig* config, const struct mCoreOptions* opts) {
Expand All @@ -465,6 +488,21 @@ void mCoreConfigLoadDefaults(struct mCoreConfig* config, const struct mCoreOptio
ConfigurationSetIntValue(&config->defaultsTable, 0, "lockIntegerScaling", opts->lockIntegerScaling);
ConfigurationSetIntValue(&config->defaultsTable, 0, "resampleVideo", opts->resampleVideo);
ConfigurationSetIntValue(&config->defaultsTable, 0, "suspendScreensaver", opts->suspendScreensaver);

ConfigurationSetIntValue(&config->defaultsTable, 0, "hwExtensions", opts->hwExtensions);

const char hexDigits[] = "0123456789ABCDEF";
char hwExtensionsFlagsKey[] = "hwExtensionsFlags_XXXX";
for (size_t index = 0; index <= HWEX_EXTENSIONS_COUNT; index++) {
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 3] = hexDigits[index & 0xF];
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 4] = hexDigits[(index >> 4) & 0xF];
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 5] = hexDigits[(index >> 8) & 0xF];

for (size_t offset = 0; offset < 0x10 && ((index << 4) + offset) < HWEX_EXTENSIONS_COUNT; offset++) {
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 2] = hexDigits[offset];
ConfigurationSetIntValue(&config->defaultsTable, 0, hwExtensionsFlagsKey, (opts->hwExtensionsFlags[index] & (1 << offset)) != 0);
}
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ditto.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also removed this.

}

static void _configEnum(const char* key, const char* value, void* user) {
Expand Down
16 changes: 16 additions & 0 deletions src/core/serialize.c
Original file line number Diff line number Diff line change
Expand Up @@ -421,6 +421,18 @@ bool mCoreSaveStateNamed(struct mCore* core, struct VFile* vf, int flags) {
mStateExtdataPut(&extdata, EXTDATA_RTC, &item);
}
}
if ((true || flags & SAVESTATE_HW_EXTENSIONS) && core->hwExtensionsSerialize) {
void* sram = NULL;
size_t size = core->hwExtensionsSerialize(core, &sram);
if (size) {
struct mStateExtdataItem item = {
.size = size,
.data = sram,
.clean = free
};
mStateExtdataPut(&extdata, EXTDATA_HW_EXTENSIONS, &item);
}
}
#ifdef USE_PNG
if (!(flags & SAVESTATE_SCREENSHOT)) {
#else
Expand Down Expand Up @@ -537,6 +549,10 @@ bool mCoreLoadStateNamed(struct mCore* core, struct VFile* vf, int flags) {
core->rtc.d.deserialize(&core->rtc.d, &item);
}
}
if ((true || flags & SAVESTATE_HW_EXTENSIONS) && core->hwExtensionsDeserialize && mStateExtdataGet(&extdata, EXTDATA_HW_EXTENSIONS, &item)) {
mLOG(SAVESTATE, INFO, "Loading hardware extensions");
core->hwExtensionsDeserialize(core, item.data, item.size);
}
mStateExtdataDeinit(&extdata);
return success;
}
Expand Down
59 changes: 59 additions & 0 deletions src/feature/commandline.c
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,9 @@
" -6 6x viewport\n" \
" -f Start full-screen"

#define HWEX_ARGS_OFFSET 0x1002
#define HWEX_ARGS_NO_OFFSET (HWEX_ARGS_OFFSET + HWEX_EXTENSIONS_COUNT)

static const struct option _options[] = {
{ "bios", required_argument, 0, 'b' },
{ "cheats", required_argument, 0, 'c' },
Expand All @@ -42,6 +45,13 @@ static const struct option _options[] = {
{ "savestate", required_argument, 0, 't' },
{ "patch", required_argument, 0, 'p' },
{ "version", no_argument, 0, '\0' },
// Extensions
{ "hw-extensions", no_argument, 0, HWEX_ARGS_OFFSET - 4 },
{ "no-hw-extensions", no_argument, 0, HWEX_ARGS_OFFSET - 3 },
{ "hwex-all", no_argument, 0, HWEX_ARGS_OFFSET - 2 },
{ "hwex-none", no_argument, 0, HWEX_ARGS_OFFSET - 1 },
{ "hwex-more-ram", no_argument, 0, HWEX_ARGS_OFFSET + HWEX_ID_MORE_RAM },
{ "no-hwex-more-ram", no_argument, 0, HWEX_ARGS_NO_OFFSET + HWEX_ID_MORE_RAM },
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See above about command line flags.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also removed this.

{ 0, 0, 0, 0 }
};

Expand Down Expand Up @@ -135,6 +145,32 @@ bool parseArguments(struct mArguments* args, int argc, char* const* argv, struct
case 't':
args->savestate = strdup(optarg);
break;

// Extensions
case HWEX_ARGS_OFFSET - 4:
// enable extensions
args->hwExtensions = HWEX_ENABLE;
break;
case HWEX_ARGS_OFFSET - 3:
// enable extensions
args->hwExtensions = HWEX_DISABLE;
break;
case HWEX_ARGS_OFFSET - 2:
// enable all extensions
memset(args->hwExtensionsFlags, HWEX_ENABLE, sizeof(args->hwExtensionsFlags));
break;
case HWEX_ARGS_OFFSET - 1:
// disable all extensions
memset(args->hwExtensionsFlags, HWEX_DISABLE, sizeof(args->hwExtensionsFlags));
break;
case HWEX_ARGS_OFFSET + HWEX_ID_MORE_RAM:
// enable 1 extension
args->hwExtensionsFlags[ch - HWEX_ARGS_OFFSET] = HWEX_ENABLE;
break;
case HWEX_ARGS_NO_OFFSET + HWEX_ID_MORE_RAM:
// disable 1 extension
args->hwExtensionsFlags[ch - HWEX_ARGS_OFFSET] = HWEX_ENABLE;
break;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ditto.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also removed this.

default:
if (subparser) {
if (!subparser->parse(subparser, ch, optarg)) {
Expand Down Expand Up @@ -166,6 +202,20 @@ void applyArguments(const struct mArguments* args, struct mSubParser* subparser,
if (args->bios) {
mCoreConfigSetOverrideValue(config, "bios", args->bios);
}
if (args->hwExtensions) {
mCoreConfigSetOverrideIntValue(config, "hwExtensions", args->hwExtensions == HWEX_ENABLE);
}
const char hexDigits[] = "0123456789ABCDEF";
char hwExtensionsFlagsKey[] = "hwExtensionsFlags_XXXX";
for (size_t i = 0; i < (sizeof(args->hwExtensionsFlags) / sizeof(args->hwExtensionsFlags[0])); i++) {
if (args->hwExtensionsFlags[i]) {
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 2] = hexDigits[i & 0xF];
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 3] = hexDigits[(i >> 4) & 0xF];
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 4] = hexDigits[(i >> 8) & 0xF];
hwExtensionsFlagsKey[sizeof(hwExtensionsFlagsKey) - 5] = hexDigits[(i >> 12) & 0xF];
mCoreConfigSetOverrideIntValue(config, hwExtensionsFlagsKey, args->hwExtensionsFlags[i] == HWEX_ENABLE);
}
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ditto.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also removed this.

HashTableEnumerate(&args->configOverrides, _tableApply, config);
if (subparser) {
subparser->apply(subparser, config);
Expand Down Expand Up @@ -248,6 +298,15 @@ void usage(const char* arg0, const char* extraOptions) {
puts(" -p, --patch FILE Apply a specified patch file when running");
puts(" -s, --frameskip N Skip every N frames");
puts(" --version Print version and exit");

puts("\nHardware extensions options:");
puts(" --hw-extensions Enable hardware extensions");
puts(" --no-hw-extensions Disable hardware extensions");
puts(" --hwex-all Enable all hardware extensions");
puts(" --hwex-none Disable all hardware extensions");
puts(" --hwex-more-ram Enable hardware extension \"More RAM\"");
puts(" --no-hwex-more-ram Disable hardware extension \"More RAM\"");

Comment on lines +252 to +259
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ditto

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also removed this.

if (extraOptions) {
puts(extraOptions);
}
Expand Down
1 change: 1 addition & 0 deletions src/gba/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ set(SOURCE_FILES
core.c
dma.c
gba.c
hardware-extensions.c
hle-bios.c
input.c
io.c
Expand Down
Loading