From: bamvor.zhangjian@huawei•com (Zhangjian (Bamvor))
To: linux-arm-kernel@lists•infradead.org
Subject: [RFC2 PATCH v6 00/19] ILP32 for ARM64
Date: Wed, 18 Nov 2015 16:00:26 +0800 [thread overview]
Message-ID: <564C301A.5080707@huawei.com> (raw)
In-Reply-To: <1447795019-30176-1-git-send-email-ynorov@caviumnetworks.com>
Hi, Yury
Glad to see the new version of ilp32. Here is some general questions:
On 2015/11/18 5:16, Yury Norov wrote:
> ------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);
Is there any performance comparison between v6 and v5, especially for
these changes? Compatibility is important for us, meanwhile we need to
take performance into account.
> - 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.
Do you tested on both big endian and little endian?
Regards
Bamvor
> 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
>
next prev parent reply other threads:[~2015-11-18 8:00 UTC|newest]
Thread overview: 79+ messages / expand[flat|nested] mbox.gz Atom feed top
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 at gmail.com
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 ` Zhangjian (Bamvor) [this message]
2015-11-23 16:49 ` [RFC2 PATCH v6 00/19] ILP32 for ARM64 Andreas Schwab
2015-12-03 17:59 ` Catalin Marinas
2015-12-04 15:35 ` Yury Norov
2015-12-04 17:18 ` Catalin Marinas
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=564C301A.5080707@huawei.com \
--to=bamvor.zhangjian@huawei$(echo .)com \
--cc=linux-arm-kernel@lists$(echo .)infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox