blob: 6605b5b60483c574086a14d0faa211ec01bb0f1e [file] [log] [blame]
Oscar Fuentese1ad0872008-09-26 04:40:32 +00001# LLVM_TARGET_DEFINITIONS must contain the name of the .td file to process.
2# Extra parameters for `tblgen' may come after `ofn' parameter.
3# Adds the name of the generated file to TABLEGEN_OUTPUT.
4
5macro(tablegen ofn)
Oscar Fuentesd97ea302009-07-13 21:35:00 +00006 file(GLOB local_tds "*.td")
7 file(GLOB_RECURSE global_tds "${LLVM_MAIN_SRC_DIR}/include/llvm/*.td")
Douglas Gregoraf3f5442009-03-16 21:35:18 +00008
Douglas Gregorba6fc632010-06-17 15:17:07 +00009 if (IS_ABSOLUTE ${LLVM_TARGET_DEFINITIONS})
10 set(LLVM_TARGET_DEFINITIONS_ABSOLUTE ${LLVM_TARGET_DEFINITIONS})
11 else()
12 set(LLVM_TARGET_DEFINITIONS_ABSOLUTE
13 ${CMAKE_CURRENT_SOURCE_DIR}/${LLVM_TARGET_DEFINITIONS})
14 endif()
Oscar Fuentes8c0cd082010-10-22 17:37:42 +000015 add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${ofn}.tmp
Oscar Fuentes8a116e02010-10-22 16:20:10 +000016 # Generate tablegen output in a temporary file.
Oscar Fuentes99b94892009-06-11 04:16:10 +000017 COMMAND ${LLVM_TABLEGEN_EXE} ${ARGN} -I ${CMAKE_CURRENT_SOURCE_DIR}
Oscar Fuentesbeb7a052008-11-21 00:18:45 +000018 -I ${LLVM_MAIN_SRC_DIR}/lib/Target -I ${LLVM_MAIN_INCLUDE_DIR}
Douglas Gregorba6fc632010-06-17 15:17:07 +000019 ${LLVM_TARGET_DEFINITIONS_ABSOLUTE}
Oscar Fuentes8a116e02010-10-22 16:20:10 +000020 -o ${CMAKE_CURRENT_BINARY_DIR}/${ofn}.tmp
Oscar Fuentes5b30f0a2011-01-03 20:01:32 +000021 # The file in LLVM_TARGET_DEFINITIONS may be not in the current
22 # directory and local_tds may not contain it, so we must
23 # explicitly list it here:
Oscar Fuentesd538e242011-02-03 20:57:36 +000024 DEPENDS ${LLVM_TABLEGEN_EXE} ${local_tds} ${global_tds}
25 ${LLVM_TARGET_DEFINITIONS_ABSOLUTE}
Oscar Fuentes8c0cd082010-10-22 17:37:42 +000026 COMMENT "Building ${ofn}..."
27 )
28 add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${ofn}
Oscar Fuentes8a116e02010-10-22 16:20:10 +000029 # Only update the real output file if there are any differences.
30 # This prevents recompilation of all the files depending on it if there
31 # aren't any.
32 COMMAND ${CMAKE_COMMAND} -E copy_if_different
33 ${CMAKE_CURRENT_BINARY_DIR}/${ofn}.tmp
34 ${CMAKE_CURRENT_BINARY_DIR}/${ofn}
Oscar Fuentes8c0cd082010-10-22 17:37:42 +000035 DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${ofn}.tmp
36 COMMENT ""
Oscar Fuentese1ad0872008-09-26 04:40:32 +000037 )
Oscar Fuentesba6ac912011-02-04 03:47:50 +000038
39 # `make clean' must remove all those generated files:
40 set_property(DIRECTORY APPEND
41 PROPERTY ADDITIONAL_MAKE_CLEAN_FILES ${ofn}.tmp ${ofn})
42
Oscar Fuentese1ad0872008-09-26 04:40:32 +000043 set(TABLEGEN_OUTPUT ${TABLEGEN_OUTPUT} ${CMAKE_CURRENT_BINARY_DIR}/${ofn})
Douglas Gregor4b738932009-06-25 05:03:06 +000044 set_source_files_properties(${CMAKE_CURRENT_BINARY_DIR}/${ofn}
45 PROPERTIES GENERATED 1)
Oscar Fuentese1ad0872008-09-26 04:40:32 +000046endmacro(tablegen)
Oscar Fuentesddfb69c2011-07-25 14:11:55 +000047
48
49function(create_tablegenning_custom_target target)
50 # Creates the global target that runs the file-level dependencies
51 # for tablegenning.
52 if( TABLEGEN_OUTPUT )
53 add_custom_target(${target}Table_gen
54 DEPENDS ${TABLEGEN_OUTPUT})
55 add_dependencies(${target}Table_gen ${LLVM_COMMON_DEPENDS})
56 endif( TABLEGEN_OUTPUT )
57endfunction()
58
59function(add_tablegenning_dependency target)
60 # Makes the tablegenning step created with
61 # create_tablegenning_custom_target dependent on `target'.
62 if ( TABLEGEN_OUTPUT )
63 add_dependencies(${target} ${target}Table_gen)
64 set_target_properties(${target}Table_gen PROPERTIES FOLDER "Tablegenning")
65 endif (TABLEGEN_OUTPUT)
66endfunction()
67