[RFC PATCH 00/27] ARM64: support ILP32

From: Yury Norov
Date: Tue Jun 21 2016 - 01:41:56 EST


This series enables aarch64 port with ilp32 mode.

After long discussions in kernel list, we finally got
consensus on how ABI should look. This patchset adds
support for the ABI in GLIBC. It is tested with LTP
with no big regressions comparing to LP64 and AARCH32.

Though it's very raw. Please be patient reviewing it.

ABI details:
- types are taken from AARCH32, next types turned to 64-bit,
as modern requirement for new APIs tells:
ino_t is u64 type
off_t is s64 type
blkcnt_t is s64 type
fsblkcnt_t is u64 type
fsfilcnt_t is u64 type
- 64-bit arguments are passed in syscall as register pair,
as kernel internally clears top halves for all input regs;
- standard syscall table is used;
- 32-bit time_t is used. AARCH64/ILP32 is waiting for general
fix of Y2038 problem just like other 32-bit arches;
- stat{64}, statfs{64} structures are of the identical layout
with LP64. Corresponding syscalls are taken from 64-bit code.

Links:
This series: https://github.com/norov/glibc/commits/ilp32-2.23
Kernel series: https://github.com/norov/linux/commits/ilp32-nowrap
Kernel in LKML: https://lkml.org/lkml/2016/6/17/990

Please review it. Any comments appreciated.

Yury.

Andrew Pinski (24):
[AARCH64] Fix utmp struct for compatibility reasons.
[AARCH64] Add header guards to sysdep.h headers.
Add dynamic ILP32 AARCH64 relocations to elf.h
[AARCH64] Add PTR_REG, PTR_LOG_SIZE, and PTR_SIZE. Use it in
LDST_PCREL and LDST_GLOBAL.
[AARCH64] Use PTR_REG in crti.S.
[AARCH64] Use PTR_REG/PTR_SIZE/PTR_SIZE_LOG in dl-tlsesc.S
[AARCH64] Use PTR_* macros in dl-trampoline.S
[AARCH64] Use PTR_* in start.S
[AARCH64] Use PTR_REG in getcontext.S.
[AARCH64] Detect ILP32 in configure scripts.
[AARCH64] Syscalls for ILP32 are passed always via 64bit values.
[AARCH64] Add ILP32 support to elf_machine_load_address.
[AARCH64] Set up wordsize for ILP32.
[AARCH64] Add ILP32 to makefiles
[AARCH64] Add support to ldconfig for ILP32 and libilp32
[AARCH64] Add ILP32 ld.so to the known interpreter names.
[AARCH64] Add ldd-rewrite.sed so that ilp32 ld.so can be found
[AARCH64] Add kernel_sigaction.h for AARCH64 ILP32
[AARCH64] Add typesizes.h for ILP32
[AARCH64] Make lp64 and ilp32 directories.
Add support for AT_ARM64_MIDR.
[AARCH64] Fix ILP32 warning
[AARCH64] Change type of __align to long long
Fix PTRDIFF_MIN/PTRDIFF_MIN and PTRDIFF_MIN for ILP32.

Yury Norov (3):
[AARCH64] ILP32: introduce syscalls that pass off_t
[AARCH64] ILP32: support stat syscall family
[AARCH64] delouse input arguments in system functions

elf/cache.c | 2 +
elf/dl-sysdep.c | 1 +
elf/elf.h | 3 +
sysdeps/aarch64/Implies | 6 -
sysdeps/aarch64/__longjmp.S | 6 +-
sysdeps/aarch64/bits/wordsize.h | 28 +++
sysdeps/aarch64/configure | 15 +-
sysdeps/aarch64/configure.ac | 11 +-
sysdeps/aarch64/crti.S | 3 +-
sysdeps/aarch64/dl-irel.h | 3 +-
sysdeps/aarch64/dl-machine.h | 199 ++++++++++++---------
sysdeps/aarch64/dl-tlsdesc.S | 42 +++--
sysdeps/aarch64/dl-trampoline.S | 18 +-
sysdeps/aarch64/ilp32/Implies | 6 +
sysdeps/aarch64/jmpbuf-unwind.h | 2 +-
sysdeps/aarch64/lp64/Implies | 7 +
sysdeps/aarch64/memcmp.S | 3 +
sysdeps/aarch64/memcpy.S | 4 +-
sysdeps/aarch64/memmove.S | 3 +
sysdeps/aarch64/memset.S | 3 +-
sysdeps/aarch64/nptl/bits/semaphore.h | 2 +-
sysdeps/aarch64/preconfigure | 11 +-
sysdeps/aarch64/setjmp.S | 5 +-
sysdeps/aarch64/start.S | 20 ++-
sysdeps/aarch64/strchr.S | 1 +
sysdeps/aarch64/strchrnul.S | 1 +
sysdeps/aarch64/strcmp.S | 2 +
sysdeps/aarch64/strcpy.S | 2 +
sysdeps/aarch64/strlen.S | 2 +
sysdeps/aarch64/strncmp.S | 3 +
sysdeps/aarch64/strnlen.S | 3 +
sysdeps/aarch64/strrchr.S | 1 +
sysdeps/aarch64/sysdep.h | 39 +++-
sysdeps/generic/ldconfig.h | 1 +
sysdeps/generic/stdint.h | 9 +-
sysdeps/unix/sysv/linux/aarch64/Implies | 2 -
sysdeps/unix/sysv/linux/aarch64/Makefile | 16 +-
sysdeps/unix/sysv/linux/aarch64/bits/fcntl.h | 6 +-
sysdeps/unix/sysv/linux/aarch64/bits/stat.h | 195 ++++++++++++++++++++
sysdeps/unix/sysv/linux/aarch64/bits/statfs.h | 72 ++++++++
sysdeps/unix/sysv/linux/aarch64/bits/typesizes.h | 91 ++++++++++
sysdeps/unix/sysv/linux/aarch64/clone.S | 7 +
sysdeps/unix/sysv/linux/aarch64/configure | 24 ++-
sysdeps/unix/sysv/linux/aarch64/configure.ac | 11 +-
sysdeps/unix/sysv/linux/aarch64/dl-auxv.h | 25 +++
sysdeps/unix/sysv/linux/aarch64/dl-cache.h | 13 +-
sysdeps/unix/sysv/linux/aarch64/dl-sysdep.c | 5 +
sysdeps/unix/sysv/linux/aarch64/getcontext.S | 3 +-
sysdeps/unix/sysv/linux/aarch64/ilp32/Implies | 4 +
.../unix/sysv/linux/aarch64/ilp32/dl-fxstatat64.c | 6 +
sysdeps/unix/sysv/linux/aarch64/ilp32/dl-xstat64.c | 6 +
sysdeps/unix/sysv/linux/aarch64/ilp32/fallocate.c | 31 ++++
.../unix/sysv/linux/aarch64/ilp32/fallocate64.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/fstatfs.c | 29 +++
sysdeps/unix/sysv/linux/aarch64/ilp32/fstatfs64.c | 72 ++++++++
sysdeps/unix/sysv/linux/aarch64/ilp32/ftruncate.c | 1 +
.../unix/sysv/linux/aarch64/ilp32/ftruncate64.c | 4 +
sysdeps/unix/sysv/linux/aarch64/ilp32/fxstat.c | 51 ++++++
sysdeps/unix/sysv/linux/aarch64/ilp32/fxstat64.c | 54 ++++++
sysdeps/unix/sysv/linux/aarch64/ilp32/fxstatat.c | 48 +++++
sysdeps/unix/sysv/linux/aarch64/ilp32/fxstatat64.c | 52 ++++++
sysdeps/unix/sysv/linux/aarch64/ilp32/getdents.c | 78 ++++++++
sysdeps/unix/sysv/linux/aarch64/ilp32/getdents64.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/llseek.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/lseek.c | 36 ++++
sysdeps/unix/sysv/linux/aarch64/ilp32/lseek64.c | 0
sysdeps/unix/sysv/linux/aarch64/ilp32/lxstat.c | 47 +++++
sysdeps/unix/sysv/linux/aarch64/ilp32/mmap.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/mmap64.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/msgctl.c | 32 ++++
.../unix/sysv/linux/aarch64/ilp32/posix_fadvise.c | 1 +
.../sysv/linux/aarch64/ilp32/posix_fadvise64.c | 2 +
sysdeps/unix/sysv/linux/aarch64/ilp32/pread.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/pread64.c | 5 +
sysdeps/unix/sysv/linux/aarch64/ilp32/preadv.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/preadv64.c | 5 +
sysdeps/unix/sysv/linux/aarch64/ilp32/pwrite.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/pwrite64.c | 5 +
sysdeps/unix/sysv/linux/aarch64/ilp32/pwritev.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/pwritev64.c | 5 +
sysdeps/unix/sysv/linux/aarch64/ilp32/readahead.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/readdir64.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/semctl.c | 53 ++++++
.../unix/sysv/linux/aarch64/ilp32/shlib-versions | 7 +
sysdeps/unix/sysv/linux/aarch64/ilp32/shmctl.c | 32 ++++
sysdeps/unix/sysv/linux/aarch64/ilp32/statfs.c | 30 ++++
sysdeps/unix/sysv/linux/aarch64/ilp32/statfs64.c | 29 +++
.../unix/sysv/linux/aarch64/ilp32/syscalls.list | 0
sysdeps/unix/sysv/linux/aarch64/ilp32/truncate.c | 1 +
sysdeps/unix/sysv/linux/aarch64/ilp32/truncate64.c | 4 +
sysdeps/unix/sysv/linux/aarch64/ilp32/xstat.c | 47 +++++
sysdeps/unix/sysv/linux/aarch64/ilp32/xstat64.c | 47 +++++
sysdeps/unix/sysv/linux/aarch64/ioctl.S | 31 ----
sysdeps/unix/sysv/linux/aarch64/kernel_sigaction.h | 12 ++
sysdeps/unix/sysv/linux/aarch64/ldconfig.h | 2 +
sysdeps/unix/sysv/linux/aarch64/ldd-rewrite.sed | 1 +
sysdeps/unix/sysv/linux/aarch64/lp64/Implies | 4 +
sysdeps/unix/sysv/linux/aarch64/lp64/ioctl.S | 31 ++++
sysdeps/unix/sysv/linux/aarch64/lp64/mmap.c | 34 ++++
.../unix/sysv/linux/aarch64/lp64/shlib-versions | 7 +
sysdeps/unix/sysv/linux/aarch64/mmap.c | 34 ----
sysdeps/unix/sysv/linux/aarch64/setcontext.S | 1 +
sysdeps/unix/sysv/linux/aarch64/shlib-versions | 7 -
sysdeps/unix/sysv/linux/aarch64/sigaction.c | 10 +-
sysdeps/unix/sysv/linux/aarch64/sigcontextinfo.h | 2 +-
sysdeps/unix/sysv/linux/aarch64/swapcontext.S | 1 +
sysdeps/unix/sysv/linux/aarch64/sysdep.h | 56 +++---
sysdeps/unix/sysv/linux/arm/readelflib.c | 4 +-
sysdeps/unix/sysv/linux/generic/brk.c | 2 +-
sysdeps/unix/sysv/linux/sysdep-vdso.h | 4 +-
110 files changed, 1744 insertions(+), 271 deletions(-)
delete mode 100644 sysdeps/aarch64/Implies
create mode 100644 sysdeps/aarch64/bits/wordsize.h
mode change 100644 => 100755 sysdeps/aarch64/configure
create mode 100644 sysdeps/aarch64/ilp32/Implies
create mode 100644 sysdeps/aarch64/lp64/Implies
create mode 100644 sysdeps/unix/sysv/linux/aarch64/bits/stat.h
create mode 100644 sysdeps/unix/sysv/linux/aarch64/bits/statfs.h
create mode 100644 sysdeps/unix/sysv/linux/aarch64/bits/typesizes.h
mode change 100644 => 100755 sysdeps/unix/sysv/linux/aarch64/configure
create mode 100644 sysdeps/unix/sysv/linux/aarch64/dl-auxv.h
create mode 100644 sysdeps/unix/sysv/linux/aarch64/dl-sysdep.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/Implies
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/dl-fxstatat64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/dl-xstat64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/fallocate.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/fallocate64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/fstatfs.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/fstatfs64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/ftruncate.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/ftruncate64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/fxstat.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/fxstat64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/fxstatat.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/fxstatat64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/getdents.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/getdents64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/llseek.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/lseek.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/lseek64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/lxstat.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/mmap.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/mmap64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/msgctl.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/posix_fadvise.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/posix_fadvise64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/pread.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/pread64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/preadv.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/preadv64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/pwrite.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/pwrite64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/pwritev.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/pwritev64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/readahead.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/readdir64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/semctl.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/shlib-versions
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/shmctl.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/statfs.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/statfs64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/syscalls.list
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/truncate.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/truncate64.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/xstat.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ilp32/xstat64.c
delete mode 100644 sysdeps/unix/sysv/linux/aarch64/ioctl.S
create mode 100644 sysdeps/unix/sysv/linux/aarch64/kernel_sigaction.h
create mode 100644 sysdeps/unix/sysv/linux/aarch64/ldd-rewrite.sed
create mode 100644 sysdeps/unix/sysv/linux/aarch64/lp64/Implies
create mode 100644 sysdeps/unix/sysv/linux/aarch64/lp64/ioctl.S
create mode 100644 sysdeps/unix/sysv/linux/aarch64/lp64/mmap.c
create mode 100644 sysdeps/unix/sysv/linux/aarch64/lp64/shlib-versions
delete mode 100644 sysdeps/unix/sysv/linux/aarch64/mmap.c
delete mode 100644 sysdeps/unix/sysv/linux/aarch64/shlib-versions

--
2.7.4