move 'randomize MAC' setting to firmware settings, and add setting for changing the MAC.
make things overall betterer.
This commit is contained in:
parent
1fc775d964
commit
1472a0ec4b
|
@ -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():
|
||||||
|
|
41
src/SPI.cpp
41
src/SPI.cpp
|
@ -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",
|
||||||
|
|
|
@ -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},
|
||||||
|
|
|
@ -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];
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
|
|
|
@ -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;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -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">
|
||||||
|
|
|
@ -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)
|
||||||
{
|
{
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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><html><head/><body><p>Randomizes the console's MAC address upon reset. Required for local multiplayer if each melonDS instance uses the same firmware file.</p></body></html></string>
|
|
||||||
</property>
|
|
||||||
<property name="text">
|
|
||||||
<string>Randomize MAC address</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
|
|
@ -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()
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue