diff options
-rw-r--r-- | melonDS.cbp | 5 | ||||
-rw-r--r-- | src/ARM.cpp | 17 | ||||
-rw-r--r-- | src/Config.cpp | 128 | ||||
-rw-r--r-- | src/Config.h | 50 | ||||
-rw-r--r-- | src/libui_sdl/DlgAudioSettings.cpp | 2 | ||||
-rw-r--r-- | src/libui_sdl/DlgEmuSettings.cpp | 2 | ||||
-rw-r--r-- | src/libui_sdl/DlgInputConfig.cpp | 2 | ||||
-rw-r--r-- | src/libui_sdl/DlgWifiSettings.cpp | 2 | ||||
-rw-r--r-- | src/libui_sdl/LAN_PCap.cpp | 2 | ||||
-rw-r--r-- | src/libui_sdl/LAN_Socket.cpp | 66 | ||||
-rw-r--r-- | src/libui_sdl/Platform.cpp | 2 | ||||
-rw-r--r-- | src/libui_sdl/PlatformConfig.cpp | 123 | ||||
-rw-r--r-- | src/libui_sdl/PlatformConfig.h | 69 | ||||
-rw-r--r-- | src/libui_sdl/main.cpp | 2 |
14 files changed, 290 insertions, 182 deletions
diff --git a/melonDS.cbp b/melonDS.cbp index d5ffc22..5bc0ff6 100644 --- a/melonDS.cbp +++ b/melonDS.cbp @@ -34,6 +34,7 @@ <Add library="uxtheme" /> <Add library="iphlpapi" /> <Add library="user32" /> + <Add library="ws2_32" /> </Linker> </Target> <Target title="Release Windows"> @@ -65,6 +66,7 @@ <Add library="uxtheme" /> <Add library="iphlpapi" /> <Add library="user32" /> + <Add library="ws2_32" /> </Linker> </Target> <Target title="DebugFast Windows"> @@ -95,6 +97,7 @@ <Add library="uxtheme" /> <Add library="iphlpapi" /> <Add library="user32" /> + <Add library="ws2_32" /> </Linker> </Target> </Build> @@ -163,6 +166,8 @@ <Unit filename="src/libui_sdl/LAN_Socket.cpp" /> <Unit filename="src/libui_sdl/LAN_Socket.h" /> <Unit filename="src/libui_sdl/Platform.cpp" /> + <Unit filename="src/libui_sdl/PlatformConfig.cpp" /> + <Unit filename="src/libui_sdl/PlatformConfig.h" /> <Unit filename="src/libui_sdl/libui/common/areaevents.c"> <Option compilerVar="CC" /> </Unit> diff --git a/src/ARM.cpp b/src/ARM.cpp index 1a5fc3e..f1bed5f 100644 --- a/src/ARM.cpp +++ b/src/ARM.cpp @@ -180,9 +180,6 @@ void ARMv5::JumpTo(u32 addr, bool restorecpsr) if (R[15]==0x0204BE5E) printf("recvfrom() ret:%d errno:%d %08X\n", R[0], NDS::ARM9Read32(0x217F398), addr); if (R[15]==0x0205038A) printf("sgrecvfrom() ret:%d errno:%d %08X\n", R[0], NDS::ARM9Read32(0x217F398), addr); if (addr==0x02050379 || addr==0x0205036D) printf("morp %08X->%08X, %d\n", R[15], addr, R[7]);*/ - if (R[15]==0x02050542) printf("calc UDP checksum: %04X\n", R[0]); - if (addr==0x0204FC2D) printf("calcchk %08X\n", R[15]); - if (addr==0x0204B521) printf("zog check %08X\n", R[15]); u32 oldregion = R[15] >> 24; u32 newregion = addr >> 24; @@ -454,7 +451,7 @@ void ARMv5::DataAbort() R[14] = R[15] + (oldcpsr & 0x20 ? 6 : 4); JumpTo(ExceptionBase + 0x10); } -namespace LAN{extern u32 zarp;} + void ARMv5::Execute() { if (Halted) @@ -512,18 +509,6 @@ void ARMv5::Execute() else AddCycles_C(); } - /*if (R[15]>=0x0204E07C && R[15]<=0x0204E388) - { - printf("TACHYCARDIE. %08X\n", R[15]-4); - } - if (LAN::zarp!=0) - { - for (int i = 0; i < 15; i++) - { - if (R[i]==LAN::zarp) - printf("!! TRANSID IN R%d AT %08X\n", i, R[15]); - } - }*/ // TODO optimize this shit!!! if (Halted) diff --git a/src/Config.cpp b/src/Config.cpp index bf010dc..477ee1e 100644 --- a/src/Config.cpp +++ b/src/Config.cpp @@ -31,123 +31,30 @@ namespace Config const char* kConfigFile = "melonDS.ini"; -int KeyMapping[12]; -int JoyMapping[12]; - -int HKKeyMapping[HK_MAX]; -int HKJoyMapping[HK_MAX]; - -int WindowWidth; -int WindowHeight; -int WindowMaximized; - -int ScreenRotation; -int ScreenGap; -int ScreenLayout; -int ScreenSizing; -int ScreenFilter; - -int LimitFPS; - -int DirectBoot; - int Threaded3D; -int SocketBindAnyAddr; -char LANDevice[128]; -int DirectLAN; - -int SavestateRelocSRAM; - -int AudioVolume; -int MicInputType; -char MicWavPath[512]; - -char LastROMFolder[512]; - -typedef struct -{ - char Name[16]; - int Type; - void* Value; - int DefaultInt; - char* DefaultStr; - int StrLength; // should be set to actual array length minus one - -} ConfigEntry; - ConfigEntry ConfigFile[] = { - {"Key_A", 0, &KeyMapping[0], 32, NULL, 0}, - {"Key_B", 0, &KeyMapping[1], 31, NULL, 0}, - {"Key_Select", 0, &KeyMapping[2], 57, NULL, 0}, - {"Key_Start", 0, &KeyMapping[3], 28, NULL, 0}, - {"Key_Right", 0, &KeyMapping[4], 333, NULL, 0}, - {"Key_Left", 0, &KeyMapping[5], 331, NULL, 0}, - {"Key_Up", 0, &KeyMapping[6], 328, NULL, 0}, - {"Key_Down", 0, &KeyMapping[7], 336, NULL, 0}, - {"Key_R", 0, &KeyMapping[8], 54, NULL, 0}, - {"Key_L", 0, &KeyMapping[9], 86, NULL, 0}, - {"Key_X", 0, &KeyMapping[10], 17, NULL, 0}, - {"Key_Y", 0, &KeyMapping[11], 30, NULL, 0}, - - {"Joy_A", 0, &JoyMapping[0], -1, NULL, 0}, - {"Joy_B", 0, &JoyMapping[1], -1, NULL, 0}, - {"Joy_Select", 0, &JoyMapping[2], -1, NULL, 0}, - {"Joy_Start", 0, &JoyMapping[3], -1, NULL, 0}, - {"Joy_Right", 0, &JoyMapping[4], -1, NULL, 0}, - {"Joy_Left", 0, &JoyMapping[5], -1, NULL, 0}, - {"Joy_Up", 0, &JoyMapping[6], -1, NULL, 0}, - {"Joy_Down", 0, &JoyMapping[7], -1, NULL, 0}, - {"Joy_R", 0, &JoyMapping[8], -1, NULL, 0}, - {"Joy_L", 0, &JoyMapping[9], -1, NULL, 0}, - {"Joy_X", 0, &JoyMapping[10], -1, NULL, 0}, - {"Joy_Y", 0, &JoyMapping[11], -1, NULL, 0}, - - {"HKKey_Lid", 0, &HKKeyMapping[HK_Lid], 0x0E, NULL, 0}, - {"HKKey_Mic", 0, &HKKeyMapping[HK_Mic], 0x35, NULL, 0}, - - {"HKJoy_Lid", 0, &HKJoyMapping[HK_Lid], -1, NULL, 0}, - {"HKJoy_Mic", 0, &HKJoyMapping[HK_Mic], -1, NULL, 0}, - - {"WindowWidth", 0, &WindowWidth, 256, NULL, 0}, - {"WindowHeight", 0, &WindowHeight, 384, NULL, 0}, - {"WindowMax", 0, &WindowMaximized, 0, NULL, 0}, - - {"ScreenRotation", 0, &ScreenRotation, 0, NULL, 0}, - {"ScreenGap", 0, &ScreenGap, 0, NULL, 0}, - {"ScreenLayout", 0, &ScreenLayout, 0, NULL, 0}, - {"ScreenSizing", 0, &ScreenSizing, 0, NULL, 0}, - {"ScreenFilter", 0, &ScreenFilter, 1, NULL, 0}, - - {"LimitFPS", 0, &LimitFPS, 1, NULL, 0}, - - {"DirectBoot", 0, &DirectBoot, 1, NULL, 0}, - {"Threaded3D", 0, &Threaded3D, 1, NULL, 0}, - {"SockBindAnyAddr", 0, &SocketBindAnyAddr, 0, NULL, 0}, - {"LANDevice", 1, LANDevice, 0, "", 127}, - {"DirectLAN", 0, &DirectLAN, 0, NULL, 0}, - - {"SavStaRelocSRAM", 0, &SavestateRelocSRAM, 0, NULL, 0}, - - {"AudioVolume", 0, &AudioVolume, 256, NULL, 0}, - {"MicInputType", 0, &MicInputType, 1, NULL, 0}, - {"MicWavPath", 1, MicWavPath, 0, "", 511}, - - {"LastROMFolder", 1, LastROMFolder, 0, "", 511}, - {"", -1, NULL, 0, NULL, 0} }; +extern ConfigEntry PlatformConfigFile[]; + void Load() { ConfigEntry* entry = &ConfigFile[0]; + int c = 0; for (;;) { - if (!entry->Value) break; + if (!entry->Value) + { + if (c > 0) break; + entry = &PlatformConfigFile[0]; + c++; + } if (entry->Type == 0) *(int*)entry->Value = entry->DefaultInt; @@ -173,9 +80,15 @@ void Load() if (ret < 2) continue; ConfigEntry* entry = &ConfigFile[0]; + c = 0; for (;;) { - if (!entry->Value) break; + if (!entry->Value) + { + if (c > 0) break; + entry = &PlatformConfigFile[0]; + c++; + } if (!strncmp(entry->Name, entryname, 15)) { @@ -196,6 +109,7 @@ void Load() void Save() { + // TODO not make path search shit tself and pick the wrong ath every damn tiem!!!!! FILE* f; if (LocalFileExists(kConfigFile)) { @@ -218,9 +132,15 @@ void Save() } ConfigEntry* entry = &ConfigFile[0]; + int c = 0; for (;;) { - if (!entry->Value) break; + if (!entry->Value) + { + if (c > 0) break; + entry = &PlatformConfigFile[0]; + c++; + } if (entry->Type == 0) fprintf(f, "%s=%d\n", entry->Name, *(int*)entry->Value); diff --git a/src/Config.h b/src/Config.h index 701ea41..25d1ee2 100644 --- a/src/Config.h +++ b/src/Config.h @@ -21,55 +21,27 @@ #include "types.h" -enum +namespace Config { - HK_Lid = 0, - HK_Mic, - - HK_MAX -}; -namespace Config +typedef struct { + char Name[16]; + int Type; + void* Value; + int DefaultInt; + char* DefaultStr; + int StrLength; // should be set to actual array length minus one + +} ConfigEntry; + FILE* GetConfigFile(const char* fileName, const char* permissions); bool HasConfigFile(const char* fileName); void Load(); void Save(); -extern int KeyMapping[12]; -extern int JoyMapping[12]; - -extern int HKKeyMapping[HK_MAX]; -extern int HKJoyMapping[HK_MAX]; - -extern int WindowWidth; -extern int WindowHeight; -extern int WindowMaximized; - -extern int ScreenRotation; -extern int ScreenGap; -extern int ScreenLayout; -extern int ScreenSizing; -extern int ScreenFilter; - -extern int LimitFPS; - -extern int DirectBoot; - extern int Threaded3D; -extern int SocketBindAnyAddr; -extern char LANDevice[128]; -extern int DirectLAN; - -extern int SavestateRelocSRAM; - -extern int AudioVolume; -extern int MicInputType; -extern char MicWavPath[512]; - -extern char LastROMFolder[512]; - } #endif // CONFIG_H diff --git a/src/libui_sdl/DlgAudioSettings.cpp b/src/libui_sdl/DlgAudioSettings.cpp index 5fe4ebc..66bdf61 100644 --- a/src/libui_sdl/DlgAudioSettings.cpp +++ b/src/libui_sdl/DlgAudioSettings.cpp @@ -23,7 +23,7 @@ #include "libui/ui.h" #include "../types.h" -#include "../Config.h" +#include "PlatformConfig.h" #include "DlgAudioSettings.h" diff --git a/src/libui_sdl/DlgEmuSettings.cpp b/src/libui_sdl/DlgEmuSettings.cpp index 666ac35..7d774a0 100644 --- a/src/libui_sdl/DlgEmuSettings.cpp +++ b/src/libui_sdl/DlgEmuSettings.cpp @@ -22,7 +22,7 @@ #include "libui/ui.h" #include "../types.h" -#include "../Config.h" +#include "PlatformConfig.h" #include "DlgEmuSettings.h" diff --git a/src/libui_sdl/DlgInputConfig.cpp b/src/libui_sdl/DlgInputConfig.cpp index 1869ec0..513bd90 100644 --- a/src/libui_sdl/DlgInputConfig.cpp +++ b/src/libui_sdl/DlgInputConfig.cpp @@ -24,7 +24,7 @@ #include "libui/ui.h" #include "../types.h" -#include "../Config.h" +#include "PlatformConfig.h" #include "DlgInputConfig.h" diff --git a/src/libui_sdl/DlgWifiSettings.cpp b/src/libui_sdl/DlgWifiSettings.cpp index 76f3840..c1acb35 100644 --- a/src/libui_sdl/DlgWifiSettings.cpp +++ b/src/libui_sdl/DlgWifiSettings.cpp @@ -23,7 +23,7 @@ #include "libui/ui.h" #include "../types.h" -#include "../Config.h" +#include "PlatformConfig.h" #include "LAN_Socket.h" #include "LAN_PCap.h" diff --git a/src/libui_sdl/LAN_PCap.cpp b/src/libui_sdl/LAN_PCap.cpp index 6f4fdca..d1c0dd9 100644 --- a/src/libui_sdl/LAN_PCap.cpp +++ b/src/libui_sdl/LAN_PCap.cpp @@ -25,7 +25,7 @@ #include <pcap/pcap.h> #include "Wifi.h" #include "LAN_PCap.h" -#include "../Config.h" +#include "PlatformConfig.h" #ifdef __WIN32__ #include <iphlpapi.h> diff --git a/src/libui_sdl/LAN_Socket.cpp b/src/libui_sdl/LAN_Socket.cpp index 0ca60ca..9da5769 100644 --- a/src/libui_sdl/LAN_Socket.cpp +++ b/src/libui_sdl/LAN_Socket.cpp @@ -621,6 +621,8 @@ void TCP_SYNACK(TCPSocket* sock, u8* data, int len) seqnum++; sock->AckNum = seqnum; + printf("SYNACK SEQ=%08X|%08X\n", sock->SeqNum, sock->AckNum); + // ethernet memcpy(out, &data[6], 6); out += 6; memcpy(out, kServerMAC, 6); out += 6; @@ -674,16 +676,18 @@ void TCP_SYNACK(TCPSocket* sock, u8* data, int len) RXNum = 1; } -void TCP_ACK(TCPSocket* sock, u8* data, int len) +void TCP_ACK(TCPSocket* sock, bool fin) { u8 resp[64]; u8* out = &resp[0]; - u8* ipheader = &data[0xE]; - u8* tcpheader = &data[0x22]; + u16 flags = 0x5010; + if (fin) flags |= 0x0001; + + printf("%sACK SEQ=%08X|%08X\n", fin?"FIN":" ", sock->SeqNum, sock->AckNum); // ethernet - memcpy(out, &data[6], 6); out += 6; + memcpy(out, Wifi::GetMAC(), 6); out += 6; memcpy(out, kServerMAC, 6); out += 6; *(u16*)out = htons(0x0800); out += 2; @@ -698,16 +702,16 @@ void TCP_ACK(TCPSocket* sock, u8* data, int len) *out++ = 0x80; // TTL *out++ = 0x06; // protocol (TCP) *(u16*)out = 0; out += 2; // checksum - *(u32*)out = *(u32*)&ipheader[16]; out += 4; // source IP - *(u32*)out = *(u32*)&ipheader[12]; out += 4; // destination IP + *(u32*)out = *(u32*)&sock->DestIP; out += 4; // source IP + *(u32*)out = htonl(kClientIP); out += 4; // destination IP // TCP u8* resp_tcpheader = out; - *(u16*)out = *(u16*)&tcpheader[2]; out += 2; // source port - *(u16*)out = *(u16*)&tcpheader[0]; out += 2; // destination port + *(u16*)out = htonl(sock->DestPort); out += 2; // source port + *(u16*)out = htonl(sock->SourcePort); out += 2; // destination port *(u32*)out = htonl(sock->SeqNum); out += 4; // seq number *(u32*)out = htonl(sock->AckNum); out += 4; // ack seq number - *(u16*)out = htons(0x5010); out += 2; // flags (ACK) + *(u16*)out = htons(flags); out += 2; // flags *(u16*)out = htons(0x7000); out += 2; // window size (uuuh) *(u16*)out = 0; out += 2; // checksum *(u16*)out = 0; out += 2; // urgent pointer @@ -731,7 +735,7 @@ void TCP_BuildIncomingFrame(TCPSocket* sock, u8* data, int len) u8* out = &resp[0]; if (len > 1536) return; - +printf("INCOMING SEQ=%08X|%08X\n", sock->SeqNum, sock->AckNum); // ethernet memcpy(out, Wifi::GetMAC(), 6); out += 6; // hurf memcpy(out, kServerMAC, 6); out += 6; @@ -774,6 +778,8 @@ void TCP_BuildIncomingFrame(TCPSocket* sock, u8* data, int len) PacketLen = framelen; memcpy(PacketBuffer, resp, PacketLen); RXNum = 1; + + sock->SeqNum += len; } void HandleTCPFrame(u8* data, int len) @@ -789,6 +795,11 @@ void HandleTCPFrame(u8* data, int len) u32 tcplen = ntohs(*(u16*)&ipheader[2]) - 0x14; u32 tcpdatalen = tcplen - tcpheaderlen; + printf("tcpflags=%04X header=%d data=%d seq=%08X|%08X\n", + flags, tcpheaderlen, tcpdatalen, + ntohl(*(u32*)&tcpheader[4]), + ntohl(*(u32*)&tcpheader[8])); + if (flags & 0x002) // SYN { int sockid = -1; @@ -796,7 +807,7 @@ void HandleTCPFrame(u8* data, int len) for (int i = 0; i < (sizeof(TCPSocketList)/sizeof(TCPSocket)); i++) { sock = &TCPSocketList[i]; - if (sock->Status == 1 && !memcmp(&sock->DestIP, &ipheader[16], 4) && + if (sock->Status != 0 && !memcmp(&sock->DestIP, &ipheader[16], 4) && sock->SourcePort == srcport && sock->DestPort == dstport) { printf("LANMAGIC: duplicate TCP socket\n"); @@ -846,7 +857,6 @@ void HandleTCPFrame(u8* data, int len) struct sockaddr_in conn_addr; memset(&conn_addr, 0, sizeof(conn_addr)); conn_addr.sin_family = AF_INET; - //conn_addr.sin_addr.S_un.S_addr = *(u32*)&ipheader[16]; memcpy(&conn_addr.sin_addr, &ipheader[16], 4); conn_addr.sin_port = htons(dstport); if (connect(sock->Backend, (sockaddr*)&conn_addr, sizeof(conn_addr)) == SOCKET_ERROR) @@ -866,7 +876,7 @@ void HandleTCPFrame(u8* data, int len) for (int i = 0; i < (sizeof(TCPSocketList)/sizeof(TCPSocket)); i++) { sock = &TCPSocketList[i]; - if (sock->Status == 1 && !memcmp(&sock->DestIP, &ipheader[16], 4) && + if (sock->Status != 0 && !memcmp(&sock->DestIP, &ipheader[16], 4) && sock->SourcePort == srcport && sock->DestPort == dstport) { sockid = i; @@ -895,7 +905,7 @@ void HandleTCPFrame(u8* data, int len) send(sock->Backend, (char*)tcpdata, tcpdatalen, 0); // kind of a hack, there - TCP_ACK(sock, data, len); + TCP_ACK(sock, false); } if (flags & 0x001) // FIN @@ -1052,10 +1062,35 @@ int RecvPacket(u8* data) u8 recvbuf[1024]; int recvlen = recv(sock->Backend, (char*)recvbuf, 1024, 0); - if (recvlen < 1) continue; + if (recvlen < 1) + { + if (recvlen == 0) + { + // socket has closed from the other side + printf("TCP: socket %d closed from other side\n", i); + sock->Status = 2; + TCP_ACK(sock, true); + } + continue; + } printf("TCP: socket %d receiving %d bytes\n", i, recvlen); TCP_BuildIncomingFrame(sock, recvbuf, recvlen); + + // debug + for (int j = 0; j < recvlen; j += 16) + { + int rem = recvlen - j; + if (rem > 16) rem = 16; + for (int k = 0; k < rem; k++) + { + printf("%02X ", recvbuf[k+j]); + } + printf("\n"); + } + + //recvlen = recv(sock->Backend, (char*)recvbuf, 1024, 0); + //if (recvlen == 0) printf("it closed immediately after\n"); } for (int i = 0; i < (sizeof(UDPSocketList)/sizeof(UDPSocket)); i++) @@ -1077,7 +1112,6 @@ int RecvPacket(u8* data) } u8 recvbuf[1024]; - //int recvlen = recv(sock->Backend, (char*)recvbuf, 1024, 0); sockaddr_t fromAddr; socklen_t fromLen = sizeof(sockaddr_t); int recvlen = recvfrom(sock->Backend, (char*)recvbuf, 1024, 0, &fromAddr, &fromLen); diff --git a/src/libui_sdl/Platform.cpp b/src/libui_sdl/Platform.cpp index 2c467ac..f5ec32e 100644 --- a/src/libui_sdl/Platform.cpp +++ b/src/libui_sdl/Platform.cpp @@ -21,7 +21,7 @@ #include <string.h> #include <SDL2/SDL.h> #include "../Platform.h" -#include "../Config.h" +#include "PlatformConfig.h" #include "LAN_Socket.h" #include "LAN_PCap.h" diff --git a/src/libui_sdl/PlatformConfig.cpp b/src/libui_sdl/PlatformConfig.cpp new file mode 100644 index 0000000..2daf746 --- /dev/null +++ b/src/libui_sdl/PlatformConfig.cpp @@ -0,0 +1,123 @@ +/* + Copyright 2016-2019 Arisotura + + This file is part of melonDS. + + melonDS is free software: you can redistribute it and/or modify it under + the terms of the GNU General Public License as published by the Free + Software Foundation, either version 3 of the License, or (at your option) + any later version. + + melonDS 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 General Public License for more details. + + You should have received a copy of the GNU General Public License along + with melonDS. If not, see http://www.gnu.org/licenses/. +*/ + +#include <stdio.h> +#include <string.h> +#include <stdlib.h> +#include "PlatformConfig.h" + +namespace Config +{ + +int KeyMapping[12]; +int JoyMapping[12]; + +int HKKeyMapping[HK_MAX]; +int HKJoyMapping[HK_MAX]; + +int WindowWidth; +int WindowHeight; +int WindowMaximized; + +int ScreenRotation; +int ScreenGap; +int ScreenLayout; +int ScreenSizing; +int ScreenFilter; + +int LimitFPS; + +int DirectBoot; + +int SocketBindAnyAddr; +char LANDevice[128]; +int DirectLAN; + +int SavestateRelocSRAM; + +int AudioVolume; +int MicInputType; +char MicWavPath[512]; + +char LastROMFolder[512]; + + +ConfigEntry PlatformConfigFile[] = +{ + {"Key_A", 0, &KeyMapping[0], 32, NULL, 0}, + {"Key_B", 0, &KeyMapping[1], 31, NULL, 0}, + {"Key_Select", 0, &KeyMapping[2], 57, NULL, 0}, + {"Key_Start", 0, &KeyMapping[3], 28, NULL, 0}, + {"Key_Right", 0, &KeyMapping[4], 333, NULL, 0}, + {"Key_Left", 0, &KeyMapping[5], 331, NULL, 0}, + {"Key_Up", 0, &KeyMapping[6], 328, NULL, 0}, + {"Key_Down", 0, &KeyMapping[7], 336, NULL, 0}, + {"Key_R", 0, &KeyMapping[8], 54, NULL, 0}, + {"Key_L", 0, &KeyMapping[9], 86, NULL, 0}, + {"Key_X", 0, &KeyMapping[10], 17, NULL, 0}, + {"Key_Y", 0, &KeyMapping[11], 30, NULL, 0}, + + {"Joy_A", 0, &JoyMapping[0], -1, NULL, 0}, + {"Joy_B", 0, &JoyMapping[1], -1, NULL, 0}, + {"Joy_Select", 0, &JoyMapping[2], -1, NULL, 0}, + {"Joy_Start", 0, &JoyMapping[3], -1, NULL, 0}, + {"Joy_Right", 0, &JoyMapping[4], -1, NULL, 0}, + {"Joy_Left", 0, &JoyMapping[5], -1, NULL, 0}, + {"Joy_Up", 0, &JoyMapping[6], -1, NULL, 0}, + {"Joy_Down", 0, &JoyMapping[7], -1, NULL, 0}, + {"Joy_R", 0, &JoyMapping[8], -1, NULL, 0}, + {"Joy_L", 0, &JoyMapping[9], -1, NULL, 0}, + {"Joy_X", 0, &JoyMapping[10], -1, NULL, 0}, + {"Joy_Y", 0, &JoyMapping[11], -1, NULL, 0}, + + {"HKKey_Lid", 0, &HKKeyMapping[HK_Lid], 0x0E, NULL, 0}, + {"HKKey_Mic", 0, &HKKeyMapping[HK_Mic], 0x35, NULL, 0}, + + {"HKJoy_Lid", 0, &HKJoyMapping[HK_Lid], -1, NULL, 0}, + {"HKJoy_Mic", 0, &HKJoyMapping[HK_Mic], -1, NULL, 0}, + + {"WindowWidth", 0, &WindowWidth, 256, NULL, 0}, + {"WindowHeight", 0, &WindowHeight, 384, NULL, 0}, + {"WindowMax", 0, &WindowMaximized, 0, NULL, 0}, + + {"ScreenRotation", 0, &ScreenRotation, 0, NULL, 0}, + {"ScreenGap", 0, &ScreenGap, 0, NULL, 0}, + {"ScreenLayout", 0, &ScreenLayout, 0, NULL, 0}, + {"ScreenSizing", 0, &ScreenSizing, 0, NULL, 0}, + {"ScreenFilter", 0, &ScreenFilter, 1, NULL, 0}, + + {"LimitFPS", 0, &LimitFPS, 1, NULL, 0}, + + {"DirectBoot", 0, &DirectBoot, 1, NULL, 0}, + + {"SockBindAnyAddr", 0, &SocketBindAnyAddr, 0, NULL, 0}, + {"LANDevice", 1, LANDevice, 0, "", 127}, + {"DirectLAN", 0, &DirectLAN, 0, NULL, 0}, + + {"SavStaRelocSRAM", 0, &SavestateRelocSRAM, 0, NULL, 0}, + + {"AudioVolume", 0, &AudioVolume, 256, NULL, 0}, + {"MicInputType", 0, &MicInputType, 1, NULL, 0}, + {"MicWavPath", 1, MicWavPath, 0, "", 511}, + + {"LastROMFolder", 1, LastROMFolder, 0, "", 511}, + + {"", -1, NULL, 0, NULL, 0} +}; + +} diff --git a/src/libui_sdl/PlatformConfig.h b/src/libui_sdl/PlatformConfig.h new file mode 100644 index 0000000..ed31e18 --- /dev/null +++ b/src/libui_sdl/PlatformConfig.h @@ -0,0 +1,69 @@ +/* + Copyright 2016-2019 Arisotura + + This file is part of melonDS. + + melonDS is free software: you can redistribute it and/or modify it under + the terms of the GNU General Public License as published by the Free + Software Foundation, either version 3 of the License, or (at your option) + any later version. + + melonDS 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 General Public License for more details. + + You should have received a copy of the GNU General Public License along + with melonDS. If not, see http://www.gnu.org/licenses/. +*/ + +#ifndef PLATFORMCONFIG_H +#define PLATFORMCONFIG_H + +#include "../Config.h" + +enum +{ + HK_Lid = 0, + HK_Mic, + + HK_MAX +}; + +namespace Config +{ + +extern int KeyMapping[12]; +extern int JoyMapping[12]; + +extern int HKKeyMapping[HK_MAX]; +extern int HKJoyMapping[HK_MAX]; + +extern int WindowWidth; +extern int WindowHeight; +extern int WindowMaximized; + +extern int ScreenRotation; +extern int ScreenGap; +extern int ScreenLayout; +extern int ScreenSizing; +extern int ScreenFilter; + +extern int LimitFPS; + +extern int DirectBoot; + +extern int SocketBindAnyAddr; +extern char LANDevice[128]; +extern int DirectLAN; + +extern int SavestateRelocSRAM; + +extern int AudioVolume; +extern int MicInputType; +extern char MicWavPath[512]; + +extern char LastROMFolder[512]; + +} + +#endif // PLATFORMCONFIG_H diff --git a/src/libui_sdl/main.cpp b/src/libui_sdl/main.cpp index 9c6b38b..25c7249 100644 --- a/src/libui_sdl/main.cpp +++ b/src/libui_sdl/main.cpp @@ -27,7 +27,7 @@ #include "../types.h" #include "../melon_fopen.h" #include "../version.h" -#include "../Config.h" +#include "PlatformConfig.h" #include "DlgEmuSettings.h" #include "DlgInputConfig.h" |