]> Gitweb @ Texas Instruments - Open Source Git Repositories - git.TI.com/gitweb - android/external-libkmsxx.git/blobdiff - CMakeLists.txt
draw_rect: support yuv modes
[android/external-libkmsxx.git] / CMakeLists.txt
index 630685287dab154eaf1879762588fa3bd102200e..57088bc5f78fd98a6605fb66332874a2f63b29de 100644 (file)
@@ -18,10 +18,16 @@ ENDIF()
 string(TOUPPER "${CMAKE_BUILD_TYPE}" U_CMAKE_BUILD_TYPE)
 
 option(BUILD_SHARED_LIBS "Build shared libs" FALSE)
+option(TREAT_WARNINGS_AS_ERRORS "Treat warnings as errors" FALSE)
 
 set(KMSXX_ENABLE_PYTHON ON CACHE BOOL "Enable Python wrappers")
+set(KMSXX_PYTHON_VERSION "python3;python2" CACHE STRING "Python pkgconfig package")
+
 set(KMSXX_ENABLE_KMSCUBE OFF CACHE BOOL "Enable kmscube")
 
+set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=c11 -Wall")
+set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wextra -Wno-unused-parameter")
+
 set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -Wall")
 set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wextra -Wno-unused-parameter")
 
@@ -32,8 +38,17 @@ if (CMAKE_COMPILER_IS_GNUCC)
     endif()
 endif()
 
+# HACK: cmake always adds "-rdynamic", this removes it
+SET(CMAKE_SHARED_LIBRARY_LINK_C_FLAGS "")
+SET(CMAKE_SHARED_LIBRARY_LINK_CXX_FLAGS "")
+
 set(CMAKE_POSITION_INDEPENDENT_CODE TRUE)
 
+if (TREAT_WARNINGS_AS_ERRORS)
+    set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Werror")
+    set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror")
+endif()
+
 # static link libc
 # set(CMAKE_EXE_LINKER_FLAGS "-static-libgcc -static-libstdc++")
 
@@ -41,6 +56,7 @@ check_lto()
 
 if (NOT ${U_CMAKE_BUILD_TYPE} MATCHES DEBUG)
     if (LTO_WORKS)
+        set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -flto")
         set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -flto")
         set(CMAKE_AR "${LTO_AR}")
         set(CMAKE_RANLIB "${LTO_RANLIB}")
@@ -50,6 +66,11 @@ endif()
 find_package(PkgConfig REQUIRED)
 pkg_check_modules(LIBDRM libdrm>=2.4.64 REQUIRED)
 
+pkg_check_modules(LIBDRM_OMAP libdrm_omap)
+if(LIBDRM_OMAP_FOUND)
+    add_definitions(-DHAS_LIBDRM_OMAP)
+endif()
+
 enable_testing()
 
 add_subdirectory(kms++)
@@ -63,3 +84,5 @@ endif()
 if(KMSXX_ENABLE_PYTHON)
         add_subdirectory(py)
 endif()
+
+add_custom_target(docs SOURCES "README.md")