X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=CMakeLists.txt;h=2072c703715d959407d318c2375df69433179fd1;hb=fd3b7b7df3d539d1244933d375a766d7a7fe6c91;hp=f3c89f1938fe59499e193df051a04352e76abb32;hpb=6326a0d5090110c334a3a554bfb10b37a6fe4709;p=oota-llvm.git diff --git a/CMakeLists.txt b/CMakeLists.txt index f3c89f1938f..2072c703715 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -38,6 +38,10 @@ set(LLVM_ALL_TARGETS XCore ) +# List of targets whose asmprinters need to be forced to link +# into executables on some platforms (i.e. Windows): +set(LLVM_ASMPRINTERS_FORCE_LINK X86 PowerPC) + if( MSVC ) set(LLVM_TARGETS_TO_BUILD X86 CACHE STRING "Semicolon-separated list of targets to build, or \"all\".") @@ -46,6 +50,8 @@ else( MSVC ) CACHE STRING "Semicolon-separated list of targets to build, or \"all\".") endif( MSVC ) +option(LLVM_ENABLE_THREADS "Use threads if available." ON) + if( LLVM_TARGETS_TO_BUILD STREQUAL "all" ) set( LLVM_TARGETS_TO_BUILD ${LLVM_ALL_TARGETS} ) endif() @@ -95,11 +101,20 @@ endif(WIN32) if( EXISTS ${LLVM_TOOLS_BINARY_DIR}/llvm-config ) set(HAVE_LLVM_CONFIG 1) endif( EXISTS ${LLVM_TOOLS_BINARY_DIR}/llvm-config ) -# find_file(HAVE_LLVM_CONFIG llvm-config ${LLVM_TOOLS_BINARY_DIR}) -# message(STATUS ${HAVE_LLVM_CONFIG}) include(config-ix) +option(LLVM_ENABLE_PIC "Build Position-Independent Code" OFF) + +if( LLVM_ENABLE_PIC ) + if( SUPPORTS_FPIC_FLAG ) + message(STATUS "Building with -fPIC") + add_definitions(-fPIC) + else( SUPPORTS_FPIC_FLAG ) + message(STATUS "Warning: -fPIC not supported.") + endif() +endif() + set( CMAKE_RUNTIME_OUTPUT_DIRECTORY ${LLVM_TOOLS_BINARY_DIR} ) set( CMAKE_LIBRARY_OUTPUT_DIRECTORY ${LLVM_BINARY_DIR}/lib ) set( CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${LLVM_BINARY_DIR}/lib ) @@ -114,14 +129,14 @@ set(LLVM_PLO_FLAGS "" CACHE if( CMAKE_SIZEOF_VOID_P EQUAL 8 AND NOT WIN32 ) # TODO: support other platforms and toolchains. - option(BUILD_32_BITS "Build 32 bits executables and libraries." OFF) - if( BUILD_32_BITS ) + option(LLVM_BUILD_32_BITS "Build 32 bits executables and libraries." OFF) + if( LLVM_BUILD_32_BITS ) message(STATUS "Building 32 bits executables and libraries.") add_definitions( -m32 ) - set( CMAKE_EXE_LINKER_FLAGS "-m32 ${CMAKE_EXE_LINKER_FLAGS}" ) - set( CMAKE_LINK_LIBRARY_FLAG "-m32 ${CMAKE_LINK_LIBRARY_FLAG}" ) + list(APPEND CMAKE_EXE_LINKER_FLAGS -m32) + list(APPEND CMAKE_SHARED_LINKER_FLAGS -m32) set( LLVM_PLO_FLAGS -melf_i386 ${LLVM_PLO_FLAGS} ) - endif( BUILD_32_BITS ) + endif( LLVM_BUILD_32_BITS ) endif( CMAKE_SIZEOF_VOID_P EQUAL 8 AND NOT WIN32 ) if( MSVC ) @@ -133,9 +148,6 @@ if( MSVC ) endif( MSVC ) include_directories( ${LLVM_BINARY_DIR}/include ${LLVM_MAIN_INCLUDE_DIR}) -#link_directories( d:/dev/lib ) - -#add_subdirectory(lib) include(AddLLVM) include(AddPartiallyLinkedObject) @@ -157,15 +169,7 @@ if( CMAKE_CROSSCOMPILING ) include( CrossCompileLLVM ) endif( CMAKE_CROSSCOMPILING ) -add_custom_command(OUTPUT ${llvm_builded_incs_dir}/Intrinsics.gen - COMMAND ${LLVM_TABLEGEN} -gen-intrinsic -I ${LLVM_MAIN_INCLUDE_DIR} ${LLVM_MAIN_INCLUDE_DIR}/llvm/Intrinsics.td -o ${llvm_builded_incs_dir}/Intrinsics.gen - DEPENDS tblgen - COMMENT "Building intrinsics.gen...") - -add_custom_target(intrinsics_gen ALL - DEPENDS ${llvm_builded_incs_dir}/Intrinsics.gen) - -set(LLVM_COMMON_DEPENDS ${LLVM_COMMON_DEPENDS} intrinsics_gen ) +add_subdirectory(include/llvm) add_subdirectory(lib/VMCore) add_subdirectory(lib/CodeGen) @@ -185,9 +189,9 @@ add_subdirectory(lib/Analysis/IPA) foreach(t ${LLVM_TARGETS_TO_BUILD}) message(STATUS "Targeting ${t}") add_subdirectory(lib/Target/${t}) - if( EXISTS ${CMAKE_SOURCE_DIR}/lib/Target/${t}/AsmPrinter/CMakeLists.txt ) + if( EXISTS ${LLVM_MAIN_SRC_DIR}/lib/Target/${t}/AsmPrinter/CMakeLists.txt ) add_subdirectory(lib/Target/${t}/AsmPrinter) - endif( EXISTS ${CMAKE_SOURCE_DIR}/lib/Target/${t}/AsmPrinter/CMakeLists.txt ) + endif( EXISTS ${LLVM_MAIN_SRC_DIR}/lib/Target/${t}/AsmPrinter/CMakeLists.txt ) endforeach(t) add_subdirectory(lib/ExecutionEngine)