[libc-commits] [libc] [libc] newheadergen: configured cmake (PR #98828)
via libc-commits
libc-commits at lists.llvm.org
Tue Jul 16 14:53:28 PDT 2024
https://github.com/RoseZhang03 updated https://github.com/llvm/llvm-project/pull/98828
>From d13a098ad71ecc7f269ac8ee94a5d69b98baba29 Mon Sep 17 00:00:00 2001
From: Aaryan Shukla <aaryanshukla at google.com>
Date: Sun, 14 Jul 2024 18:20:08 +0000
Subject: [PATCH 01/17] [libc] newheadergen: configured cmake
- all headers in the build system are generated by newheadergen
- tested on gpu-build
---
libc/cmake/modules/LLVMLibCHeaderRules.cmake | 131 ++++++++++++++--
libc/include/CMakeLists.txt | 155 ++++++++++++-------
2 files changed, 217 insertions(+), 69 deletions(-)
diff --git a/libc/cmake/modules/LLVMLibCHeaderRules.cmake b/libc/cmake/modules/LLVMLibCHeaderRules.cmake
index 7fc6860f23eb2..1bcca5f19577c 100644
--- a/libc/cmake/modules/LLVMLibCHeaderRules.cmake
+++ b/libc/cmake/modules/LLVMLibCHeaderRules.cmake
@@ -66,7 +66,106 @@ function(add_header target_name)
)
endfunction(add_header)
-# A rule for generated header file targets.
+function(add_gen_header2 target_name)
+ cmake_parse_arguments(
+ "ADD_GEN_HDR2"
+ "PUBLIC" # No optional arguments
+ "YAML_FILE;DEF_FILE;GEN_HDR" # Single value arguments
+ "DEPENDS" # Multi value arguments
+ ${ARGN}
+ )
+ get_fq_target_name(${target_name} fq_target_name)
+ if(NOT LLVM_LIBC_FULL_BUILD)
+ add_library(${fq_target_name} INTERFACE)
+ return()
+ endif()
+ if(NOT ADD_GEN_HDR2_DEF_FILE)
+ mesage(FATAL_ERROR "`add_gen_hdr2` rule requires DEF_FILE to be specified.")
+ endif()
+ if(NOT ADD_GEN_HDR2_GEN_HDR)
+ message(FATAL_ERROR "`add_gen_hdr2` rule requires GEN_HDR to be specified.")
+ endif()
+ if(NOT ADD_GEN_HDR2_YAML_FILE)
+ message(FATAL_ERROR "`add_gen_hdr2` rule requires YAML_FILE to be specified.")
+ endif()
+
+ set(absolute_path ${CMAKE_CURRENT_SOURCE_DIR}/${ADD_GEN_HDR2_GEN_HDR})
+ file(RELATIVE_PATH relative_path ${LIBC_INCLUDE_SOURCE_DIR} ${absolute_path})
+ set(out_file ${LIBC_INCLUDE_DIR}/${relative_path})
+ set(yaml_file ${CMAKE_SOURCE_DIR}/${ADD_GEN_HDR2_YAML_FILE})
+ set(def_file ${CMAKE_CURRENT_SOURCE_DIR}/${ADD_GEN_HDR2_DEF_FILE})
+
+ set(fq_data_files "")
+ if(ADD_GEN_HDR2_DATA_FILES)
+ foreach(data_file IN 2LISTS ADD_GEN_HDR2_DATA_FILES)
+ list(APPEND fq_data_files "${CMAKE_CURRENT_SOURCE_DIR}/${data_file}")
+ endforeach(data_file)
+ endif()
+
+ set(entry_points "${TARGET_ENTRYPOINT_NAME_LIST}")
+ list(TRANSFORM entry_points PREPEND "--e=")
+
+ add_custom_command(
+ OUTPUT ${out_file}
+ COMMAND ${Python3_EXECUTABLE} ${LIBC_SOURCE_DIR}/newhdrgen/yaml_to_classes.py
+ ${yaml_file}
+ --h_def_file ${def_file}
+ ${entry_points}
+ --output_dir ${out_file}
+ DEPENDS ${yaml_file} ${def_file} ${fq_data_files}
+ COMMENT "Generating header ${ADD_GEN_HDR2_GE2N_HDR} from ${yaml_file} and ${def_file}"
+ )
+ if(LIBC_TARGET_OS_IS_GPU)
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls)
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls/gpu)
+ set(decl_out_file ${LIBC_INCLUDE_DIR}/llvm-libc-decls/${relative_path})
+ add_custom_command(
+ OUTPUT ${decl_out_file}
+ COMMAND ${Python3_EXECUTABLE} ${LIBC_SOURCE_DIR}/newhdrgen/yaml_to_classes.py
+ ${yaml_file}
+ --export-decls
+ ${entry_points}
+ --output_dir ${decl_out_file}
+ WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
+ DEPENDS ${yaml_file} ${fq_data_files}
+ )
+ endif()
+ 2
+ if(ADD_GEN_HDR2_DEPENDS)
+ get_fq_deps_list(f2q_deps_list ${ADD_GEN_HDR2_DEPENDS})
+ # Dependencies of a add_header target can only be another add_gen_header target
+ # or an add_header target.
+ foreach(dep IN LISTS fq_deps_list)
+ get_target_property(header_file ${dep} HEADER_FILE_PATH)
+ if(NOT header_file)
+ message(FATAL_ERROR "Invalid dependency '${dep}' for '${fq_target_name}'.")
+ endif()
+ endforeach()
+ endif()
+ set(generated_hdr_target ${fq_target_name}.__generated_hdr__)
+ add_custom_target(
+ ${generated_hdr_target}
+ DEPENDS ${out_file} ${fq_deps_list} ${decl_out_file}
+ )
+
+ add_header_library(
+ ${target_name}
+ HDRS
+ ${out_file}
+ )
+
+ add_dependencies(${fq_target_name} ${generated_hdr_target})
+
+ set_target_properties(
+ ${fq_target_name}
+ PROPERTIES
+ HEADER_FILE_PATH ${out_file}
+ DEPS "${fq_deps_list}"
+ )
+
+
+endfunction(add_gen_header2)
+
# Usage:
# add_gen_header(
# <target name>
@@ -140,22 +239,22 @@ function(add_gen_header target_name)
)
if(LIBC_TARGET_OS_IS_GPU)
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls)
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls/gpu)
- set(decl_out_file ${LIBC_INCLUDE_DIR}/llvm-libc-decls/${relative_path})
- add_custom_command(
- OUTPUT ${decl_out_file}
- COMMAND ${hdrgen_exe} -o ${decl_out_file}
- --header ${ADD_GEN_HDR_GEN_HDR} --def ${in_file} --export-decls
- ${replacement_params} -I ${LIBC_SOURCE_DIR} ${ENTRYPOINT_NAME_LIST_ARG}
- ${LIBC_SOURCE_DIR}/config/${LIBC_TARGET_OS}/api.td
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls)
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls/gpu)
+ set(decl_out_file ${LIBC_INCLUDE_DIR}/llvm-libc-decls/${relative_path})
+ add_custom_command(
+ OUTPUT ${decl_out_file}
+ COMMAND ${hdrgen_exe} -o ${decl_out_file}
+ --header ${ADD_GEN_HDR_GEN_HDR} --def ${in_file} --export-decls
+ ${replacement_params} -I ${LIBC_SOURCE_DIR} ${ENTRYPOINT_NAME_LIST_ARG}
+ ${LIBC_SOURCE_DIR}/config/${LIBC_TARGET_OS}/api.td
- WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
- DEPENDS ${in_file} ${fq_data_files} ${td_includes}
- ${LIBC_SOURCE_DIR}/config/${LIBC_TARGET_OS}/api.td
- ${hdrgen_deps}
- )
- endif()
+ WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
+ DEPENDS ${in_file} ${fq_data_files} ${td_includes}
+ ${LIBC_SOURCE_DIR}/config/${LIBC_TARGET_OS}/api.td
+ ${hdrgen_deps}
+ )
+endif()
if(ADD_GEN_HDR_DEPENDS)
get_fq_deps_list(fq_deps_list ${ADD_GEN_HDR_DEPENDS})
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index 2cf7206f3a625..8e9942fac69e1 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -17,16 +17,18 @@ add_header(
__llvm-libc-common.h
)
-add_gen_header(
+add_gen_header2(
ctype
+ YAML_FILE ../libc/newhdrgen/yaml/ctype.yaml
DEF_FILE ctype.h.def
GEN_HDR ctype.h
DEPENDS
.llvm_libc_common_h
)
-add_gen_header(
+add_gen_header2(
dirent
+ YAML_FILE ../libc/newhdrgen/yaml/dirent.yaml
DEF_FILE dirent.h.def
GEN_HDR dirent.h
DEPENDS
@@ -36,8 +38,9 @@ add_gen_header(
.llvm-libc-types.struct_dirent
)
-add_gen_header(
+add_gen_header2(
fcntl
+ YAML_FILE ../libc/newhdrgen/yaml/fcntl.yaml
DEF_FILE fcntl.h.def
GEN_HDR fcntl.h
DEPENDS
@@ -51,8 +54,9 @@ add_gen_header(
.llvm_libc_common_h
)
-add_gen_header(
+add_gen_header2(
dlfcn
+ YAML_FILE ../libc/newhdrgen/yaml/dlfcn.yaml
DEF_FILE dlfcn.h.def
GEN_HDR dlfcn.h
DEPENDS
@@ -60,8 +64,9 @@ add_gen_header(
.llvm_libc_common_h
)
-add_gen_header(
+add_gen_header2(
features
+ YAML_FILE ../libc/newhdrgen/yaml/features.yaml
DEF_FILE features.h.def
GEN_HDR features.h
DEPENDS
@@ -69,8 +74,9 @@ add_gen_header(
.llvm-libc-macros.features_macros
)
-add_gen_header(
+add_gen_header2(
fenv
+ YAML_FILE ../libc/newhdrgen/yaml/fenv.yaml
DEF_FILE fenv.h.def
GEN_HDR fenv.h
DEPENDS
@@ -80,8 +86,9 @@ add_gen_header(
.llvm-libc-types.fexcept_t
)
-add_gen_header(
+add_gen_header2(
inttypes
+ YAML_FILE ../libc/newhdrgen/yaml/inttypes.yaml
DEF_FILE inttypes.h.def
GEN_HDR inttypes.h
DEPENDS
@@ -90,46 +97,50 @@ add_gen_header(
.llvm-libc-macros.inttypes_macros
)
-add_gen_header(
+add_gen_header2(
float
+ YAML_FILE ../libc/newhdrgen/yaml/float.yaml
DEF_FILE float.h.def
GEN_HDR float.h
DEPENDS
.llvm-libc-macros.float_macros
)
-add_gen_header(
+add_gen_header2(
stdint
+ YAML_FILE ../libc/newhdrgen/yaml/stdint.yaml
DEF_FILE stdint.h.def
GEN_HDR stdint.h
DEPENDS
.llvm-libc-macros.stdint_macros
)
-add_gen_header(
+add_gen_header2(
limits
+ YAML_FILE ../libc/newhdrgen/yaml/limits.yaml
DEF_FILE limits.h.def
GEN_HDR limits.h
DEPENDS
.llvm-libc-macros.limits_macros
)
-add_gen_header(
+add_gen_header2(
math
+ YAML_FILE ../libc/newhdrgen/yaml/math.yaml
DEF_FILE math.h.def
GEN_HDR math.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.float16_macros
.llvm-libc-macros.math_macros
- .llvm-libc-macros.math_function_macros
.llvm-libc-types.double_t
.llvm-libc-types.float_t
.llvm-libc-types.float128
)
-add_gen_header(
+add_gen_header2(
stdfix
+ YAML_FILE ../libc/newhdrgen/yaml/stdfix.yaml
DEF_FILE stdfix.h.def
GEN_HDR stdfix.h
DEPENDS
@@ -139,15 +150,16 @@ add_gen_header(
# TODO: This should be conditional on POSIX networking being included.
file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/arpa)
-add_gen_header(
+add_gen_header2(
arpa_inet
+ YAML_FILE ../libc/newhdrgen/yaml/arpa_inet.yaml
DEF_FILE arpa/inet.h.def
GEN_HDR arpa/inet.h
DEPENDS
.llvm_libc_common_h
)
-add_gen_header(
+add_gen_header2(
assert
DEF_FILE assert.h.def
GEN_HDR assert.h
@@ -156,8 +168,9 @@ add_gen_header(
.llvm-libc-macros.assert_macros
)
-add_gen_header(
+add_gen_header2(
setjmp
+ YAML_FILE ../libc/newhdrgen/yaml/setjmp.yaml
DEF_FILE setjmp.h.def
GEN_HDR setjmp.h
DEPENDS
@@ -165,8 +178,9 @@ add_gen_header(
.llvm-libc-types.jmp_buf
)
-add_gen_header(
+add_gen_header2(
string
+ YAML_FILE ../libc/newhdrgen/yaml/string.yaml
DEF_FILE string.h.def
GEN_HDR string.h
DEPENDS
@@ -175,8 +189,9 @@ add_gen_header(
.llvm-libc-types.size_t
)
-add_gen_header(
+add_gen_header2(
strings
+ YAML_FILE ../libc/newhdrgen/yaml/strings.yaml
DEF_FILE strings.h.def
GEN_HDR strings.h
DEPENDS
@@ -184,8 +199,9 @@ add_gen_header(
.llvm-libc-types.size_t
)
-add_gen_header(
+add_gen_header2(
search
+ YAML_FILE ../libc/newhdrgen/yaml/search.yaml
DEF_FILE search.h.def
GEN_HDR search.h
DEPENDS
@@ -196,8 +212,9 @@ add_gen_header(
.llvm-libc-types.size_t
)
-add_gen_header(
+add_gen_header2(
time
+ YAML_FILE ../libc/newhdrgen/yaml/time.yaml
DEF_FILE time.h.def
GEN_HDR time.h
DEPENDS
@@ -211,8 +228,9 @@ add_gen_header(
.llvm-libc-types.clockid_t
)
-add_gen_header(
+add_gen_header2(
threads
+ YAML_FILE ../libc/newhdrgen/yaml/threads.yaml
DEF_FILE threads.h.def
GEN_HDR threads.h
DEPENDS
@@ -227,8 +245,9 @@ add_gen_header(
.llvm-libc-types.tss_dtor_t
)
-add_gen_header(
+add_gen_header2(
errno
+ YAML_FILE ../libc/newhdrgen/yaml/errno.yaml
DEF_FILE errno.h.def
GEN_HDR errno.h
DEPENDS
@@ -236,8 +255,9 @@ add_gen_header(
.llvm-libc-macros.error_number_macros
)
-add_gen_header(
+add_gen_header2(
signal
+ YAML_FILE ../libc/newhdrgen/yaml/signal.yaml
DEF_FILE signal.h.def
GEN_HDR signal.h
DEPENDS
@@ -251,8 +271,9 @@ add_gen_header(
.llvm-libc-types.pid_t
)
-add_gen_header(
+add_gen_header2(
stdbit
+ YAML_FILE ../libc/newhdrgen/yaml/stdbit.yaml
DEF_FILE stdbit.h.def
GEN_HDR stdbit.h
DEPENDS
@@ -260,8 +281,9 @@ add_gen_header(
.llvm-libc-macros.stdbit_macros
)
-add_gen_header(
+add_gen_header2(
stdckdint
+ YAML_FILE ../libc/newhdrgen/yaml/stdckdint.yaml
DEF_FILE stdckdint.h.def
GEN_HDR stdckdint.h
DEPENDS
@@ -269,8 +291,9 @@ add_gen_header(
.llvm-libc-macros.stdckdint_macros
)
-add_gen_header(
+add_gen_header2(
stdio
+ YAML_FILE ../libc/newhdrgen/yaml/stdio.yaml
DEF_FILE stdio.h.def
GEN_HDR stdio.h
DEPENDS
@@ -284,8 +307,9 @@ add_gen_header(
.llvm_libc_common_h
)
-add_gen_header(
+add_gen_header2(
stdlib
+ YAML_FILE ../libc/newhdrgen/yaml/stdlib.yaml
DEF_FILE stdlib.h.def
GEN_HDR stdlib.h
DEPENDS
@@ -301,8 +325,9 @@ add_gen_header(
.llvm-libc-types.__atexithandler_t
)
-add_gen_header(
+add_gen_header2(
unistd
+ YAML_FILE ../libc/newhdrgen/yaml/unistd.yaml
DEF_FILE unistd.h.def
GEN_HDR unistd.h
DEPENDS
@@ -319,8 +344,9 @@ add_gen_header(
.llvm-libc-types.__getoptargv_t
)
-add_gen_header(
+add_gen_header2(
pthread
+ YAML_FILE ../libc/newhdrgen/yaml/pthread.yaml
DEF_FILE pthread.h.def
GEN_HDR pthread.h
DEPENDS
@@ -340,8 +366,9 @@ add_gen_header(
.llvm-libc-types.pthread_t
)
-add_gen_header(
+add_gen_header2(
sched
+ YAML_FILE ../libc/newhdrgen/yaml/sched.yaml
DEF_FILE sched.h.def
GEN_HDR sched.h
DEPENDS
@@ -356,8 +383,9 @@ add_gen_header(
.llvm-libc-types.struct_timespec
)
-add_gen_header(
+add_gen_header2(
spawn
+ YAML_FILE ../libc/newhdrgen/yaml/spawn.yaml
DEF_FILE spawn.h.def
GEN_HDR spawn.h
DEPENDS
@@ -373,8 +401,9 @@ add_gen_header(
# them.
file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/sys)
-add_gen_header(
+add_gen_header2(
sys_auxv
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_auxv.yaml
DEF_FILE sys/auxv.h.def
GEN_HDR sys/auxv.h
DEPENDS
@@ -382,8 +411,9 @@ add_gen_header(
.llvm-libc-macros.sys_auxv_macros
)
-add_gen_header(
+add_gen_header2(
sys_epoll
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_epoll.yaml
DEF_FILE sys/epoll.h.def
GEN_HDR sys/epoll.h
DEPENDS
@@ -394,8 +424,9 @@ add_gen_header(
.llvm-libc-macros.sys_epoll_macros
)
-add_gen_header(
+add_gen_header2(
sys_ioctl
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_ioctl.yaml
DEF_FILE sys/ioctl.h.def
GEN_HDR sys/ioctl.h
DEPENDS
@@ -403,8 +434,9 @@ add_gen_header(
.llvm-libc-macros.sys_ioctl_macros
)
-add_gen_header(
+add_gen_header2(
sys_mman
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_mman.yaml
DEF_FILE sys/mman.h.def
GEN_HDR sys/mman.h
DEPENDS
@@ -415,8 +447,9 @@ add_gen_header(
.llvm-libc-types.ssize_t
)
-add_gen_header(
+add_gen_header2(
sys_prctl
+ YAML_FILE ../libc/newhdrgen/yaml/sys_prctl.yaml
DEF_FILE sys/prctl.h.def
GEN_HDR sys/prctl.h
DEPENDS
@@ -431,8 +464,9 @@ add_header(
.llvm-libc-macros.sys_queue_macros
)
-add_gen_header(
+add_gen_header2(
sys_random
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_random.yaml
DEF_FILE sys/random.h.def
GEN_HDR sys/random.h
DEPENDS
@@ -442,8 +476,9 @@ add_gen_header(
.llvm-libc-types.ssize_t
)
-add_gen_header(
+add_gen_header2(
sys_resource
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_resource.yaml
DEF_FILE sys/resource.h.def
GEN_HDR sys/resource.h
DEPENDS
@@ -453,8 +488,9 @@ add_gen_header(
.llvm-libc-types.struct_rlimit
)
-add_gen_header(
+add_gen_header2(
sys_stat
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_stat.yaml
DEF_FILE sys/stat.h.def
GEN_HDR sys/stat.h
DEPENDS
@@ -474,8 +510,9 @@ add_gen_header(
.llvm-libc-types.struct_stat
)
-add_gen_header(
+add_gen_header2(
sys_select
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_select.yaml
DEF_FILE sys/select.h.def
GEN_HDR sys/select.h
DEPENDS
@@ -489,8 +526,9 @@ add_gen_header(
.llvm-libc-types.struct_timeval
)
-add_gen_header(
+add_gen_header2(
sys_sendfile
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_sendfile.yaml
DEF_FILE sys/sendfile.h.def
GEN_HDR sys/sendfile.h
DEPENDS
@@ -500,8 +538,9 @@ add_gen_header(
.llvm-libc-types.ssize_t
)
-add_gen_header(
+add_gen_header2(
sys_socket
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_socket.yaml
DEF_FILE sys/socket.h.def
GEN_HDR sys/socket.h
DEPENDS
@@ -513,8 +552,9 @@ add_gen_header(
.llvm-libc-types.struct_sockaddr_un
)
-add_gen_header(
+add_gen_header2(
sys_statvfs
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_statvfs.yaml
DEF_FILE sys/statvfs.h.def
GEN_HDR sys/statvfs.h
DEPENDS
@@ -522,14 +562,16 @@ add_gen_header(
.llvm-libc-types.struct_statvfs
)
-add_gen_header(
+add_gen_header2(
sys_syscall
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_syscall.yaml
DEF_FILE sys/syscall.h.def
GEN_HDR sys/syscall.h
)
-add_gen_header(
+add_gen_header2(
sys_time
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_time.yaml
DEF_FILE sys/time.h.def
GEN_HDR sys/time.h
DEPENDS
@@ -538,8 +580,9 @@ add_gen_header(
.llvm-libc-macros.sys_time_macros
)
-add_gen_header(
+add_gen_header2(
sys_types
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_types.yaml
DEF_FILE sys/types.h.def
GEN_HDR sys/types.h
DEPENDS
@@ -567,8 +610,9 @@ add_gen_header(
.llvm-libc-types.uid_t
)
-add_gen_header(
+add_gen_header2(
sys_utsname
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_utsname.yaml
DEF_FILE sys/utsname.h.def
GEN_HDR sys/utsname.h
DEPENDS
@@ -576,8 +620,9 @@ add_gen_header(
.llvm-libc-types.struct_utsname
)
-add_gen_header(
+add_gen_header2(
sys_wait
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_wait.yaml
DEF_FILE sys/wait.h.def
GEN_HDR sys/wait.h
DEPENDS
@@ -588,8 +633,9 @@ add_gen_header(
.llvm-libc-types.siginfo_t
)
-add_gen_header(
+add_gen_header2(
termios
+ YAML_FILE ../libc/newhdrgen/yaml/termios.yaml
DEF_FILE termios.h.def
GEN_HDR termios.h
DEPENDS
@@ -602,8 +648,9 @@ add_gen_header(
.llvm-libc-types.tcflag_t
)
-add_gen_header(
+add_gen_header2(
uchar
+ YAML_FILE ../libc/newhdrgen/yaml/uchar.yaml
DEF_FILE uchar.h.def
GEN_HDR uchar.h
DEPENDS
@@ -614,8 +661,9 @@ add_gen_header(
.llvm-libc-types.char32_t
)
-add_gen_header(
+add_gen_header2(
wchar
+ YAML_FILE ../libc/newhdrgen/yaml/wchar.yaml
DEF_FILE wchar.h.def
GEN_HDR wchar.h
DEPENDS
@@ -630,8 +678,9 @@ add_gen_header(
if(LIBC_TARGET_OS_IS_GPU)
file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/gpu)
- add_gen_header(
+ add_gen_header2(
gpu_rpc
+ YAML_FILE ../libc/newhdrgen/yaml/rpc.yaml
DEF_FILE gpu/rpc.h.def
GEN_HDR gpu/rpc.h
DEPENDS
@@ -703,4 +752,4 @@ if(LLVM_LIBC_FULL_BUILD)
-P "${CMAKE_BINARY_DIR}/cmake_install.cmake")
# Stripping is a no-op for headers
add_custom_target(install-libc-headers-stripped DEPENDS install-libc-headers)
-endif()
+endif()
\ No newline at end of file
>From a1e40be8d64c912bfb0f5039179b96d9bc480463 Mon Sep 17 00:00:00 2001
From: Aaryan Shukla <aaryanshukla at google.com>
Date: Sun, 14 Jul 2024 18:27:42 +0000
Subject: [PATCH 02/17] added sys path for prctl
---
libc/include/CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index 8e9942fac69e1..0d59f21e0fffa 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -449,7 +449,7 @@ add_gen_header2(
add_gen_header2(
sys_prctl
- YAML_FILE ../libc/newhdrgen/yaml/sys_prctl.yaml
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_prctl.yaml
DEF_FILE sys/prctl.h.def
GEN_HDR sys/prctl.h
DEPENDS
>From 1c921deb482de0546c33253b3987920a755a9a3b Mon Sep 17 00:00:00 2001
From: Aaryan Shukla <aaryanshukla at google.com>
Date: Sun, 14 Jul 2024 18:28:34 +0000
Subject: [PATCH 03/17] added newline for CMakeLists.txt
---
libc/include/CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index 0d59f21e0fffa..7bb15371c91b0 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -752,4 +752,4 @@ if(LLVM_LIBC_FULL_BUILD)
-P "${CMAKE_BINARY_DIR}/cmake_install.cmake")
# Stripping is a no-op for headers
add_custom_target(install-libc-headers-stripped DEPENDS install-libc-headers)
-endif()
\ No newline at end of file
+endif()
>From 1475b2b8432be52a095924d05d2d7e1e4f2429a4 Mon Sep 17 00:00:00 2001
From: Aaryan Shukla <aaryanshukla at google.com>
Date: Sun, 14 Jul 2024 18:30:45 +0000
Subject: [PATCH 04/17] spacing and nits
---
libc/cmake/modules/LLVMLibCHeaderRules.cmake | 10 +++++-----
1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/libc/cmake/modules/LLVMLibCHeaderRules.cmake b/libc/cmake/modules/LLVMLibCHeaderRules.cmake
index 1bcca5f19577c..b87137c5f1a0d 100644
--- a/libc/cmake/modules/LLVMLibCHeaderRules.cmake
+++ b/libc/cmake/modules/LLVMLibCHeaderRules.cmake
@@ -130,7 +130,7 @@ function(add_gen_header2 target_name)
DEPENDS ${yaml_file} ${fq_data_files}
)
endif()
- 2
+
if(ADD_GEN_HDR2_DEPENDS)
get_fq_deps_list(f2q_deps_list ${ADD_GEN_HDR2_DEPENDS})
# Dependencies of a add_header target can only be another add_gen_header target
@@ -239,10 +239,10 @@ function(add_gen_header target_name)
)
if(LIBC_TARGET_OS_IS_GPU)
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls)
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls/gpu)
- set(decl_out_file ${LIBC_INCLUDE_DIR}/llvm-libc-decls/${relative_path})
- add_custom_command(
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls)
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls/gpu)
+ set(decl_out_file ${LIBC_INCLUDE_DIR}/llvm-libc-decls/${relative_path})
+ add_custom_command(
OUTPUT ${decl_out_file}
COMMAND ${hdrgen_exe} -o ${decl_out_file}
--header ${ADD_GEN_HDR_GEN_HDR} --def ${in_file} --export-decls
>From 05ff1da089e045d60a29da51dd277404896ccef3 Mon Sep 17 00:00:00 2001
From: Rose Zhang <rosezhang at google.com>
Date: Mon, 15 Jul 2024 22:09:36 +0000
Subject: [PATCH 05/17] added switch for using old versus new headergen in
CMakeLists
---
libc/include/CMakeLists.txt | 1853 +++++++++++++++++++++++------------
1 file changed, 1239 insertions(+), 614 deletions(-)
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index 7bb15371c91b0..3a9f511d47d77 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -17,676 +17,1301 @@ add_header(
__llvm-libc-common.h
)
-add_gen_header2(
- ctype
- YAML_FILE ../libc/newhdrgen/yaml/ctype.yaml
- DEF_FILE ctype.h.def
- GEN_HDR ctype.h
- DEPENDS
- .llvm_libc_common_h
-)
-
-add_gen_header2(
- dirent
- YAML_FILE ../libc/newhdrgen/yaml/dirent.yaml
- DEF_FILE dirent.h.def
- GEN_HDR dirent.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.ino_t
- .llvm-libc-types.DIR
- .llvm-libc-types.struct_dirent
-)
+if (USE_NEW_HEADER_GEN)
+ add_gen_header2(
+ ctype
+ YAML_FILE ../libc/newhdrgen/yaml/ctype.yaml
+ DEF_FILE ctype.h.def
+ GEN_HDR ctype.h
+ DEPENDS
+ .llvm_libc_common_h
+ )
-add_gen_header2(
- fcntl
- YAML_FILE ../libc/newhdrgen/yaml/fcntl.yaml
- DEF_FILE fcntl.h.def
- GEN_HDR fcntl.h
- DEPENDS
- .llvm-libc-macros.fcntl_macros
- .llvm-libc-types.mode_t
- .llvm-libc-types.struct_flock
- .llvm-libc-types.struct_flock64
- .llvm-libc-types.off64_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.off_t
- .llvm_libc_common_h
-)
+ add_gen_header2(
+ dirent
+ YAML_FILE ../libc/newhdrgen/yaml/dirent.yaml
+ DEF_FILE dirent.h.def
+ GEN_HDR dirent.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.ino_t
+ .llvm-libc-types.DIR
+ .llvm-libc-types.struct_dirent
+ )
-add_gen_header2(
- dlfcn
- YAML_FILE ../libc/newhdrgen/yaml/dlfcn.yaml
- DEF_FILE dlfcn.h.def
- GEN_HDR dlfcn.h
- DEPENDS
- .llvm-libc-macros.dlfcn_macros
- .llvm_libc_common_h
-)
+ add_gen_header2(
+ fcntl
+ YAML_FILE ../libc/newhdrgen/yaml/fcntl.yaml
+ DEF_FILE fcntl.h.def
+ GEN_HDR fcntl.h
+ DEPENDS
+ .llvm-libc-macros.fcntl_macros
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.struct_flock
+ .llvm-libc-types.struct_flock64
+ .llvm-libc-types.off64_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.off_t
+ .llvm_libc_common_h
+ )
-add_gen_header2(
- features
- YAML_FILE ../libc/newhdrgen/yaml/features.yaml
- DEF_FILE features.h.def
- GEN_HDR features.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.features_macros
-)
+ add_gen_header2(
+ dlfcn
+ YAML_FILE ../libc/newhdrgen/yaml/dlfcn.yaml
+ DEF_FILE dlfcn.h.def
+ GEN_HDR dlfcn.h
+ DEPENDS
+ .llvm-libc-macros.dlfcn_macros
+ .llvm_libc_common_h
+ )
-add_gen_header2(
- fenv
- YAML_FILE ../libc/newhdrgen/yaml/fenv.yaml
- DEF_FILE fenv.h.def
- GEN_HDR fenv.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.fenv_macros
- .llvm-libc-types.fenv_t
- .llvm-libc-types.fexcept_t
-)
+ add_gen_header2(
+ features
+ YAML_FILE ../libc/newhdrgen/yaml/features.yaml
+ DEF_FILE features.h.def
+ GEN_HDR features.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.features_macros
+ )
-add_gen_header2(
- inttypes
- YAML_FILE ../libc/newhdrgen/yaml/inttypes.yaml
- DEF_FILE inttypes.h.def
- GEN_HDR inttypes.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.imaxdiv_t
- .llvm-libc-macros.inttypes_macros
-)
+ add_gen_header2(
+ fenv
+ YAML_FILE ../libc/newhdrgen/yaml/fenv.yaml
+ DEF_FILE fenv.h.def
+ GEN_HDR fenv.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.fenv_macros
+ .llvm-libc-types.fenv_t
+ .llvm-libc-types.fexcept_t
+ )
-add_gen_header2(
- float
- YAML_FILE ../libc/newhdrgen/yaml/float.yaml
- DEF_FILE float.h.def
- GEN_HDR float.h
- DEPENDS
- .llvm-libc-macros.float_macros
-)
+ add_gen_header2(
+ inttypes
+ YAML_FILE ../libc/newhdrgen/yaml/inttypes.yaml
+ DEF_FILE inttypes.h.def
+ GEN_HDR inttypes.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.imaxdiv_t
+ .llvm-libc-macros.inttypes_macros
+ )
-add_gen_header2(
- stdint
- YAML_FILE ../libc/newhdrgen/yaml/stdint.yaml
- DEF_FILE stdint.h.def
- GEN_HDR stdint.h
- DEPENDS
- .llvm-libc-macros.stdint_macros
-)
+ add_gen_header2(
+ float
+ YAML_FILE ../libc/newhdrgen/yaml/float.yaml
+ DEF_FILE float.h.def
+ GEN_HDR float.h
+ DEPENDS
+ .llvm-libc-macros.float_macros
+ )
-add_gen_header2(
- limits
- YAML_FILE ../libc/newhdrgen/yaml/limits.yaml
- DEF_FILE limits.h.def
- GEN_HDR limits.h
- DEPENDS
- .llvm-libc-macros.limits_macros
-)
+ add_gen_header2(
+ stdint
+ YAML_FILE ../libc/newhdrgen/yaml/stdint.yaml
+ DEF_FILE stdint.h.def
+ GEN_HDR stdint.h
+ DEPENDS
+ .llvm-libc-macros.stdint_macros
+ )
-add_gen_header2(
- math
- YAML_FILE ../libc/newhdrgen/yaml/math.yaml
- DEF_FILE math.h.def
- GEN_HDR math.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.float16_macros
- .llvm-libc-macros.math_macros
- .llvm-libc-types.double_t
- .llvm-libc-types.float_t
- .llvm-libc-types.float128
-)
+ add_gen_header2(
+ limits
+ YAML_FILE ../libc/newhdrgen/yaml/limits.yaml
+ DEF_FILE limits.h.def
+ GEN_HDR limits.h
+ DEPENDS
+ .llvm-libc-macros.limits_macros
+ )
-add_gen_header2(
- stdfix
- YAML_FILE ../libc/newhdrgen/yaml/stdfix.yaml
- DEF_FILE stdfix.h.def
- GEN_HDR stdfix.h
- DEPENDS
- .llvm-libc-macros.stdfix_macros
-)
+ add_gen_header2(
+ math
+ YAML_FILE ../libc/newhdrgen/yaml/math.yaml
+ DEF_FILE math.h.def
+ GEN_HDR math.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.float16_macros
+ .llvm-libc-macros.math_macros
+ .llvm-libc-types.double_t
+ .llvm-libc-types.float_t
+ .llvm-libc-types.float128
+ )
-# TODO: This should be conditional on POSIX networking being included.
-file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/arpa)
+ add_gen_header2(
+ stdfix
+ YAML_FILE ../libc/newhdrgen/yaml/stdfix.yaml
+ DEF_FILE stdfix.h.def
+ GEN_HDR stdfix.h
+ DEPENDS
+ .llvm-libc-macros.stdfix_macros
+ )
-add_gen_header2(
- arpa_inet
- YAML_FILE ../libc/newhdrgen/yaml/arpa_inet.yaml
- DEF_FILE arpa/inet.h.def
- GEN_HDR arpa/inet.h
- DEPENDS
- .llvm_libc_common_h
-)
+ # TODO: This should be conditional on POSIX networking being included.
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/arpa)
-add_gen_header2(
- assert
- DEF_FILE assert.h.def
- GEN_HDR assert.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.assert_macros
-)
+ add_gen_header2(
+ arpa_inet
+ YAML_FILE ../libc/newhdrgen/yaml/arpa_inet.yaml
+ DEF_FILE arpa/inet.h.def
+ GEN_HDR arpa/inet.h
+ DEPENDS
+ .llvm_libc_common_h
+ )
-add_gen_header2(
- setjmp
- YAML_FILE ../libc/newhdrgen/yaml/setjmp.yaml
- DEF_FILE setjmp.h.def
- GEN_HDR setjmp.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.jmp_buf
-)
+ add_gen_header2(
+ assert
+ DEF_FILE assert.h.def
+ GEN_HDR assert.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.assert_macros
+ )
-add_gen_header2(
- string
- YAML_FILE ../libc/newhdrgen/yaml/string.yaml
- DEF_FILE string.h.def
- GEN_HDR string.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.null_macro
- .llvm-libc-types.size_t
-)
+ add_gen_header2(
+ setjmp
+ YAML_FILE ../libc/newhdrgen/yaml/setjmp.yaml
+ DEF_FILE setjmp.h.def
+ GEN_HDR setjmp.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.jmp_buf
+ )
-add_gen_header2(
- strings
- YAML_FILE ../libc/newhdrgen/yaml/strings.yaml
- DEF_FILE strings.h.def
- GEN_HDR strings.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.size_t
-)
+ add_gen_header2(
+ string
+ YAML_FILE ../libc/newhdrgen/yaml/string.yaml
+ DEF_FILE string.h.def
+ GEN_HDR string.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.null_macro
+ .llvm-libc-types.size_t
+ )
-add_gen_header2(
- search
- YAML_FILE ../libc/newhdrgen/yaml/search.yaml
- DEF_FILE search.h.def
- GEN_HDR search.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.ACTION
- .llvm-libc-types.ENTRY
- .llvm-libc-types.struct_hsearch_data
- .llvm-libc-types.size_t
-)
+ add_gen_header2(
+ strings
+ YAML_FILE ../libc/newhdrgen/yaml/strings.yaml
+ DEF_FILE strings.h.def
+ GEN_HDR strings.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.size_t
+ )
-add_gen_header2(
- time
- YAML_FILE ../libc/newhdrgen/yaml/time.yaml
- DEF_FILE time.h.def
- GEN_HDR time.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.time_macros
- .llvm-libc-types.clock_t
- .llvm-libc-types.time_t
- .llvm-libc-types.struct_tm
- .llvm-libc-types.struct_timespec
- .llvm-libc-types.struct_timeval
- .llvm-libc-types.clockid_t
-)
+ add_gen_header2(
+ search
+ YAML_FILE ../libc/newhdrgen/yaml/search.yaml
+ DEF_FILE search.h.def
+ GEN_HDR search.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.ACTION
+ .llvm-libc-types.ENTRY
+ .llvm-libc-types.struct_hsearch_data
+ .llvm-libc-types.size_t
+ )
-add_gen_header2(
- threads
- YAML_FILE ../libc/newhdrgen/yaml/threads.yaml
- DEF_FILE threads.h.def
- GEN_HDR threads.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.__call_once_func_t
- .llvm-libc-types.once_flag
- .llvm-libc-types.cnd_t
- .llvm-libc-types.mtx_t
- .llvm-libc-types.thrd_t
- .llvm-libc-types.thrd_start_t
- .llvm-libc-types.tss_t
- .llvm-libc-types.tss_dtor_t
-)
+ add_gen_header2(
+ time
+ YAML_FILE ../libc/newhdrgen/yaml/time.yaml
+ DEF_FILE time.h.def
+ GEN_HDR time.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.time_macros
+ .llvm-libc-types.clock_t
+ .llvm-libc-types.time_t
+ .llvm-libc-types.struct_tm
+ .llvm-libc-types.struct_timespec
+ .llvm-libc-types.struct_timeval
+ .llvm-libc-types.clockid_t
+ )
-add_gen_header2(
- errno
- YAML_FILE ../libc/newhdrgen/yaml/errno.yaml
- DEF_FILE errno.h.def
- GEN_HDR errno.h
- DEPENDS
- .llvm-libc-macros.generic_error_number_macros
- .llvm-libc-macros.error_number_macros
-)
+ add_gen_header2(
+ threads
+ YAML_FILE ../libc/newhdrgen/yaml/threads.yaml
+ DEF_FILE threads.h.def
+ GEN_HDR threads.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.__call_once_func_t
+ .llvm-libc-types.once_flag
+ .llvm-libc-types.cnd_t
+ .llvm-libc-types.mtx_t
+ .llvm-libc-types.thrd_t
+ .llvm-libc-types.thrd_start_t
+ .llvm-libc-types.tss_t
+ .llvm-libc-types.tss_dtor_t
+ )
-add_gen_header2(
- signal
- YAML_FILE ../libc/newhdrgen/yaml/signal.yaml
- DEF_FILE signal.h.def
- GEN_HDR signal.h
- DEPENDS
- .llvm-libc-macros.signal_macros
- .llvm-libc-types.sig_atomic_t
- .llvm-libc-types.sigset_t
- .llvm-libc-types.struct_sigaction
- .llvm-libc-types.union_sigval
- .llvm-libc-types.siginfo_t
- .llvm-libc-types.stack_t
- .llvm-libc-types.pid_t
-)
+ add_gen_header2(
+ errno
+ YAML_FILE ../libc/newhdrgen/yaml/errno.yaml
+ DEF_FILE errno.h.def
+ GEN_HDR errno.h
+ DEPENDS
+ .llvm-libc-macros.generic_error_number_macros
+ .llvm-libc-macros.error_number_macros
+ )
-add_gen_header2(
- stdbit
- YAML_FILE ../libc/newhdrgen/yaml/stdbit.yaml
- DEF_FILE stdbit.h.def
- GEN_HDR stdbit.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.stdbit_macros
-)
+ add_gen_header2(
+ signal
+ YAML_FILE ../libc/newhdrgen/yaml/signal.yaml
+ DEF_FILE signal.h.def
+ GEN_HDR signal.h
+ DEPENDS
+ .llvm-libc-macros.signal_macros
+ .llvm-libc-types.sig_atomic_t
+ .llvm-libc-types.sigset_t
+ .llvm-libc-types.struct_sigaction
+ .llvm-libc-types.union_sigval
+ .llvm-libc-types.siginfo_t
+ .llvm-libc-types.stack_t
+ .llvm-libc-types.pid_t
+ )
-add_gen_header2(
- stdckdint
- YAML_FILE ../libc/newhdrgen/yaml/stdckdint.yaml
- DEF_FILE stdckdint.h.def
- GEN_HDR stdckdint.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.stdckdint_macros
-)
+ add_gen_header2(
+ stdbit
+ YAML_FILE ../libc/newhdrgen/yaml/stdbit.yaml
+ DEF_FILE stdbit.h.def
+ GEN_HDR stdbit.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.stdbit_macros
+ )
-add_gen_header2(
- stdio
- YAML_FILE ../libc/newhdrgen/yaml/stdio.yaml
- DEF_FILE stdio.h.def
- GEN_HDR stdio.h
- DEPENDS
- .llvm-libc-macros.file_seek_macros
- .llvm-libc-macros.stdio_macros
- .llvm-libc-types.FILE
- .llvm-libc-types.cookie_io_functions_t
- .llvm-libc-types.off_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- .llvm_libc_common_h
-)
+ add_gen_header2(
+ stdckdint
+ YAML_FILE ../libc/newhdrgen/yaml/stdckdint.yaml
+ DEF_FILE stdckdint.h.def
+ GEN_HDR stdckdint.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.stdckdint_macros
+ )
-add_gen_header2(
- stdlib
- YAML_FILE ../libc/newhdrgen/yaml/stdlib.yaml
- DEF_FILE stdlib.h.def
- GEN_HDR stdlib.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.stdlib_macros
- .llvm-libc-types.div_t
- .llvm-libc-types.ldiv_t
- .llvm-libc-types.lldiv_t
- .llvm-libc-types.size_t
- .llvm-libc-types.__bsearchcompare_t
- .llvm-libc-types.__qsortcompare_t
- .llvm-libc-types.__qsortrcompare_t
- .llvm-libc-types.__atexithandler_t
-)
+ add_gen_header2(
+ stdio
+ YAML_FILE ../libc/newhdrgen/yaml/stdio.yaml
+ DEF_FILE stdio.h.def
+ GEN_HDR stdio.h
+ DEPENDS
+ .llvm-libc-macros.file_seek_macros
+ .llvm-libc-macros.stdio_macros
+ .llvm-libc-types.FILE
+ .llvm-libc-types.cookie_io_functions_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ .llvm_libc_common_h
+ )
-add_gen_header2(
- unistd
- YAML_FILE ../libc/newhdrgen/yaml/unistd.yaml
- DEF_FILE unistd.h.def
- GEN_HDR unistd.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.file_seek_macros
- .llvm-libc-macros.unistd_macros
- .llvm-libc-types.__exec_argv_t
- .llvm-libc-types.__exec_envp_t
- .llvm-libc-types.off_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- .llvm-libc-types.uid_t
- .llvm-libc-types.__getoptargv_t
-)
+ add_gen_header2(
+ stdlib
+ YAML_FILE ../libc/newhdrgen/yaml/stdlib.yaml
+ DEF_FILE stdlib.h.def
+ GEN_HDR stdlib.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.stdlib_macros
+ .llvm-libc-types.div_t
+ .llvm-libc-types.ldiv_t
+ .llvm-libc-types.lldiv_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.__bsearchcompare_t
+ .llvm-libc-types.__qsortcompare_t
+ .llvm-libc-types.__qsortrcompare_t
+ .llvm-libc-types.__atexithandler_t
+ )
-add_gen_header2(
- pthread
- YAML_FILE ../libc/newhdrgen/yaml/pthread.yaml
- DEF_FILE pthread.h.def
- GEN_HDR pthread.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.__atfork_callback_t
- .llvm-libc-types.__pthread_once_func_t
- .llvm-libc-types.__pthread_start_t
- .llvm-libc-types.__pthread_tss_dtor_t
- .llvm-libc-types.pthread_attr_t
- .llvm-libc-types.pthread_condattr_t
- .llvm-libc-types.pthread_key_t
- .llvm-libc-types.pthread_mutex_t
- .llvm-libc-types.pthread_mutexattr_t
- .llvm-libc-types.pthread_once_t
- .llvm-libc-types.pthread_rwlock_t
- .llvm-libc-types.pthread_rwlockattr_t
- .llvm-libc-types.pthread_t
-)
+ add_gen_header2(
+ unistd
+ YAML_FILE ../libc/newhdrgen/yaml/unistd.yaml
+ DEF_FILE unistd.h.def
+ GEN_HDR unistd.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.file_seek_macros
+ .llvm-libc-macros.unistd_macros
+ .llvm-libc-types.__exec_argv_t
+ .llvm-libc-types.__exec_envp_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ .llvm-libc-types.uid_t
+ .llvm-libc-types.__getoptargv_t
+ )
-add_gen_header2(
- sched
- YAML_FILE ../libc/newhdrgen/yaml/sched.yaml
- DEF_FILE sched.h.def
- GEN_HDR sched.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sched_macros
- .llvm-libc-types.cpu_set_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.size_t
- .llvm-libc-types.struct_sched_param
- # Needed according to posix standard
- .llvm-libc-types.time_t
- .llvm-libc-types.struct_timespec
-)
+ add_gen_header2(
+ pthread
+ YAML_FILE ../libc/newhdrgen/yaml/pthread.yaml
+ DEF_FILE pthread.h.def
+ GEN_HDR pthread.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.__atfork_callback_t
+ .llvm-libc-types.__pthread_once_func_t
+ .llvm-libc-types.__pthread_start_t
+ .llvm-libc-types.__pthread_tss_dtor_t
+ .llvm-libc-types.pthread_attr_t
+ .llvm-libc-types.pthread_condattr_t
+ .llvm-libc-types.pthread_key_t
+ .llvm-libc-types.pthread_mutex_t
+ .llvm-libc-types.pthread_mutexattr_t
+ .llvm-libc-types.pthread_once_t
+ .llvm-libc-types.pthread_rwlock_t
+ .llvm-libc-types.pthread_rwlockattr_t
+ .llvm-libc-types.pthread_t
+ )
-add_gen_header2(
- spawn
- YAML_FILE ../libc/newhdrgen/yaml/spawn.yaml
- DEF_FILE spawn.h.def
- GEN_HDR spawn.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.mode_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.posix_spawnattr_t
- .llvm-libc-types.posix_spawn_file_actions_t
-)
+ add_gen_header2(
+ sched
+ YAML_FILE ../libc/newhdrgen/yaml/sched.yaml
+ DEF_FILE sched.h.def
+ GEN_HDR sched.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sched_macros
+ .llvm-libc-types.cpu_set_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.struct_sched_param
+ # Needed according to posix standard
+ .llvm-libc-types.time_t
+ .llvm-libc-types.struct_timespec
+ )
-# TODO: Not all platforms will have a include/sys directory. Add the sys
-# directory and the targets for sys/*.h files conditional to the OS requiring
-# them.
-file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/sys)
-
-add_gen_header2(
- sys_auxv
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_auxv.yaml
- DEF_FILE sys/auxv.h.def
- GEN_HDR sys/auxv.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_auxv_macros
-)
+ add_gen_header2(
+ spawn
+ YAML_FILE ../libc/newhdrgen/yaml/spawn.yaml
+ DEF_FILE spawn.h.def
+ GEN_HDR spawn.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.posix_spawnattr_t
+ .llvm-libc-types.posix_spawn_file_actions_t
+ )
-add_gen_header2(
- sys_epoll
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_epoll.yaml
- DEF_FILE sys/epoll.h.def
- GEN_HDR sys/epoll.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_epoll_event
- .llvm-libc-types.struct_epoll_data
- .llvm-libc-types.sigset_t
- .llvm-libc-macros.sys_epoll_macros
-)
+ # TODO: Not all platforms will have a include/sys directory. Add the sys
+ # directory and the targets for sys/*.h files conditional to the OS requiring
+ # them.
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/sys)
-add_gen_header2(
- sys_ioctl
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_ioctl.yaml
- DEF_FILE sys/ioctl.h.def
- GEN_HDR sys/ioctl.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_ioctl_macros
-)
+ add_gen_header2(
+ sys_auxv
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_auxv.yaml
+ DEF_FILE sys/auxv.h.def
+ GEN_HDR sys/auxv.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_auxv_macros
+ )
-add_gen_header2(
- sys_mman
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_mman.yaml
- DEF_FILE sys/mman.h.def
- GEN_HDR sys/mman.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_mman_macros
- .llvm-libc-types.off_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
-)
+ add_gen_header2(
+ sys_epoll
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_epoll.yaml
+ DEF_FILE sys/epoll.h.def
+ GEN_HDR sys/epoll.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_epoll_event
+ .llvm-libc-types.struct_epoll_data
+ .llvm-libc-types.sigset_t
+ .llvm-libc-macros.sys_epoll_macros
+ )
-add_gen_header2(
- sys_prctl
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_prctl.yaml
- DEF_FILE sys/prctl.h.def
- GEN_HDR sys/prctl.h
- DEPENDS
- .llvm_libc_common_h
-)
+ add_gen_header2(
+ sys_ioctl
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_ioctl.yaml
+ DEF_FILE sys/ioctl.h.def
+ GEN_HDR sys/ioctl.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_ioctl_macros
+ )
-add_header(
- sys_queue
- HDR
- sys/queue.h
- DEPENDS
- .llvm-libc-macros.sys_queue_macros
-)
+ add_gen_header2(
+ sys_mman
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_mman.yaml
+ DEF_FILE sys/mman.h.def
+ GEN_HDR sys/mman.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_mman_macros
+ .llvm-libc-types.off_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ )
-add_gen_header2(
- sys_random
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_random.yaml
- DEF_FILE sys/random.h.def
- GEN_HDR sys/random.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_random_macros
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
-)
+ add_gen_header2(
+ sys_prctl
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_prctl.yaml
+ DEF_FILE sys/prctl.h.def
+ GEN_HDR sys/prctl.h
+ DEPENDS
+ .llvm_libc_common_h
+ )
-add_gen_header2(
- sys_resource
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_resource.yaml
- DEF_FILE sys/resource.h.def
- GEN_HDR sys/resource.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_resource_macros
- .llvm-libc-types.rlim_t
- .llvm-libc-types.struct_rlimit
-)
+ add_header(
+ sys_queue
+ HDR
+ sys/queue.h
+ DEPENDS
+ .llvm-libc-macros.sys_queue_macros
+ )
-add_gen_header2(
- sys_stat
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_stat.yaml
- DEF_FILE sys/stat.h.def
- GEN_HDR sys/stat.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_stat_macros
- .llvm-libc-types.mode_t
- .llvm-libc-types.dev_t
- .llvm-libc-types.ino_t
- .llvm-libc-types.nlink_t
- .llvm-libc-types.uid_t
- .llvm-libc-types.gid_t
- .llvm-libc-types.off_t
- .llvm-libc-types.struct_timespec
- .llvm-libc-types.struct_timeval
- .llvm-libc-types.blksize_t
- .llvm-libc-types.blkcnt_t
- .llvm-libc-types.struct_stat
-)
+ add_gen_header2(
+ sys_random
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_random.yaml
+ DEF_FILE sys/random.h.def
+ GEN_HDR sys/random.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_random_macros
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ )
-add_gen_header2(
- sys_select
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_select.yaml
- DEF_FILE sys/select.h.def
- GEN_HDR sys/select.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_select_macros
- .llvm-libc-types.fd_set
- .llvm-libc-types.sigset_t
- .llvm-libc-types.suseconds_t
- .llvm-libc-types.time_t
- .llvm-libc-types.struct_timespec
- .llvm-libc-types.struct_timeval
-)
+ add_gen_header2(
+ sys_resource
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_resource.yaml
+ DEF_FILE sys/resource.h.def
+ GEN_HDR sys/resource.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_resource_macros
+ .llvm-libc-types.rlim_t
+ .llvm-libc-types.struct_rlimit
+ )
-add_gen_header2(
- sys_sendfile
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_sendfile.yaml
- DEF_FILE sys/sendfile.h.def
- GEN_HDR sys/sendfile.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.off_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
-)
+ add_gen_header2(
+ sys_stat
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_stat.yaml
+ DEF_FILE sys/stat.h.def
+ GEN_HDR sys/stat.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_stat_macros
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.dev_t
+ .llvm-libc-types.ino_t
+ .llvm-libc-types.nlink_t
+ .llvm-libc-types.uid_t
+ .llvm-libc-types.gid_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.struct_timespec
+ .llvm-libc-types.struct_timeval
+ .llvm-libc-types.blksize_t
+ .llvm-libc-types.blkcnt_t
+ .llvm-libc-types.struct_stat
+ )
-add_gen_header2(
- sys_socket
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_socket.yaml
- DEF_FILE sys/socket.h.def
- GEN_HDR sys/socket.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_socket_macros
- .llvm-libc-types.sa_family_t
- .llvm-libc-types.socklen_t
- .llvm-libc-types.struct_sockaddr
- .llvm-libc-types.struct_sockaddr_un
-)
+ add_gen_header2(
+ sys_select
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_select.yaml
+ DEF_FILE sys/select.h.def
+ GEN_HDR sys/select.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_select_macros
+ .llvm-libc-types.fd_set
+ .llvm-libc-types.sigset_t
+ .llvm-libc-types.suseconds_t
+ .llvm-libc-types.time_t
+ .llvm-libc-types.struct_timespec
+ .llvm-libc-types.struct_timeval
+ )
-add_gen_header2(
- sys_statvfs
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_statvfs.yaml
- DEF_FILE sys/statvfs.h.def
- GEN_HDR sys/statvfs.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_statvfs
-)
+ add_gen_header2(
+ sys_sendfile
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_sendfile.yaml
+ DEF_FILE sys/sendfile.h.def
+ GEN_HDR sys/sendfile.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.off_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ )
-add_gen_header2(
- sys_syscall
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_syscall.yaml
- DEF_FILE sys/syscall.h.def
- GEN_HDR sys/syscall.h
-)
+ add_gen_header2(
+ sys_socket
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_socket.yaml
+ DEF_FILE sys/socket.h.def
+ GEN_HDR sys/socket.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_socket_macros
+ .llvm-libc-types.sa_family_t
+ .llvm-libc-types.socklen_t
+ .llvm-libc-types.struct_sockaddr
+ .llvm-libc-types.struct_sockaddr_un
+ )
-add_gen_header2(
- sys_time
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_time.yaml
- DEF_FILE sys/time.h.def
- GEN_HDR sys/time.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_timeval
- .llvm-libc-macros.sys_time_macros
-)
+ add_gen_header2(
+ sys_statvfs
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_statvfs.yaml
+ DEF_FILE sys/statvfs.h.def
+ GEN_HDR sys/statvfs.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_statvfs
+ )
-add_gen_header2(
- sys_types
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_types.yaml
- DEF_FILE sys/types.h.def
- GEN_HDR sys/types.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.blkcnt_t
- .llvm-libc-types.blksize_t
- .llvm-libc-types.clockid_t
- .llvm-libc-types.dev_t
- .llvm-libc-types.gid_t
- .llvm-libc-types.ino_t
- .llvm-libc-types.mode_t
- .llvm-libc-types.nlink_t
- .llvm-libc-types.off_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.pthread_attr_t
- .llvm-libc-types.pthread_key_t
- .llvm-libc-types.pthread_mutex_t
- .llvm-libc-types.pthread_mutexattr_t
- .llvm-libc-types.pthread_once_t
- .llvm-libc-types.pthread_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- .llvm-libc-types.suseconds_t
- .llvm-libc-types.time_t
- .llvm-libc-types.uid_t
-)
+ add_gen_header2(
+ sys_syscall
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_syscall.yaml
+ DEF_FILE sys/syscall.h.def
+ GEN_HDR sys/syscall.h
+ )
-add_gen_header2(
- sys_utsname
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_utsname.yaml
- DEF_FILE sys/utsname.h.def
- GEN_HDR sys/utsname.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_utsname
-)
+ add_gen_header2(
+ sys_time
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_time.yaml
+ DEF_FILE sys/time.h.def
+ GEN_HDR sys/time.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_timeval
+ .llvm-libc-macros.sys_time_macros
+ )
-add_gen_header2(
- sys_wait
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_wait.yaml
- DEF_FILE sys/wait.h.def
- GEN_HDR sys/wait.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_wait_macros
- .llvm-libc-types.pid_t
- .llvm-libc-types.struct_rusage
- .llvm-libc-types.siginfo_t
-)
+ add_gen_header2(
+ sys_types
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_types.yaml
+ DEF_FILE sys/types.h.def
+ GEN_HDR sys/types.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.blkcnt_t
+ .llvm-libc-types.blksize_t
+ .llvm-libc-types.clockid_t
+ .llvm-libc-types.dev_t
+ .llvm-libc-types.gid_t
+ .llvm-libc-types.ino_t
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.nlink_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.pthread_attr_t
+ .llvm-libc-types.pthread_key_t
+ .llvm-libc-types.pthread_mutex_t
+ .llvm-libc-types.pthread_mutexattr_t
+ .llvm-libc-types.pthread_once_t
+ .llvm-libc-types.pthread_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ .llvm-libc-types.suseconds_t
+ .llvm-libc-types.time_t
+ .llvm-libc-types.uid_t
+ )
-add_gen_header2(
- termios
- YAML_FILE ../libc/newhdrgen/yaml/termios.yaml
- DEF_FILE termios.h.def
- GEN_HDR termios.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.termios_macros
- .llvm-libc-types.cc_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.speed_t
- .llvm-libc-types.struct_termios
- .llvm-libc-types.tcflag_t
-)
+ add_gen_header2(
+ sys_utsname
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_utsname.yaml
+ DEF_FILE sys/utsname.h.def
+ GEN_HDR sys/utsname.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_utsname
+ )
-add_gen_header2(
- uchar
- YAML_FILE ../libc/newhdrgen/yaml/uchar.yaml
- DEF_FILE uchar.h.def
- GEN_HDR uchar.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.mbstate_t
- .llvm-libc-types.char8_t
- .llvm-libc-types.char16_t
- .llvm-libc-types.char32_t
-)
+ add_gen_header2(
+ sys_wait
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_wait.yaml
+ DEF_FILE sys/wait.h.def
+ GEN_HDR sys/wait.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_wait_macros
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.struct_rusage
+ .llvm-libc-types.siginfo_t
+ )
-add_gen_header2(
- wchar
- YAML_FILE ../libc/newhdrgen/yaml/wchar.yaml
- DEF_FILE wchar.h.def
- GEN_HDR wchar.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.wchar_macros
- .llvm-libc-types.mbstate_t
- .llvm-libc-types.size_t
- .llvm-libc-types.wint_t
- .llvm-libc-types.wchar_t
-)
+ add_gen_header2(
+ termios
+ YAML_FILE ../libc/newhdrgen/yaml/termios.yaml
+ DEF_FILE termios.h.def
+ GEN_HDR termios.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.termios_macros
+ .llvm-libc-types.cc_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.speed_t
+ .llvm-libc-types.struct_termios
+ .llvm-libc-types.tcflag_t
+ )
-if(LIBC_TARGET_OS_IS_GPU)
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/gpu)
+ add_gen_header2(
+ uchar
+ YAML_FILE ../libc/newhdrgen/yaml/uchar.yaml
+ DEF_FILE uchar.h.def
+ GEN_HDR uchar.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.mbstate_t
+ .llvm-libc-types.char8_t
+ .llvm-libc-types.char16_t
+ .llvm-libc-types.char32_t
+ )
add_gen_header2(
- gpu_rpc
- YAML_FILE ../libc/newhdrgen/yaml/rpc.yaml
- DEF_FILE gpu/rpc.h.def
- GEN_HDR gpu/rpc.h
+ wchar
+ YAML_FILE ../libc/newhdrgen/yaml/wchar.yaml
+ DEF_FILE wchar.h.def
+ GEN_HDR wchar.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.wchar_macros
+ .llvm-libc-types.mbstate_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.wint_t
+ .llvm-libc-types.wchar_t
+ )
+
+ if(LIBC_TARGET_OS_IS_GPU)
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/gpu)
+
+ add_gen_header2(
+ gpu_rpc
+ YAML_FILE ../libc/newhdrgen/yaml/rpc.yaml
+ DEF_FILE gpu/rpc.h.def
+ GEN_HDR gpu/rpc.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.rpc_opcodes_t
+ )
+ endif()
+else()
+ add_gen_header(
+ ctype
+ DEF_FILE ctype.h.def
+ GEN_HDR ctype.h
+ DEPENDS
+ .llvm_libc_common_h
+ )
+
+ add_gen_header(
+ dirent
+ DEF_FILE dirent.h.def
+ GEN_HDR dirent.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.ino_t
+ .llvm-libc-types.DIR
+ .llvm-libc-types.struct_dirent
+ )
+
+ add_gen_header(
+ fcntl
+ DEF_FILE fcntl.h.def
+ GEN_HDR fcntl.h
+ DEPENDS
+ .llvm-libc-macros.fcntl_macros
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.struct_flock
+ .llvm-libc-types.struct_flock64
+ .llvm-libc-types.off64_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.off_t
+ .llvm_libc_common_h
+ )
+
+ add_gen_header(
+ dlfcn
+ DEF_FILE dlfcn.h.def
+ GEN_HDR dlfcn.h
+ DEPENDS
+ .llvm-libc-macros.dlfcn_macros
+ .llvm_libc_common_h
+ )
+
+ add_gen_header(
+ features
+ DEF_FILE features.h.def
+ GEN_HDR features.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.features_macros
+ )
+
+ add_gen_header(
+ fenv
+ DEF_FILE fenv.h.def
+ GEN_HDR fenv.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.fenv_macros
+ .llvm-libc-types.fenv_t
+ .llvm-libc-types.fexcept_t
+ )
+
+ add_gen_header(
+ inttypes
+ DEF_FILE inttypes.h.def
+ GEN_HDR inttypes.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.imaxdiv_t
+ .llvm-libc-macros.inttypes_macros
+ )
+
+ add_gen_header(
+ float
+ DEF_FILE float.h.def
+ GEN_HDR float.h
+ DEPENDS
+ .llvm-libc-macros.float_macros
+ )
+
+ add_gen_header(
+ stdint
+ DEF_FILE stdint.h.def
+ GEN_HDR stdint.h
+ DEPENDS
+ .llvm-libc-macros.stdint_macros
+ )
+
+ add_gen_header(
+ limits
+ DEF_FILE limits.h.def
+ GEN_HDR limits.h
+ DEPENDS
+ .llvm-libc-macros.limits_macros
+ )
+
+ add_gen_header(
+ math
+ DEF_FILE math.h.def
+ GEN_HDR math.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.float16_macros
+ .llvm-libc-macros.math_macros
+ .llvm-libc-macros.math_function_macros
+ .llvm-libc-types.double_t
+ .llvm-libc-types.float_t
+ .llvm-libc-types.float128
+ )
+
+ add_gen_header(
+ stdfix
+ DEF_FILE stdfix.h.def
+ GEN_HDR stdfix.h
+ DEPENDS
+ .llvm-libc-macros.stdfix_macros
+ )
+
+ # TODO: This should be conditional on POSIX networking being included.
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/arpa)
+
+ add_gen_header(
+ arpa_inet
+ DEF_FILE arpa/inet.h.def
+ GEN_HDR arpa/inet.h
+ DEPENDS
+ .llvm_libc_common_h
+ )
+
+ add_gen_header(
+ assert
+ DEF_FILE assert.h.def
+ GEN_HDR assert.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.assert_macros
+ )
+
+ add_gen_header(
+ setjmp
+ DEF_FILE setjmp.h.def
+ GEN_HDR setjmp.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.jmp_buf
+ )
+
+ add_gen_header(
+ string
+ DEF_FILE string.h.def
+ GEN_HDR string.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.null_macro
+ .llvm-libc-types.size_t
+ )
+
+ add_gen_header(
+ strings
+ DEF_FILE strings.h.def
+ GEN_HDR strings.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.size_t
+ )
+
+ add_gen_header(
+ search
+ DEF_FILE search.h.def
+ GEN_HDR search.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.ACTION
+ .llvm-libc-types.ENTRY
+ .llvm-libc-types.struct_hsearch_data
+ .llvm-libc-types.size_t
+ )
+
+ add_gen_header(
+ time
+ DEF_FILE time.h.def
+ GEN_HDR time.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.time_macros
+ .llvm-libc-types.clock_t
+ .llvm-libc-types.time_t
+ .llvm-libc-types.struct_tm
+ .llvm-libc-types.struct_timespec
+ .llvm-libc-types.struct_timeval
+ .llvm-libc-types.clockid_t
+ )
+
+ add_gen_header(
+ threads
+ DEF_FILE threads.h.def
+ GEN_HDR threads.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.__call_once_func_t
+ .llvm-libc-types.once_flag
+ .llvm-libc-types.cnd_t
+ .llvm-libc-types.mtx_t
+ .llvm-libc-types.thrd_t
+ .llvm-libc-types.thrd_start_t
+ .llvm-libc-types.tss_t
+ .llvm-libc-types.tss_dtor_t
+ )
+
+ add_gen_header(
+ errno
+ DEF_FILE errno.h.def
+ GEN_HDR errno.h
+ DEPENDS
+ .llvm-libc-macros.generic_error_number_macros
+ .llvm-libc-macros.error_number_macros
+ )
+
+ add_gen_header(
+ signal
+ DEF_FILE signal.h.def
+ GEN_HDR signal.h
+ DEPENDS
+ .llvm-libc-macros.signal_macros
+ .llvm-libc-types.sig_atomic_t
+ .llvm-libc-types.sigset_t
+ .llvm-libc-types.struct_sigaction
+ .llvm-libc-types.union_sigval
+ .llvm-libc-types.siginfo_t
+ .llvm-libc-types.stack_t
+ .llvm-libc-types.pid_t
+ )
+
+ add_gen_header(
+ stdbit
+ DEF_FILE stdbit.h.def
+ GEN_HDR stdbit.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.stdbit_macros
+ )
+
+ add_gen_header(
+ stdckdint
+ DEF_FILE stdckdint.h.def
+ GEN_HDR stdckdint.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.stdckdint_macros
+ )
+
+ add_gen_header(
+ stdio
+ DEF_FILE stdio.h.def
+ GEN_HDR stdio.h
+ DEPENDS
+ .llvm-libc-macros.file_seek_macros
+ .llvm-libc-macros.stdio_macros
+ .llvm-libc-types.FILE
+ .llvm-libc-types.cookie_io_functions_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ .llvm_libc_common_h
+ )
+
+ add_gen_header(
+ stdlib
+ DEF_FILE stdlib.h.def
+ GEN_HDR stdlib.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.stdlib_macros
+ .llvm-libc-types.div_t
+ .llvm-libc-types.ldiv_t
+ .llvm-libc-types.lldiv_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.__bsearchcompare_t
+ .llvm-libc-types.__qsortcompare_t
+ .llvm-libc-types.__qsortrcompare_t
+ .llvm-libc-types.__atexithandler_t
+ )
+
+ add_gen_header(
+ unistd
+ DEF_FILE unistd.h.def
+ GEN_HDR unistd.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.file_seek_macros
+ .llvm-libc-macros.unistd_macros
+ .llvm-libc-types.__exec_argv_t
+ .llvm-libc-types.__exec_envp_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ .llvm-libc-types.uid_t
+ .llvm-libc-types.__getoptargv_t
+ )
+
+ add_gen_header(
+ pthread
+ DEF_FILE pthread.h.def
+ GEN_HDR pthread.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.__atfork_callback_t
+ .llvm-libc-types.__pthread_once_func_t
+ .llvm-libc-types.__pthread_start_t
+ .llvm-libc-types.__pthread_tss_dtor_t
+ .llvm-libc-types.pthread_attr_t
+ .llvm-libc-types.pthread_condattr_t
+ .llvm-libc-types.pthread_key_t
+ .llvm-libc-types.pthread_mutex_t
+ .llvm-libc-types.pthread_mutexattr_t
+ .llvm-libc-types.pthread_once_t
+ .llvm-libc-types.pthread_rwlock_t
+ .llvm-libc-types.pthread_rwlockattr_t
+ .llvm-libc-types.pthread_t
+ )
+
+ add_gen_header(
+ sched
+ DEF_FILE sched.h.def
+ GEN_HDR sched.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sched_macros
+ .llvm-libc-types.cpu_set_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.struct_sched_param
+ # Needed according to posix standard
+ .llvm-libc-types.time_t
+ .llvm-libc-types.struct_timespec
+ )
+
+ add_gen_header(
+ spawn
+ DEF_FILE spawn.h.def
+ GEN_HDR spawn.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.posix_spawnattr_t
+ .llvm-libc-types.posix_spawn_file_actions_t
+ )
+
+ # TODO: Not all platforms will have a include/sys directory. Add the sys
+ # directory and the targets for sys/*.h files conditional to the OS requiring
+ # them.
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/sys)
+
+ add_gen_header(
+ sys_auxv
+ DEF_FILE sys/auxv.h.def
+ GEN_HDR sys/auxv.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_auxv_macros
+ )
+
+ add_gen_header(
+ sys_epoll
+ DEF_FILE sys/epoll.h.def
+ GEN_HDR sys/epoll.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_epoll_event
+ .llvm-libc-types.struct_epoll_data
+ .llvm-libc-types.sigset_t
+ .llvm-libc-macros.sys_epoll_macros
+ )
+
+ add_gen_header(
+ sys_ioctl
+ DEF_FILE sys/ioctl.h.def
+ GEN_HDR sys/ioctl.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_ioctl_macros
+ )
+
+ add_gen_header(
+ sys_mman
+ DEF_FILE sys/mman.h.def
+ GEN_HDR sys/mman.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_mman_macros
+ .llvm-libc-types.off_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ )
+
+ add_gen_header(
+ sys_prctl
+ DEF_FILE sys/prctl.h.def
+ GEN_HDR sys/prctl.h
+ DEPENDS
+ .llvm_libc_common_h
+ )
+
+ add_header(
+ sys_queue
+ HDR
+ sys/queue.h
+ DEPENDS
+ .llvm-libc-macros.sys_queue_macros
+ )
+
+ add_gen_header(
+ sys_random
+ DEF_FILE sys/random.h.def
+ GEN_HDR sys/random.h
DEPENDS
.llvm_libc_common_h
- .llvm-libc-types.rpc_opcodes_t
+ .llvm-libc-macros.sys_random_macros
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
)
+
+ add_gen_header(
+ sys_resource
+ DEF_FILE sys/resource.h.def
+ GEN_HDR sys/resource.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_resource_macros
+ .llvm-libc-types.rlim_t
+ .llvm-libc-types.struct_rlimit
+ )
+
+ add_gen_header(
+ sys_stat
+ DEF_FILE sys/stat.h.def
+ GEN_HDR sys/stat.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_stat_macros
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.dev_t
+ .llvm-libc-types.ino_t
+ .llvm-libc-types.nlink_t
+ .llvm-libc-types.uid_t
+ .llvm-libc-types.gid_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.struct_timespec
+ .llvm-libc-types.struct_timeval
+ .llvm-libc-types.blksize_t
+ .llvm-libc-types.blkcnt_t
+ .llvm-libc-types.struct_stat
+ )
+
+ add_gen_header(
+ sys_select
+ DEF_FILE sys/select.h.def
+ GEN_HDR sys/select.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_select_macros
+ .llvm-libc-types.fd_set
+ .llvm-libc-types.sigset_t
+ .llvm-libc-types.suseconds_t
+ .llvm-libc-types.time_t
+ .llvm-libc-types.struct_timespec
+ .llvm-libc-types.struct_timeval
+ )
+
+ add_gen_header(
+ sys_sendfile
+ DEF_FILE sys/sendfile.h.def
+ GEN_HDR sys/sendfile.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.off_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ )
+
+ add_gen_header(
+ sys_socket
+ DEF_FILE sys/socket.h.def
+ GEN_HDR sys/socket.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_socket_macros
+ .llvm-libc-types.sa_family_t
+ .llvm-libc-types.socklen_t
+ .llvm-libc-types.struct_sockaddr
+ .llvm-libc-types.struct_sockaddr_un
+ )
+
+ add_gen_header(
+ sys_statvfs
+ DEF_FILE sys/statvfs.h.def
+ GEN_HDR sys/statvfs.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_statvfs
+ )
+
+ add_gen_header(
+ sys_syscall
+ DEF_FILE sys/syscall.h.def
+ GEN_HDR sys/syscall.h
+ )
+
+ add_gen_header(
+ sys_time
+ DEF_FILE sys/time.h.def
+ GEN_HDR sys/time.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_timeval
+ .llvm-libc-macros.sys_time_macros
+ )
+
+ add_gen_header(
+ sys_types
+ DEF_FILE sys/types.h.def
+ GEN_HDR sys/types.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.blkcnt_t
+ .llvm-libc-types.blksize_t
+ .llvm-libc-types.clockid_t
+ .llvm-libc-types.dev_t
+ .llvm-libc-types.gid_t
+ .llvm-libc-types.ino_t
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.nlink_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.pthread_attr_t
+ .llvm-libc-types.pthread_key_t
+ .llvm-libc-types.pthread_mutex_t
+ .llvm-libc-types.pthread_mutexattr_t
+ .llvm-libc-types.pthread_once_t
+ .llvm-libc-types.pthread_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ .llvm-libc-types.suseconds_t
+ .llvm-libc-types.time_t
+ .llvm-libc-types.uid_t
+ )
+
+ add_gen_header(
+ sys_utsname
+ DEF_FILE sys/utsname.h.def
+ GEN_HDR sys/utsname.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_utsname
+ )
+
+ add_gen_header(
+ sys_wait
+ DEF_FILE sys/wait.h.def
+ GEN_HDR sys/wait.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_wait_macros
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.struct_rusage
+ .llvm-libc-types.siginfo_t
+ )
+
+ add_gen_header(
+ termios
+ DEF_FILE termios.h.def
+ GEN_HDR termios.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.termios_macros
+ .llvm-libc-types.cc_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.speed_t
+ .llvm-libc-types.struct_termios
+ .llvm-libc-types.tcflag_t
+ )
+
+ add_gen_header(
+ uchar
+ DEF_FILE uchar.h.def
+ GEN_HDR uchar.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.mbstate_t
+ .llvm-libc-types.char8_t
+ .llvm-libc-types.char16_t
+ .llvm-libc-types.char32_t
+ )
+
+ add_gen_header(
+ wchar
+ DEF_FILE wchar.h.def
+ GEN_HDR wchar.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.wchar_macros
+ .llvm-libc-types.mbstate_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.wint_t
+ .llvm-libc-types.wchar_t
+ )
+
+ if(LIBC_TARGET_OS_IS_GPU)
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/gpu)
+
+ add_gen_header(
+ gpu_rpc
+ DEF_FILE gpu/rpc.h.def
+ GEN_HDR gpu/rpc.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.rpc_opcodes_t
+ )
+ endif()
endif()
if(NOT LLVM_LIBC_FULL_BUILD)
>From cb20a5f098f4340557b65587f1f1d90504fb16bc Mon Sep 17 00:00:00 2001
From: Rose Zhang <rosezhang at google.com>
Date: Mon, 15 Jul 2024 23:05:58 +0000
Subject: [PATCH 06/17] added option and changed name to start with LIBC_
---
libc/CMakeLists.txt | 1 +
libc/include/CMakeLists.txt | 2 +-
2 files changed, 2 insertions(+), 1 deletion(-)
diff --git a/libc/CMakeLists.txt b/libc/CMakeLists.txt
index 6ba54475d0fd1..c89897f2900fe 100644
--- a/libc/CMakeLists.txt
+++ b/libc/CMakeLists.txt
@@ -72,6 +72,7 @@ option(LIBC_BUILD_GPU_LOADER "Always build the GPU loader utilities" OFF)
if(LIBC_BUILD_GPU_LOADER OR (LLVM_LIBC_GPU_BUILD AND NOT LLVM_RUNTIMES_BUILD))
add_subdirectory(utils/gpu)
endif()
+option(LIBC_USE_NEW_HEADER_GEN "Generate header files using new headergen instead of the old one" ON)
set(NEED_LIBC_HDRGEN FALSE)
if(NOT LLVM_RUNTIMES_BUILD)
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index 3a9f511d47d77..91fd8ce1a1f79 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -17,7 +17,7 @@ add_header(
__llvm-libc-common.h
)
-if (USE_NEW_HEADER_GEN)
+if (LIBC_USE_NEW_HEADER_GEN)
add_gen_header2(
ctype
YAML_FILE ../libc/newhdrgen/yaml/ctype.yaml
>From ea8b7a160223b6119fa9cb689a2de3e94cc667e7 Mon Sep 17 00:00:00 2001
From: Aaryan Shukla <aaryanshukla at google.com>
Date: Mon, 15 Jul 2024 23:50:38 +0000
Subject: [PATCH 07/17] spacing for gpu target and assert.yaml
---
libc/cmake/modules/LLVMLibCHeaderRules.cmake | 22 ++++++++++----------
libc/include/CMakeLists.txt | 1 +
2 files changed, 12 insertions(+), 11 deletions(-)
diff --git a/libc/cmake/modules/LLVMLibCHeaderRules.cmake b/libc/cmake/modules/LLVMLibCHeaderRules.cmake
index b87137c5f1a0d..121dab0e40c1b 100644
--- a/libc/cmake/modules/LLVMLibCHeaderRules.cmake
+++ b/libc/cmake/modules/LLVMLibCHeaderRules.cmake
@@ -243,18 +243,18 @@ function(add_gen_header target_name)
file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/llvm-libc-decls/gpu)
set(decl_out_file ${LIBC_INCLUDE_DIR}/llvm-libc-decls/${relative_path})
add_custom_command(
- OUTPUT ${decl_out_file}
- COMMAND ${hdrgen_exe} -o ${decl_out_file}
- --header ${ADD_GEN_HDR_GEN_HDR} --def ${in_file} --export-decls
- ${replacement_params} -I ${LIBC_SOURCE_DIR} ${ENTRYPOINT_NAME_LIST_ARG}
- ${LIBC_SOURCE_DIR}/config/${LIBC_TARGET_OS}/api.td
+ OUTPUT ${decl_out_file}
+ COMMAND ${hdrgen_exe} -o ${decl_out_file}
+ --header ${ADD_GEN_HDR_GEN_HDR} --def ${in_file} --export-decls
+ ${replacement_params} -I ${LIBC_SOURCE_DIR} ${ENTRYPOINT_NAME_LIST_ARG}
+ ${LIBC_SOURCE_DIR}/config/${LIBC_TARGET_OS}/api.td
- WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
- DEPENDS ${in_file} ${fq_data_files} ${td_includes}
- ${LIBC_SOURCE_DIR}/config/${LIBC_TARGET_OS}/api.td
- ${hdrgen_deps}
- )
-endif()
+ WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
+ DEPENDS ${in_file} ${fq_data_files} ${td_includes}
+ ${LIBC_SOURCE_DIR}/config/${LIBC_TARGET_OS}/api.td
+ ${hdrgen_deps}
+ )
+ endif()
if(ADD_GEN_HDR_DEPENDS)
get_fq_deps_list(fq_deps_list ${ADD_GEN_HDR_DEPENDS})
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index 91fd8ce1a1f79..bd07a3dc9b3d0 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -162,6 +162,7 @@ if (LIBC_USE_NEW_HEADER_GEN)
add_gen_header2(
assert
+ YAML_FILE ../libc/newhdrgen/yaml/assert.yaml
DEF_FILE assert.h.def
GEN_HDR assert.h
DEPENDS
>From 09f03a446d23d83ee3d0d6b2ea6c8f7e09fdf8e9 Mon Sep 17 00:00:00 2001
From: Rose Zhang <rosezhang at google.com>
Date: Tue, 16 Jul 2024 00:28:33 +0000
Subject: [PATCH 08/17] added macro
---
libc/include/CMakeLists.txt | 1871 ++++++++++++-----------------------
1 file changed, 632 insertions(+), 1239 deletions(-)
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index bd07a3dc9b3d0..5ad09e4ae8aad 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -17,1304 +17,697 @@ add_header(
__llvm-libc-common.h
)
-if (LIBC_USE_NEW_HEADER_GEN)
- add_gen_header2(
- ctype
- YAML_FILE ../libc/newhdrgen/yaml/ctype.yaml
- DEF_FILE ctype.h.def
- GEN_HDR ctype.h
- DEPENDS
- .llvm_libc_common_h
- )
-
- add_gen_header2(
- dirent
- YAML_FILE ../libc/newhdrgen/yaml/dirent.yaml
- DEF_FILE dirent.h.def
- GEN_HDR dirent.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.ino_t
- .llvm-libc-types.DIR
- .llvm-libc-types.struct_dirent
- )
-
- add_gen_header2(
- fcntl
- YAML_FILE ../libc/newhdrgen/yaml/fcntl.yaml
- DEF_FILE fcntl.h.def
- GEN_HDR fcntl.h
- DEPENDS
- .llvm-libc-macros.fcntl_macros
- .llvm-libc-types.mode_t
- .llvm-libc-types.struct_flock
- .llvm-libc-types.struct_flock64
- .llvm-libc-types.off64_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.off_t
- .llvm_libc_common_h
- )
-
- add_gen_header2(
- dlfcn
- YAML_FILE ../libc/newhdrgen/yaml/dlfcn.yaml
- DEF_FILE dlfcn.h.def
- GEN_HDR dlfcn.h
- DEPENDS
- .llvm-libc-macros.dlfcn_macros
- .llvm_libc_common_h
- )
-
- add_gen_header2(
- features
- YAML_FILE ../libc/newhdrgen/yaml/features.yaml
- DEF_FILE features.h.def
- GEN_HDR features.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.features_macros
- )
-
- add_gen_header2(
- fenv
- YAML_FILE ../libc/newhdrgen/yaml/fenv.yaml
- DEF_FILE fenv.h.def
- GEN_HDR fenv.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.fenv_macros
- .llvm-libc-types.fenv_t
- .llvm-libc-types.fexcept_t
- )
-
- add_gen_header2(
- inttypes
- YAML_FILE ../libc/newhdrgen/yaml/inttypes.yaml
- DEF_FILE inttypes.h.def
- GEN_HDR inttypes.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.imaxdiv_t
- .llvm-libc-macros.inttypes_macros
- )
-
- add_gen_header2(
- float
- YAML_FILE ../libc/newhdrgen/yaml/float.yaml
- DEF_FILE float.h.def
- GEN_HDR float.h
- DEPENDS
- .llvm-libc-macros.float_macros
- )
-
- add_gen_header2(
- stdint
- YAML_FILE ../libc/newhdrgen/yaml/stdint.yaml
- DEF_FILE stdint.h.def
- GEN_HDR stdint.h
- DEPENDS
- .llvm-libc-macros.stdint_macros
- )
-
- add_gen_header2(
- limits
- YAML_FILE ../libc/newhdrgen/yaml/limits.yaml
- DEF_FILE limits.h.def
- GEN_HDR limits.h
- DEPENDS
- .llvm-libc-macros.limits_macros
- )
-
- add_gen_header2(
- math
- YAML_FILE ../libc/newhdrgen/yaml/math.yaml
- DEF_FILE math.h.def
- GEN_HDR math.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.float16_macros
- .llvm-libc-macros.math_macros
- .llvm-libc-types.double_t
- .llvm-libc-types.float_t
- .llvm-libc-types.float128
- )
-
- add_gen_header2(
- stdfix
- YAML_FILE ../libc/newhdrgen/yaml/stdfix.yaml
- DEF_FILE stdfix.h.def
- GEN_HDR stdfix.h
- DEPENDS
- .llvm-libc-macros.stdfix_macros
- )
-
- # TODO: This should be conditional on POSIX networking being included.
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/arpa)
-
- add_gen_header2(
- arpa_inet
- YAML_FILE ../libc/newhdrgen/yaml/arpa_inet.yaml
- DEF_FILE arpa/inet.h.def
- GEN_HDR arpa/inet.h
- DEPENDS
- .llvm_libc_common_h
- )
-
- add_gen_header2(
- assert
- YAML_FILE ../libc/newhdrgen/yaml/assert.yaml
- DEF_FILE assert.h.def
- GEN_HDR assert.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.assert_macros
- )
-
- add_gen_header2(
- setjmp
- YAML_FILE ../libc/newhdrgen/yaml/setjmp.yaml
- DEF_FILE setjmp.h.def
- GEN_HDR setjmp.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.jmp_buf
- )
-
- add_gen_header2(
- string
- YAML_FILE ../libc/newhdrgen/yaml/string.yaml
- DEF_FILE string.h.def
- GEN_HDR string.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.null_macro
- .llvm-libc-types.size_t
- )
-
- add_gen_header2(
- strings
- YAML_FILE ../libc/newhdrgen/yaml/strings.yaml
- DEF_FILE strings.h.def
- GEN_HDR strings.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.size_t
- )
-
- add_gen_header2(
- search
- YAML_FILE ../libc/newhdrgen/yaml/search.yaml
- DEF_FILE search.h.def
- GEN_HDR search.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.ACTION
- .llvm-libc-types.ENTRY
- .llvm-libc-types.struct_hsearch_data
- .llvm-libc-types.size_t
- )
-
- add_gen_header2(
- time
- YAML_FILE ../libc/newhdrgen/yaml/time.yaml
- DEF_FILE time.h.def
- GEN_HDR time.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.time_macros
- .llvm-libc-types.clock_t
- .llvm-libc-types.time_t
- .llvm-libc-types.struct_tm
- .llvm-libc-types.struct_timespec
- .llvm-libc-types.struct_timeval
- .llvm-libc-types.clockid_t
- )
-
- add_gen_header2(
- threads
- YAML_FILE ../libc/newhdrgen/yaml/threads.yaml
- DEF_FILE threads.h.def
- GEN_HDR threads.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.__call_once_func_t
- .llvm-libc-types.once_flag
- .llvm-libc-types.cnd_t
- .llvm-libc-types.mtx_t
- .llvm-libc-types.thrd_t
- .llvm-libc-types.thrd_start_t
- .llvm-libc-types.tss_t
- .llvm-libc-types.tss_dtor_t
- )
-
- add_gen_header2(
- errno
- YAML_FILE ../libc/newhdrgen/yaml/errno.yaml
- DEF_FILE errno.h.def
- GEN_HDR errno.h
- DEPENDS
- .llvm-libc-macros.generic_error_number_macros
- .llvm-libc-macros.error_number_macros
- )
-
- add_gen_header2(
- signal
- YAML_FILE ../libc/newhdrgen/yaml/signal.yaml
- DEF_FILE signal.h.def
- GEN_HDR signal.h
- DEPENDS
- .llvm-libc-macros.signal_macros
- .llvm-libc-types.sig_atomic_t
- .llvm-libc-types.sigset_t
- .llvm-libc-types.struct_sigaction
- .llvm-libc-types.union_sigval
- .llvm-libc-types.siginfo_t
- .llvm-libc-types.stack_t
- .llvm-libc-types.pid_t
- )
-
- add_gen_header2(
- stdbit
- YAML_FILE ../libc/newhdrgen/yaml/stdbit.yaml
- DEF_FILE stdbit.h.def
- GEN_HDR stdbit.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.stdbit_macros
- )
-
- add_gen_header2(
- stdckdint
- YAML_FILE ../libc/newhdrgen/yaml/stdckdint.yaml
- DEF_FILE stdckdint.h.def
- GEN_HDR stdckdint.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.stdckdint_macros
- )
-
- add_gen_header2(
- stdio
- YAML_FILE ../libc/newhdrgen/yaml/stdio.yaml
- DEF_FILE stdio.h.def
- GEN_HDR stdio.h
- DEPENDS
- .llvm-libc-macros.file_seek_macros
- .llvm-libc-macros.stdio_macros
- .llvm-libc-types.FILE
- .llvm-libc-types.cookie_io_functions_t
- .llvm-libc-types.off_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- .llvm_libc_common_h
- )
-
- add_gen_header2(
- stdlib
- YAML_FILE ../libc/newhdrgen/yaml/stdlib.yaml
- DEF_FILE stdlib.h.def
- GEN_HDR stdlib.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.stdlib_macros
- .llvm-libc-types.div_t
- .llvm-libc-types.ldiv_t
- .llvm-libc-types.lldiv_t
- .llvm-libc-types.size_t
- .llvm-libc-types.__bsearchcompare_t
- .llvm-libc-types.__qsortcompare_t
- .llvm-libc-types.__qsortrcompare_t
- .llvm-libc-types.__atexithandler_t
- )
-
- add_gen_header2(
- unistd
- YAML_FILE ../libc/newhdrgen/yaml/unistd.yaml
- DEF_FILE unistd.h.def
- GEN_HDR unistd.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.file_seek_macros
- .llvm-libc-macros.unistd_macros
- .llvm-libc-types.__exec_argv_t
- .llvm-libc-types.__exec_envp_t
- .llvm-libc-types.off_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- .llvm-libc-types.uid_t
- .llvm-libc-types.__getoptargv_t
- )
-
- add_gen_header2(
- pthread
- YAML_FILE ../libc/newhdrgen/yaml/pthread.yaml
- DEF_FILE pthread.h.def
- GEN_HDR pthread.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.__atfork_callback_t
- .llvm-libc-types.__pthread_once_func_t
- .llvm-libc-types.__pthread_start_t
- .llvm-libc-types.__pthread_tss_dtor_t
- .llvm-libc-types.pthread_attr_t
- .llvm-libc-types.pthread_condattr_t
- .llvm-libc-types.pthread_key_t
- .llvm-libc-types.pthread_mutex_t
- .llvm-libc-types.pthread_mutexattr_t
- .llvm-libc-types.pthread_once_t
- .llvm-libc-types.pthread_rwlock_t
- .llvm-libc-types.pthread_rwlockattr_t
- .llvm-libc-types.pthread_t
- )
-
- add_gen_header2(
- sched
- YAML_FILE ../libc/newhdrgen/yaml/sched.yaml
- DEF_FILE sched.h.def
- GEN_HDR sched.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sched_macros
- .llvm-libc-types.cpu_set_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.size_t
- .llvm-libc-types.struct_sched_param
- # Needed according to posix standard
- .llvm-libc-types.time_t
- .llvm-libc-types.struct_timespec
- )
-
- add_gen_header2(
- spawn
- YAML_FILE ../libc/newhdrgen/yaml/spawn.yaml
- DEF_FILE spawn.h.def
- GEN_HDR spawn.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.mode_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.posix_spawnattr_t
- .llvm-libc-types.posix_spawn_file_actions_t
- )
-
- # TODO: Not all platforms will have a include/sys directory. Add the sys
- # directory and the targets for sys/*.h files conditional to the OS requiring
- # them.
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/sys)
-
- add_gen_header2(
- sys_auxv
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_auxv.yaml
- DEF_FILE sys/auxv.h.def
- GEN_HDR sys/auxv.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_auxv_macros
- )
-
- add_gen_header2(
- sys_epoll
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_epoll.yaml
- DEF_FILE sys/epoll.h.def
- GEN_HDR sys/epoll.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_epoll_event
- .llvm-libc-types.struct_epoll_data
- .llvm-libc-types.sigset_t
- .llvm-libc-macros.sys_epoll_macros
- )
-
- add_gen_header2(
- sys_ioctl
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_ioctl.yaml
- DEF_FILE sys/ioctl.h.def
- GEN_HDR sys/ioctl.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_ioctl_macros
- )
-
- add_gen_header2(
- sys_mman
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_mman.yaml
- DEF_FILE sys/mman.h.def
- GEN_HDR sys/mman.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_mman_macros
- .llvm-libc-types.off_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- )
-
- add_gen_header2(
- sys_prctl
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_prctl.yaml
- DEF_FILE sys/prctl.h.def
- GEN_HDR sys/prctl.h
- DEPENDS
- .llvm_libc_common_h
- )
-
- add_header(
- sys_queue
- HDR
- sys/queue.h
- DEPENDS
- .llvm-libc-macros.sys_queue_macros
- )
-
- add_gen_header2(
- sys_random
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_random.yaml
- DEF_FILE sys/random.h.def
- GEN_HDR sys/random.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_random_macros
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- )
-
- add_gen_header2(
- sys_resource
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_resource.yaml
- DEF_FILE sys/resource.h.def
- GEN_HDR sys/resource.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_resource_macros
- .llvm-libc-types.rlim_t
- .llvm-libc-types.struct_rlimit
- )
-
- add_gen_header2(
- sys_stat
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_stat.yaml
- DEF_FILE sys/stat.h.def
- GEN_HDR sys/stat.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_stat_macros
- .llvm-libc-types.mode_t
- .llvm-libc-types.dev_t
- .llvm-libc-types.ino_t
- .llvm-libc-types.nlink_t
- .llvm-libc-types.uid_t
- .llvm-libc-types.gid_t
- .llvm-libc-types.off_t
- .llvm-libc-types.struct_timespec
- .llvm-libc-types.struct_timeval
- .llvm-libc-types.blksize_t
- .llvm-libc-types.blkcnt_t
- .llvm-libc-types.struct_stat
- )
-
- add_gen_header2(
- sys_select
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_select.yaml
- DEF_FILE sys/select.h.def
- GEN_HDR sys/select.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_select_macros
- .llvm-libc-types.fd_set
- .llvm-libc-types.sigset_t
- .llvm-libc-types.suseconds_t
- .llvm-libc-types.time_t
- .llvm-libc-types.struct_timespec
- .llvm-libc-types.struct_timeval
- )
-
- add_gen_header2(
- sys_sendfile
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_sendfile.yaml
- DEF_FILE sys/sendfile.h.def
- GEN_HDR sys/sendfile.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.off_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- )
-
- add_gen_header2(
- sys_socket
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_socket.yaml
- DEF_FILE sys/socket.h.def
- GEN_HDR sys/socket.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_socket_macros
- .llvm-libc-types.sa_family_t
- .llvm-libc-types.socklen_t
- .llvm-libc-types.struct_sockaddr
- .llvm-libc-types.struct_sockaddr_un
- )
-
- add_gen_header2(
- sys_statvfs
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_statvfs.yaml
- DEF_FILE sys/statvfs.h.def
- GEN_HDR sys/statvfs.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_statvfs
- )
-
- add_gen_header2(
- sys_syscall
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_syscall.yaml
- DEF_FILE sys/syscall.h.def
- GEN_HDR sys/syscall.h
- )
-
- add_gen_header2(
- sys_time
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_time.yaml
- DEF_FILE sys/time.h.def
- GEN_HDR sys/time.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_timeval
- .llvm-libc-macros.sys_time_macros
- )
-
- add_gen_header2(
- sys_types
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_types.yaml
- DEF_FILE sys/types.h.def
- GEN_HDR sys/types.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.blkcnt_t
- .llvm-libc-types.blksize_t
- .llvm-libc-types.clockid_t
- .llvm-libc-types.dev_t
- .llvm-libc-types.gid_t
- .llvm-libc-types.ino_t
- .llvm-libc-types.mode_t
- .llvm-libc-types.nlink_t
- .llvm-libc-types.off_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.pthread_attr_t
- .llvm-libc-types.pthread_key_t
- .llvm-libc-types.pthread_mutex_t
- .llvm-libc-types.pthread_mutexattr_t
- .llvm-libc-types.pthread_once_t
- .llvm-libc-types.pthread_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- .llvm-libc-types.suseconds_t
- .llvm-libc-types.time_t
- .llvm-libc-types.uid_t
- )
-
- add_gen_header2(
- sys_utsname
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_utsname.yaml
- DEF_FILE sys/utsname.h.def
- GEN_HDR sys/utsname.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_utsname
- )
-
- add_gen_header2(
- sys_wait
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_wait.yaml
- DEF_FILE sys/wait.h.def
- GEN_HDR sys/wait.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_wait_macros
- .llvm-libc-types.pid_t
- .llvm-libc-types.struct_rusage
- .llvm-libc-types.siginfo_t
- )
-
- add_gen_header2(
- termios
- YAML_FILE ../libc/newhdrgen/yaml/termios.yaml
- DEF_FILE termios.h.def
- GEN_HDR termios.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.termios_macros
- .llvm-libc-types.cc_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.speed_t
- .llvm-libc-types.struct_termios
- .llvm-libc-types.tcflag_t
- )
-
- add_gen_header2(
- uchar
- YAML_FILE ../libc/newhdrgen/yaml/uchar.yaml
- DEF_FILE uchar.h.def
- GEN_HDR uchar.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.mbstate_t
- .llvm-libc-types.char8_t
- .llvm-libc-types.char16_t
- .llvm-libc-types.char32_t
- )
-
- add_gen_header2(
- wchar
- YAML_FILE ../libc/newhdrgen/yaml/wchar.yaml
- DEF_FILE wchar.h.def
- GEN_HDR wchar.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.wchar_macros
- .llvm-libc-types.mbstate_t
- .llvm-libc-types.size_t
- .llvm-libc-types.wint_t
- .llvm-libc-types.wchar_t
- )
-
- if(LIBC_TARGET_OS_IS_GPU)
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/gpu)
-
+macro(add_header_macro TYPE YAML_FILE DEF_FILE GEN_HDR DEPENDS)
+ if (LIBC_USE_NEW_HEADER_GEN)
add_gen_header2(
- gpu_rpc
- YAML_FILE ../libc/newhdrgen/yaml/rpc.yaml
- DEF_FILE gpu/rpc.h.def
- GEN_HDR gpu/rpc.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.rpc_opcodes_t
+ ${TYPE}
+ ${YAML_FILE}
+ ${DEF_FILE}
+ ${GEN_HDR}
+ ${DEPENDS}
+ )
+ else()
+ add_gen_header(
+ ${TYPE}
+ ${DEF_FILE}
+ ${GEN_HDR}
+ ${DEPENDS}
)
endif()
-else()
- add_gen_header(
- ctype
- DEF_FILE ctype.h.def
- GEN_HDR ctype.h
- DEPENDS
- .llvm_libc_common_h
- )
+endmacro()
+
+add_header_macro(
+ ctype
+ YAML_FILE ../libc/newhdrgen/yaml/ctype.yaml
+ DEF_FILE ctype.h.def
+ GEN_HDR ctype.h
+ DEPENDS
+ .llvm_libc_common_h
+)
- add_gen_header(
- dirent
- DEF_FILE dirent.h.def
- GEN_HDR dirent.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.ino_t
- .llvm-libc-types.DIR
- .llvm-libc-types.struct_dirent
- )
+add_header_macro(
+ dirent
+ YAML_FILE ../libc/newhdrgen/yaml/dirent.yaml
+ DEF_FILE dirent.h.def
+ GEN_HDR dirent.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.ino_t
+ .llvm-libc-types.DIR
+ .llvm-libc-types.struct_dirent
+)
- add_gen_header(
- fcntl
- DEF_FILE fcntl.h.def
- GEN_HDR fcntl.h
- DEPENDS
- .llvm-libc-macros.fcntl_macros
- .llvm-libc-types.mode_t
- .llvm-libc-types.struct_flock
- .llvm-libc-types.struct_flock64
- .llvm-libc-types.off64_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.off_t
- .llvm_libc_common_h
- )
+add_header_macro(
+ fcntl
+ YAML_FILE ../libc/newhdrgen/yaml/fcntl.yaml
+ DEF_FILE fcntl.h.def
+ GEN_HDR fcntl.h
+ DEPENDS
+ .llvm-libc-macros.fcntl_macros
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.struct_flock
+ .llvm-libc-types.struct_flock64
+ .llvm-libc-types.off64_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.off_t
+ .llvm_libc_common_h
+)
- add_gen_header(
- dlfcn
- DEF_FILE dlfcn.h.def
- GEN_HDR dlfcn.h
- DEPENDS
- .llvm-libc-macros.dlfcn_macros
- .llvm_libc_common_h
- )
+add_header_macro(
+ dlfcn
+ YAML_FILE ../libc/newhdrgen/yaml/dlfcn.yaml
+ DEF_FILE dlfcn.h.def
+ GEN_HDR dlfcn.h
+ DEPENDS
+ .llvm-libc-macros.dlfcn_macros
+ .llvm_libc_common_h
+)
- add_gen_header(
- features
- DEF_FILE features.h.def
- GEN_HDR features.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.features_macros
- )
+add_header_macro(
+ features
+ YAML_FILE ../libc/newhdrgen/yaml/features.yaml
+ DEF_FILE features.h.def
+ GEN_HDR features.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.features_macros
+)
- add_gen_header(
- fenv
- DEF_FILE fenv.h.def
- GEN_HDR fenv.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.fenv_macros
- .llvm-libc-types.fenv_t
- .llvm-libc-types.fexcept_t
- )
+add_header_macro(
+ fenv
+ YAML_FILE ../libc/newhdrgen/yaml/fenv.yaml
+ DEF_FILE fenv.h.def
+ GEN_HDR fenv.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.fenv_macros
+ .llvm-libc-types.fenv_t
+ .llvm-libc-types.fexcept_t
+)
- add_gen_header(
- inttypes
- DEF_FILE inttypes.h.def
- GEN_HDR inttypes.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.imaxdiv_t
- .llvm-libc-macros.inttypes_macros
- )
+add_header_macro(
+ inttypes
+ YAML_FILE ../libc/newhdrgen/yaml/inttypes.yaml
+ DEF_FILE inttypes.h.def
+ GEN_HDR inttypes.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.imaxdiv_t
+ .llvm-libc-macros.inttypes_macros
+)
- add_gen_header(
- float
- DEF_FILE float.h.def
- GEN_HDR float.h
- DEPENDS
- .llvm-libc-macros.float_macros
- )
+add_header_macro(
+ float
+ YAML_FILE ../libc/newhdrgen/yaml/float.yaml
+ DEF_FILE float.h.def
+ GEN_HDR float.h
+ DEPENDS
+ .llvm-libc-macros.float_macros
+)
- add_gen_header(
- stdint
- DEF_FILE stdint.h.def
- GEN_HDR stdint.h
- DEPENDS
- .llvm-libc-macros.stdint_macros
- )
+add_header_macro(
+ stdint
+ YAML_FILE ../libc/newhdrgen/yaml/stdint.yaml
+ DEF_FILE stdint.h.def
+ GEN_HDR stdint.h
+ DEPENDS
+ .llvm-libc-macros.stdint_macros
+)
- add_gen_header(
- limits
- DEF_FILE limits.h.def
- GEN_HDR limits.h
- DEPENDS
- .llvm-libc-macros.limits_macros
- )
+add_header_macro(
+ limits
+ YAML_FILE ../libc/newhdrgen/yaml/limits.yaml
+ DEF_FILE limits.h.def
+ GEN_HDR limits.h
+ DEPENDS
+ .llvm-libc-macros.limits_macros
+)
- add_gen_header(
- math
- DEF_FILE math.h.def
- GEN_HDR math.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.float16_macros
- .llvm-libc-macros.math_macros
- .llvm-libc-macros.math_function_macros
- .llvm-libc-types.double_t
- .llvm-libc-types.float_t
- .llvm-libc-types.float128
- )
+add_header_macro(
+ math
+ YAML_FILE ../libc/newhdrgen/yaml/math.yaml
+ DEF_FILE math.h.def
+ GEN_HDR math.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.float16_macros
+ .llvm-libc-macros.math_macros
+ .llvm-libc-types.double_t
+ .llvm-libc-types.float_t
+ .llvm-libc-types.float128
+)
- add_gen_header(
- stdfix
- DEF_FILE stdfix.h.def
- GEN_HDR stdfix.h
- DEPENDS
- .llvm-libc-macros.stdfix_macros
- )
+add_header_macro(
+ stdfix
+ YAML_FILE ../libc/newhdrgen/yaml/stdfix.yaml
+ DEF_FILE stdfix.h.def
+ GEN_HDR stdfix.h
+ DEPENDS
+ .llvm-libc-macros.stdfix_macros
+)
- # TODO: This should be conditional on POSIX networking being included.
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/arpa)
+# TODO: This should be conditional on POSIX networking being included.
+file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/arpa)
- add_gen_header(
- arpa_inet
- DEF_FILE arpa/inet.h.def
- GEN_HDR arpa/inet.h
- DEPENDS
- .llvm_libc_common_h
- )
+add_header_macro(
+ arpa_inet
+ YAML_FILE ../libc/newhdrgen/yaml/arpa_inet.yaml
+ DEF_FILE arpa/inet.h.def
+ GEN_HDR arpa/inet.h
+ DEPENDS
+ .llvm_libc_common_h
+)
- add_gen_header(
- assert
- DEF_FILE assert.h.def
- GEN_HDR assert.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.assert_macros
- )
+add_header_macro(
+ assert
+ YAML_FILE ../libc/newhdrgen/yaml/assert.yaml
+ DEF_FILE assert.h.def
+ GEN_HDR assert.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.assert_macros
+)
- add_gen_header(
- setjmp
- DEF_FILE setjmp.h.def
- GEN_HDR setjmp.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.jmp_buf
- )
+add_header_macro(
+ setjmp
+ YAML_FILE ../libc/newhdrgen/yaml/setjmp.yaml
+ DEF_FILE setjmp.h.def
+ GEN_HDR setjmp.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.jmp_buf
+)
- add_gen_header(
- string
- DEF_FILE string.h.def
- GEN_HDR string.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.null_macro
- .llvm-libc-types.size_t
- )
+add_header_macro(
+ string
+ YAML_FILE ../libc/newhdrgen/yaml/string.yaml
+ DEF_FILE string.h.def
+ GEN_HDR string.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.null_macro
+ .llvm-libc-types.size_t
+)
- add_gen_header(
- strings
- DEF_FILE strings.h.def
- GEN_HDR strings.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.size_t
- )
+add_header_macro(
+ strings
+ YAML_FILE ../libc/newhdrgen/yaml/strings.yaml
+ DEF_FILE strings.h.def
+ GEN_HDR strings.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.size_t
+)
- add_gen_header(
- search
- DEF_FILE search.h.def
- GEN_HDR search.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.ACTION
- .llvm-libc-types.ENTRY
- .llvm-libc-types.struct_hsearch_data
- .llvm-libc-types.size_t
- )
+add_header_macro(
+ search
+ YAML_FILE ../libc/newhdrgen/yaml/search.yaml
+ DEF_FILE search.h.def
+ GEN_HDR search.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.ACTION
+ .llvm-libc-types.ENTRY
+ .llvm-libc-types.struct_hsearch_data
+ .llvm-libc-types.size_t
+)
- add_gen_header(
- time
- DEF_FILE time.h.def
- GEN_HDR time.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.time_macros
- .llvm-libc-types.clock_t
- .llvm-libc-types.time_t
- .llvm-libc-types.struct_tm
- .llvm-libc-types.struct_timespec
- .llvm-libc-types.struct_timeval
- .llvm-libc-types.clockid_t
- )
+add_header_macro(
+ time
+ YAML_FILE ../libc/newhdrgen/yaml/time.yaml
+ DEF_FILE time.h.def
+ GEN_HDR time.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.time_macros
+ .llvm-libc-types.clock_t
+ .llvm-libc-types.time_t
+ .llvm-libc-types.struct_tm
+ .llvm-libc-types.struct_timespec
+ .llvm-libc-types.struct_timeval
+ .llvm-libc-types.clockid_t
+)
- add_gen_header(
- threads
- DEF_FILE threads.h.def
- GEN_HDR threads.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.__call_once_func_t
- .llvm-libc-types.once_flag
- .llvm-libc-types.cnd_t
- .llvm-libc-types.mtx_t
- .llvm-libc-types.thrd_t
- .llvm-libc-types.thrd_start_t
- .llvm-libc-types.tss_t
- .llvm-libc-types.tss_dtor_t
- )
+add_header_macro(
+ threads
+ YAML_FILE ../libc/newhdrgen/yaml/threads.yaml
+ DEF_FILE threads.h.def
+ GEN_HDR threads.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.__call_once_func_t
+ .llvm-libc-types.once_flag
+ .llvm-libc-types.cnd_t
+ .llvm-libc-types.mtx_t
+ .llvm-libc-types.thrd_t
+ .llvm-libc-types.thrd_start_t
+ .llvm-libc-types.tss_t
+ .llvm-libc-types.tss_dtor_t
+)
- add_gen_header(
- errno
- DEF_FILE errno.h.def
- GEN_HDR errno.h
- DEPENDS
- .llvm-libc-macros.generic_error_number_macros
- .llvm-libc-macros.error_number_macros
- )
+add_header_macro(
+ errno
+ YAML_FILE ../libc/newhdrgen/yaml/errno.yaml
+ DEF_FILE errno.h.def
+ GEN_HDR errno.h
+ DEPENDS
+ .llvm-libc-macros.generic_error_number_macros
+ .llvm-libc-macros.error_number_macros
+)
- add_gen_header(
- signal
- DEF_FILE signal.h.def
- GEN_HDR signal.h
- DEPENDS
- .llvm-libc-macros.signal_macros
- .llvm-libc-types.sig_atomic_t
- .llvm-libc-types.sigset_t
- .llvm-libc-types.struct_sigaction
- .llvm-libc-types.union_sigval
- .llvm-libc-types.siginfo_t
- .llvm-libc-types.stack_t
- .llvm-libc-types.pid_t
- )
+add_header_macro(
+ signal
+ YAML_FILE ../libc/newhdrgen/yaml/signal.yaml
+ DEF_FILE signal.h.def
+ GEN_HDR signal.h
+ DEPENDS
+ .llvm-libc-macros.signal_macros
+ .llvm-libc-types.sig_atomic_t
+ .llvm-libc-types.sigset_t
+ .llvm-libc-types.struct_sigaction
+ .llvm-libc-types.union_sigval
+ .llvm-libc-types.siginfo_t
+ .llvm-libc-types.stack_t
+ .llvm-libc-types.pid_t
+)
- add_gen_header(
- stdbit
- DEF_FILE stdbit.h.def
- GEN_HDR stdbit.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.stdbit_macros
- )
+add_header_macro(
+ stdbit
+ YAML_FILE ../libc/newhdrgen/yaml/stdbit.yaml
+ DEF_FILE stdbit.h.def
+ GEN_HDR stdbit.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.stdbit_macros
+)
- add_gen_header(
- stdckdint
- DEF_FILE stdckdint.h.def
- GEN_HDR stdckdint.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.stdckdint_macros
- )
+add_header_macro(
+ stdckdint
+ YAML_FILE ../libc/newhdrgen/yaml/stdckdint.yaml
+ DEF_FILE stdckdint.h.def
+ GEN_HDR stdckdint.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.stdckdint_macros
+)
- add_gen_header(
- stdio
- DEF_FILE stdio.h.def
- GEN_HDR stdio.h
- DEPENDS
- .llvm-libc-macros.file_seek_macros
- .llvm-libc-macros.stdio_macros
- .llvm-libc-types.FILE
- .llvm-libc-types.cookie_io_functions_t
- .llvm-libc-types.off_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- .llvm_libc_common_h
- )
+add_header_macro(
+ stdio
+ YAML_FILE ../libc/newhdrgen/yaml/stdio.yaml
+ DEF_FILE stdio.h.def
+ GEN_HDR stdio.h
+ DEPENDS
+ .llvm-libc-macros.file_seek_macros
+ .llvm-libc-macros.stdio_macros
+ .llvm-libc-types.FILE
+ .llvm-libc-types.cookie_io_functions_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ .llvm_libc_common_h
+)
- add_gen_header(
- stdlib
- DEF_FILE stdlib.h.def
- GEN_HDR stdlib.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.stdlib_macros
- .llvm-libc-types.div_t
- .llvm-libc-types.ldiv_t
- .llvm-libc-types.lldiv_t
- .llvm-libc-types.size_t
- .llvm-libc-types.__bsearchcompare_t
- .llvm-libc-types.__qsortcompare_t
- .llvm-libc-types.__qsortrcompare_t
- .llvm-libc-types.__atexithandler_t
- )
+add_header_macro(
+ stdlib
+ YAML_FILE ../libc/newhdrgen/yaml/stdlib.yaml
+ DEF_FILE stdlib.h.def
+ GEN_HDR stdlib.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.stdlib_macros
+ .llvm-libc-types.div_t
+ .llvm-libc-types.ldiv_t
+ .llvm-libc-types.lldiv_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.__bsearchcompare_t
+ .llvm-libc-types.__qsortcompare_t
+ .llvm-libc-types.__qsortrcompare_t
+ .llvm-libc-types.__atexithandler_t
+)
- add_gen_header(
- unistd
- DEF_FILE unistd.h.def
- GEN_HDR unistd.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.file_seek_macros
- .llvm-libc-macros.unistd_macros
- .llvm-libc-types.__exec_argv_t
- .llvm-libc-types.__exec_envp_t
- .llvm-libc-types.off_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- .llvm-libc-types.uid_t
- .llvm-libc-types.__getoptargv_t
- )
+add_header_macro(
+ unistd
+ YAML_FILE ../libc/newhdrgen/yaml/unistd.yaml
+ DEF_FILE unistd.h.def
+ GEN_HDR unistd.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.file_seek_macros
+ .llvm-libc-macros.unistd_macros
+ .llvm-libc-types.__exec_argv_t
+ .llvm-libc-types.__exec_envp_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ .llvm-libc-types.uid_t
+ .llvm-libc-types.__getoptargv_t
+)
- add_gen_header(
- pthread
- DEF_FILE pthread.h.def
- GEN_HDR pthread.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.__atfork_callback_t
- .llvm-libc-types.__pthread_once_func_t
- .llvm-libc-types.__pthread_start_t
- .llvm-libc-types.__pthread_tss_dtor_t
- .llvm-libc-types.pthread_attr_t
- .llvm-libc-types.pthread_condattr_t
- .llvm-libc-types.pthread_key_t
- .llvm-libc-types.pthread_mutex_t
- .llvm-libc-types.pthread_mutexattr_t
- .llvm-libc-types.pthread_once_t
- .llvm-libc-types.pthread_rwlock_t
- .llvm-libc-types.pthread_rwlockattr_t
- .llvm-libc-types.pthread_t
- )
+add_header_macro(
+ pthread
+ YAML_FILE ../libc/newhdrgen/yaml/pthread.yaml
+ DEF_FILE pthread.h.def
+ GEN_HDR pthread.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.__atfork_callback_t
+ .llvm-libc-types.__pthread_once_func_t
+ .llvm-libc-types.__pthread_start_t
+ .llvm-libc-types.__pthread_tss_dtor_t
+ .llvm-libc-types.pthread_attr_t
+ .llvm-libc-types.pthread_condattr_t
+ .llvm-libc-types.pthread_key_t
+ .llvm-libc-types.pthread_mutex_t
+ .llvm-libc-types.pthread_mutexattr_t
+ .llvm-libc-types.pthread_once_t
+ .llvm-libc-types.pthread_rwlock_t
+ .llvm-libc-types.pthread_rwlockattr_t
+ .llvm-libc-types.pthread_t
+)
- add_gen_header(
- sched
- DEF_FILE sched.h.def
- GEN_HDR sched.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sched_macros
- .llvm-libc-types.cpu_set_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.size_t
- .llvm-libc-types.struct_sched_param
- # Needed according to posix standard
- .llvm-libc-types.time_t
- .llvm-libc-types.struct_timespec
- )
+add_header_macro(
+ sched
+ YAML_FILE ../libc/newhdrgen/yaml/sched.yaml
+ DEF_FILE sched.h.def
+ GEN_HDR sched.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sched_macros
+ .llvm-libc-types.cpu_set_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.struct_sched_param
+ # Needed according to posix standard
+ .llvm-libc-types.time_t
+ .llvm-libc-types.struct_timespec
+)
- add_gen_header(
- spawn
- DEF_FILE spawn.h.def
- GEN_HDR spawn.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.mode_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.posix_spawnattr_t
- .llvm-libc-types.posix_spawn_file_actions_t
- )
+add_header_macro(
+ spawn
+ YAML_FILE ../libc/newhdrgen/yaml/spawn.yaml
+ DEF_FILE spawn.h.def
+ GEN_HDR spawn.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.posix_spawnattr_t
+ .llvm-libc-types.posix_spawn_file_actions_t
+)
- # TODO: Not all platforms will have a include/sys directory. Add the sys
- # directory and the targets for sys/*.h files conditional to the OS requiring
- # them.
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/sys)
+# TODO: Not all platforms will have a include/sys directory. Add the sys
+# directory and the targets for sys/*.h files conditional to the OS requiring
+# them.
+file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/sys)
+
+add_header_macro(
+ sys_auxv
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_auxv.yaml
+ DEF_FILE sys/auxv.h.def
+ GEN_HDR sys/auxv.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_auxv_macros
+)
- add_gen_header(
- sys_auxv
- DEF_FILE sys/auxv.h.def
- GEN_HDR sys/auxv.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_auxv_macros
- )
+add_header_macro(
+ sys_epoll
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_epoll.yaml
+ DEF_FILE sys/epoll.h.def
+ GEN_HDR sys/epoll.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_epoll_event
+ .llvm-libc-types.struct_epoll_data
+ .llvm-libc-types.sigset_t
+ .llvm-libc-macros.sys_epoll_macros
+)
- add_gen_header(
- sys_epoll
- DEF_FILE sys/epoll.h.def
- GEN_HDR sys/epoll.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_epoll_event
- .llvm-libc-types.struct_epoll_data
- .llvm-libc-types.sigset_t
- .llvm-libc-macros.sys_epoll_macros
- )
+add_header_macro(
+ sys_ioctl
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_ioctl.yaml
+ DEF_FILE sys/ioctl.h.def
+ GEN_HDR sys/ioctl.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_ioctl_macros
+)
- add_gen_header(
- sys_ioctl
- DEF_FILE sys/ioctl.h.def
- GEN_HDR sys/ioctl.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_ioctl_macros
- )
+add_header_macro(
+ sys_mman
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_mman.yaml
+ DEF_FILE sys/mman.h.def
+ GEN_HDR sys/mman.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_mman_macros
+ .llvm-libc-types.off_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+)
- add_gen_header(
- sys_mman
- DEF_FILE sys/mman.h.def
- GEN_HDR sys/mman.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_mman_macros
- .llvm-libc-types.off_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- )
+add_header_macro(
+ sys_prctl
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_prctl.yaml
+ DEF_FILE sys/prctl.h.def
+ GEN_HDR sys/prctl.h
+ DEPENDS
+ .llvm_libc_common_h
+)
- add_gen_header(
- sys_prctl
- DEF_FILE sys/prctl.h.def
- GEN_HDR sys/prctl.h
- DEPENDS
- .llvm_libc_common_h
- )
+add_header(
+ sys_queue
+ HDR
+ sys/queue.h
+ DEPENDS
+ .llvm-libc-macros.sys_queue_macros
+)
- add_header(
- sys_queue
- HDR
- sys/queue.h
- DEPENDS
- .llvm-libc-macros.sys_queue_macros
- )
+add_header_macro(
+ sys_random
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_random.yaml
+ DEF_FILE sys/random.h.def
+ GEN_HDR sys/random.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_random_macros
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+)
- add_gen_header(
- sys_random
- DEF_FILE sys/random.h.def
- GEN_HDR sys/random.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_random_macros
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- )
+add_header_macro(
+ sys_resource
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_resource.yaml
+ DEF_FILE sys/resource.h.def
+ GEN_HDR sys/resource.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_resource_macros
+ .llvm-libc-types.rlim_t
+ .llvm-libc-types.struct_rlimit
+)
- add_gen_header(
- sys_resource
- DEF_FILE sys/resource.h.def
- GEN_HDR sys/resource.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_resource_macros
- .llvm-libc-types.rlim_t
- .llvm-libc-types.struct_rlimit
- )
+add_header_macro(
+ sys_stat
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_stat.yaml
+ DEF_FILE sys/stat.h.def
+ GEN_HDR sys/stat.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_stat_macros
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.dev_t
+ .llvm-libc-types.ino_t
+ .llvm-libc-types.nlink_t
+ .llvm-libc-types.uid_t
+ .llvm-libc-types.gid_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.struct_timespec
+ .llvm-libc-types.struct_timeval
+ .llvm-libc-types.blksize_t
+ .llvm-libc-types.blkcnt_t
+ .llvm-libc-types.struct_stat
+)
- add_gen_header(
- sys_stat
- DEF_FILE sys/stat.h.def
- GEN_HDR sys/stat.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_stat_macros
- .llvm-libc-types.mode_t
- .llvm-libc-types.dev_t
- .llvm-libc-types.ino_t
- .llvm-libc-types.nlink_t
- .llvm-libc-types.uid_t
- .llvm-libc-types.gid_t
- .llvm-libc-types.off_t
- .llvm-libc-types.struct_timespec
- .llvm-libc-types.struct_timeval
- .llvm-libc-types.blksize_t
- .llvm-libc-types.blkcnt_t
- .llvm-libc-types.struct_stat
- )
+add_header_macro(
+ sys_select
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_select.yaml
+ DEF_FILE sys/select.h.def
+ GEN_HDR sys/select.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_select_macros
+ .llvm-libc-types.fd_set
+ .llvm-libc-types.sigset_t
+ .llvm-libc-types.suseconds_t
+ .llvm-libc-types.time_t
+ .llvm-libc-types.struct_timespec
+ .llvm-libc-types.struct_timeval
+)
- add_gen_header(
- sys_select
- DEF_FILE sys/select.h.def
- GEN_HDR sys/select.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_select_macros
- .llvm-libc-types.fd_set
- .llvm-libc-types.sigset_t
- .llvm-libc-types.suseconds_t
- .llvm-libc-types.time_t
- .llvm-libc-types.struct_timespec
- .llvm-libc-types.struct_timeval
- )
+add_header_macro(
+ sys_sendfile
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_sendfile.yaml
+ DEF_FILE sys/sendfile.h.def
+ GEN_HDR sys/sendfile.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.off_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+)
- add_gen_header(
- sys_sendfile
- DEF_FILE sys/sendfile.h.def
- GEN_HDR sys/sendfile.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.off_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- )
+add_header_macro(
+ sys_socket
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_socket.yaml
+ DEF_FILE sys/socket.h.def
+ GEN_HDR sys/socket.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_socket_macros
+ .llvm-libc-types.sa_family_t
+ .llvm-libc-types.socklen_t
+ .llvm-libc-types.struct_sockaddr
+ .llvm-libc-types.struct_sockaddr_un
+)
- add_gen_header(
- sys_socket
- DEF_FILE sys/socket.h.def
- GEN_HDR sys/socket.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_socket_macros
- .llvm-libc-types.sa_family_t
- .llvm-libc-types.socklen_t
- .llvm-libc-types.struct_sockaddr
- .llvm-libc-types.struct_sockaddr_un
- )
+add_header_macro(
+ sys_statvfs
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_statvfs.yaml
+ DEF_FILE sys/statvfs.h.def
+ GEN_HDR sys/statvfs.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_statvfs
+)
- add_gen_header(
- sys_statvfs
- DEF_FILE sys/statvfs.h.def
- GEN_HDR sys/statvfs.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_statvfs
- )
+add_header_macro(
+ sys_syscall
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_syscall.yaml
+ DEF_FILE sys/syscall.h.def
+ GEN_HDR sys/syscall.h
+)
- add_gen_header(
- sys_syscall
- DEF_FILE sys/syscall.h.def
- GEN_HDR sys/syscall.h
- )
+add_header_macro(
+ sys_time
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_time.yaml
+ DEF_FILE sys/time.h.def
+ GEN_HDR sys/time.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_timeval
+ .llvm-libc-macros.sys_time_macros
+)
- add_gen_header(
- sys_time
- DEF_FILE sys/time.h.def
- GEN_HDR sys/time.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_timeval
- .llvm-libc-macros.sys_time_macros
- )
+add_header_macro(
+ sys_types
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_types.yaml
+ DEF_FILE sys/types.h.def
+ GEN_HDR sys/types.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.blkcnt_t
+ .llvm-libc-types.blksize_t
+ .llvm-libc-types.clockid_t
+ .llvm-libc-types.dev_t
+ .llvm-libc-types.gid_t
+ .llvm-libc-types.ino_t
+ .llvm-libc-types.mode_t
+ .llvm-libc-types.nlink_t
+ .llvm-libc-types.off_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.pthread_attr_t
+ .llvm-libc-types.pthread_key_t
+ .llvm-libc-types.pthread_mutex_t
+ .llvm-libc-types.pthread_mutexattr_t
+ .llvm-libc-types.pthread_once_t
+ .llvm-libc-types.pthread_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.ssize_t
+ .llvm-libc-types.suseconds_t
+ .llvm-libc-types.time_t
+ .llvm-libc-types.uid_t
+)
- add_gen_header(
- sys_types
- DEF_FILE sys/types.h.def
- GEN_HDR sys/types.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.blkcnt_t
- .llvm-libc-types.blksize_t
- .llvm-libc-types.clockid_t
- .llvm-libc-types.dev_t
- .llvm-libc-types.gid_t
- .llvm-libc-types.ino_t
- .llvm-libc-types.mode_t
- .llvm-libc-types.nlink_t
- .llvm-libc-types.off_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.pthread_attr_t
- .llvm-libc-types.pthread_key_t
- .llvm-libc-types.pthread_mutex_t
- .llvm-libc-types.pthread_mutexattr_t
- .llvm-libc-types.pthread_once_t
- .llvm-libc-types.pthread_t
- .llvm-libc-types.size_t
- .llvm-libc-types.ssize_t
- .llvm-libc-types.suseconds_t
- .llvm-libc-types.time_t
- .llvm-libc-types.uid_t
- )
+add_header_macro(
+ sys_utsname
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_utsname.yaml
+ DEF_FILE sys/utsname.h.def
+ GEN_HDR sys/utsname.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.struct_utsname
+)
- add_gen_header(
- sys_utsname
- DEF_FILE sys/utsname.h.def
- GEN_HDR sys/utsname.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.struct_utsname
- )
+add_header_macro(
+ sys_wait
+ YAML_FILE ../libc/newhdrgen/yaml/sys/sys_wait.yaml
+ DEF_FILE sys/wait.h.def
+ GEN_HDR sys/wait.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.sys_wait_macros
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.struct_rusage
+ .llvm-libc-types.siginfo_t
+)
- add_gen_header(
- sys_wait
- DEF_FILE sys/wait.h.def
- GEN_HDR sys/wait.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.sys_wait_macros
- .llvm-libc-types.pid_t
- .llvm-libc-types.struct_rusage
- .llvm-libc-types.siginfo_t
- )
+add_header_macro(
+ termios
+ YAML_FILE ../libc/newhdrgen/yaml/termios.yaml
+ DEF_FILE termios.h.def
+ GEN_HDR termios.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.termios_macros
+ .llvm-libc-types.cc_t
+ .llvm-libc-types.pid_t
+ .llvm-libc-types.speed_t
+ .llvm-libc-types.struct_termios
+ .llvm-libc-types.tcflag_t
+)
- add_gen_header(
- termios
- DEF_FILE termios.h.def
- GEN_HDR termios.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-macros.termios_macros
- .llvm-libc-types.cc_t
- .llvm-libc-types.pid_t
- .llvm-libc-types.speed_t
- .llvm-libc-types.struct_termios
- .llvm-libc-types.tcflag_t
- )
+add_header_macro(
+ uchar
+ YAML_FILE ../libc/newhdrgen/yaml/uchar.yaml
+ DEF_FILE uchar.h.def
+ GEN_HDR uchar.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-types.mbstate_t
+ .llvm-libc-types.char8_t
+ .llvm-libc-types.char16_t
+ .llvm-libc-types.char32_t
+)
- add_gen_header(
- uchar
- DEF_FILE uchar.h.def
- GEN_HDR uchar.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.mbstate_t
- .llvm-libc-types.char8_t
- .llvm-libc-types.char16_t
- .llvm-libc-types.char32_t
- )
+add_header_macro(
+ wchar
+ YAML_FILE ../libc/newhdrgen/yaml/wchar.yaml
+ DEF_FILE wchar.h.def
+ GEN_HDR wchar.h
+ DEPENDS
+ .llvm_libc_common_h
+ .llvm-libc-macros.wchar_macros
+ .llvm-libc-types.mbstate_t
+ .llvm-libc-types.size_t
+ .llvm-libc-types.wint_t
+ .llvm-libc-types.wchar_t
+)
+
+if(LIBC_TARGET_OS_IS_GPU)
+ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/gpu)
- add_gen_header(
- wchar
- DEF_FILE wchar.h.def
- GEN_HDR wchar.h
+ add_header_macro(
+ gpu_rpc
+ YAML_FILE ../libc/newhdrgen/yaml/rpc.yaml
+ DEF_FILE gpu/rpc.h.def
+ GEN_HDR gpu/rpc.h
DEPENDS
.llvm_libc_common_h
- .llvm-libc-macros.wchar_macros
- .llvm-libc-types.mbstate_t
- .llvm-libc-types.size_t
- .llvm-libc-types.wint_t
- .llvm-libc-types.wchar_t
+ .llvm-libc-types.rpc_opcodes_t
)
- if(LIBC_TARGET_OS_IS_GPU)
- file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/gpu)
-
- add_gen_header(
- gpu_rpc
- DEF_FILE gpu/rpc.h.def
- GEN_HDR gpu/rpc.h
- DEPENDS
- .llvm_libc_common_h
- .llvm-libc-types.rpc_opcodes_t
- )
- endif()
-endif()
-
if(NOT LLVM_LIBC_FULL_BUILD)
# We don't install headers in non-fullbuild mode.
return()
>From ce29cfff972a35a39460178ddcf4c16c96f4e268 Mon Sep 17 00:00:00 2001
From: Rose Zhang <rosezhang at google.com>
Date: Tue, 16 Jul 2024 00:38:07 +0000
Subject: [PATCH 09/17] added deleted endif()
---
libc/include/CMakeLists.txt | 1 +
1 file changed, 1 insertion(+)
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index 5ad09e4ae8aad..68fd7d3bec415 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -707,6 +707,7 @@ if(LIBC_TARGET_OS_IS_GPU)
.llvm_libc_common_h
.llvm-libc-types.rpc_opcodes_t
)
+endif()
if(NOT LLVM_LIBC_FULL_BUILD)
# We don't install headers in non-fullbuild mode.
>From 1e763d3389bcd2e0b02505654f2187cad7720167 Mon Sep 17 00:00:00 2001
From: Rose Zhang <rosezhang at google.com>
Date: Tue, 16 Jul 2024 00:46:11 +0000
Subject: [PATCH 10/17] changed argument name TYPE to NAME
---
libc/include/CMakeLists.txt | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index 68fd7d3bec415..4645f7b59990c 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -17,10 +17,10 @@ add_header(
__llvm-libc-common.h
)
-macro(add_header_macro TYPE YAML_FILE DEF_FILE GEN_HDR DEPENDS)
+macro(add_header_macro NAME YAML_FILE DEF_FILE GEN_HDR DEPENDS)
if (LIBC_USE_NEW_HEADER_GEN)
add_gen_header2(
- ${TYPE}
+ ${NAME}
${YAML_FILE}
${DEF_FILE}
${GEN_HDR}
@@ -28,7 +28,7 @@ macro(add_header_macro TYPE YAML_FILE DEF_FILE GEN_HDR DEPENDS)
)
else()
add_gen_header(
- ${TYPE}
+ ${NAME}
${DEF_FILE}
${GEN_HDR}
${DEPENDS}
>From e6930766f829a7799518151342537692543e3219 Mon Sep 17 00:00:00 2001
From: Rose Zhang <rosezhang at google.com>
Date: Tue, 16 Jul 2024 00:50:37 +0000
Subject: [PATCH 11/17] updated argument NAME to TARGET_NAME
---
libc/include/CMakeLists.txt | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index 4645f7b59990c..ce2bbe75a53c3 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -17,10 +17,10 @@ add_header(
__llvm-libc-common.h
)
-macro(add_header_macro NAME YAML_FILE DEF_FILE GEN_HDR DEPENDS)
+macro(add_header_macro TARGET_NAME YAML_FILE DEF_FILE GEN_HDR DEPENDS)
if (LIBC_USE_NEW_HEADER_GEN)
add_gen_header2(
- ${NAME}
+ ${TARGET_NAME}
${YAML_FILE}
${DEF_FILE}
${GEN_HDR}
@@ -28,7 +28,7 @@ macro(add_header_macro NAME YAML_FILE DEF_FILE GEN_HDR DEPENDS)
)
else()
add_gen_header(
- ${NAME}
+ ${TARGET_NAME}
${DEF_FILE}
${GEN_HDR}
${DEPENDS}
>From 8abda5261b83dd20e0aee0ee473e9601a56b0dff Mon Sep 17 00:00:00 2001
From: Rose Zhang <rosezhang at google.com>
Date: Tue, 16 Jul 2024 17:33:56 +0000
Subject: [PATCH 12/17] changed option LIBC_USE_NEW_HEADER_GEN to default OFF
---
libc/CMakeLists.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/libc/CMakeLists.txt b/libc/CMakeLists.txt
index c89897f2900fe..3b8e4e6c517e9 100644
--- a/libc/CMakeLists.txt
+++ b/libc/CMakeLists.txt
@@ -72,7 +72,7 @@ option(LIBC_BUILD_GPU_LOADER "Always build the GPU loader utilities" OFF)
if(LIBC_BUILD_GPU_LOADER OR (LLVM_LIBC_GPU_BUILD AND NOT LLVM_RUNTIMES_BUILD))
add_subdirectory(utils/gpu)
endif()
-option(LIBC_USE_NEW_HEADER_GEN "Generate header files using new headergen instead of the old one" ON)
+option(LIBC_USE_NEW_HEADER_GEN "Generate header files using new headergen instead of the old one" OFF)
set(NEED_LIBC_HDRGEN FALSE)
if(NOT LLVM_RUNTIMES_BUILD)
>From ce5d7e7e910a86b8c344f3460d496fa6dcbd3bae Mon Sep 17 00:00:00 2001
From: Rose Zhang <rosezhang at google.com>
Date: Tue, 16 Jul 2024 19:58:33 +0000
Subject: [PATCH 13/17] fixed macro implementation, fixed message typo in
LLVMLibCHeaderRules.cmake
---
libc/cmake/modules/LLVMLibCHeaderRules.cmake | 2 +-
libc/include/CMakeLists.txt | 316 +++++++++----------
2 files changed, 159 insertions(+), 159 deletions(-)
diff --git a/libc/cmake/modules/LLVMLibCHeaderRules.cmake b/libc/cmake/modules/LLVMLibCHeaderRules.cmake
index 121dab0e40c1b..fa743279641c5 100644
--- a/libc/cmake/modules/LLVMLibCHeaderRules.cmake
+++ b/libc/cmake/modules/LLVMLibCHeaderRules.cmake
@@ -80,7 +80,7 @@ function(add_gen_header2 target_name)
return()
endif()
if(NOT ADD_GEN_HDR2_DEF_FILE)
- mesage(FATAL_ERROR "`add_gen_hdr2` rule requires DEF_FILE to be specified.")
+ message(FATAL_ERROR "`add_gen_hdr2` rule requires DEF_FILE to be specified.")
endif()
if(NOT ADD_GEN_HDR2_GEN_HDR)
message(FATAL_ERROR "`add_gen_hdr2` rule requires GEN_HDR to be specified.")
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index ce2bbe75a53c3..cb89c2565d5fe 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -21,16 +21,16 @@ macro(add_header_macro TARGET_NAME YAML_FILE DEF_FILE GEN_HDR DEPENDS)
if (LIBC_USE_NEW_HEADER_GEN)
add_gen_header2(
${TARGET_NAME}
- ${YAML_FILE}
- ${DEF_FILE}
- ${GEN_HDR}
+ YAML_FILE ${YAML_FILE}
+ DEF_FILE ${DEF_FILE}
+ GEN_HDR ${GEN_HDR}
${DEPENDS}
)
else()
add_gen_header(
${TARGET_NAME}
- ${DEF_FILE}
- ${GEN_HDR}
+ DEF_FILE ${DEF_FILE}
+ GEN_HDR ${GEN_HDR}
${DEPENDS}
)
endif()
@@ -38,18 +38,18 @@ endmacro()
add_header_macro(
ctype
- YAML_FILE ../libc/newhdrgen/yaml/ctype.yaml
- DEF_FILE ctype.h.def
- GEN_HDR ctype.h
+ ../libc/newhdrgen/yaml/ctype.yaml
+ ctype.h.def
+ ctype.h
DEPENDS
.llvm_libc_common_h
)
add_header_macro(
dirent
- YAML_FILE ../libc/newhdrgen/yaml/dirent.yaml
- DEF_FILE dirent.h.def
- GEN_HDR dirent.h
+ ../libc/newhdrgen/yaml/dirent.yaml
+ dirent.h.def
+ dirent.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.ino_t
@@ -59,9 +59,9 @@ add_header_macro(
add_header_macro(
fcntl
- YAML_FILE ../libc/newhdrgen/yaml/fcntl.yaml
- DEF_FILE fcntl.h.def
- GEN_HDR fcntl.h
+ ../libc/newhdrgen/yaml/fcntl.yaml
+ fcntl.h.def
+ fcntl.h
DEPENDS
.llvm-libc-macros.fcntl_macros
.llvm-libc-types.mode_t
@@ -75,9 +75,9 @@ add_header_macro(
add_header_macro(
dlfcn
- YAML_FILE ../libc/newhdrgen/yaml/dlfcn.yaml
- DEF_FILE dlfcn.h.def
- GEN_HDR dlfcn.h
+ ../libc/newhdrgen/yaml/dlfcn.yaml
+ dlfcn.h.def
+ dlfcn.h
DEPENDS
.llvm-libc-macros.dlfcn_macros
.llvm_libc_common_h
@@ -85,9 +85,9 @@ add_header_macro(
add_header_macro(
features
- YAML_FILE ../libc/newhdrgen/yaml/features.yaml
- DEF_FILE features.h.def
- GEN_HDR features.h
+ ../libc/newhdrgen/yaml/features.yaml
+ features.h.def
+ features.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.features_macros
@@ -95,9 +95,9 @@ add_header_macro(
add_header_macro(
fenv
- YAML_FILE ../libc/newhdrgen/yaml/fenv.yaml
- DEF_FILE fenv.h.def
- GEN_HDR fenv.h
+ ../libc/newhdrgen/yaml/fenv.yaml
+ fenv.h.def
+ fenv.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.fenv_macros
@@ -107,9 +107,9 @@ add_header_macro(
add_header_macro(
inttypes
- YAML_FILE ../libc/newhdrgen/yaml/inttypes.yaml
- DEF_FILE inttypes.h.def
- GEN_HDR inttypes.h
+ ../libc/newhdrgen/yaml/inttypes.yaml
+ inttypes.h.def
+ inttypes.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.imaxdiv_t
@@ -118,36 +118,36 @@ add_header_macro(
add_header_macro(
float
- YAML_FILE ../libc/newhdrgen/yaml/float.yaml
- DEF_FILE float.h.def
- GEN_HDR float.h
+ ../libc/newhdrgen/yaml/float.yaml
+ float.h.def
+ float.h
DEPENDS
.llvm-libc-macros.float_macros
)
add_header_macro(
stdint
- YAML_FILE ../libc/newhdrgen/yaml/stdint.yaml
- DEF_FILE stdint.h.def
- GEN_HDR stdint.h
+ ../libc/newhdrgen/yaml/stdint.yaml
+ stdint.h.def
+ stdint.h
DEPENDS
.llvm-libc-macros.stdint_macros
)
add_header_macro(
limits
- YAML_FILE ../libc/newhdrgen/yaml/limits.yaml
- DEF_FILE limits.h.def
- GEN_HDR limits.h
+ ../libc/newhdrgen/yaml/limits.yaml
+ limits.h.def
+ limits.h
DEPENDS
.llvm-libc-macros.limits_macros
)
add_header_macro(
math
- YAML_FILE ../libc/newhdrgen/yaml/math.yaml
- DEF_FILE math.h.def
- GEN_HDR math.h
+ ../libc/newhdrgen/yaml/math.yaml
+ math.h.def
+ math.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.float16_macros
@@ -159,9 +159,9 @@ add_header_macro(
add_header_macro(
stdfix
- YAML_FILE ../libc/newhdrgen/yaml/stdfix.yaml
- DEF_FILE stdfix.h.def
- GEN_HDR stdfix.h
+ ../libc/newhdrgen/yaml/stdfix.yaml
+ stdfix.h.def
+ stdfix.h
DEPENDS
.llvm-libc-macros.stdfix_macros
)
@@ -171,18 +171,18 @@ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/arpa)
add_header_macro(
arpa_inet
- YAML_FILE ../libc/newhdrgen/yaml/arpa_inet.yaml
- DEF_FILE arpa/inet.h.def
- GEN_HDR arpa/inet.h
+ ../libc/newhdrgen/yaml/arpa_inet.yaml
+ arpa/inet.h.def
+ arpa/inet.h
DEPENDS
.llvm_libc_common_h
)
add_header_macro(
assert
- YAML_FILE ../libc/newhdrgen/yaml/assert.yaml
- DEF_FILE assert.h.def
- GEN_HDR assert.h
+ ../libc/newhdrgen/yaml/assert.yaml
+ assert.h.def
+ assert.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.assert_macros
@@ -190,9 +190,9 @@ add_header_macro(
add_header_macro(
setjmp
- YAML_FILE ../libc/newhdrgen/yaml/setjmp.yaml
- DEF_FILE setjmp.h.def
- GEN_HDR setjmp.h
+ ../libc/newhdrgen/yaml/setjmp.yaml
+ setjmp.h.def
+ setjmp.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.jmp_buf
@@ -200,9 +200,9 @@ add_header_macro(
add_header_macro(
string
- YAML_FILE ../libc/newhdrgen/yaml/string.yaml
- DEF_FILE string.h.def
- GEN_HDR string.h
+ ../libc/newhdrgen/yaml/string.yaml
+ string.h.def
+ string.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.null_macro
@@ -211,9 +211,9 @@ add_header_macro(
add_header_macro(
strings
- YAML_FILE ../libc/newhdrgen/yaml/strings.yaml
- DEF_FILE strings.h.def
- GEN_HDR strings.h
+ ../libc/newhdrgen/yaml/strings.yaml
+ strings.h.def
+ strings.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.size_t
@@ -221,9 +221,9 @@ add_header_macro(
add_header_macro(
search
- YAML_FILE ../libc/newhdrgen/yaml/search.yaml
- DEF_FILE search.h.def
- GEN_HDR search.h
+ ../libc/newhdrgen/yaml/search.yaml
+ search.h.def
+ search.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.ACTION
@@ -234,9 +234,9 @@ add_header_macro(
add_header_macro(
time
- YAML_FILE ../libc/newhdrgen/yaml/time.yaml
- DEF_FILE time.h.def
- GEN_HDR time.h
+ ../libc/newhdrgen/yaml/time.yaml
+ time.h.def
+ time.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.time_macros
@@ -250,9 +250,9 @@ add_header_macro(
add_header_macro(
threads
- YAML_FILE ../libc/newhdrgen/yaml/threads.yaml
- DEF_FILE threads.h.def
- GEN_HDR threads.h
+ ../libc/newhdrgen/yaml/threads.yaml
+ threads.h.def
+ threads.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.__call_once_func_t
@@ -267,9 +267,9 @@ add_header_macro(
add_header_macro(
errno
- YAML_FILE ../libc/newhdrgen/yaml/errno.yaml
- DEF_FILE errno.h.def
- GEN_HDR errno.h
+ ../libc/newhdrgen/yaml/errno.yaml
+ errno.h.def
+ errno.h
DEPENDS
.llvm-libc-macros.generic_error_number_macros
.llvm-libc-macros.error_number_macros
@@ -277,9 +277,9 @@ add_header_macro(
add_header_macro(
signal
- YAML_FILE ../libc/newhdrgen/yaml/signal.yaml
- DEF_FILE signal.h.def
- GEN_HDR signal.h
+ ../libc/newhdrgen/yaml/signal.yaml
+ signal.h.def
+ signal.h
DEPENDS
.llvm-libc-macros.signal_macros
.llvm-libc-types.sig_atomic_t
@@ -293,9 +293,9 @@ add_header_macro(
add_header_macro(
stdbit
- YAML_FILE ../libc/newhdrgen/yaml/stdbit.yaml
- DEF_FILE stdbit.h.def
- GEN_HDR stdbit.h
+ ../libc/newhdrgen/yaml/stdbit.yaml
+ stdbit.h.def
+ stdbit.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.stdbit_macros
@@ -303,9 +303,9 @@ add_header_macro(
add_header_macro(
stdckdint
- YAML_FILE ../libc/newhdrgen/yaml/stdckdint.yaml
- DEF_FILE stdckdint.h.def
- GEN_HDR stdckdint.h
+ ../libc/newhdrgen/yaml/stdckdint.yaml
+ stdckdint.h.def
+ stdckdint.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.stdckdint_macros
@@ -313,9 +313,9 @@ add_header_macro(
add_header_macro(
stdio
- YAML_FILE ../libc/newhdrgen/yaml/stdio.yaml
- DEF_FILE stdio.h.def
- GEN_HDR stdio.h
+ ../libc/newhdrgen/yaml/stdio.yaml
+ stdio.h.def
+ stdio.h
DEPENDS
.llvm-libc-macros.file_seek_macros
.llvm-libc-macros.stdio_macros
@@ -329,9 +329,9 @@ add_header_macro(
add_header_macro(
stdlib
- YAML_FILE ../libc/newhdrgen/yaml/stdlib.yaml
- DEF_FILE stdlib.h.def
- GEN_HDR stdlib.h
+ ../libc/newhdrgen/yaml/stdlib.yaml
+ stdlib.h.def
+ stdlib.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.stdlib_macros
@@ -347,9 +347,9 @@ add_header_macro(
add_header_macro(
unistd
- YAML_FILE ../libc/newhdrgen/yaml/unistd.yaml
- DEF_FILE unistd.h.def
- GEN_HDR unistd.h
+ ../libc/newhdrgen/yaml/unistd.yaml
+ unistd.h.def
+ unistd.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.file_seek_macros
@@ -366,9 +366,9 @@ add_header_macro(
add_header_macro(
pthread
- YAML_FILE ../libc/newhdrgen/yaml/pthread.yaml
- DEF_FILE pthread.h.def
- GEN_HDR pthread.h
+ ../libc/newhdrgen/yaml/pthread.yaml
+ pthread.h.def
+ pthread.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.__atfork_callback_t
@@ -388,9 +388,9 @@ add_header_macro(
add_header_macro(
sched
- YAML_FILE ../libc/newhdrgen/yaml/sched.yaml
- DEF_FILE sched.h.def
- GEN_HDR sched.h
+ ../libc/newhdrgen/yaml/sched.yaml
+ sched.h.def
+ sched.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.sched_macros
@@ -405,9 +405,9 @@ add_header_macro(
add_header_macro(
spawn
- YAML_FILE ../libc/newhdrgen/yaml/spawn.yaml
- DEF_FILE spawn.h.def
- GEN_HDR spawn.h
+ ../libc/newhdrgen/yaml/spawn.yaml
+ spawn.h.def
+ spawn.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.mode_t
@@ -423,9 +423,9 @@ file(MAKE_DIRECTORY ${LIBC_INCLUDE_DIR}/sys)
add_header_macro(
sys_auxv
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_auxv.yaml
- DEF_FILE sys/auxv.h.def
- GEN_HDR sys/auxv.h
+ ../libc/newhdrgen/yaml/sys/sys_auxv.yaml
+ sys/auxv.h.def
+ sys/auxv.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.sys_auxv_macros
@@ -433,9 +433,9 @@ add_header_macro(
add_header_macro(
sys_epoll
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_epoll.yaml
- DEF_FILE sys/epoll.h.def
- GEN_HDR sys/epoll.h
+ ../libc/newhdrgen/yaml/sys/sys_epoll.yaml
+ sys/epoll.h.def
+ sys/epoll.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.struct_epoll_event
@@ -446,9 +446,9 @@ add_header_macro(
add_header_macro(
sys_ioctl
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_ioctl.yaml
- DEF_FILE sys/ioctl.h.def
- GEN_HDR sys/ioctl.h
+ ../libc/newhdrgen/yaml/sys/sys_ioctl.yaml
+ sys/ioctl.h.def
+ sys/ioctl.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.sys_ioctl_macros
@@ -456,9 +456,9 @@ add_header_macro(
add_header_macro(
sys_mman
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_mman.yaml
- DEF_FILE sys/mman.h.def
- GEN_HDR sys/mman.h
+ ../libc/newhdrgen/yaml/sys/sys_mman.yaml
+ sys/mman.h.def
+ sys/mman.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.sys_mman_macros
@@ -469,9 +469,9 @@ add_header_macro(
add_header_macro(
sys_prctl
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_prctl.yaml
- DEF_FILE sys/prctl.h.def
- GEN_HDR sys/prctl.h
+ ../libc/newhdrgen/yaml/sys/sys_prctl.yaml
+ sys/prctl.h.def
+ sys/prctl.h
DEPENDS
.llvm_libc_common_h
)
@@ -486,9 +486,9 @@ add_header(
add_header_macro(
sys_random
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_random.yaml
- DEF_FILE sys/random.h.def
- GEN_HDR sys/random.h
+ ../libc/newhdrgen/yaml/sys/sys_random.yaml
+ sys/random.h.def
+ sys/random.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.sys_random_macros
@@ -498,9 +498,9 @@ add_header_macro(
add_header_macro(
sys_resource
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_resource.yaml
- DEF_FILE sys/resource.h.def
- GEN_HDR sys/resource.h
+ ../libc/newhdrgen/yaml/sys/sys_resource.yaml
+ sys/resource.h.def
+ sys/resource.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.sys_resource_macros
@@ -510,9 +510,9 @@ add_header_macro(
add_header_macro(
sys_stat
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_stat.yaml
- DEF_FILE sys/stat.h.def
- GEN_HDR sys/stat.h
+ ../libc/newhdrgen/yaml/sys/sys_stat.yaml
+ sys/stat.h.def
+ sys/stat.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.sys_stat_macros
@@ -532,9 +532,9 @@ add_header_macro(
add_header_macro(
sys_select
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_select.yaml
- DEF_FILE sys/select.h.def
- GEN_HDR sys/select.h
+ ../libc/newhdrgen/yaml/sys/sys_select.yaml
+ sys/select.h.def
+ sys/select.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.sys_select_macros
@@ -548,9 +548,9 @@ add_header_macro(
add_header_macro(
sys_sendfile
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_sendfile.yaml
- DEF_FILE sys/sendfile.h.def
- GEN_HDR sys/sendfile.h
+ ../libc/newhdrgen/yaml/sys/sys_sendfile.yaml
+ sys/sendfile.h.def
+ sys/sendfile.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.off_t
@@ -560,9 +560,9 @@ add_header_macro(
add_header_macro(
sys_socket
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_socket.yaml
- DEF_FILE sys/socket.h.def
- GEN_HDR sys/socket.h
+ ../libc/newhdrgen/yaml/sys/sys_socket.yaml
+ sys/socket.h.def
+ sys/socket.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.sys_socket_macros
@@ -574,9 +574,9 @@ add_header_macro(
add_header_macro(
sys_statvfs
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_statvfs.yaml
- DEF_FILE sys/statvfs.h.def
- GEN_HDR sys/statvfs.h
+ ../libc/newhdrgen/yaml/sys/sys_statvfs.yaml
+ sys/statvfs.h.def
+ sys/statvfs.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.struct_statvfs
@@ -584,16 +584,16 @@ add_header_macro(
add_header_macro(
sys_syscall
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_syscall.yaml
- DEF_FILE sys/syscall.h.def
- GEN_HDR sys/syscall.h
+ ../libc/newhdrgen/yaml/sys/sys_syscall.yaml
+ sys/syscall.h.def
+ sys/syscall.h
)
add_header_macro(
sys_time
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_time.yaml
- DEF_FILE sys/time.h.def
- GEN_HDR sys/time.h
+ ../libc/newhdrgen/yaml/sys/sys_time.yaml
+ sys/time.h.def
+ sys/time.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.struct_timeval
@@ -602,9 +602,9 @@ add_header_macro(
add_header_macro(
sys_types
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_types.yaml
- DEF_FILE sys/types.h.def
- GEN_HDR sys/types.h
+ ../libc/newhdrgen/yaml/sys/sys_types.yaml
+ sys/types.h.def
+ sys/types.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.blkcnt_t
@@ -632,9 +632,9 @@ add_header_macro(
add_header_macro(
sys_utsname
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_utsname.yaml
- DEF_FILE sys/utsname.h.def
- GEN_HDR sys/utsname.h
+ ../libc/newhdrgen/yaml/sys/sys_utsname.yaml
+ sys/utsname.h.def
+ sys/utsname.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.struct_utsname
@@ -642,9 +642,9 @@ add_header_macro(
add_header_macro(
sys_wait
- YAML_FILE ../libc/newhdrgen/yaml/sys/sys_wait.yaml
- DEF_FILE sys/wait.h.def
- GEN_HDR sys/wait.h
+ ../libc/newhdrgen/yaml/sys/sys_wait.yaml
+ sys/wait.h.def
+ sys/wait.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.sys_wait_macros
@@ -655,9 +655,9 @@ add_header_macro(
add_header_macro(
termios
- YAML_FILE ../libc/newhdrgen/yaml/termios.yaml
- DEF_FILE termios.h.def
- GEN_HDR termios.h
+ ../libc/newhdrgen/yaml/termios.yaml
+ termios.h.def
+ termios.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.termios_macros
@@ -670,9 +670,9 @@ add_header_macro(
add_header_macro(
uchar
- YAML_FILE ../libc/newhdrgen/yaml/uchar.yaml
- DEF_FILE uchar.h.def
- GEN_HDR uchar.h
+ ../libc/newhdrgen/yaml/uchar.yaml
+ uchar.h.def
+ uchar.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.mbstate_t
@@ -683,9 +683,9 @@ add_header_macro(
add_header_macro(
wchar
- YAML_FILE ../libc/newhdrgen/yaml/wchar.yaml
- DEF_FILE wchar.h.def
- GEN_HDR wchar.h
+ ../libc/newhdrgen/yaml/wchar.yaml
+ wchar.h.def
+ wchar.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-macros.wchar_macros
@@ -700,9 +700,9 @@ if(LIBC_TARGET_OS_IS_GPU)
add_header_macro(
gpu_rpc
- YAML_FILE ../libc/newhdrgen/yaml/rpc.yaml
- DEF_FILE gpu/rpc.h.def
- GEN_HDR gpu/rpc.h
+ ../libc/newhdrgen/yaml/rpc.yaml
+ gpu/rpc.h.def
+ gpu/rpc.h
DEPENDS
.llvm_libc_common_h
.llvm-libc-types.rpc_opcodes_t
>From 37c21f1e8d3b1a5aefdf570885177d1bb1833360 Mon Sep 17 00:00:00 2001
From: aaryanshukla <53713108+aaryanshukla at users.noreply.github.com>
Date: Tue, 16 Jul 2024 12:44:08 -0700
Subject: [PATCH 14/17] [libc] newheadergen: script adjusted for cmake (#98825)
- added entrypoints and headerfile parameters depending on target
- fixed nits in yaml files causing errors
- tested with new cmake config
- cmake patch will be seperate
---
.../class_implementation/classes/function.py | 4 +-
libc/newhdrgen/gpu_headers.py | 78 ++++++++++++++++
libc/newhdrgen/header.py | 10 +-
libc/newhdrgen/yaml/features.yaml | 8 ++
libc/newhdrgen/yaml/pthread.yaml | 31 +------
libc/newhdrgen/yaml/sys/sys_random.yaml | 2 +-
libc/newhdrgen/yaml/time.yaml | 2 +-
libc/newhdrgen/yaml_to_classes.py | 91 +++++++++++++------
8 files changed, 162 insertions(+), 64 deletions(-)
create mode 100644 libc/newhdrgen/gpu_headers.py
create mode 100644 libc/newhdrgen/yaml/features.yaml
diff --git a/libc/newhdrgen/class_implementation/classes/function.py b/libc/newhdrgen/class_implementation/classes/function.py
index ea5e8223a538e..ccfd93547c1d8 100644
--- a/libc/newhdrgen/class_implementation/classes/function.py
+++ b/libc/newhdrgen/class_implementation/classes/function.py
@@ -26,7 +26,7 @@ def __str__(self):
attributes_str = " ".join(self.attributes)
arguments_str = ", ".join(self.arguments)
if attributes_str == "":
- result = f"{self.return_type} {self.name}({arguments_str}) __NOEXCEPT;"
+ result = f"{self.return_type} {self.name}({arguments_str});"
else:
- result = f"{attributes_str} {self.return_type} {self.name}({arguments_str}) __NOEXCEPT;"
+ result = f"{attributes_str} {self.return_type} {self.name}({arguments_str})"
return result
diff --git a/libc/newhdrgen/gpu_headers.py b/libc/newhdrgen/gpu_headers.py
new file mode 100644
index 0000000000000..cc13096cd47c1
--- /dev/null
+++ b/libc/newhdrgen/gpu_headers.py
@@ -0,0 +1,78 @@
+#!/usr/bin/env python
+#
+# ===- GPU HeaderFile Class for --export-decls version --------*- python -*--==#
+#
+# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+# See https://llvm.org/LICENSE.txt for license information.
+# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+#
+# ==-------------------------------------------------------------------------==#
+
+
+class GpuHeaderFile:
+ def __init__(self, name):
+ self.name = name
+ self.macros = []
+ self.types = []
+ self.enumerations = []
+ self.objects = []
+ self.functions = []
+ self.includes = []
+
+ def add_macro(self, macro):
+ self.macros.append(macro)
+
+ def add_type(self, type_):
+ self.types.append(type_)
+
+ def add_enumeration(self, enumeration):
+ self.enumerations.append(enumeration)
+
+ def add_object(self, object):
+ self.objects.append(object)
+
+ def add_function(self, function):
+ self.functions.append(function)
+
+ def __str__(self):
+ content = []
+
+ content.append(
+ f"//===-- C standard declarations for {self.name} ------------------------------===//"
+ )
+ content.append("//")
+ content.append(
+ "// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions."
+ )
+ content.append("// See https://llvm.org/LICENSE.txt for license information.")
+ content.append("// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception")
+ content.append("//")
+ content.append(
+ "//===----------------------------------------------------------------------===//\n"
+ )
+
+ header_guard = f"__LLVM_LIBC_DECLARATIONS_{self.name.upper()[:-2]}_H"
+ content.append(f"#ifndef {header_guard}")
+ content.append(f"#define {header_guard}\n")
+
+ content.append("#ifndef __LIBC_ATTRS")
+ content.append("#define __LIBC_ATTRS")
+ content.append("#endif\n")
+
+ content.append("#ifdef __cplusplus")
+ content.append('extern "C" {')
+ content.append("#endif\n")
+
+ for function in self.functions:
+ content.append(f"{function} __LIBC_ATTRS;\n")
+
+ for object in self.objects:
+ content.append(f"{object} __LIBC_ATTRS;\n")
+
+ content.append("#ifdef __cplusplus")
+ content.append("}")
+ content.append("#endif\n")
+
+ content.append(f"#endif")
+
+ return "\n".join(content)
diff --git a/libc/newhdrgen/header.py b/libc/newhdrgen/header.py
index ac45bae7c933e..69de81eebb719 100644
--- a/libc/newhdrgen/header.py
+++ b/libc/newhdrgen/header.py
@@ -60,16 +60,16 @@ def __str__(self):
current_guard = None
for function in self.functions:
if function.guard == None:
- content.append(str(function))
+ content.append(str(function) + "__NOEXCEPT")
content.append("")
else:
if current_guard == None:
current_guard = function.guard
content.append(f"#ifdef {current_guard}")
- content.append(str(function))
+ content.append(str(function) + "__NOEXCEPT")
content.append("")
elif current_guard == function.guard:
- content.append(str(function))
+ content.append(str(function) + "__NOEXCEPT")
content.append("")
else:
content.pop()
@@ -77,12 +77,12 @@ def __str__(self):
content.append("")
current_guard = function.guard
content.append(f"#ifdef {current_guard}")
- content.append(str(function))
+ content.append(str(function) + "__NOEXCEPT")
content.append("")
if current_guard != None:
content.pop()
content.append(f"#endif // {current_guard}")
- content.append("")
+ content.append("")
for object in self.objects:
content.append(str(object))
diff --git a/libc/newhdrgen/yaml/features.yaml b/libc/newhdrgen/yaml/features.yaml
new file mode 100644
index 0000000000000..86bc0acfe89ed
--- /dev/null
+++ b/libc/newhdrgen/yaml/features.yaml
@@ -0,0 +1,8 @@
+header: features.h
+standards:
+ - stdc
+macros: []
+types: []
+enums: []
+objects: []
+functions: []
diff --git a/libc/newhdrgen/yaml/pthread.yaml b/libc/newhdrgen/yaml/pthread.yaml
index 14a562082d5de..f22767eb1b752 100644
--- a/libc/newhdrgen/yaml/pthread.yaml
+++ b/libc/newhdrgen/yaml/pthread.yaml
@@ -13,33 +13,8 @@ types:
- type_name: __pthread_start_t
- type_name: __pthread_once_func_t
- type_name: __atfork_callback_t
-enums:
- - name: PTHREAD_CREATE_JOINABLE
- value: 0x0
- - name: PTHREAD_CREATE_DETACHED
- value: 0x1
- - name: PTHREAD_MUTEX_NORMAL
- value: 0x0
- - name: PTHREAD_MUTEX_ERRORCHECK
- value: 0x1
- - name: PTHREAD_MUTEX_RECURSIVE
- value: 0x2
- - name: PTHREAD_MUTEX_DEFAULT
- value: 0x0
- - name: PTHREAD_PROCESS_PRIVATE
- value: 0x0
- - name: PTHREAD_PROCESS_SHARED
- value: 0x1
- - name: PTHREAD_MUTEX_STALLED
- value: 0x0
- - name: PTHREAD_MUTEX_ROBUST
- value: 0x1
- - name: PTHREAD_RWLOCK_PREFER_READER_NP
- value: 0
- - name: PTHREAD_RWLOCK_PREFER_WRITER_NP
- value: 1
- - name: PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP
- value: 2
+ - type_name: pthread_rwlock_t
+enums: []
functions:
- name: pthread_atfork
standards:
@@ -184,7 +159,7 @@ functions:
- name: pthread_exit
standards:
- POSIX
- return_type: __Noreturn void
+ return_type: _Noreturn void
arguments:
- type: void *
- name: pthread_getname_np
diff --git a/libc/newhdrgen/yaml/sys/sys_random.yaml b/libc/newhdrgen/yaml/sys/sys_random.yaml
index 233fb2c7988cb..6d84056d7dd71 100644
--- a/libc/newhdrgen/yaml/sys/sys_random.yaml
+++ b/libc/newhdrgen/yaml/sys/sys_random.yaml
@@ -4,7 +4,7 @@ types:
- type_name: ssize_t
- type_name: size_t
enums: []
-objects:
+objects: []
functions:
- name: getrandom
standards:
diff --git a/libc/newhdrgen/yaml/time.yaml b/libc/newhdrgen/yaml/time.yaml
index e7f8de65eeb75..220d4328dbbdb 100644
--- a/libc/newhdrgen/yaml/time.yaml
+++ b/libc/newhdrgen/yaml/time.yaml
@@ -15,7 +15,7 @@ functions:
- stdc
return_type: char *
arguments:
- - type: struct tm *
+ - type: const struct tm *
- name: asctime_r
standard:
- stdc
diff --git a/libc/newhdrgen/yaml_to_classes.py b/libc/newhdrgen/yaml_to_classes.py
index 6bccda8e03640..205bb35fe691a 100644
--- a/libc/newhdrgen/yaml_to_classes.py
+++ b/libc/newhdrgen/yaml_to_classes.py
@@ -8,12 +8,11 @@
#
# ==-------------------------------------------------------------------------==#
-
import yaml
import argparse
-
from pathlib import Path
from header import HeaderFile
+from gpu_headers import GpuHeaderFile as GpuHeader
from class_implementation.classes.macro import Macro
from class_implementation.classes.type import Type
from class_implementation.classes.function import Function
@@ -22,18 +21,20 @@
from class_implementation.classes.object import Object
-def yaml_to_classes(yaml_data):
+def yaml_to_classes(yaml_data, header_class, entry_points=None):
"""
Convert YAML data to header classes.
Args:
yaml_data: The YAML data containing header specifications.
+ header_class: The class to use for creating the header.
+ entry_points: A list of specific function names to include in the header.
Returns:
HeaderFile: An instance of HeaderFile populated with the data.
"""
header_name = yaml_data.get("header")
- header = HeaderFile(header_name)
+ header = header_class(header_name)
for macro_data in yaml_data.get("macros", []):
header.add_macro(Macro(macro_data["macro_name"], macro_data["macro_value"]))
@@ -49,12 +50,15 @@ def yaml_to_classes(yaml_data):
)
functions = yaml_data.get("functions", [])
+ if entry_points:
+ entry_points_set = set(entry_points)
+ functions = [f for f in functions if f["name"] in entry_points_set]
sorted_functions = sorted(functions, key=lambda x: x["name"])
guards = []
guarded_function_dict = {}
for function_data in sorted_functions:
guard = function_data.get("guard", None)
- if guard == None:
+ if guard is None:
arguments = [arg["type"] for arg in function_data["arguments"]]
attributes = function_data.get("attributes", None)
standards = function_data.get("standards", None)
@@ -105,19 +109,21 @@ def yaml_to_classes(yaml_data):
return header
-def load_yaml_file(yaml_file):
+def load_yaml_file(yaml_file, header_class, entry_points):
"""
Load YAML file and convert it to header classes.
Args:
- yaml_file: The path to the YAML file.
+ yaml_file: Path to the YAML file.
+ header_class: The class to use for creating the header (HeaderFile or GpuHeader).
+ entry_points: A list of specific function names to include in the header.
Returns:
- HeaderFile: An instance of HeaderFile populated with the data from the YAML file.
+ HeaderFile: An instance of HeaderFile populated with the data.
"""
with open(yaml_file, "r") as f:
yaml_data = yaml.safe_load(f)
- return yaml_to_classes(yaml_data)
+ return yaml_to_classes(yaml_data, header_class, entry_points)
def fill_public_api(header_str, h_def_content):
@@ -207,7 +213,14 @@ def increase_indent(self, flow=False, indentless=False):
print(f"Added function {new_function.name} to {yaml_file}")
-def main(yaml_file, h_def_file, output_dir, add_function=None):
+def main(
+ yaml_file,
+ output_dir=None,
+ h_def_file=None,
+ add_function=None,
+ entry_points=None,
+ export_decls=False,
+):
"""
Main function to generate header files from YAML and .h.def templates.
@@ -216,41 +229,50 @@ def main(yaml_file, h_def_file, output_dir, add_function=None):
h_def_file: Path to the .h.def template file.
output_dir: Directory to output the generated header file.
add_function: Details of the function to be added to the YAML file (if any).
+ entry_points: A list of specific function names to include in the header.
+ export_decls: Flag to use GpuHeader for exporting declarations.
"""
-
if add_function:
add_function_to_yaml(yaml_file, add_function)
- header = load_yaml_file(yaml_file)
-
- with open(h_def_file, "r") as f:
- h_def_content = f.read()
+ header_class = GpuHeader if export_decls else HeaderFile
+ header = load_yaml_file(yaml_file, header_class, entry_points)
header_str = str(header)
- final_header_content = fill_public_api(header_str, h_def_content)
- output_file_name = Path(h_def_file).stem
- output_file_path = Path(output_dir) / output_file_name
-
- with open(output_file_path, "w") as f:
- f.write(final_header_content)
+ if output_dir:
+ output_file_path = Path(output_dir)
+ if output_file_path.is_dir():
+ output_file_path /= f"{Path(yaml_file).stem}.h"
+ else:
+ output_file_path = Path(f"{Path(yaml_file).stem}.h")
+
+ if not export_decls and h_def_file:
+ with open(h_def_file, "r") as f:
+ h_def_content = f.read()
+ final_header_content = fill_public_api(header_str, h_def_content)
+ with open(output_file_path, "w") as f:
+ f.write(final_header_content)
+ else:
+ with open(output_file_path, "w") as f:
+ f.write(header_str)
print(f"Generated header file: {output_file_path}")
if __name__ == "__main__":
- parser = argparse.ArgumentParser(
- description="Generate header files from YAML and .h.def templates"
- )
+ parser = argparse.ArgumentParser(description="Generate header files from YAML")
parser.add_argument(
"yaml_file", help="Path to the YAML file containing header specification"
)
- parser.add_argument("h_def_file", help="Path to the .h.def template file")
parser.add_argument(
"--output_dir",
- default=".",
help="Directory to output the generated header file",
)
+ parser.add_argument(
+ "--h_def_file",
+ help="Path to the .h.def template file (required if not using --export_decls)",
+ )
parser.add_argument(
"--add_function",
nargs=6,
@@ -264,6 +286,21 @@ def main(yaml_file, h_def_file, output_dir, add_function=None):
),
help="Add a function to the YAML file",
)
+ parser.add_argument(
+ "--e", action="append", help="Entry point to include", dest="entry_points"
+ )
+ parser.add_argument(
+ "--export-decls",
+ action="store_true",
+ help="Flag to use GpuHeader for exporting declarations",
+ )
args = parser.parse_args()
- main(args.yaml_file, args.h_def_file, args.output_dir, args.add_function)
+ main(
+ args.yaml_file,
+ args.output_dir,
+ args.h_def_file,
+ args.add_function,
+ args.entry_points,
+ args.export_decls,
+ )
>From 0ebb02613ff2797bda5387f7dd3d3a8a09c60d16 Mon Sep 17 00:00:00 2001
From: Rose Zhang <rosezhang at google.com>
Date: Tue, 16 Jul 2024 20:22:15 +0000
Subject: [PATCH 15/17] added missing DEPENDS
---
libc/include/CMakeLists.txt | 1 +
1 file changed, 1 insertion(+)
diff --git a/libc/include/CMakeLists.txt b/libc/include/CMakeLists.txt
index cb89c2565d5fe..d15671a23fbaf 100644
--- a/libc/include/CMakeLists.txt
+++ b/libc/include/CMakeLists.txt
@@ -587,6 +587,7 @@ add_header_macro(
../libc/newhdrgen/yaml/sys/sys_syscall.yaml
sys/syscall.h.def
sys/syscall.h
+ DEPENDS
)
add_header_macro(
>From 00aaf5b9bbb5fe5268cddaaf0c4f398bce40b2a3 Mon Sep 17 00:00:00 2001
From: Petr Hosek <phosek at google.com>
Date: Sun, 14 Jul 2024 13:24:11 -0700
Subject: [PATCH 16/17] [libc] Extend the baremetal I/O vendor ABI (#98683)
This refines and extends the external ABI for I/O, later changes will
update the baremetal implementations of I/O functions to use these.
---
libc/src/__support/OSUtil/baremetal/io.cpp | 50 +++++++++++++++++++---
libc/src/__support/OSUtil/baremetal/io.h | 1 +
2 files changed, 45 insertions(+), 6 deletions(-)
diff --git a/libc/src/__support/OSUtil/baremetal/io.cpp b/libc/src/__support/OSUtil/baremetal/io.cpp
index de278eb0092f8..f8ec603568936 100644
--- a/libc/src/__support/OSUtil/baremetal/io.cpp
+++ b/libc/src/__support/OSUtil/baremetal/io.cpp
@@ -13,20 +13,58 @@
namespace LIBC_NAMESPACE_DECL {
-// This is intended to be provided by the vendor.
+// These are intended to be provided by the vendor.
+//
+// The signature of these types and functions intentionally match `fopencookie`
+// which allows the following:
+//
+// ```
+// struct __llvm_libc_stdio_cookie { ... };
+// ...
+// struct __llvm_libc_stdio_cookie __llvm_libc_stdin_cookie;
+// cookie_io_functions_t stdin_func = { .read = __llvm_libc_stdio_read };
+// FILE *stdin = fopencookie(&__llvm_libc_stdin_cookie, "r", stdin_func);
+// ...
+// struct __llvm_libc_stdio_cookie __llvm_libc_stdout_cookie;
+// cookie_io_functions_t stdout_func = { .write = __llvm_libc_stdio_write };
+// FILE *stdout = fopencookie(&__llvm_libc_stdout_cookie, "w", stdout_func);
+// ...
+// struct __llvm_libc_stdio_cookie __llvm_libc_stderr_cookie;
+// cookie_io_functions_t stderr_func = { .write = __llvm_libc_stdio_write };
+// FILE *stderr = fopencookie(&__llvm_libc_stderr_cookie, "w", stderr_func);
+// ```
+//
+// At the same time, implementation of functions like `printf` and `scanf` can
+// use `__llvm_libc_stdio_read` and `__llvm_libc_stdio_write` directly to avoid
+// the extra indirection.
+//
+// All three symbols `__llvm_libc_stdin_cookie`, `__llvm_libc_stdout_cookie`,
+// and `__llvm_libc_stderr_cookie` must be provided, even if they don't point
+// at anything.
-extern struct __llvm_libc_stdin __llvm_libc_stdin;
-extern "C" ssize_t __llvm_libc_stdin_read(void *cookie, char *buf, size_t size);
+struct __llvm_libc_stdio_cookie;
-extern "C" void __llvm_libc_log_write(const char *msg, size_t len);
+extern struct __llvm_libc_stdio_cookie __llvm_libc_stdin_cookie;
+extern struct __llvm_libc_stdio_cookie __llvm_libc_stdout_cookie;
+extern struct __llvm_libc_stdio_cookie __llvm_libc_stderr_cookie;
+
+extern "C" ssize_t __llvm_libc_stdio_read(void *cookie, char *buf, size_t size);
+extern "C" ssize_t __llvm_libc_stdio_write(void *cookie, const char *buf,
+ size_t size);
ssize_t read_from_stdin(char *buf, size_t size) {
- return __llvm_libc_stdin_read(reinterpret_cast<void *>(&__llvm_libc_stdin),
+ return __llvm_libc_stdio_read(static_cast<void *>(&__llvm_libc_stdin_cookie),
buf, size);
}
+void write_to_stdout(cpp::string_view msg) {
+ __llvm_libc_stdio_write(static_cast<void *>(&__llvm_libc_stdout_cookie),
+ msg.data(), msg.size());
+}
+
void write_to_stderr(cpp::string_view msg) {
- __llvm_libc_log_write(msg.data(), msg.size());
+ __llvm_libc_stdio_write(static_cast<void *>(&__llvm_libc_stderr_cookie),
+ msg.data(), msg.size());
}
} // namespace LIBC_NAMESPACE_DECL
diff --git a/libc/src/__support/OSUtil/baremetal/io.h b/libc/src/__support/OSUtil/baremetal/io.h
index 92bf3db6b3fd1..aed34ec7e62e3 100644
--- a/libc/src/__support/OSUtil/baremetal/io.h
+++ b/libc/src/__support/OSUtil/baremetal/io.h
@@ -18,6 +18,7 @@ namespace LIBC_NAMESPACE_DECL {
ssize_t read_from_stdin(char *buf, size_t size);
void write_to_stderr(cpp::string_view msg);
+void write_to_stdout(cpp::string_view msg);
} // namespace LIBC_NAMESPACE_DECL
>From 49c5f1c4731d34fef4cc50c4f8e4da91a547898d Mon Sep 17 00:00:00 2001
From: Rose Zhang <rosezhang at google.com>
Date: Tue, 16 Jul 2024 21:53:02 +0000
Subject: [PATCH 17/17] moved __NOEXCEPT to be in front of semicolon, updated
my own assert files that aren't showing up
---
libc/config/baremetal/api.td | 36 -------------------
libc/config/gpu/api.td | 30 ----------------
libc/config/linux/api.td | 36 -------------------
libc/include/assert.h.def | 33 ++++++++++-------
.../class_implementation/classes/function.py | 2 +-
libc/newhdrgen/header.py | 8 ++---
libc/newhdrgen/yaml/assert.yaml | 16 +++++++++
7 files changed, 42 insertions(+), 119 deletions(-)
create mode 100644 libc/newhdrgen/yaml/assert.yaml
diff --git a/libc/config/baremetal/api.td b/libc/config/baremetal/api.td
index a6547d843c85e..08d62a0f58b89 100644
--- a/libc/config/baremetal/api.td
+++ b/libc/config/baremetal/api.td
@@ -5,42 +5,6 @@ include "spec/stdc_ext.td"
include "spec/bsd_ext.td"
include "spec/llvm_libc_stdfix_ext.td"
-def AssertMacro : MacroDef<"assert"> {
- let Defn = [{
- #undef assert
-
- #ifdef NDEBUG
- #define assert(e) (void)0
- #else
-
- #ifdef __cplusplus
- extern "C"
- #endif
- _Noreturn void __assert_fail(const char *, const char *, unsigned, const char *) __NOEXCEPT;
-
- #define assert(e) \
- ((e) ? (void)0 : __assert_fail(#e, __FILE__, __LINE__, __PRETTY_FUNCTION__))
-
- #endif
- }];
-}
-
-def StaticAssertMacro : MacroDef<"static_assert"> {
- let Defn = [{
- #ifndef __cplusplus
- #undef static_assert
- #define static_assert _Static_assert
- #endif
- }];
-}
-
-def AssertAPI : PublicAPI<"assert.h"> {
- let Macros = [
- AssertMacro,
- StaticAssertMacro,
- ];
-}
-
def CTypeAPI : PublicAPI<"ctype.h"> {
}
diff --git a/libc/config/gpu/api.td b/libc/config/gpu/api.td
index 21ddbb95b70c9..c18228265c42c 100644
--- a/libc/config/gpu/api.td
+++ b/libc/config/gpu/api.td
@@ -7,36 +7,6 @@ include "spec/gnu_ext.td"
include "spec/stdc_ext.td"
include "spec/llvm_libc_ext.td"
-def AssertMacro : MacroDef<"assert"> {
- let Defn = [{
- #undef assert
-
- #ifdef NDEBUG
- #define assert(e) (void)0
- #else
-
- #define assert(e) \
- ((e) ? (void)0 : __assert_fail(#e, __FILE__, __LINE__, __PRETTY_FUNCTION__))
- #endif
- }];
-}
-
-def StaticAssertMacro : MacroDef<"static_assert"> {
- let Defn = [{
- #ifndef __cplusplus
- #undef static_assert
- #define static_assert _Static_assert
- #endif
- }];
-}
-
-def AssertAPI : PublicAPI<"assert.h"> {
- let Macros = [
- AssertMacro,
- StaticAssertMacro,
- ];
-}
-
def StringAPI : PublicAPI<"string.h"> {
let Types = ["size_t"];
}
diff --git a/libc/config/linux/api.td b/libc/config/linux/api.td
index 60e9b70f0d8a4..a10dec06e2452 100644
--- a/libc/config/linux/api.td
+++ b/libc/config/linux/api.td
@@ -9,42 +9,6 @@ include "spec/stdc_ext.td"
include "spec/llvm_libc_ext.td"
include "spec/llvm_libc_stdfix_ext.td"
-def AssertMacro : MacroDef<"assert"> {
- let Defn = [{
- #undef assert
-
- #ifdef NDEBUG
- #define assert(e) (void)0
- #else
-
- #ifdef __cplusplus
- extern "C"
- #endif
- _Noreturn void __assert_fail(const char *, const char *, unsigned, const char *) __NOEXCEPT;
-
- #define assert(e) \
- ((e) ? (void)0 : __assert_fail(#e, __FILE__, __LINE__, __PRETTY_FUNCTION__))
-
- #endif
- }];
-}
-
-def StaticAssertMacro : MacroDef<"static_assert"> {
- let Defn = [{
- #ifndef __cplusplus
- #undef static_assert
- #define static_assert _Static_assert
- #endif
- }];
-}
-
-def AssertAPI : PublicAPI<"assert.h"> {
- let Macros = [
- AssertMacro,
- StaticAssertMacro,
- ];
-}
-
def CTypeAPI : PublicAPI<"ctype.h"> {
}
diff --git a/libc/include/assert.h.def b/libc/include/assert.h.def
index 15077e53e2ca4..58a6a3e77cbae 100644
--- a/libc/include/assert.h.def
+++ b/libc/include/assert.h.def
@@ -1,15 +1,24 @@
-//===-- C standard library header assert.h --------------------------------===//
-//
-// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
-// See https://llvm.org/LICENSE.txt for license information.
-// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
-//
-//===----------------------------------------------------------------------===//
-
-#include "__llvm-libc-common.h"
-#include "llvm-libc-macros/assert-macros.h"
-
// This file may be usefully included multiple times to change assert()'s
// definition based on NDEBUG.
-%%public_api()
+
+#undef assert
+#ifdef NDEBUG
+#define assert(e) (void)0
+#else
+
+#ifndef __cplusplus
+#undef static_assert
+#define static_assert _Static_assert
+#endif
+
+#ifdef __cplusplus
+extern "C"
+#endif
+_Noreturn void __assert_fail(const char *, const char *, unsigned, const char *) __NOEXCEPT;
+
+#define assert(e) \
+ ((e) ? (void)0 : __assert_fail(#e, __FILE__, __LINE__, __PRETTY_FUNCTION__))
+#endif
+
+%%public_api()
\ No newline at end of file
diff --git a/libc/newhdrgen/class_implementation/classes/function.py b/libc/newhdrgen/class_implementation/classes/function.py
index ccfd93547c1d8..845ef1aebf54b 100644
--- a/libc/newhdrgen/class_implementation/classes/function.py
+++ b/libc/newhdrgen/class_implementation/classes/function.py
@@ -26,7 +26,7 @@ def __str__(self):
attributes_str = " ".join(self.attributes)
arguments_str = ", ".join(self.arguments)
if attributes_str == "":
- result = f"{self.return_type} {self.name}({arguments_str});"
+ result = f"{self.return_type} {self.name}({arguments_str})"
else:
result = f"{attributes_str} {self.return_type} {self.name}({arguments_str})"
return result
diff --git a/libc/newhdrgen/header.py b/libc/newhdrgen/header.py
index 69de81eebb719..d1f0fe96dbc60 100644
--- a/libc/newhdrgen/header.py
+++ b/libc/newhdrgen/header.py
@@ -60,16 +60,16 @@ def __str__(self):
current_guard = None
for function in self.functions:
if function.guard == None:
- content.append(str(function) + "__NOEXCEPT")
+ content.append(str(function) + "__NOEXCEPT;")
content.append("")
else:
if current_guard == None:
current_guard = function.guard
content.append(f"#ifdef {current_guard}")
- content.append(str(function) + "__NOEXCEPT")
+ content.append(str(function) + "__NOEXCEPT;")
content.append("")
elif current_guard == function.guard:
- content.append(str(function) + "__NOEXCEPT")
+ content.append(str(function) + "__NOEXCEPT;")
content.append("")
else:
content.pop()
@@ -77,7 +77,7 @@ def __str__(self):
content.append("")
current_guard = function.guard
content.append(f"#ifdef {current_guard}")
- content.append(str(function) + "__NOEXCEPT")
+ content.append(str(function) + "__NOEXCEPT;")
content.append("")
if current_guard != None:
content.pop()
diff --git a/libc/newhdrgen/yaml/assert.yaml b/libc/newhdrgen/yaml/assert.yaml
new file mode 100644
index 0000000000000..660be7fb6063f
--- /dev/null
+++ b/libc/newhdrgen/yaml/assert.yaml
@@ -0,0 +1,16 @@
+header: assert.h
+macros: []
+types: []
+enums: []
+objects: []
+functions:
+ - name: __assert_fail
+ standards:
+ - llvm_libc_ext
+ return_type: _Noreturn void
+ arguments:
+ - type: const char *
+ - type: const char *
+ - type: unsigned
+ - type: const char *
+ guard: __cplusplus
\ No newline at end of file
More information about the libc-commits
mailing list