diff --git a/CMakeLists.txt b/CMakeLists.txt index a02270e7..dbb48953 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -40,6 +40,7 @@ if(SUPPORTS_WAYLAND) endif() if((LINUX OR FREEBSD) OR ANDROID) option(USE_EGL "Support EGL OpenGL context creation" ON) + option(USE_MALI "Link with libmali for EGL support" OFF) endif() if((LINUX OR FREEBSD) AND NOT ANDROID) option(USE_DRMKMS "Support DRM/KMS OpenGL contexts" OFF) @@ -232,7 +233,7 @@ elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "x86" OR ${CMAKE_SYSTEM_PROCESSOR} STR elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "aarch64" OR ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "arm64") set(CPU_ARCH "aarch64") elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "arm" OR ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "armv7-a" OR - ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "armv7l") + ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "armv7l" OR ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "armv8l") set(CPU_ARCH "aarch32") if(ANDROID) # Force ARM mode, since apparently ANDROID_ARM_MODE isn't working.. @@ -240,8 +241,13 @@ elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "arm" OR ${CMAKE_SYSTEM_PROCESSOR} STR set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -marm") else() # Enable NEON. - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -marm -march=armv7-a") - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -marm -march=armv7-a") + if(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "armv8l") + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -marm -mtune=cortex-a72") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -marm -mtune=cortex-a72") + else() + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -marm -march=armv7-a") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -marm -march=armv7-a") + endif() endif() else() message(FATAL_ERROR "Unknown system processor: " ${CMAKE_SYSTEM_PROCESSOR}) diff -u -r /home/romain/duckstation/CMakeModules/FindEGL.cmake ./CMakeModules/FindEGL.cmake --- /home/romain/duckstation/CMakeModules/FindEGL.cmake 2021-02-13 00:29:48.693304818 +0100 +++ ./CMakeModules/FindEGL.cmake 2021-02-13 00:45:35.564462969 +0100 @@ -86,6 +86,17 @@ ${PKG_EGL_LIBRARY_DIRS} ) +if(USE_MALI) +pkg_check_modules(PKG_MALI QUIET mali) +find_library(MALI_LIBRARY + NAMES + mali + HINTS + ${PKG_MALI_LIBRARY_DIRS} +) +endif() + + # NB: We do *not* use the version information from pkg-config, as that # is the implementation version (eg: the Mesa version) if(EGL_INCLUDE_DIR) @@ -117,7 +128,11 @@ cmake_push_check_state(RESET) list(APPEND CMAKE_REQUIRED_LIBRARIES "${EGL_LIBRARY}") +if(USE_MALI) +list(APPEND CMAKE_REQUIRED_LIBRARIES "${MALI_LIBRARY}") +endif() list(APPEND CMAKE_REQUIRED_INCLUDES "${EGL_INCLUDE_DIR}") +list(APPEND CMAKE_REQUIRED_DEFINITIONS "-DEGL_NO_X11 -DUSE_X11=NO") check_cxx_source_compiles(" #include @@ -161,7 +176,11 @@ mark_as_advanced(EGL_LIBRARY EGL_INCLUDE_DIR HAVE_EGL) # compatibility variables +if (USE_MALI) +set(EGL_LIBRARIES ${EGL_LIBRARY} ${MALI_LIBRARY}) +else() set(EGL_LIBRARIES ${EGL_LIBRARY}) +endif() set(EGL_INCLUDE_DIRS ${EGL_INCLUDE_DIR}) set(EGL_VERSION_STRING ${EGL_VERSION}) Seulement dans ./CMakeModules: FindEGL.cmake.orig diff -u -r /home/romain/duckstation/dep/glad/CMakeLists.txt ./dep/glad/CMakeLists.txt --- /home/romain/duckstation/dep/glad/CMakeLists.txt 2021-02-13 00:29:48.765302377 +0100 +++ ./dep/glad/CMakeLists.txt 2021-02-13 00:42:20.848512028 +0100 @@ -17,8 +17,9 @@ target_sources(glad PRIVATE src/glad_wgl.c) else() if(USE_EGL) + target_compile_definitions(glad PRIVATE -DEGL_NO_X11) target_sources(glad PRIVATE src/glad_egl.c) - target_link_libraries(glad PRIVATE EGL::EGL) + target_link_libraries(glad PRIVATE EGL) endif() if(USE_X11) target_sources(glad PRIVATE src/glad_glx.c) diff -u -r /home/romain/duckstation/src/common/CMakeLists.txt ./src/common/CMakeLists.txt --- /home/romain/duckstation/src/common/CMakeLists.txt 2021-02-13 00:29:48.885298307 +0100 +++ ./src/common/CMakeLists.txt 2021-02-13 00:42:20.848512028 +0100 @@ -175,12 +175,13 @@ ) endif() if(USE_DRMKMS) + target_compile_definitions(common PRIVATE "-DEGL_NO_X11=1") target_compile_definitions(common PRIVATE "-DUSE_GBM=1") target_sources(common PRIVATE gl/context_egl_gbm.cpp gl/context_egl_gbm.h ) - target_link_libraries(common PUBLIC GBM::GBM) + target_link_libraries(common PUBLIC gbm EGL) endif() endif() diff -u -r /home/romain/duckstation/src/duckstation-nogui/CMakeLists.txt ./src/duckstation-nogui/CMakeLists.txt --- /home/romain/duckstation/src/duckstation-nogui/CMakeLists.txt 2021-02-13 00:29:48.901297765 +0100 +++ ./src/duckstation-nogui/CMakeLists.txt 2021-02-13 00:56:19.913224314 +0100 @@ -29,6 +29,10 @@ target_compile_definitions(duckstation-nogui PRIVATE "-DUSE_LIBEVDEV=1") target_include_directories(duckstation-nogui PRIVATE ${LIBEVDEV_INCLUDE_DIRS}) target_link_libraries(duckstation-nogui PRIVATE ${LIBEVDEV_LIBRARIES}) +if (USE_MALI) + target_link_libraries(duckstation-nogui PRIVATE ${MALI_LIBRARY}) +endif() + endif() if(WIN32)