cosmopolitan/libc
Justine Tunney db0d8dd806 Support Linux binfmt_misc and APE loading on Apple
The "no modify self" variant of Actually Portable Executable is now
supported on all platforms. If you use `$(APE_NO_MODIFY_SELF)` then
ld.bfd will embed a 4096 byte ELF binary and a 4096 byte Macho file
which are installed on the fly to ${TMPDIR:-/tmp}, which enables us
launch the executable, without needing to copy the whole executable

To prevent it from copying a tiny executable to your temp directory
you need to install the `ape` command (renamed from ape-loader), to
a system path. For example:

    # FreeBSD / NetBSD / OpenBSD
    make -j8 o//ape/ape
    cp o//ape/ape /usr/bin/ape

    # Mac OS
    # make -j8 o//ape/ape.macho
    curl https://justine.lol/ape.macho >/usr/bin/ape
    chmod +x /usr/bin/ape

On Linux you can get even more performance with the new binfmt_misc
support which makes launching non-modifying APE binaries as fast as
launching ELF executables. Running the following command:

    # Linux
    ape/apeinstall.sh

Will copy APE loader to /usr/bin/ape and register with binfmt_misc
Lastly, this change also fixes a really interesting race condition
with OpenBSD thread joining.
2022-05-21 09:28:25 -07:00
..
alg Import C++ Standard Template Library 2022-03-22 06:41:54 -07:00
bits Fix amalgamation warnings 2022-05-19 19:08:35 -07:00
calls Support Linux binfmt_misc and APE loading on Apple 2022-05-21 09:28:25 -07:00
crt Support Linux binfmt_misc and APE loading on Apple 2022-05-21 09:28:25 -07:00
dns Make improvements 2022-04-28 09:57:07 -07:00
elf Make improvements 2022-04-26 16:46:15 -07:00
fmt Support Linux binfmt_misc and APE loading on Apple 2022-05-21 09:28:25 -07:00
integral Make fixes and improvements 2022-05-19 16:57:49 -07:00
intrin Fix many thread and file descriptor issues on Windows 2022-05-20 20:57:19 -07:00
isystem Make some systemic improvements 2022-05-18 16:52:36 -07:00
linux [WIP] Threading (#282) 2021-10-13 11:26:05 -07:00
log Make fixes and improvements 2022-05-19 16:57:49 -07:00
mem Make some systemic improvements 2022-05-18 16:52:36 -07:00
nexgen32e Fix many thread and file descriptor issues on Windows 2022-05-20 20:57:19 -07:00
nt Make fixes and improvements 2022-05-19 16:57:49 -07:00
rand Fix many thread and file descriptor issues on Windows 2022-05-20 20:57:19 -07:00
runtime Support Linux binfmt_misc and APE loading on Apple 2022-05-21 09:28:25 -07:00
sock Fix many thread and file descriptor issues on Windows 2022-05-20 20:57:19 -07:00
stdio Make fixes and improvements 2022-05-19 16:57:49 -07:00
str Make fixes and improvements 2022-05-19 16:57:49 -07:00
stubs Support thread local storage 2022-05-16 13:20:08 -07:00
sysv Fix stdio regression 2022-05-19 00:51:15 -07:00
testlib Support Linux binfmt_misc and APE loading on Apple 2022-05-21 09:28:25 -07:00
thread Make some systemic improvements 2022-05-18 16:52:36 -07:00
time Improve threading support further 2022-05-17 04:14:28 -07:00
tinymath Fix some more reported issues 2022-04-28 20:36:33 -07:00
unicode Fix more things 2022-03-24 00:12:29 -07:00
x Make some systemic improvements 2022-05-18 16:52:36 -07:00
zipos Fix many thread and file descriptor issues on Windows 2022-05-20 20:57:19 -07:00
assert.h Import C++ Standard Template Library 2022-03-22 06:41:54 -07:00
atomic.h Make some systemic improvements 2022-05-18 16:52:36 -07:00
complex.h Fix some more reported issues 2022-04-28 20:36:33 -07:00
dce.h Restart CI for New Technology and UBSAN hunting 2022-03-21 04:32:57 -07:00
disclaimer.inc Improve Libc by making Python work even better 2021-08-18 22:16:23 -07:00
dos.h Mold the redbean binary to minimize page faults 2021-05-03 12:14:13 -07:00
errno.h Support thread local storage 2022-05-16 13:20:08 -07:00
inttypes.h Import C++ Standard Template Library 2022-03-22 06:41:54 -07:00
libc.mk Import C++ Standard Template Library 2022-03-22 06:41:54 -07:00
limits.h Import C++ Standard Template Library 2022-03-22 06:41:54 -07:00
literal.h Import C++ Standard Template Library 2022-03-22 06:41:54 -07:00
mach.h Perform some minor fixups 2021-03-16 22:19:51 -07:00
macho.internal.h Get Cosmopolitan into releasable state 2020-11-25 08:19:00 -08:00
macros-cpp.internal.inc Fix bugs with recent change 2022-04-16 10:40:23 -07:00
macros.internal.h Make fixes, improvements, and chibicc python bindings 2021-10-08 08:41:57 -07:00
macros.internal.inc Support thread local storage 2022-05-16 13:20:08 -07:00
math.h Import C++ Standard Template Library 2022-03-22 06:41:54 -07:00
notice.inc Improve Libc by making Python work even better 2021-08-18 22:16:23 -07:00
notice.internal.h Add epoll and do more release readiness changes 2020-11-28 12:01:51 -08:00
paths.h Initial import 2020-06-15 07:18:57 -07:00
README.md Add x86_64-linux-gnu emulator 2020-08-25 04:43:42 -07:00
type2str.h Improve synchronization 2022-04-15 15:31:55 -07:00
zip.h Make improvements 2022-04-24 10:06:05 -07:00

SYNOPSIS

Cosmopolitan Standard Library.

OVERVIEW

This directory defines static archives defining functions, like printf(), mmap(), win32, etc. Please note that the Cosmopolitan build configuration doesn't link any C/C++ library dependencies by default, so you still have the flexibility to choose the one provided by your system. If you'd prefer Cosmopolitan, just add $(LIBC) and $(CRT) to your linker arguments.

Your library is compromised of many bite-sized static archives. We use the checkdeps tool to guarantee that the contents of the archives are organized in a logical way that's easy to use with or without our makefile infrastructure, since there's no cyclic dependencies.

The Cosmopolitan Library exports only the most stable canonical system calls for all supported operating systems, regardless of which platform is used for compilation. We polyfill many of the APIs, e.g. read(), write() so they work consistently everywhere while other apis, e.g. CreateWindowEx(), might only work on one platform, in which case they become no-op functions on others.

Cosmopolitan polyfill wrappers will usually use the dollar sign naming convention, so they may be bypassed when necessary. This same convention is used when multiple implementations of string library and other performance-critical function are provided to allow Cosmopolitan to go fast on both old and newer computers.

We take an approach to configuration that relies heavily on the compiler's dead code elimination pass (libc/dce.h). Most of the code is written so that, for example, folks not wanting support for OpenBSD can flip a bit in SUPPORT_VECTOR and that code will be omitted from the build. The same is true for builds that are tuned using -march=native which effectively asks the library to not include runtime support hooks for x86 processors older than what you use.

Please note that, unlike Cygwin or MinGW, Cosmopolitan does not achieve broad support by bolting on a POSIX emulation layer. We do nothing more than (in most cases) stateless API translations that get you 90% of the way there in a fast lightweight manner. We therefore can't address some of the subtle differences, such as the nuances of absolute paths on Windows. Our approach could be compared to something more along the lines of, "the Russians just used a pencil to write in space", versus spending millions researching a pen like NASA.