mirror of
https://github.com/CTCaer/RetroArch.git
synced 2025-01-24 12:15:08 +00:00
384 lines
11 KiB
Bash
384 lines
11 KiB
Bash
check_switch_c C99 -std=gnu99 "Cannot find C99 compatible compiler."
|
|
|
|
check_switch_c NOUNUSED -Wno-unused-result
|
|
add_define_make NOUNUSED "$HAVE_NOUNUSED"
|
|
check_switch_c NOUNUSED_VARIABLE -Wno-unused-variable
|
|
add_define_make NOUNUSED_VARIABLE "$HAVE_NOUNUSED_VARIABLE"
|
|
|
|
# There are still broken 64-bit Linux distros out there. :)
|
|
[ -z "$CROSS_COMPILE" ] && [ -d /usr/lib64 ] && add_library_dirs /usr/lib64
|
|
|
|
[ -z "$CROSS_COMPILE" ] && [ -d /opt/local/lib ] && add_library_dirs /opt/local/lib
|
|
|
|
DYLIB=-ldl;
|
|
CLIB=-lc
|
|
PTHREADLIB=-lpthread
|
|
SOCKETLIB=-lc
|
|
SOCKETHEADER=
|
|
|
|
if [ "$OS" = 'BSD' ]; then
|
|
DYLIB=-lc;
|
|
elif [ "$OS" = 'Haiku' ]; then
|
|
DYLIB=""
|
|
CLIB=-lroot
|
|
PTHREADLIB=-lroot
|
|
SOCKETLIB=-lnetwork
|
|
elif [ "$OS" = 'Win32' ]; then
|
|
SOCKETLIB=-lws2_32
|
|
SOCKETHEADER="#include <winsock2.h>"
|
|
DYLIB=
|
|
fi
|
|
|
|
add_define_make DYLIB_LIB "$DYLIB"
|
|
|
|
[ "$OS" = 'Darwin' ] && HAVE_X11=no # X11 breaks on recent OSXes even if present.
|
|
|
|
[ -d /opt/vc/lib ] && add_library_dirs /opt/vc/lib
|
|
check_lib VIDEOCORE -lbcm_host bcm_host_init "-lvcos -lvchiq_arm"
|
|
|
|
if [ "$HAVE_VIDEOCORE" = 'yes' ]; then
|
|
[ -d /opt/vc/include ] && add_include_dirs /opt/vc/include
|
|
[ -d /opt/vc/include/interface/vcos/pthreads ] && add_include_dirs /opt/vc/include/interface/vcos/pthreads
|
|
[ -d /opt/vc/include/interface/vmcs_host/linux ] && add_include_dirs /opt/vc/include/interface/vmcs_host/linux
|
|
HAVE_GLES='auto'
|
|
EXTRA_GL_LIBS="-lEGL -lGLESv2 -lbcm_host -lvcos -lvchiq_arm"
|
|
fi
|
|
|
|
if [ "$HAVE_NEON" = "yes" ]; then
|
|
CFLAGS="$CFLAGS -mfpu=neon -marm"
|
|
CXXFLAGS="$CXXFLAGS -mfpu=neon -marm"
|
|
ASFLAGS="$ASFLAGS -mfpu=neon"
|
|
fi
|
|
|
|
if [ "$HAVE_7ZIP" = "yes" ]; then
|
|
add_include_dirs ./decompress/7zip/
|
|
fi
|
|
|
|
if [ "$HAVE_PRESERVE_DYLIB" = "yes" ]; then
|
|
echo "Notice: Disabling dlclose() of shared objects for Valgrind support."
|
|
add_define_make HAVE_PRESERVE_DYLIB "1"
|
|
fi
|
|
|
|
if [ "$HAVE_FLOATHARD" = "yes" ]; then
|
|
CFLAGS="$CFLAGS -mfloat-abi=hard"
|
|
CXXFLAGS="$CXXFLAGS -mfloat-abi=hard"
|
|
ASFLAGS="$ASFLAGS -mfloat-abi=hard"
|
|
fi
|
|
|
|
if [ "$HAVE_FLOATSOFTFP" = "yes" ]; then
|
|
CFLAGS="$CFLAGS -mfloat-abi=softfp"
|
|
CXXFLAGS="$CXXFLAGS -mfloat-abi=softfp"
|
|
ASFLAGS="$ASFLAGS -mfloat-abi=softfp"
|
|
fi
|
|
|
|
if [ "$HAVE_NEON" = "yes" ]; then
|
|
CFLAGS="$CFLAGS -mfpu=neon -marm"
|
|
CXXFLAGS="$CXXFLAGS -mfpu=neon -marm"
|
|
ASFLAGS="$ASFLAGS -mfpu=neon"
|
|
fi
|
|
|
|
if [ "$HAVE_FLOATHARD" = "yes" ]; then
|
|
CFLAGS="$CFLAGS -mfloat-abi=hard"
|
|
CXXFLAGS="$CXXFLAGS -mfloat-abi=hard"
|
|
ASFLAGS="$ASFLAGS -mfloat-abi=hard"
|
|
fi
|
|
|
|
if [ "$HAVE_FLOATSOFTFP" = "yes" ]; then
|
|
CFLAGS="$CFLAGS -mfloat-abi=softfp"
|
|
CXXFLAGS="$CXXFLAGS -mfloat-abi=softfp"
|
|
ASFLAGS="$ASFLAGS -mfloat-abi=softfp"
|
|
fi
|
|
|
|
if [ "$HAVE_SSE" = "yes" ]; then
|
|
CFLAGS="$CFLAGS -msse -msse2"
|
|
CXXFLAGS="$CXXFLAGS -msse -msse2"
|
|
fi
|
|
|
|
if [ "$HAVE_EGL" != "no" ]; then
|
|
check_pkgconf EGL egl
|
|
# some systems have EGL libs, but no pkgconfig
|
|
if [ "$HAVE_EGL" = "no" ]; then
|
|
HAVE_EGL=auto && check_lib EGL "-lEGL $EXTRA_GL_LIBS"
|
|
[ "$HAVE_EGL" = "yes" ] && EGL_LIBS=-lEGL
|
|
else
|
|
EGL_LIBS="$EGL_LIBS $EXTRA_GL_LIBS"
|
|
fi
|
|
fi
|
|
|
|
if [ "$HAVE_EXYNOS" != "no" ]; then
|
|
check_pkgconf EXYNOS libdrm_exynos
|
|
check_pkgconf DRM libdrm
|
|
fi
|
|
|
|
if [ "$HAVE_DISPMANX" != "no" ]; then
|
|
PKG_CONF_USED="$PKG_CONF_USED DISPMANX"
|
|
fi
|
|
|
|
if [ "$LIBRETRO" ]; then
|
|
echo "Notice: Explicit libretro used, disabling dynamic libretro loading ..."
|
|
HAVE_DYNAMIC='no'
|
|
else LIBRETRO="-lretro"
|
|
fi
|
|
|
|
[ "$HAVE_DYNAMIC" = 'yes' ] || {
|
|
check_lib_cxx RETRO "$LIBRETRO" retro_init "$DYLIB" "Cannot find libretro."
|
|
add_define_make libretro "$LIBRETRO"
|
|
}
|
|
|
|
if [ "$MAN_DIR" ]; then
|
|
add_define_make MAN_DIR "$MAN_DIR"
|
|
else
|
|
add_define_make MAN_DIR "${PREFIX}/share/man/man1"
|
|
fi
|
|
|
|
if [ "$OS" = 'Win32' ]; then
|
|
HAVE_THREADS=yes
|
|
HAVE_DYLIB=yes
|
|
else
|
|
check_lib THREADS "$PTHREADLIB" pthread_create
|
|
check_lib DYLIB "$DYLIB" dlopen
|
|
fi
|
|
|
|
check_lib NETWORKING "$SOCKETLIB" socket "" "$SOCKETHEADER"
|
|
|
|
if [ "$HAVE_NETWORKING" = 'yes' ]; then
|
|
HAVE_GETADDRINFO=auto
|
|
HAVE_SOCKET_LEGACY=no
|
|
|
|
# WinXP+ implements getaddrinfo()
|
|
if [ "$OS" = 'Win32' ]; then
|
|
HAVE_GETADDRINFO=yes
|
|
else
|
|
check_lib GETADDRINFO "$SOCKETLIB" getaddrinfo
|
|
if [ "$HAVE_GETADDRINFO" != 'yes' ]; then
|
|
HAVE_SOCKET_LEGACY=yes
|
|
echo "Notice: RetroArch will use legacy socket support"
|
|
fi
|
|
fi
|
|
HAVE_NETWORK_CMD=yes
|
|
|
|
[ "$HAVE_NETPLAY" != 'no' ] && HAVE_NETPLAY='yes'
|
|
else
|
|
echo "Warning: All networking features have been disabled."
|
|
HAVE_NETWORK_CMD='no'
|
|
HAVE_NETPLAY='no'
|
|
fi
|
|
|
|
check_lib STDIN_CMD "$CLIB" fcntl
|
|
|
|
if [ "$HAVE_NETWORK_CMD" = "yes" ] || [ "$HAVE_STDIN_CMD" = "yes" ]; then
|
|
HAVE_COMMAND='yes'
|
|
else
|
|
HAVE_COMMAND='no'
|
|
fi
|
|
|
|
check_lib GETOPT_LONG "$CLIB" getopt_long
|
|
|
|
if [ "$HAVE_DYLIB" = 'no' ] && [ "$HAVE_DYNAMIC" = 'yes' ]; then
|
|
echo "Error: Dynamic loading of libretro is enabled, but your platform does not appear to have dlopen(), use --disable-dynamic or --with-libretro=\"-lretro\"".
|
|
exit 1
|
|
fi
|
|
|
|
check_pkgconf ALSA alsa
|
|
check_header OSS sys/soundcard.h
|
|
check_header OSS_BSD soundcard.h
|
|
check_lib OSS_LIB -lossaudio
|
|
|
|
if [ "$OS" = 'Darwin' ]; then
|
|
check_lib AL "-framework OpenAL" alcOpenDevice
|
|
HAVE_SDL=no
|
|
else
|
|
check_lib AL -lopenal alcOpenDevice
|
|
fi
|
|
|
|
check_pkgconf RSOUND rsound 1.1
|
|
check_pkgconf ROAR libroar
|
|
check_pkgconf JACK jack 0.120.1
|
|
check_pkgconf PULSE libpulse
|
|
|
|
if [ "$OS" = 'Darwin' ]; then
|
|
check_lib COREAUDIO "-framework AudioUnit" AudioUnitInitialize
|
|
|
|
check_lib CORETEXT "-framework CoreText" CTFontCreateWithName
|
|
|
|
check_lib COCOA "-framework AppKit" NSApplicationMain
|
|
check_lib AVFOUNDATION "-framework AVFoundation"
|
|
check_lib CORELOCATION "-framework CoreLocation"
|
|
check_lib IOHIDMANAGER "-framework IOKit" IOHIDManagerCreate
|
|
fi
|
|
|
|
check_pkgconf SDL sdl 1.2.10
|
|
check_pkgconf SDL2 sdl2 2.0.0
|
|
|
|
if [ "$HAVE_SDL2" = 'yes' ]; then
|
|
if [ "$HAVE_SDL2" = 'yes' ] && [ "$HAVE_SDL" = 'yes' ]; then
|
|
echo "Notice: SDL drivers will be replaced by SDL2 ones."
|
|
HAVE_SDL=no
|
|
elif [ "$HAVE_SDL2" = 'no' ]; then
|
|
echo "Warning: SDL2 not found, skipping."
|
|
HAVE_SDL2=no
|
|
fi
|
|
fi
|
|
|
|
check_pkgconf LIBUSB libusb-1.0 1.0.16
|
|
|
|
if [ "$OS" = 'Win32' ]; then
|
|
check_lib DINPUT -ldinput8
|
|
check_lib D3D9 -ld3d9
|
|
check_lib DSOUND -ldsound
|
|
|
|
if [ "$HAVE_DINPUT" != 'no' ]; then
|
|
HAVE_XINPUT=yes
|
|
fi
|
|
|
|
HAVE_XAUDIO=yes
|
|
else
|
|
HAVE_D3D9=no
|
|
fi
|
|
|
|
if [ "$HAVE_OPENGL" != 'no' ] && [ "$HAVE_GLES" != 'yes' ]; then
|
|
if [ "$OS" = 'Darwin' ]; then
|
|
check_lib CG "-framework Cg" cgCreateContext
|
|
[ "$HAVE_CG" = 'yes' ] && CG_LIBS='-framework Cg'
|
|
elif [ "$OS" = 'Win32' ]; then
|
|
check_lib_cxx CG -lcg cgCreateContext
|
|
[ "$HAVE_CG" = 'yes' ] && CG_LIBS='-lcg -lcgGL'
|
|
else
|
|
# On some distros, -lCg doesn't link against -lstdc++ it seems ...
|
|
check_lib_cxx CG -lCg cgCreateContext
|
|
[ "$HAVE_CG" = 'yes' ] && CG_LIBS='-lCg -lCgGL'
|
|
fi
|
|
|
|
# fix undefined variables
|
|
PKG_CONF_USED="$PKG_CONF_USED CG"
|
|
else
|
|
echo "Notice: Ignoring Cg. Desktop OpenGL is not enabled."
|
|
HAVE_CG='no'
|
|
fi
|
|
|
|
if [ "$OS" = 'Darwin' ]; then
|
|
check_lib ZLIB "-lz"
|
|
else
|
|
check_pkgconf ZLIB zlib
|
|
fi
|
|
|
|
if [ "$HAVE_THREADS" != 'no' ]; then
|
|
if [ "$HAVE_FFMPEG" != 'no' ]; then
|
|
check_pkgconf AVCODEC libavcodec 54
|
|
check_pkgconf AVFORMAT libavformat 54
|
|
check_pkgconf AVUTIL libavutil 51
|
|
check_pkgconf SWSCALE libswscale 2.1
|
|
check_header AV_CHANNEL_LAYOUT libavutil/channel_layout.h
|
|
|
|
HAVE_FFMPEG='yes'
|
|
if [ "$HAVE_AVCODEC" = 'no' ] || [ "$HAVE_AVFORMAT" = 'no' ] || [ "$HAVE_AVUTIL" = 'no' ] || [ "$HAVE_SWSCALE" = 'no' ]; then
|
|
HAVE_FFMPEG='no'
|
|
echo "Notice: FFmpeg recording disabled due to missing or unsuitable packages."
|
|
fi
|
|
fi
|
|
else
|
|
echo "Notice: Not building with threading support. Will skip FFmpeg."
|
|
HAVE_FFMPEG='no'
|
|
fi
|
|
|
|
if [ "$OS" != 'Win32' ]; then
|
|
check_lib DYNAMIC "$DYLIB" dlopen
|
|
fi
|
|
|
|
if [ "$HAVE_KMS" != "no" ]; then
|
|
check_pkgconf GBM gbm 9.0
|
|
check_pkgconf DRM libdrm
|
|
if [ "$HAVE_GBM" = "yes" ] && [ "$HAVE_DRM" = "yes" ] && [ "$HAVE_EGL" = "yes" ]; then
|
|
HAVE_KMS=yes
|
|
elif [ "$HAVE_KMS" = "yes" ]; then
|
|
echo "Error: Cannot find libgbm, libdrm and EGL libraries required for KMS. Compile without --enable-kms."
|
|
exit 1
|
|
else
|
|
HAVE_KMS=no
|
|
fi
|
|
fi
|
|
|
|
check_pkgconf LIBXML2 libxml-2.0
|
|
|
|
if [ "$HAVE_EGL" = "yes" ]; then
|
|
if [ "$HAVE_GLES" != "no" ]; then
|
|
if [ "$GLES_LIBS" ] || [ "$GLES_CFLAGS" ]; then
|
|
echo "Notice: Using custom OpenGLES CFLAGS ($GLES_CFLAGS) and LDFLAGS ($GLES_LIBS)."
|
|
add_define_make GLES_LIBS "$GLES_LIBS"
|
|
add_define_make GLES_CFLAGS "$GLES_CFLAGS"
|
|
else
|
|
HAVE_GLES=auto check_pkgconf GLES glesv2
|
|
[ "$HAVE_GLES" = "no" ] && HAVE_GLES=auto check_lib GLES "-lGLESv2 $EXTRA_GL_LIBS" && add_define_make GLES_LIBS "-lGLESv2 $EXTRA_GL_LIBS"
|
|
fi
|
|
fi
|
|
if [ "$HAVE_VG" != "no" ]; then
|
|
check_pkgconf VG vg
|
|
if [ "$HAVE_VG" = "no" ]; then
|
|
HAVE_VG=auto check_lib VG "-lOpenVG $EXTRA_GL_LIBS"
|
|
[ "$HAVE_VG" = "yes" ] && VG_LIBS=-lOpenVG
|
|
fi
|
|
fi
|
|
else
|
|
HAVE_VG=no
|
|
HAVE_GLES=no
|
|
fi
|
|
|
|
check_pkgconf V4L2 libv4l2
|
|
|
|
if [ "$OS" = 'Darwin' ]; then
|
|
check_lib FBO "-framework OpenGL" glFramebufferTexture2D
|
|
elif [ "$OS" = 'Win32' ]; then
|
|
HAVE_FBO=yes
|
|
else
|
|
if [ "$HAVE_GLES" = "yes" ]; then
|
|
[ $HAVE_FBO != "no" ] && HAVE_FBO=yes
|
|
else
|
|
check_lib FBO -lGL glFramebufferTexture2D
|
|
fi
|
|
fi
|
|
|
|
check_pkgconf FREETYPE freetype2
|
|
check_pkgconf X11 x11
|
|
[ "$HAVE_X11" = "no" ] && HAVE_XEXT=no && HAVE_XF86VM=no && HAVE_XINERAMA=no
|
|
|
|
check_pkgconf WAYLAND wayland-egl
|
|
|
|
check_pkgconf XKBCOMMON xkbcommon 0.3.2
|
|
check_pkgconf XEXT xext
|
|
check_pkgconf XF86VM xxf86vm
|
|
check_pkgconf XINERAMA xinerama
|
|
if [ "$HAVE_X11" = 'yes' ] && [ "$HAVE_XEXT" = 'yes' ] && [ "$HAVE_XF86VM" = 'yes' ]; then
|
|
check_pkgconf XVIDEO xv
|
|
else
|
|
echo "Notice: X11, Xext or xf86vm not present. Skipping X11 code paths."
|
|
HAVE_X11='no'
|
|
HAVE_XVIDEO='no'
|
|
fi
|
|
|
|
if [ "$HAVE_UDEV" != "no" ]; then
|
|
check_pkgconf UDEV libudev
|
|
if [ "$HAVE_UDEV" = "no" ]; then
|
|
HAVE_UDEV=auto && check_lib UDEV "-ludev"
|
|
[ "$HAVE_UDEV" = "yes" ] && UDEV_LIBS=-ludev
|
|
fi
|
|
fi
|
|
|
|
check_header PARPORT linux/parport.h
|
|
check_header PARPORT linux/ppdev.h
|
|
|
|
check_lib STRL "$CLIB" strlcpy
|
|
check_lib STRCASESTR "$CLIB" strcasestr
|
|
check_lib MMAP "$CLIB" mmap
|
|
|
|
check_pkgconf PYTHON python3
|
|
|
|
check_macro NEON __ARM_NEON__
|
|
|
|
add_define_make OS "$OS"
|
|
|
|
# Creates config.mk and config.h.
|
|
add_define_make GLOBAL_CONFIG_DIR "$GLOBAL_CONFIG_DIR"
|
|
VARS="RGUI LAKKA GLUI XMB ALSA OSS OSS_BSD OSS_LIB AL RSOUND ROAR JACK COREAUDIO CORETEXT PULSE SDL SDL2 D3D9 DINPUT LIBUSB XINPUT DSOUND XAUDIO OPENGL EXYNOS DISPMANX SUNXI OMAP GLES GLES3 VG EGL KMS GBM DRM DYLIB GETOPT_LONG THREADS CG LIBXML2 ZLIB DYNAMIC FFMPEG AVCODEC AVFORMAT AVUTIL SWSCALE FREETYPE XKBCOMMON XVIDEO X11 XEXT XF86VM XINERAMA WAYLAND MALI_FBDEV VIVANTE_FBDEV NETWORKING NETPLAY NETWORK_CMD STDIN_CMD COMMAND SOCKET_LEGACY FBO STRL STRCASESTR MMAP PYTHON FFMPEG_ALLOC_CONTEXT3 FFMPEG_AVCODEC_OPEN2 FFMPEG_AVIO_OPEN FFMPEG_AVFORMAT_WRITE_HEADER FFMPEG_AVFORMAT_NEW_STREAM FFMPEG_AVCODEC_ENCODE_AUDIO2 FFMPEG_AVCODEC_ENCODE_VIDEO2 BSV_MOVIE VIDEOCORE NEON FLOATHARD FLOATSOFTFP UDEV V4L2 AV_CHANNEL_LAYOUT 7ZIP PARPORT COCOA AVFOUNDATION CORELOCATION IOHIDMANAGER LIBRETRODB"
|
|
create_config_make config.mk $VARS
|
|
create_config_header config.h $VARS
|