Make building with libslirp optional
This commit is contained in:
parent
1cd477db71
commit
d47ba88fd4
|
@ -12,7 +12,6 @@ SET(SOURCES_QT_SDL
|
||||||
InterfaceSettingsDialog.cpp
|
InterfaceSettingsDialog.cpp
|
||||||
Input.cpp
|
Input.cpp
|
||||||
LAN_PCap.cpp
|
LAN_PCap.cpp
|
||||||
LAN_Socket.cpp
|
|
||||||
OSD.cpp
|
OSD.cpp
|
||||||
OSD_shaders.h
|
OSD_shaders.h
|
||||||
font.h
|
font.h
|
||||||
|
@ -70,21 +69,41 @@ find_package(Threads REQUIRED)
|
||||||
find_package(PkgConfig REQUIRED)
|
find_package(PkgConfig REQUIRED)
|
||||||
find_package(Iconv REQUIRED)
|
find_package(Iconv REQUIRED)
|
||||||
pkg_check_modules(SDL2 REQUIRED sdl2)
|
pkg_check_modules(SDL2 REQUIRED sdl2)
|
||||||
pkg_check_modules(SLIRP REQUIRED slirp)
|
pkg_check_modules(SLIRP slirp)
|
||||||
pkg_check_modules(LIBARCHIVE REQUIRED libarchive)
|
pkg_check_modules(LIBARCHIVE REQUIRED libarchive)
|
||||||
add_compile_definitions(ARCHIVE_SUPPORT_ENABLED)
|
add_compile_definitions(ARCHIVE_SUPPORT_ENABLED)
|
||||||
|
|
||||||
|
if (SLIRP_FOUND)
|
||||||
|
option(ENABLE_LIBSLIRP "Enable use of libslirp for network sockets" ON)
|
||||||
|
else()
|
||||||
|
option(ENABLE_LIBSLIRP "Enable use of libslirp for network sockets" OFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
if (WIN32 AND (CMAKE_BUILD_TYPE STREQUAL Release))
|
if (WIN32 AND (CMAKE_BUILD_TYPE STREQUAL Release))
|
||||||
add_executable(melonDS WIN32 ${SOURCES_QT_SDL})
|
add_executable(melonDS WIN32 ${SOURCES_QT_SDL})
|
||||||
else()
|
else()
|
||||||
add_executable(melonDS ${SOURCES_QT_SDL})
|
add_executable(melonDS ${SOURCES_QT_SDL})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if (ENABLE_LIBSLIRP)
|
||||||
|
target_compile_definitions(melonDS PRIVATE -DHAVE_LIBSLIRP)
|
||||||
|
target_sources(melonDS PRIVATE LAN_Socket.cpp)
|
||||||
|
endif()
|
||||||
|
|
||||||
target_link_libraries(melonDS ${CMAKE_THREAD_LIBS_INIT})
|
target_link_libraries(melonDS ${CMAKE_THREAD_LIBS_INIT})
|
||||||
|
|
||||||
target_include_directories(melonDS PRIVATE ${SDL2_INCLUDE_DIRS} ${SDL2_PREFIX}/include ${SLIRP_INCLUDE_DIRS} ${LIBARCHIVE_INCLUDE_DIRS})
|
target_include_directories(
|
||||||
target_link_directories(melonDS PRIVATE ${SDL2_LIBRARY_DIRS} ${SLIRP_LIBRARY_DIRS})
|
melonDS PRIVATE
|
||||||
target_link_directories(melonDS PRIVATE ${LIBARCHIVE_LIBRARY_DIRS})
|
${SDL2_INCLUDE_DIRS} ${SDL2_PREFIX}/include
|
||||||
|
${SLIRP_INCLUDE_DIRS}
|
||||||
|
${LIBARCHIVE_INCLUDE_DIRS}
|
||||||
|
)
|
||||||
|
target_link_directories(
|
||||||
|
melonDS PRIVATE
|
||||||
|
${SDL2_LIBRARY_DIRS}
|
||||||
|
${SLIRP_LIBRARY_DIRS}
|
||||||
|
${LIBARCHIVE_LIBRARY_DIRS}
|
||||||
|
)
|
||||||
|
|
||||||
target_include_directories(melonDS PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}")
|
target_include_directories(melonDS PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}")
|
||||||
target_include_directories(melonDS PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/..")
|
target_include_directories(melonDS PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/..")
|
||||||
|
|
|
@ -51,7 +51,11 @@
|
||||||
|
|
||||||
#include "Platform.h"
|
#include "Platform.h"
|
||||||
#include "PlatformConfig.h"
|
#include "PlatformConfig.h"
|
||||||
|
|
||||||
|
#ifdef HAVE_LIBSLIRP
|
||||||
#include "LAN_Socket.h"
|
#include "LAN_Socket.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "LAN_PCap.h"
|
#include "LAN_PCap.h"
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
@ -393,6 +397,7 @@ int MP_RecvPacket(u8* data, bool block)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_LIBSLIRP
|
||||||
bool LAN_Init()
|
bool LAN_Init()
|
||||||
{
|
{
|
||||||
if (Config::DirectLAN)
|
if (Config::DirectLAN)
|
||||||
|
@ -408,6 +413,12 @@ bool LAN_Init()
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
bool LAN_Init()
|
||||||
|
{
|
||||||
|
return LAN_PCap::Init(true);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void LAN_DeInit()
|
void LAN_DeInit()
|
||||||
{
|
{
|
||||||
|
@ -417,9 +428,12 @@ void LAN_DeInit()
|
||||||
//else
|
//else
|
||||||
// LAN_Socket::DeInit();
|
// LAN_Socket::DeInit();
|
||||||
LAN_PCap::DeInit();
|
LAN_PCap::DeInit();
|
||||||
|
#ifdef HAVE_LIBSLIRP
|
||||||
LAN_Socket::DeInit();
|
LAN_Socket::DeInit();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef HAVE_LIBSLIRP
|
||||||
int LAN_SendPacket(u8* data, int len)
|
int LAN_SendPacket(u8* data, int len)
|
||||||
{
|
{
|
||||||
if (Config::DirectLAN)
|
if (Config::DirectLAN)
|
||||||
|
@ -435,6 +449,17 @@ int LAN_RecvPacket(u8* data)
|
||||||
else
|
else
|
||||||
return LAN_Socket::RecvPacket(data);
|
return LAN_Socket::RecvPacket(data);
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
int LAN_SendPacket(u8* data, int len)
|
||||||
|
{
|
||||||
|
return LAN_PCap::SendPacket(data, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
int LAN_RecvPacket(u8* data)
|
||||||
|
{
|
||||||
|
return LAN_PCap::RecvPacket(data);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void Sleep(u64 usecs)
|
void Sleep(u64 usecs)
|
||||||
{
|
{
|
||||||
|
|
|
@ -51,7 +51,9 @@ WifiSettingsDialog::WifiSettingsDialog(QWidget* parent) : QDialog(parent), ui(ne
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
setAttribute(Qt::WA_DeleteOnClose);
|
setAttribute(Qt::WA_DeleteOnClose);
|
||||||
|
|
||||||
|
#ifdef HAVE_LIBSLIRP
|
||||||
LAN_Socket::Init();
|
LAN_Socket::Init();
|
||||||
|
#endif
|
||||||
haspcap = LAN_PCap::Init(false);
|
haspcap = LAN_PCap::Init(false);
|
||||||
|
|
||||||
ui->rbDirectMode->setText("Direct mode (requires " PCAP_NAME " and ethernet connection)");
|
ui->rbDirectMode->setText("Direct mode (requires " PCAP_NAME " and ethernet connection)");
|
||||||
|
@ -71,8 +73,14 @@ WifiSettingsDialog::WifiSettingsDialog(QWidget* parent) : QDialog(parent), ui(ne
|
||||||
}
|
}
|
||||||
ui->cbxDirectAdapter->setCurrentIndex(sel);
|
ui->cbxDirectAdapter->setCurrentIndex(sel);
|
||||||
|
|
||||||
|
#ifdef HAVE_LIBSLIRP
|
||||||
ui->rbDirectMode->setChecked(Config::DirectLAN != 0);
|
ui->rbDirectMode->setChecked(Config::DirectLAN != 0);
|
||||||
ui->rbIndirectMode->setChecked(Config::DirectLAN == 0);
|
ui->rbIndirectMode->setChecked(Config::DirectLAN == 0);
|
||||||
|
#else
|
||||||
|
ui->rbDirectMode->setChecked(true);
|
||||||
|
ui->rbIndirectMode->setEnabled(false);
|
||||||
|
ui->rbIndirectMode->setText("Indirect mode (unavailable, compiled without libslirp)");
|
||||||
|
#endif
|
||||||
if (!haspcap) ui->rbDirectMode->setEnabled(false);
|
if (!haspcap) ui->rbDirectMode->setEnabled(false);
|
||||||
|
|
||||||
updateAdapterControls();
|
updateAdapterControls();
|
||||||
|
|
Loading…
Reference in New Issue