blob: 84431ccceeabac978123d55e311e4bb5088b4760 [file] [log] [blame]
LLVM libc build rules
=====================
At the cost of verbosity, we want to keep the build system of LLVM libc
as simple as possible. We also want to be highly modular with our build
targets. This makes picking and choosing desired pieces a straighforward
task.
Targets for entrypoints
-----------------------
Every entrypoint in LLVM-libc has its own build target. This target is listed
using the ``add_entrypoint_object`` rule. This rule generates a single object
file containing the implementation of the entrypoint.
Targets for redirecting entrypoints are also listed using the
``add_entrypoint_object`` rule. However, one will have to additionally specify
the ``REDIRECTED`` option with the rule.
Targets for entrypoint libraries
--------------------------------
Standards like POSIX require that a libc provide certain library files like
``libc.a``, ``libm.a``, etc. The targets for such library files are listed in
the ``lib`` directory as ``add_entrypoint_library`` targets. An
``add_entrypoint_library`` target takes a list of ``add_entrypoint_object``
targets and produces a static library containing the object files corresponding
to the ``add_entrypoint_targets``.
Targets for redirectors
-----------------------
Similar to how every entrypoint in LLVM-libc has its own build target, every
redirector function also has its own build target. This target is listed using
the ``add_redirector_object`` rule. This rule generates a single object file
which can be packaged along with other redirector objects into shared library
of redirectors (see below).
Targets for library of redirectors
----------------------------------
Targets for shared libraries of redirectors are listed using the
``add_redirector_library`` rule.