move 'randomize MAC' setting to firmware settings, and add setting for changing the MAC.

make things overall betterer.
This commit is contained in:
Arisotura 2021-11-19 13:31:14 +01:00
parent 1fc775d964
commit 1472a0ec4b
11 changed files with 335 additions and 129 deletions

View File

@ -69,7 +69,6 @@ enum ConfigEntry
DSiSD_FolderSync, DSiSD_FolderSync,
DSiSD_FolderPath, DSiSD_FolderPath,
Firm_RandomizeMAC,
Firm_OverrideSettings, Firm_OverrideSettings,
Firm_Username, Firm_Username,
Firm_Language, Firm_Language,
@ -77,6 +76,8 @@ enum ConfigEntry
Firm_BirthdayDay, Firm_BirthdayDay,
Firm_Color, Firm_Color,
Firm_Message, Firm_Message,
Firm_MAC,
Firm_RandomizeMAC,
AudioBitrate, AudioBitrate,
}; };
@ -84,6 +85,7 @@ enum ConfigEntry
int GetConfigInt(ConfigEntry entry); int GetConfigInt(ConfigEntry entry);
bool GetConfigBool(ConfigEntry entry); bool GetConfigBool(ConfigEntry entry);
std::string GetConfigString(ConfigEntry entry); std::string GetConfigString(ConfigEntry entry);
bool GetConfigArray(ConfigEntry entry, void* data);
// fopen() wrappers // fopen() wrappers
// * OpenFile(): // * OpenFile():

View File

@ -197,6 +197,7 @@ void Reset()
if (Firmware) delete[] Firmware; if (Firmware) delete[] Firmware;
Firmware = nullptr; Firmware = nullptr;
FirmwarePath = ""; FirmwarePath = "";
bool firmoverride = false;
if (Platform::GetConfigBool(Platform::ExternalBIOSEnable)) if (Platform::GetConfigBool(Platform::ExternalBIOSEnable))
{ {
@ -221,6 +222,11 @@ void Reset()
if (FirmwarePath.empty()) if (FirmwarePath.empty())
{ {
LoadDefaultFirmware(); LoadDefaultFirmware();
firmoverride = true;
}
else
{
firmoverride = Platform::GetConfigBool(Platform::Firm_OverrideSettings);
} }
FirmwareMask = FirmwareLength - 1; FirmwareMask = FirmwareLength - 1;
@ -234,7 +240,7 @@ void Reset()
UserSettings = userdata; UserSettings = userdata;
if (FirmwarePath.empty() || Platform::GetConfigBool(Platform::Firm_OverrideSettings)) if (firmoverride)
LoadUserSettingsFromConfig(); LoadUserSettingsFromConfig();
// fix touchscreen coords // fix touchscreen coords
@ -252,17 +258,32 @@ void Reset()
*(u16*)&Firmware[userdata+0x72] = CRC16(&Firmware[userdata], 0x70, 0xFFFF); *(u16*)&Firmware[userdata+0x72] = CRC16(&Firmware[userdata], 0x70, 0xFFFF);
if (Platform::GetConfigBool(Platform::Firm_RandomizeMAC)) if (firmoverride)
{ {
// replace MAC address with random address u8 mac[6];
Firmware[0x36] = 0x00; bool rep;
Firmware[0x37] = 0x09;
Firmware[0x38] = 0xBF;
Firmware[0x39] = rand()&0xFF;
Firmware[0x3A] = rand()&0xFF;
Firmware[0x3B] = rand()&0xFF;
*(u16*)&Firmware[0x2A] = CRC16(&Firmware[0x2C], *(u16*)&Firmware[0x2C], 0x0000); if (Platform::GetConfigBool(Platform::Firm_RandomizeMAC))
{
mac[0] = 0x00;
mac[1] = 0x09;
mac[2] = 0xBF;
mac[3] = rand()&0xFF;
mac[4] = rand()&0xFF;
mac[5] = rand()&0xFF;
rep = true;
}
else
{
rep = Platform::GetConfigArray(Platform::Firm_MAC, mac);
}
if (rep)
{
memcpy(&Firmware[0x36], mac, 6);
*(u16*)&Firmware[0x2A] = CRC16(&Firmware[0x2C], *(u16*)&Firmware[0x2C], 0x0000);
}
} }
printf("MAC: %02X:%02X:%02X:%02X:%02X:%02X\n", printf("MAC: %02X:%02X:%02X:%02X:%02X:%02X\n",

View File

@ -98,7 +98,6 @@ int DSiSDReadOnly;
int DSiSDFolderSync; int DSiSDFolderSync;
char DSiSDFolderPath[1024]; char DSiSDFolderPath[1024];
int RandomizeMAC;
int FirmwareOverrideSettings; int FirmwareOverrideSettings;
char FirmwareUsername[64]; char FirmwareUsername[64];
int FirmwareLanguage; int FirmwareLanguage;
@ -106,6 +105,8 @@ int FirmwareBirthdayMonth;
int FirmwareBirthdayDay; int FirmwareBirthdayDay;
int FirmwareFavouriteColour; int FirmwareFavouriteColour;
char FirmwareMessage[1024]; char FirmwareMessage[1024];
char FirmwareMAC[18];
int RandomizeMAC;
int SocketBindAnyAddr; int SocketBindAnyAddr;
char LANDevice[128]; char LANDevice[128];
@ -255,7 +256,6 @@ ConfigEntry ConfigFile[] =
{"DSiSDFolderSync", 0, &DSiSDFolderSync, 0, NULL, 0}, {"DSiSDFolderSync", 0, &DSiSDFolderSync, 0, NULL, 0},
{"DSiSDFolderPath", 1, DSiSDFolderPath, 0, "", 1023}, {"DSiSDFolderPath", 1, DSiSDFolderPath, 0, "", 1023},
{"RandomizeMAC", 0, &RandomizeMAC, 0, NULL, 0},
{"FirmwareOverrideSettings", 0, &FirmwareOverrideSettings, false, NULL, 0}, {"FirmwareOverrideSettings", 0, &FirmwareOverrideSettings, false, NULL, 0},
{"FirmwareUsername", 1, FirmwareUsername, 0, "melonDS", 63}, {"FirmwareUsername", 1, FirmwareUsername, 0, "melonDS", 63},
{"FirmwareLanguage", 0, &FirmwareLanguage, 1, NULL, 0}, {"FirmwareLanguage", 0, &FirmwareLanguage, 1, NULL, 0},
@ -263,6 +263,8 @@ ConfigEntry ConfigFile[] =
{"FirmwareBirthdayDay", 0, &FirmwareBirthdayDay, 0, NULL, 0}, {"FirmwareBirthdayDay", 0, &FirmwareBirthdayDay, 0, NULL, 0},
{"FirmwareFavouriteColour", 0, &FirmwareFavouriteColour, 0, NULL, 0}, {"FirmwareFavouriteColour", 0, &FirmwareFavouriteColour, 0, NULL, 0},
{"FirmwareMessage", 1, FirmwareMessage, 0, "", 1023}, {"FirmwareMessage", 1, FirmwareMessage, 0, "", 1023},
{"FirmwareMAC", 1, FirmwareMAC, 0, "", 17},
{"RandomizeMAC", 0, &RandomizeMAC, 0, NULL, 0},
{"SockBindAnyAddr", 0, &SocketBindAnyAddr, 0, NULL, 0}, {"SockBindAnyAddr", 0, &SocketBindAnyAddr, 0, NULL, 0},
{"LANDevice", 1, LANDevice, 0, "", 127}, {"LANDevice", 1, LANDevice, 0, "", 127},

View File

@ -121,7 +121,6 @@ extern int DSiSDReadOnly;
extern int DSiSDFolderSync; extern int DSiSDFolderSync;
extern char DSiSDFolderPath[1024]; extern char DSiSDFolderPath[1024];
extern int RandomizeMAC;
extern int FirmwareOverrideSettings; extern int FirmwareOverrideSettings;
extern char FirmwareUsername[64]; extern char FirmwareUsername[64];
extern int FirmwareLanguage; extern int FirmwareLanguage;
@ -129,6 +128,8 @@ extern int FirmwareBirthdayMonth;
extern int FirmwareBirthdayDay; extern int FirmwareBirthdayDay;
extern int FirmwareFavouriteColour; extern int FirmwareFavouriteColour;
extern char FirmwareMessage[1024]; extern char FirmwareMessage[1024];
extern char FirmwareMAC[18];
extern int RandomizeMAC;
extern int SocketBindAnyAddr; extern int SocketBindAnyAddr;
extern char LANDevice[128]; extern char LANDevice[128];

View File

@ -16,13 +16,20 @@
with melonDS. If not, see http://www.gnu.org/licenses/. with melonDS. If not, see http://www.gnu.org/licenses/.
*/ */
#include <QMessageBox>
#include "Config.h" #include "Config.h"
#include "FirmwareSettingsDialog.h" #include "FirmwareSettingsDialog.h"
#include "ui_FirmwareSettingsDialog.h" #include "ui_FirmwareSettingsDialog.h"
FirmwareSettingsDialog* FirmwareSettingsDialog::currentDlg = nullptr; FirmwareSettingsDialog* FirmwareSettingsDialog::currentDlg = nullptr;
extern bool RunningSomething;
bool FirmwareSettingsDialog::needsReset = false;
FirmwareSettingsDialog::FirmwareSettingsDialog(QWidget* parent) : QDialog(parent), ui(new Ui::FirmwareSettingsDialog) FirmwareSettingsDialog::FirmwareSettingsDialog(QWidget* parent) : QDialog(parent), ui(new Ui::FirmwareSettingsDialog)
{ {
ui->setupUi(this); ui->setupUi(this);
@ -55,6 +62,10 @@ FirmwareSettingsDialog::FirmwareSettingsDialog(QWidget* parent) : QDialog(parent
ui->messageEdit->setText(Config::FirmwareMessage); ui->messageEdit->setText(Config::FirmwareMessage);
ui->overrideFirmwareBox->setChecked(Config::FirmwareOverrideSettings); ui->overrideFirmwareBox->setChecked(Config::FirmwareOverrideSettings);
ui->txtMAC->setText(Config::FirmwareMAC);
ui->cbRandomizeMAC->setChecked(Config::RandomizeMAC != 0);
on_cbRandomizeMAC_toggled();
} }
FirmwareSettingsDialog::~FirmwareSettingsDialog() FirmwareSettingsDialog::~FirmwareSettingsDialog()
@ -62,31 +73,112 @@ FirmwareSettingsDialog::~FirmwareSettingsDialog()
delete ui; delete ui;
} }
void FirmwareSettingsDialog::on_FirmwareSettingsDialog_accepted() bool FirmwareSettingsDialog::verifyMAC()
{ {
std::string newName = ui->usernameEdit->text().toStdString(); QString mac = ui->txtMAC->text();
strncpy(Config::FirmwareUsername, newName.c_str(), 63); Config::FirmwareUsername[63] = '\0'; int maclen = mac.length();
Config::FirmwareLanguage = ui->languageBox->currentIndex(); // blank MAC = no MAC override
Config::FirmwareFavouriteColour = ui->colorsEdit->currentIndex(); if (maclen == 0)
Config::FirmwareBirthdayDay = ui->cbxBirthdayDay->currentIndex() + 1; return true;
Config::FirmwareBirthdayMonth = ui->cbxBirthdayMonth->currentIndex() + 1;
Config::FirmwareOverrideSettings = ui->overrideFirmwareBox->isChecked();
std::string newMessage = ui->messageEdit->text().toStdString(); // length should be 12 or 17 if separators are used
strncpy(Config::FirmwareMessage, newMessage.c_str(), 1023); Config::FirmwareMessage[1023] = '\0'; if (maclen != 12 && maclen != 17)
Config::Save(); return false;
closeDlg(); bool hassep = maclen==17;
int pos = 0;
for (int i = 0; i < maclen;)
{
QCharRef c = mac[i];
bool good = false;
if (c >= '0' && c <= '9') good = true;
else if (c >= 'a' && c <= 'f') good = true;
else if (c >= 'A' && c <= 'F') good = true;
if (!good) return false;
i++;
pos++;
if (pos >= 2)
{
pos = 0;
if (hassep) i++;
}
}
return true;
} }
void FirmwareSettingsDialog::on_FirmwareSettingsDialog_rejected() void FirmwareSettingsDialog::done(int r)
{ {
needsReset = false;
if (r == QDialog::Accepted)
{
if (!verifyMAC())
{
QMessageBox::critical(this, "Invalid MAC address",
"The MAC address you entered isn't valid. It should contain 6 pairs of hexadecimal digits, optionally separated.");
return;
}
int newOverride = ui->overrideFirmwareBox->isChecked();
std::string newName = ui->usernameEdit->text().toStdString();
int newLanguage = ui->languageBox->currentIndex();
int newFavColor = ui->colorsEdit->currentIndex();
int newBirthdayDay = ui->cbxBirthdayDay->currentIndex() + 1;
int newBirthdayMonth = ui->cbxBirthdayMonth->currentIndex() + 1;
std::string newMessage = ui->messageEdit->text().toStdString();
std::string newMAC = ui->txtMAC->text().toStdString();
int newRandomizeMAC = ui->cbRandomizeMAC->isChecked() ? 1:0;
if ( newOverride != Config::FirmwareOverrideSettings
|| strcmp(newName.c_str(), Config::FirmwareUsername) != 0
|| newLanguage != Config::FirmwareLanguage
|| newFavColor != Config::FirmwareFavouriteColour
|| newBirthdayDay != Config::FirmwareBirthdayDay
|| newBirthdayMonth != Config::FirmwareBirthdayMonth
|| strcmp(newMessage.c_str(), Config::FirmwareMessage) != 0
|| strcmp(newMAC.c_str(), Config::FirmwareMAC) != 0
|| newRandomizeMAC != Config::RandomizeMAC)
{
if (RunningSomething
&& QMessageBox::warning(this, "Reset necessary to apply changes",
"The emulation will be reset for the changes to take place.",
QMessageBox::Ok, QMessageBox::Cancel) != QMessageBox::Ok)
return;
Config::FirmwareOverrideSettings = newOverride;
strncpy(Config::FirmwareUsername, newName.c_str(), 63); Config::FirmwareUsername[63] = '\0';
Config::FirmwareLanguage = newLanguage;
Config::FirmwareFavouriteColour = newFavColor;
Config::FirmwareBirthdayDay = newBirthdayDay;
Config::FirmwareBirthdayMonth = newBirthdayMonth;
strncpy(Config::FirmwareMessage, newMessage.c_str(), 1023); Config::FirmwareMessage[1023] = '\0';
strncpy(Config::FirmwareMAC, newMAC.c_str(), 17); Config::FirmwareMAC[17] = '\0';
Config::RandomizeMAC = newRandomizeMAC;
Config::Save();
needsReset = true;
}
}
QDialog::done(r);
closeDlg(); closeDlg();
} }
void FirmwareSettingsDialog::on_cbxBirthdayMonth_currentIndexChanged(int idx) void FirmwareSettingsDialog::on_cbxBirthdayMonth_currentIndexChanged(int idx)
{ {
// prevent spurious changes
if (ui->cbxBirthdayMonth->count() < 12) return;
// the DS firmware caps the birthday day depending on the birthday month // the DS firmware caps the birthday day depending on the birthday month
// for February, the limit is 29 // for February, the limit is 29
const int ndays[12] = {31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; const int ndays[12] = {31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
@ -109,3 +201,9 @@ void FirmwareSettingsDialog::on_cbxBirthdayMonth_currentIndexChanged(int idx)
} }
} }
} }
void FirmwareSettingsDialog::on_cbRandomizeMAC_toggled()
{
bool disable = ui->cbRandomizeMAC->isChecked();
ui->txtMAC->setDisabled(disable);
}

View File

@ -117,13 +117,17 @@ public:
currentDlg = nullptr; currentDlg = nullptr;
} }
static bool needsReset;
private slots: private slots:
void on_FirmwareSettingsDialog_accepted(); void done(int r);
void on_FirmwareSettingsDialog_rejected();
void on_cbxBirthdayMonth_currentIndexChanged(int idx); void on_cbxBirthdayMonth_currentIndexChanged(int idx);
void on_cbRandomizeMAC_toggled();
private: private:
bool verifyMAC();
Ui::FirmwareSettingsDialog* ui; Ui::FirmwareSettingsDialog* ui;
}; };

View File

@ -7,7 +7,7 @@
<x>0</x> <x>0</x>
<y>0</y> <y>0</y>
<width>511</width> <width>511</width>
<height>196</height> <height>342</height>
</rect> </rect>
</property> </property>
<property name="sizePolicy"> <property name="sizePolicy">
@ -24,78 +24,134 @@
<enum>QLayout::SetFixedSize</enum> <enum>QLayout::SetFixedSize</enum>
</property> </property>
<item> <item>
<layout class="QGridLayout" name="gridLayout"> <widget class="QGroupBox" name="grpGeneral">
<item row="2" column="1"> <property name="title">
<widget class="QComboBox" name="cbxBirthdayDay"/> <string>General</string>
</item> </property>
<item row="0" column="0"> <layout class="QGridLayout" name="gridLayout_3">
<widget class="QLabel" name="usernameLabel"> <item row="0" column="0">
<property name="text"> <widget class="QCheckBox" name="overrideFirmwareBox">
<string>Username:</string> <property name="text">
</property> <string>Override settings from external firmware</string>
</widget> </property>
</item> </widget>
<item row="4" column="0"> </item>
<widget class="QLabel" name="label_3"> </layout>
<property name="text"> </widget>
<string>Message:</string> </item>
</property> <item>
</widget> <widget class="QGroupBox" name="grpUserSettings">
</item> <property name="title">
<item row="3" column="0"> <string>User settings</string>
<widget class="QLabel" name="label_2"> </property>
<property name="text"> <layout class="QGridLayout" name="gridLayout">
<string>Color:</string> <property name="leftMargin">
</property> <number>9</number>
</widget> </property>
</item> <property name="topMargin">
<item row="1" column="0"> <number>9</number>
<widget class="QLabel" name="label"> </property>
<property name="text"> <property name="rightMargin">
<string>Language:</string> <number>9</number>
</property> </property>
</widget> <property name="bottomMargin">
</item> <number>9</number>
<item row="2" column="0"> </property>
<widget class="QLabel" name="label_4"> <item row="2" column="1">
<property name="text"> <widget class="QComboBox" name="cbxBirthdayDay"/>
<string>Birthday:</string> </item>
</property> <item row="2" column="2">
</widget> <widget class="QComboBox" name="cbxBirthdayMonth"/>
</item> </item>
<item row="2" column="2"> <item row="0" column="1" colspan="2">
<widget class="QComboBox" name="cbxBirthdayMonth"/> <widget class="QLineEdit" name="usernameEdit">
</item> <property name="text">
<item row="1" column="1" colspan="2"> <string>melonDS</string>
<widget class="QComboBox" name="languageBox"/> </property>
</item> <property name="maxLength">
<item row="0" column="1" colspan="2"> <number>10</number>
<widget class="QLineEdit" name="usernameEdit"> </property>
<property name="text"> <property name="clearButtonEnabled">
<string>melonDS</string> <bool>false</bool>
</property> </property>
<property name="maxLength"> </widget>
<number>10</number> </item>
</property> <item row="0" column="0">
<property name="clearButtonEnabled"> <widget class="QLabel" name="usernameLabel">
<bool>false</bool> <property name="text">
</property> <string>Username:</string>
</widget> </property>
</item> </widget>
<item row="3" column="1" colspan="2"> </item>
<widget class="QComboBox" name="colorsEdit"/> <item row="4" column="0">
</item> <widget class="QLabel" name="label_3">
<item row="4" column="1" colspan="2"> <property name="text">
<widget class="QLineEdit" name="messageEdit"/> <string>Message:</string>
</item> </property>
<item row="5" column="0" colspan="3"> </widget>
<widget class="QCheckBox" name="overrideFirmwareBox"> </item>
<property name="text"> <item row="3" column="1" colspan="2">
<string>Override settings from external firmware</string> <widget class="QComboBox" name="colorsEdit"/>
</property> </item>
</widget> <item row="3" column="0">
</item> <widget class="QLabel" name="label_2">
</layout> <property name="text">
<string>Color:</string>
</property>
</widget>
</item>
<item row="1" column="0">
<widget class="QLabel" name="label">
<property name="text">
<string>Language:</string>
</property>
</widget>
</item>
<item row="2" column="0">
<widget class="QLabel" name="label_4">
<property name="text">
<string>Birthday:</string>
</property>
</widget>
</item>
<item row="4" column="1" colspan="2">
<widget class="QLineEdit" name="messageEdit"/>
</item>
<item row="1" column="1" colspan="2">
<widget class="QComboBox" name="languageBox"/>
</item>
</layout>
</widget>
</item>
<item>
<widget class="QGroupBox" name="grpWifiSettings">
<property name="title">
<string>Network settings</string>
</property>
<layout class="QGridLayout" name="gridLayout_2">
<item row="0" column="0">
<widget class="QLabel" name="label_5">
<property name="text">
<string>MAC address:</string>
</property>
</widget>
</item>
<item row="0" column="1">
<widget class="QLineEdit" name="txtMAC">
<property name="maxLength">
<number>17</number>
</property>
</widget>
</item>
<item row="1" column="1">
<widget class="QCheckBox" name="cbRandomizeMAC">
<property name="text">
<string>Randomize</string>
</property>
</widget>
</item>
</layout>
</widget>
</item> </item>
<item> <item>
<widget class="QDialogButtonBox" name="dialogButtons"> <widget class="QDialogButtonBox" name="dialogButtons">

View File

@ -201,6 +201,43 @@ std::string GetConfigString(ConfigEntry entry)
return ""; return "";
} }
bool GetConfigArray(ConfigEntry entry, void* data)
{
switch (entry)
{
case Firm_MAC:
{
char* mac_in = Config::FirmwareMAC;
u8* mac_out = (u8*)data;
int o = 0;
u8 tmp = 0;
for (int i = 0; i < 18; i++)
{
char c = mac_in[i];
if (c == '\0') break;
int n;
if (c >= '0' && c <= '9') n = c - '0';
else if (c >= 'a' && c <= 'f') n = c - 'a' + 10;
else if (c >= 'A' && c <= 'F') n = c - 'A' + 10;
else continue;
if (!(o & 1))
tmp = n;
else
mac_out[o >> 1] = n | (tmp << 4);
o++;
if (o >= 12) return true;
}
}
return false;
}
return false;
}
FILE* OpenFile(std::string path, std::string mode, bool mustexist) FILE* OpenFile(std::string path, std::string mode, bool mustexist)
{ {

View File

@ -56,7 +56,6 @@ WifiSettingsDialog::WifiSettingsDialog(QWidget* parent) : QDialog(parent), ui(ne
ui->rbDirectMode->setText("Direct mode (requires " PCAP_NAME " and ethernet connection)"); ui->rbDirectMode->setText("Direct mode (requires " PCAP_NAME " and ethernet connection)");
ui->cbBindAnyAddr->setChecked(Config::SocketBindAnyAddr != 0); ui->cbBindAnyAddr->setChecked(Config::SocketBindAnyAddr != 0);
ui->cbRandomizeMAC->setChecked(Config::RandomizeMAC != 0);
int sel = 0; int sel = 0;
for (int i = 0; i < LAN_PCap::NumAdapters; i++) for (int i = 0; i < LAN_PCap::NumAdapters; i++)
@ -88,19 +87,7 @@ void WifiSettingsDialog::done(int r)
if (r == QDialog::Accepted) if (r == QDialog::Accepted)
{ {
int randommac = ui->cbRandomizeMAC->isChecked() ? 1:0;
if (randommac != Config::RandomizeMAC)
{
if (RunningSomething
&& QMessageBox::warning(this, "Reset necessary to apply changes",
"The emulation will be reset for the changes to take place.",
QMessageBox::Ok, QMessageBox::Cancel) != QMessageBox::Ok)
return;
}
Config::SocketBindAnyAddr = ui->cbBindAnyAddr->isChecked() ? 1:0; Config::SocketBindAnyAddr = ui->cbBindAnyAddr->isChecked() ? 1:0;
Config::RandomizeMAC = randommac;
Config::DirectLAN = ui->rbDirectMode->isChecked() ? 1:0; Config::DirectLAN = ui->rbDirectMode->isChecked() ? 1:0;
int sel = ui->cbxDirectAdapter->currentIndex(); int sel = ui->cbxDirectAdapter->currentIndex();
@ -116,8 +103,6 @@ void WifiSettingsDialog::done(int r)
} }
Config::Save(); Config::Save();
needsReset = true;
} }
QDialog::done(r); QDialog::done(r);
@ -129,10 +114,12 @@ void WifiSettingsDialog::on_rbDirectMode_clicked()
{ {
updateAdapterControls(); updateAdapterControls();
} }
void WifiSettingsDialog::on_rbIndirectMode_clicked() void WifiSettingsDialog::on_rbIndirectMode_clicked()
{ {
updateAdapterControls(); updateAdapterControls();
} }
void WifiSettingsDialog::on_cbxDirectAdapter_currentIndexChanged(int sel) void WifiSettingsDialog::on_cbxDirectAdapter_currentIndexChanged(int sel)
{ {
if (!haspcap) return; if (!haspcap) return;

View File

@ -7,7 +7,7 @@
<x>0</x> <x>0</x>
<y>0</y> <y>0</y>
<width>572</width> <width>572</width>
<height>296</height> <height>273</height>
</rect> </rect>
</property> </property>
<property name="sizePolicy"> <property name="sizePolicy">
@ -39,16 +39,6 @@
</property> </property>
</widget> </widget>
</item> </item>
<item row="1" column="0">
<widget class="QCheckBox" name="cbRandomizeMAC">
<property name="whatsThis">
<string>&lt;html&gt;&lt;head/&gt;&lt;body&gt;&lt;p&gt;Randomizes the console's MAC address upon reset. Required for local multiplayer if each melonDS instance uses the same firmware file.&lt;/p&gt;&lt;/body&gt;&lt;/html&gt;</string>
</property>
<property name="text">
<string>Randomize MAC address</string>
</property>
</widget>
</item>
</layout> </layout>
</widget> </widget>
</item> </item>

View File

@ -2451,11 +2451,19 @@ void MainWindow::onOpenAudioSettings()
void MainWindow::onOpenFirmwareSettings() void MainWindow::onOpenFirmwareSettings()
{ {
emuThread->emuPause();
FirmwareSettingsDialog* dlg = FirmwareSettingsDialog::openDlg(this); FirmwareSettingsDialog* dlg = FirmwareSettingsDialog::openDlg(this);
connect(dlg, &FirmwareSettingsDialog::finished, this, &MainWindow::onFirmwareSettingsFinished); connect(dlg, &FirmwareSettingsDialog::finished, this, &MainWindow::onFirmwareSettingsFinished);
} }
void MainWindow::onFirmwareSettingsFinished(int res) {} void MainWindow::onFirmwareSettingsFinished(int res)
{
if (FirmwareSettingsDialog::needsReset)
onReset();
emuThread->emuUnpause();
}
void MainWindow::onUpdateAudioSettings() void MainWindow::onUpdateAudioSettings()
{ {