diff options
| author | Peter Zotov <whitequark@whitequark.org> | 2014-12-01 19:50:23 +0000 |
|---|---|---|
| committer | Peter Zotov <whitequark@whitequark.org> | 2014-12-01 19:50:23 +0000 |
| commit | b20073c63ca7cd4c2f73f469bf7793ba0678fb07 (patch) | |
| tree | 3e15f61640de20fddc991b53b336c4f831197289 /llvm/bindings | |
| parent | 57148cbcbdad689080c2db7681b0e2bfc952d3d8 (diff) | |
| download | bcm5719-llvm-b20073c63ca7cd4c2f73f469bf7793ba0678fb07.tar.gz bcm5719-llvm-b20073c63ca7cd4c2f73f469bf7793ba0678fb07.zip | |
[OCaml] [cmake] Add CMake buildsystem for OCaml.
Closes PR15325.
llvm-svn: 223071
Diffstat (limited to 'llvm/bindings')
| -rw-r--r-- | llvm/bindings/ocaml/CMakeLists.txt | 11 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/all_backends/CMakeLists.txt | 5 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/analysis/CMakeLists.txt | 5 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/backends/CMakeLists.txt | 27 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/bitreader/CMakeLists.txt | 5 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/bitwriter/CMakeLists.txt | 5 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/executionengine/CMakeLists.txt | 6 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/irreader/CMakeLists.txt | 5 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/linker/CMakeLists.txt | 5 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/llvm/CMakeLists.txt | 11 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/target/CMakeLists.txt | 5 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/transforms/CMakeLists.txt | 4 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/transforms/ipo/CMakeLists.txt | 5 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/transforms/passmgr_builder/CMakeLists.txt | 5 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/transforms/scalar_opts/CMakeLists.txt | 5 | ||||
| -rw-r--r-- | llvm/bindings/ocaml/transforms/vectorize/CMakeLists.txt | 5 |
16 files changed, 114 insertions, 0 deletions
diff --git a/llvm/bindings/ocaml/CMakeLists.txt b/llvm/bindings/ocaml/CMakeLists.txt new file mode 100644 index 00000000000..20583682c3d --- /dev/null +++ b/llvm/bindings/ocaml/CMakeLists.txt @@ -0,0 +1,11 @@ +add_subdirectory(llvm) +add_subdirectory(all_backends) +add_subdirectory(analysis) +add_subdirectory(backends) +add_subdirectory(bitreader) +add_subdirectory(bitwriter) +add_subdirectory(irreader) +add_subdirectory(linker) +add_subdirectory(target) +add_subdirectory(transforms) +add_subdirectory(executionengine) diff --git a/llvm/bindings/ocaml/all_backends/CMakeLists.txt b/llvm/bindings/ocaml/all_backends/CMakeLists.txt new file mode 100644 index 00000000000..716a49cc328 --- /dev/null +++ b/llvm/bindings/ocaml/all_backends/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_all_backends + OCAML llvm_all_backends + OCAMLDEP llvm + C all_backends_ocaml + LLVM ${LLVM_TARGETS_TO_BUILD}) diff --git a/llvm/bindings/ocaml/analysis/CMakeLists.txt b/llvm/bindings/ocaml/analysis/CMakeLists.txt new file mode 100644 index 00000000000..f8ca84ddbe3 --- /dev/null +++ b/llvm/bindings/ocaml/analysis/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_analysis + OCAML llvm_analysis + OCAMLDEP llvm + C analysis_ocaml + LLVM analysis) diff --git a/llvm/bindings/ocaml/backends/CMakeLists.txt b/llvm/bindings/ocaml/backends/CMakeLists.txt new file mode 100644 index 00000000000..b660c1d66dd --- /dev/null +++ b/llvm/bindings/ocaml/backends/CMakeLists.txt @@ -0,0 +1,27 @@ +foreach(TARGET ${LLVM_TARGETS_TO_BUILD}) + set(OCAML_LLVM_TARGET ${TARGET}) + + foreach( ext ml mli ) + configure_file( + "${CMAKE_CURRENT_SOURCE_DIR}/llvm_backend.${ext}.in" + "${CMAKE_CURRENT_BINARY_DIR}/llvm_${TARGET}.${ext}") + endforeach() + + configure_file( + "${CMAKE_CURRENT_SOURCE_DIR}/backend_ocaml.c" + "${CMAKE_CURRENT_BINARY_DIR}/${TARGET}_ocaml.c") + + add_ocaml_library(llvm_${TARGET} + OCAML llvm_${TARGET} + C ${TARGET}_ocaml + CFLAGS -DTARGET=${TARGET} + LLVM ${TARGET} + NOCOPY) + + configure_file( + "${CMAKE_CURRENT_SOURCE_DIR}/META.llvm_backend.in" + "${LLVM_LIBRARY_OUTPUT_INTDIR}/ocaml/META.llvm_${TARGET}") + + install(FILES "${LLVM_LIBRARY_OUTPUT_INTDIR}/ocaml/META.llvm_${TARGET}" + DESTINATION lib/ocaml) +endforeach() diff --git a/llvm/bindings/ocaml/bitreader/CMakeLists.txt b/llvm/bindings/ocaml/bitreader/CMakeLists.txt new file mode 100644 index 00000000000..8d1610320e0 --- /dev/null +++ b/llvm/bindings/ocaml/bitreader/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_bitreader + OCAML llvm_bitreader + OCAMLDEP llvm + C bitreader_ocaml + LLVM bitreader) diff --git a/llvm/bindings/ocaml/bitwriter/CMakeLists.txt b/llvm/bindings/ocaml/bitwriter/CMakeLists.txt new file mode 100644 index 00000000000..5a14498cb07 --- /dev/null +++ b/llvm/bindings/ocaml/bitwriter/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_bitwriter + OCAML llvm_bitwriter + OCAMLDEP llvm + C bitwriter_ocaml + LLVM bitwriter) diff --git a/llvm/bindings/ocaml/executionengine/CMakeLists.txt b/llvm/bindings/ocaml/executionengine/CMakeLists.txt new file mode 100644 index 00000000000..ae9af088c02 --- /dev/null +++ b/llvm/bindings/ocaml/executionengine/CMakeLists.txt @@ -0,0 +1,6 @@ +add_ocaml_library(llvm_executionengine + OCAML llvm_executionengine + OCAMLDEP llvm llvm_target + C executionengine_ocaml + LLVM executionengine mcjit native + PKG ctypes) diff --git a/llvm/bindings/ocaml/irreader/CMakeLists.txt b/llvm/bindings/ocaml/irreader/CMakeLists.txt new file mode 100644 index 00000000000..87d269b48c7 --- /dev/null +++ b/llvm/bindings/ocaml/irreader/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_irreader + OCAML llvm_irreader + OCAMLDEP llvm + C irreader_ocaml + LLVM irreader) diff --git a/llvm/bindings/ocaml/linker/CMakeLists.txt b/llvm/bindings/ocaml/linker/CMakeLists.txt new file mode 100644 index 00000000000..b6bc8ac1e83 --- /dev/null +++ b/llvm/bindings/ocaml/linker/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_linker + OCAML llvm_linker + OCAMLDEP llvm + C linker_ocaml + LLVM linker) diff --git a/llvm/bindings/ocaml/llvm/CMakeLists.txt b/llvm/bindings/ocaml/llvm/CMakeLists.txt new file mode 100644 index 00000000000..0d0fe3bd083 --- /dev/null +++ b/llvm/bindings/ocaml/llvm/CMakeLists.txt @@ -0,0 +1,11 @@ +add_ocaml_library(llvm + OCAML llvm + C llvm_ocaml + LLVM core transformutils support) + +configure_file( + "${CMAKE_CURRENT_SOURCE_DIR}/META.llvm.in" + "${LLVM_LIBRARY_OUTPUT_INTDIR}/ocaml/META.llvm") + +install(FILES "${LLVM_LIBRARY_OUTPUT_INTDIR}/ocaml/META.llvm" + DESTINATION lib/ocaml) diff --git a/llvm/bindings/ocaml/target/CMakeLists.txt b/llvm/bindings/ocaml/target/CMakeLists.txt new file mode 100644 index 00000000000..adee0fcec65 --- /dev/null +++ b/llvm/bindings/ocaml/target/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_target + OCAML llvm_target + OCAMLDEP llvm + C target_ocaml + LLVM target) diff --git a/llvm/bindings/ocaml/transforms/CMakeLists.txt b/llvm/bindings/ocaml/transforms/CMakeLists.txt new file mode 100644 index 00000000000..8693ffb6ae2 --- /dev/null +++ b/llvm/bindings/ocaml/transforms/CMakeLists.txt @@ -0,0 +1,4 @@ +add_subdirectory(ipo) +add_subdirectory(passmgr_builder) +add_subdirectory(scalar_opts) +add_subdirectory(vectorize) diff --git a/llvm/bindings/ocaml/transforms/ipo/CMakeLists.txt b/llvm/bindings/ocaml/transforms/ipo/CMakeLists.txt new file mode 100644 index 00000000000..4b8784fad67 --- /dev/null +++ b/llvm/bindings/ocaml/transforms/ipo/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_ipo + OCAML llvm_ipo + OCAMLDEP llvm + C ipo_ocaml + LLVM ipo) diff --git a/llvm/bindings/ocaml/transforms/passmgr_builder/CMakeLists.txt b/llvm/bindings/ocaml/transforms/passmgr_builder/CMakeLists.txt new file mode 100644 index 00000000000..b012863d8ec --- /dev/null +++ b/llvm/bindings/ocaml/transforms/passmgr_builder/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_passmgr_builder + OCAML llvm_passmgr_builder + OCAMLDEP llvm + C passmgr_builder_ocaml + LLVM ipo) diff --git a/llvm/bindings/ocaml/transforms/scalar_opts/CMakeLists.txt b/llvm/bindings/ocaml/transforms/scalar_opts/CMakeLists.txt new file mode 100644 index 00000000000..98c7c6861d2 --- /dev/null +++ b/llvm/bindings/ocaml/transforms/scalar_opts/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_scalar_opts + OCAML llvm_scalar_opts + OCAMLDEP llvm + C scalar_opts_ocaml + LLVM scalaropts) diff --git a/llvm/bindings/ocaml/transforms/vectorize/CMakeLists.txt b/llvm/bindings/ocaml/transforms/vectorize/CMakeLists.txt new file mode 100644 index 00000000000..af0ffce563f --- /dev/null +++ b/llvm/bindings/ocaml/transforms/vectorize/CMakeLists.txt @@ -0,0 +1,5 @@ +add_ocaml_library(llvm_vectorize + OCAML llvm_vectorize + OCAMLDEP llvm + C vectorize_ocaml + LLVM vectorize) |

