cosmopolitan/libc/sysv
Justine Tunney 4778cd4d27
Fix bugs in termios library and cleanup code
This change fixes an issue with the tcflow() magic numbers that was
causing bash to freeze up on Linux. While auditing termios polyfills,
several other issues were identified with XNU/BSD compatibility.

Out of an abundance of caution this change undefines as much surface
area from libc/calls/struct/termios.h as possible, so that autoconf
scripts are less likely to detect non-POSIX teletypewriter APIs that
haven't been polyfilled by Cosmopolitan.

This is a *breaking change* for your static archives in /opt/cosmos if
you use the cosmocc toolchain. That's because this change disables the
ioctl() undiamonding trick for code outside the monorepo, specifically
because it'll lead to brittle ABI breakages like this. If you're using
the cosmocc toolchain, you'll need to rebuild libraries like ncurses,
readline, etc. Yes diamonds cause bloat. To work around that, consider
using tcgetwinsize() instead of ioctl(TIOCGWINSZ) since it'll help you
avoid pulling every single ioctl-related polyfill into the linkage.

The cosmocc script was specifying -DNDEBUG for some reason. It's fixed.
2023-06-14 19:30:52 -07:00
..
calls Fix bugs in cosmocc toolchain 2023-06-08 23:44:03 -07:00
consts Fix bugs in termios library and cleanup code 2023-06-14 19:30:52 -07:00
dos2errno Introduce native support for MacOS ARM64 2023-05-20 04:17:03 -07:00
errfuns Get --ftrace working on aarch64 2023-06-05 23:35:31 -07:00
consts.sh Fix bugs in termios library and cleanup code 2023-06-14 19:30:52 -07:00
describeos.greg.c Remove malloc() dependency on pledge() / unveil() 2022-07-24 21:51:37 -07:00
dos2errno.sh Add WSL to test fleet 2022-11-02 06:49:42 -07:00
errfun.S Introduce native support for MacOS ARM64 2023-05-20 04:17:03 -07:00
errfun2.c Fix bugs in cosmocc toolchain 2023-06-08 23:44:03 -07:00
errfuns.h Get aarch64 hello world working 2023-05-10 04:20:47 -07:00
errfuns.sh Change license 2020-12-27 17:18:44 -08:00
errno.c Make considerably more progress on AARCH64 2023-05-12 22:42:57 -07:00
errno_location.greg.c Fix bugs in cosmocc toolchain 2023-06-08 23:44:03 -07:00
gen.sh Get --ftrace working on aarch64 2023-06-05 23:35:31 -07:00
hostos.S Introduce native support for MacOS ARM64 2023-05-20 04:17:03 -07:00
macros.internal.h Get --ftrace working on aarch64 2023-06-05 23:35:31 -07:00
README.md Initial import 2020-06-15 07:18:57 -07:00
restorert.S Get LIBC_RUNTIME and LIBC_CALLS building on aarch64 2023-05-10 04:20:47 -07:00
strace.greg.c Make more threading improvements 2022-11-01 23:28:26 -07:00
syscall.S Get --ftrace working on aarch64 2023-06-05 23:35:31 -07:00
syscalls.sh Fix bugs in cosmocc toolchain 2023-06-08 23:44:03 -07:00
syscon.S Improve aarch64 native support some more 2023-06-04 08:58:47 -07:00
syscount.S Make considerably more progress on AARCH64 2023-05-12 22:42:57 -07:00
syslib.S Introduce native support for MacOS ARM64 2023-05-20 04:17:03 -07:00
sysret.c Get LIBC_RUNTIME and LIBC_CALLS building on aarch64 2023-05-10 04:20:47 -07:00
systemfive.S Introduce #include <cosmo.h> to toolchain users 2023-06-09 18:03:05 -07:00
sysv.mk Get --ftrace working on aarch64 2023-06-05 23:35:31 -07:00

SYNOPSIS

System Five Import Libraries

OVERVIEW

Bell System Five is the umbrella term we use to describe Linux, FreeBSD, OpenBSD, and Mac OS X which all have nearly-identical application binary interfaces that stood the test of time, having definitions nearly the same as those of AT&T back in the 1980's.

Cosmopolitan aims to help you build apps that can endure over the course of decades, just like these systems have: without needing to lift a finger for maintenance churn, broken builds, broken hearts.

The challenge to System V binary compatibility basically boils down to numbers. All these systems agree on what services are provided, but tend to grant them wildly different numbers.

We address this by putting all the numbers in a couple big shell scripts, ask the GNU Assembler to encode them into binaries using an efficient LEB128 encoding, unpacked by _init(), and ref'd via extern const. It gives us good debuggability, and any costs are gained back by fewer branches in wrapper functions.z