linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [RFC2 PATCH v6 00/19] ILP32 for ARM64
@ 2015-11-17 21:16 Yury Norov
  2015-11-17 21:16 ` [PATCH v6 01/19] arm64:ilp32: add documentation on the ILP32 ABI " Yury Norov
                   ` (21 more replies)
  0 siblings, 22 replies; 79+ messages in thread
From: Yury Norov @ 2015-11-17 21:16 UTC (permalink / raw)
  To: arnd, catalin.marinas, linux-arm-kernel, linux-kernel
  Cc: pinskia, ddaney.cavm, jan.dakinevich, Prasun.Kapoor,
	christoph.muellner, philipp.tomsich, broonie, andrey.konovalov,
	Nathan_Lynch, agraf, bamvor.zhangjian, klimov.linux, joseph,
	schwab

------8<-----
Colleagues, I'm gonna to send it to list.
Please, take a look.
------8<-----

This is still RFC because ~20 tests still fail,
and because it's based on 4.3 kernel version, and
some work is needed to rebase on 4.4. I'd preffer
to do it later. 

v3: https://lkml.org/lkml/2014/9/3/704
v4: https://lkml.org/lkml/2015/4/13/691
v5: https://lkml.org/lkml/2015/9/29/911

v6:
 - time_t, __kenel_off_t and other types turned to be 32-bit
   for compatibility reasons (after v5 discussion);
 - related changes applied to ILP32 syscall table and handlers;
 - ILP32 VDSO code excluded. It's not mandatory, and caused questions
   during review process. We definitely make sure we will follow up
   with a VDSO later on because it is needed for performance reasons;
 - fixed build issues with different combinations of AARCH32 / ILP32
   enabling in config;
 - ILP32 TLS bug fixed;
 - entry32-common.S introduced to hold wrappers needed for both ILP32
   and AARCH32_EL0;
 - documentation updated according to latest changes;
 - rebased to the current head;
 - coding style re-checked;
 - ILP32 syscall table turned around.

Testing is performed using LTP with scenario 'ltplite'.
Tested on QEMU + vanilla defconfig kernel.
Regressions are mostly related to core dump genereation,
readdir(), and futex(). Some tests fail both in ILP32, and LP64.

The full regression table is:
		ILP32		LP64

float_bessel    FAIL	 134    PASSED	0
float_exp_log   FAIL	 134    PASSED	0
float_iperb     FAIL	 134    PASSED	0
float_power     FAIL	 134    PASSED	0
float_trigo     FAIL	 134    PASSED	0
abort01         FAIL       2    FAIL 	2
fcntl14         FAIL       2    FAIL 	2
kill11          FAIL       2    FAIL 	2
mmap16          FAIL       6    PASSED	0
open12          FAIL       2    PASSED	0
pause01         PASSED     0    FAIL 	9
pipe07          FAIL       2    PASSED	0
readdir01       FAIL       1    PASSED	0
rename11        FAIL       2    PASSED	0
rmdir02         FAIL       2    PASSED	0
setregid02      FAIL       1    FAIL 	1
settimeofday01  FAIL       1    FAIL 	1
umount2_01      FAIL       2    PASSED	0
umount2_02      FAIL       2    PASSED	0
umount2_03      FAIL       2    PASSED	0
utime06         FAIL       2    PASSED	0

Kernel with this patchset, and corresponding
version of glibc is here:
https://github.com/norov/

Andrew Pinski (14):
  arm64: ensure the kernel is compiled for LP64
  arm64: rename COMPAT to AARCH32_EL0 in Kconfig
  arm64: change some CONFIG_COMPAT over to use CONFIG_AARCH32_EL0
    instead
  arm64:uapi: set __BITS_PER_LONG correctly for ILP32 and LP64
  arm64:ilp32: share signal structures between ILP32 and LP64 ABIs
  arm64: introduce is_a32_task and is_a32_thread (for AArch32 compat)
  arm64:ilp32: add is_ilp32_compat_{task,thread} and TIF_32BIT_AARCH64
  arm64:ilp32: share HWCAP between LP64 and ILP32
  arm64:ilp32 use the native LP64 'start_thread' for ILP32 threads
  arm64:ilp32: support core dump generation for ILP32
  ptrace: Allow compat to use the native siginfo
  arm64:ilp32: add sys_ilp32.c and a separate table (in entry.S) to use
    it
  arm64:ilp32: use the native siginfo instead of the compat siginfo
  arm64:ilp32: add ARM64_ILP32 to Kconfig

Jan Dakinevich (2):
  ilp32: common 32-bit wrappers
  arm64: ilp32: force IPC_64 in msgctl, shmctl, semctl

Philipp Tomsich (2):
  arm64:ilp32: add documentation on the ILP32 ABI for ARM64
  arm64:ilp32: change COMPAT_ELF_PLATFORM to report a a subplatform for
    ILP32

Yury Norov (1):
  aarch64: ilp32: use generic stat64 structure

 Documentation/arm64/ilp32.txt             |  47 +++++++
 arch/arm64/Kconfig                        |  12 ++
 arch/arm64/Makefile                       |   5 +
 arch/arm64/include/asm/compat.h           |  70 +++++++++-
 arch/arm64/include/asm/elf.h              | 105 ++++++++++++--
 arch/arm64/include/asm/fpsimd.h           |   2 +-
 arch/arm64/include/asm/hwcap.h            |  12 +-
 arch/arm64/include/asm/memory.h           |   2 +-
 arch/arm64/include/asm/processor.h        |  18 ++-
 arch/arm64/include/asm/ptrace.h           |   2 +-
 arch/arm64/include/asm/signal32.h         |  19 +++
 arch/arm64/include/asm/stat.h             |   2 +
 arch/arm64/include/asm/thread_info.h      |   3 +-
 arch/arm64/include/asm/unistd.h           |  11 +-
 arch/arm64/include/uapi/asm/bitsperlong.h |   9 +-
 arch/arm64/include/uapi/asm/siginfo.h     |  21 +++
 arch/arm64/include/uapi/asm/signal.h      |  31 +++++
 arch/arm64/kernel/Makefile                |   4 +-
 arch/arm64/kernel/asm-offsets.c           |   2 +-
 arch/arm64/kernel/entry.S                 |  18 ++-
 arch/arm64/kernel/entry32-common.S        |  37 +++++
 arch/arm64/kernel/entry32.S               |  29 ----
 arch/arm64/kernel/head.S                  |   2 +-
 arch/arm64/kernel/hw_breakpoint.c         |   7 +-
 arch/arm64/kernel/perf_regs.c             |   2 +-
 arch/arm64/kernel/process.c               |   4 +-
 arch/arm64/kernel/ptrace.c                |  47 ++++---
 arch/arm64/kernel/signal.c                |  21 ++-
 arch/arm64/kernel/sys_ilp32.c             | 223 ++++++++++++++++++++++++++++++
 arch/arm64/kernel/traps.c                 |   4 +-
 arch/arm64/kernel/vdso.c                  |  12 +-
 include/linux/compat.h                    |   4 +
 include/uapi/asm-generic/siginfo.h        |  17 ++-
 include/uapi/asm-generic/signal.h         |  27 +++-
 kernel/ptrace.c                           |  24 +++-
 35 files changed, 745 insertions(+), 110 deletions(-)
 create mode 100644 Documentation/arm64/ilp32.txt
 create mode 100644 arch/arm64/kernel/entry32-common.S
 create mode 100644 arch/arm64/kernel/sys_ilp32.c

-- 
2.1.4


^ permalink raw reply	[flat|nested] 79+ messages in thread

end of thread, other threads:[~2015-12-05 11:00 UTC | newest]

Thread overview: 79+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-11-17 21:16 [RFC2 PATCH v6 00/19] ILP32 for ARM64 Yury Norov
2015-11-17 21:16 ` [PATCH v6 01/19] arm64:ilp32: add documentation on the ILP32 ABI " Yury Norov
2015-11-18  8:09   ` Zhangjian (Bamvor)
2015-11-17 21:16 ` [PATCH v6 02/19] arm64: ensure the kernel is compiled for LP64 Yury Norov
2015-11-17 21:16 ` [PATCH v6 03/19] arm64: rename COMPAT to AARCH32_EL0 in Kconfig Yury Norov
2015-11-17 21:16 ` [PATCH v6 04/19] arm64: change some CONFIG_COMPAT over to use CONFIG_AARCH32_EL0 instead Yury Norov
2015-12-03 12:02   ` Catalin Marinas
2015-12-04 21:58     ` Yury Norov
2015-11-17 21:16 ` [PATCH v6 05/19] arm64:uapi: set __BITS_PER_LONG correctly for ILP32 and LP64 Yury Norov
2015-12-03 11:31   ` Catalin Marinas
2015-12-03 11:36     ` Dr. Philipp Tomsich
2015-11-17 21:16 ` [PATCH v6 06/19] arm64:ilp32: share signal structures between ILP32 and LP64 ABIs Yury Norov
2015-11-17 22:14   ` Arnd Bergmann
2015-11-17 21:16 ` [PATCH v6 07/19] arm64: introduce is_a32_task and is_a32_thread (for AArch32 compat) Yury Norov
2015-12-03 12:13   ` Catalin Marinas
2015-12-04 17:05     ` Yury Norov
2015-12-05 11:00       ` Catalin Marinas
2015-11-17 21:16 ` [PATCH v6 08/19] arm64:ilp32: add is_ilp32_compat_{task,thread} and TIF_32BIT_AARCH64 Yury Norov
2015-11-17 21:16 ` [PATCH v6 09/19] arm64:ilp32: share HWCAP between LP64 and ILP32 Yury Norov
2015-11-17 21:16 ` [PATCH v6 10/19] arm64:ilp32 use the native LP64 'start_thread' for ILP32 threads Yury Norov
2015-12-03 12:20   ` Catalin Marinas
2015-11-17 21:16 ` [PATCH v6 11/19] arm64:ilp32: support core dump generation for ILP32 Yury Norov
2015-12-03 16:39   ` Catalin Marinas
2015-11-17 21:16 ` [PATCH v6 12/19] ptrace: Allow compat to use the native siginfo Yury Norov
2015-11-17 21:16 ` [PATCH v6 13/19] arm64: ilp32: common 32-bit wrappers Yury Norov
2015-11-17 21:16 ` [PATCH v6 14/19] arm64:ilp32: add sys_ilp32.c and a separate table (in entry.S) to use it Yury Norov
2015-11-17 21:57   ` Arnd Bergmann
2015-11-18  8:14     ` Arnd Bergmann
2015-11-19 13:21     ` Andreas Schwab
2015-11-19 13:32       ` Arnd Bergmann
2015-11-30 15:34     ` Arnd Bergmann
2015-11-30 20:21       ` Yury Norov
2015-11-30 21:49         ` Arnd Bergmann
2015-12-01  0:20           ` Andrew Pinski
2015-12-01  0:40           ` Yury Norov
2015-12-01 10:26             ` Arnd Bergmann
2015-12-01  9:20         ` Andreas Schwab
2015-12-01 10:22           ` Arnd Bergmann
2015-12-01 11:01             ` Andreas Schwab
2015-12-01 11:30               ` Arnd Bergmann
2015-12-02  0:24                 ` Yury Norov
2015-12-02 10:03                   ` Arnd Bergmann
2015-12-03 17:17                   ` Catalin Marinas
2015-12-01 21:29     ` Yury Norov
2015-12-01 22:39       ` Arnd Bergmann
2015-12-01 23:35         ` Yury Norov
2015-12-02  8:37           ` Arnd Bergmann
2015-12-02  9:15             ` Yury Norov
2015-12-02 10:35             ` Yury Norov
2015-12-02 13:46               ` Arnd Bergmann
2015-12-02 13:54                 ` Arnd Bergmann
2015-12-02 13:57                   ` Will Deacon
2015-12-03 17:47       ` Catalin Marinas
2015-12-03 18:14         ` Yury Norov
2015-12-03 20:42           ` Arnd Bergmann
2015-12-02 10:01     ` Yury Norov
2015-12-02 11:03       ` Arnd Bergmann
2015-11-17 21:16 ` [PATCH v6 15/19] arm64: ilp32: force IPC_64 in msgctl, shmctl, semctl Yury Norov
2015-11-17 22:07   ` Arnd Bergmann
2015-11-18  8:25     ` Andreas Schwab
2015-11-18  9:23       ` Arnd Bergmann
2015-11-18 10:07         ` Geert Uytterhoeven
2015-11-18 12:04           ` Arnd Bergmann
2015-11-17 21:16 ` [PATCH v6 16/19] aarch64: ilp32: use generic stat64 structure Yury Norov
2015-11-17 22:09   ` Arnd Bergmann
2015-11-18 20:36     ` Yury Norov
2015-11-18 20:45       ` Arnd Bergmann
2015-11-17 21:16 ` [PATCH v6 17/19] arm64:ilp32: use the native siginfo instead of the compat siginfo Yury Norov
2015-11-17 21:16 ` [PATCH v6 18/19] arm64:ilp32: change COMPAT_ELF_PLATFORM to report a a subplatform for ILP32 Yury Norov
2015-11-18  8:11   ` Zhangjian (Bamvor)
2015-11-18 11:21     ` pinskia
2015-11-18 20:25       ` Yury Norov
2015-11-18 21:47         ` Dr. Philipp Tomsich
2015-11-17 21:16 ` [PATCH v6 19/19] arm64:ilp32: add ARM64_ILP32 to Kconfig Yury Norov
2015-11-18  8:00 ` [RFC2 PATCH v6 00/19] ILP32 for ARM64 Zhangjian (Bamvor)
2015-11-23 16:49 ` Andreas Schwab
2015-12-03 17:59 ` Catalin Marinas
2015-12-04 15:35   ` Yury Norov
2015-12-04 17:18     ` Catalin Marinas

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).