diff --git a/clang/lib/Headers/CMakeLists.txt b/clang/lib/Headers/CMakeLists.txt --- a/clang/lib/Headers/CMakeLists.txt +++ b/clang/lib/Headers/CMakeLists.txt @@ -1,19 +1,100 @@ -set(files - adxintrin.h - altivec.h - ammintrin.h - amxintrin.h +# core_files list contains the headers shared by all platforms. +# Please consider adding new platform specific headers +# to platform specific lists below. +set(core_files + builtins.h + float.h + inttypes.h + iso646.h + limits.h + module.modulemap + stdalign.h + stdarg.h + stdatomic.h + stdbool.h + stddef.h + __stddef_max_align_t.h + stdint.h + stdnoreturn.h + tgmath.h + unwind.h + varargs.h + ) + +set(arm_files arm_acle.h arm_cmse.h armintr.h arm64intr.h + ) + +set(cuda_files + __clang_cuda_builtin_vars.h + __clang_cuda_math.h + __clang_cuda_cmath.h + __clang_cuda_complex_builtins.h + __clang_cuda_device_functions.h + __clang_cuda_intrinsics.h + __clang_cuda_texture_intrinsics.h + __clang_cuda_libdevice_declares.h + __clang_cuda_math_forward_declares.h + __clang_cuda_runtime_wrapper.h + ) + +set(hexagon_files + hexagon_circ_brev_intrinsics.h + hexagon_protos.h + hexagon_types.h + hvx_hexagon_protos.h + ) + +set(hip_files + __clang_hip_libdevice_declares.h + __clang_hip_cmath.h + __clang_hip_math.h + __clang_hip_runtime_wrapper.h + ) + +set(mips_msa_files + msa.h + ) + +set(opencl_files + opencl-c.h + opencl-c-base.h + ) + +set(ppc_files + altivec.h + htmintrin.h + htmxlintrin.h + ) + +set(systemz_files + s390intrin.h + vecintrin.h + ) + +set(ve_files + velintrin.h + velintrin_gen.h + velintrin_approx.h + ) + +set(webassembly_files + wasm_simd128.h + ) + +set(x86_files +# Intrinsics + adxintrin.h + ammintrin.h + amxintrin.h avx2intrin.h avx512bf16intrin.h - avx512bwintrin.h avx512bitalgintrin.h - avx512vlbitalgintrin.h + avx512bwintrin.h avx512cdintrin.h - avx512vpopcntdqintrin.h avx512dqintrin.h avx512erintrin.h avx512fintrin.h @@ -21,86 +102,55 @@ avx512ifmaintrin.h avx512ifmavlintrin.h avx512pfintrin.h + avx512vbmi2intrin.h avx512vbmiintrin.h avx512vbmivlintrin.h - avx512vbmi2intrin.h - avx512vlvbmi2intrin.h avx512vlbf16intrin.h + avx512vlbitalgintrin.h avx512vlbwintrin.h avx512vlcdintrin.h avx512vldqintrin.h avx512vlfp16intrin.h avx512vlintrin.h - avx512vp2intersectintrin.h + avx512vlvbmi2intrin.h + avx512vlvnniintrin.h avx512vlvp2intersectintrin.h - avx512vpopcntdqvlintrin.h avx512vnniintrin.h - avx512vlvnniintrin.h + avx512vp2intersectintrin.h + avx512vpopcntdqintrin.h + avx512vpopcntdqvlintrin.h avxintrin.h avxvnniintrin.h bmi2intrin.h bmiintrin.h - builtins.h - __clang_cuda_builtin_vars.h - __clang_cuda_math.h - __clang_cuda_cmath.h - __clang_cuda_complex_builtins.h - __clang_cuda_device_functions.h - __clang_cuda_intrinsics.h - __clang_cuda_texture_intrinsics.h - __clang_cuda_libdevice_declares.h - __clang_cuda_math_forward_declares.h - __clang_cuda_runtime_wrapper.h - __clang_hip_libdevice_declares.h - __clang_hip_cmath.h - __clang_hip_math.h - __clang_hip_runtime_wrapper.h cetintrin.h - cet.h cldemoteintrin.h - clzerointrin.h - crc32intrin.h - cpuid.h clflushoptintrin.h clwbintrin.h + clzerointrin.h + crc32intrin.h emmintrin.h enqcmdintrin.h f16cintrin.h - float.h fma4intrin.h fmaintrin.h fxsrintrin.h gfniintrin.h - hexagon_circ_brev_intrinsics.h - hexagon_protos.h - hexagon_types.h - hvx_hexagon_protos.h hresetintrin.h - htmintrin.h - htmxlintrin.h ia32intrin.h immintrin.h - intrin.h - inttypes.h invpcidintrin.h - iso646.h keylockerintrin.h - limits.h lwpintrin.h lzcntintrin.h mm3dnow.h mmintrin.h - mm_malloc.h - module.modulemap movdirintrin.h - msa.h mwaitxintrin.h nmmintrin.h - opencl-c.h - opencl-c-base.h + pconfigintrin.h pkuintrin.h pmmintrin.h - pconfigintrin.h popcntintrin.h prfchwintrin.h ptwriteintrin.h @@ -108,33 +158,18 @@ rtmintrin.h serializeintrin.h sgxintrin.h - s390intrin.h shaintrin.h smmintrin.h - stdalign.h - stdarg.h - stdatomic.h - stdbool.h - stddef.h - __stddef_max_align_t.h - stdint.h - stdnoreturn.h tbmintrin.h - tgmath.h tmmintrin.h tsxldtrkintrin.h uintrintrin.h - unwind.h - vadefs.h vaesintrin.h - varargs.h - vecintrin.h vpclmulqdqintrin.h waitpkgintrin.h - wasm_simd128.h wbnoinvdintrin.h - wmmintrin.h __wmmintrin_aes.h + wmmintrin.h __wmmintrin_pclmul.h x86gprintrin.h x86intrin.h @@ -145,9 +180,35 @@ xsaveoptintrin.h xsavesintrin.h xtestintrin.h - velintrin.h - velintrin_gen.h - velintrin_approx.h +# others + cet.h + cpuid.h + ) + +set(windows_only_files + intrin.h + vadefs.h +) + +set(utility_files + mm_malloc.h +) + +set(files + ${core_files} + ${arm_files} + ${cuda_files} + ${hexagon_files} + ${hip_files} + ${mips_msa_files} + ${opencl_files} + ${ppc_files} + ${systemz_files} + ${ve_files} + ${x86_files} + ${webassembly_files} + ${windows_only_files} + ${utility_files} ) set(cuda_wrapper_files @@ -167,7 +228,6 @@ ppc_wrappers/bmiintrin.h ppc_wrappers/bmi2intrin.h ppc_wrappers/immintrin.h - ppc_wrappers/tmmintrin.h ppc_wrappers/x86intrin.h ppc_wrappers/x86gprintrin.h ) @@ -238,10 +298,44 @@ clang_generate_header(-gen-riscv-vector-header riscv_vector.td riscv_vector.h) endif() -add_custom_target(clang-resource-headers ALL DEPENDS ${out_files}) -set_target_properties(clang-resource-headers PROPERTIES - FOLDER "Misc" - RUNTIME_OUTPUT_DIRECTORY "${output_dir}") +set(arm_generated_files + # List is kept in the same order as these files are generated. + ${output_dir}/arm_neon.h + ${output_dir}/arm_fp16.h + ${output_dir}/arm_sve.h + ${output_dir}/arm_bf16.h + ${output_dir}/arm_mve.h + ${output_dir}/arm_cde.h + ${output_dir}/arm_neon_sve_bridge.h + ) + +set(riscv_generated_files + ${output_dir}/riscv_vector.h + ) + +function(add_header_target target_name) + add_custom_target(${target_name} ALL DEPENDS ${out_files}) + set_target_properties(${target_name} PROPERTIES + FOLDER "Misc" + RUNTIME_OUTPUT_DIRECTORY "${output_dir}") +endfunction() + +add_header_target("clang-resource-headers") + +# Architecture/platform specific targets +add_header_target("arm-resource-headers") +add_header_target("cuda-resource-headers") +add_header_target("hexagon-resource-headers") +add_header_target("hip-resource-headers") +add_header_target("mips-resource-headers") +add_header_target("opencl-resource-headers") +add_header_target("ppc-resource-headers") +add_header_target("riscv-resource-headers") +add_header_target("systemz-resource-headers") +add_header_target("ve-resource-headers") +add_header_target("webassembly-resource-headers") +add_header_target("windows-resource-headers") +add_header_target("x86-resource-headers") set(header_install_dir lib${LLVM_LIBDIR_SUFFIX}/clang/${CLANG_VERSION}/include) @@ -265,8 +359,141 @@ DESTINATION ${header_install_dir}/openmp_wrappers COMPONENT clang-resource-headers) +############################################################# +# Install rules for architecture/platform specific headers +# All the targets are subsets of the clang-resource-headers list. +install( + FILES ${core_files} ${arm_files} ${arm_generated_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT arm-resource-headers) + +install( + FILES ${cuda_wrapper_files} + DESTINATION ${header_install_dir}/cuda_wrappers + EXCLUDE_FROM_ALL + COMPONENT cuda-resource-headers) + +install( + FILES ${core_files} ${cuda_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT cuda-resource-headers) + +install( + FILES ${core_files} ${hexagon_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT hexagon-resource-headers) + +install( + FILES ${core_files} ${hip_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT hip-resource-headers) + +install( + FILES ${core_files} ${mips_msa_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT mips-resource-headers) + +install( + FILES ${core_files} ${opencl_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT opencl-resource-headers) + +install( + FILES ${ppc_wrapper_files} + DESTINATION ${header_install_dir}/ppc_wrappers + EXCLUDE_FROM_ALL + COMPONENT ppc-resource-headers) + +install( + FILES ${core_files} ${ppc_files} ${utility_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT ppc-resource-headers) + +install( + FILES ${core_files} ${riscv_generated_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT riscv-resource-headers) + +install( + FILES ${core_files} ${systemz_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT systemz-resource-headers) + +install( + FILES ${core_files} ${ve_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT ve-resource-headers) + +install( + FILES ${core_files} ${webassembly_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT webassembly-resource-headers) + +install( + FILES ${core_files} ${windows_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT windows-resource-headers) + +install( + FILES ${core_files} ${x86_files} ${utility_files} + DESTINATION ${header_install_dir} + EXCLUDE_FROM_ALL + COMPONENT x86-resource-headers) +############################################################# + if (NOT LLVM_ENABLE_IDE) add_llvm_install_targets(install-clang-resource-headers DEPENDS clang-resource-headers COMPONENT clang-resource-headers) + add_llvm_install_targets(install-arm-resource-headers + DEPENDS arm-resource-headers + COMPONENT arm-resource-headers) + add_llvm_install_targets(install-cuda-resource-headers + DEPENDS cuda-resource-headers + COMPONENT cuda-resource-headers) + add_llvm_install_targets(install-hexagon-resource-headers + DEPENDS hexagon-resource-headers + COMPONENT hexagon-resource-headers) + add_llvm_install_targets(install-hip-resource-headers + DEPENDS hip-resource-headers + COMPONENT hip-resource-headers) + add_llvm_install_targets(install-mips-resource-headers + DEPENDS mips-resource-headers + COMPONENT mips-resource-headers) + add_llvm_install_targets(install-opencl-resource-headers + DEPENDS opencl-resource-headers + COMPONENT opencl-resource-headers) + add_llvm_install_targets(install-ppc-resource-headers + DEPENDS ppc-resource-headers + COMPONENT ppc-resource-headers) + add_llvm_install_targets(install-riscv-resource-headers + DEPENDS riscv-resource-headers + COMPONENT riscv-resource-headers) + add_llvm_install_targets(install-systemz-resource-headers + DEPENDS systemz-resource-headers + COMPONENT systemz-resource-headers) + add_llvm_install_targets(install-ve-resource-headers + DEPENDS ve-resource-headers + COMPONENT ve-resource-headers) + add_llvm_install_targets(install-x86-resource-headers + DEPENDS x86-resource-headers + COMPONENT x86-resource-headers) + add_llvm_install_targets(install-webassembly-resource-headers + DEPENDS webassembly-resource-headers + COMPONENT webassembly-resource-headers) + add_llvm_install_targets(install-windows-resource-headers + DEPENDS window-resource-headers + COMPONENT windows-resource-headers) endif()