[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v4 00/36] bsd-user: arm (32-bit) support
From: |
Warner Losh |
Subject: |
[PATCH v4 00/36] bsd-user: arm (32-bit) support |
Date: |
Thu, 4 Nov 2021 21:18:41 -0600 |
This series of patches brings in 32-bit arm support for bsd-user. It implements
all the bits needed to do image activation, signal handling, stack management
and threading. This allows us to get to the "Hello World" level. The arm and x86
code are now the same as in the bsd-user fork. For full context, the fork is at
https://github.com/qemu-bsd-user/qemu-bsd-user/tree/blitz (though the the recent
sig{bus,segv} needed updates are incomplete).
v4 changes the following:
* Remove mips* -- the bsd-user fork has removed it, so clean up the clutter.
* Move target_os_ucontext.h patch earlier in the series and add check of
ucontext_t and mcontext_t sizes to match native sizes.
* Move x86 patches earlier in the patch series and Fill in the i386 and
x86_64 mcontext contents to match FreeBSD and define
TARGET_[UM]CONTEXT_SIZE to enable size checking.
* generally: Move inlines from target_arch_signal.h to signal.c
* Collapse arm's definition mcontext and trapframe into one commit and
add size with TARGET_[MU]CONTEXT_SIZE.
* Fix the saving of vfp context to use proper locking and fetching
of target address to get/save it.
* Filter out low-order bits of pc in arm set_mcontext()
Where code just moved (maybe with trivial changes), I retained reviewed-by
tagging. When the changes were more substantial due to issues discovered
by getting the size right, I droppped prior review. The following thus
lack review:
bsd-user/mips*: Remove
bsd-user/freebsd: Create common target_os_ucontext.h file
bsd-user: create a per-arch signal.c file
bsd-user/i386/target_arch_signal.h: Update mcontext_t to match FreeBSD
bsd-user/i386: Move the inlines into signal.c
bsd-user/x86_64/target_arch_signal.h: Fill in mcontext_t
bsd-user/x86_64: Move functions into signal.c
bsd-user/arm/target_arch_signal.h: arm machine context and trapframe for
signals
bsd-user/arm/target_arch_signal.h: Define size of *context_t
bsd-user/arm/target_arch_signal.c: arm get_mcontext
bsd-user/arm/target_arch_signal.c: arm set_mcontext
bsd-user/freebsd/target_os_ucontext.h: Require TARGET_*CONTEXT_SIZE
Warnings that should be ignored:
o make checkpatch has a couple of complaints about the comments for the
signal trampoline, since it's a false positive IMHO.
WARNING: Block comments use a leading /* on a separate line
+ /* 8 */ sys_sigreturn,
WARNING: Block comments use a leading /* on a separate line
+ /* 9 */ sys_exit
Warner Losh (36):
bsd-user/mips*: Remove
bsd-user/freebsd: Create common target_os_ucontext.h file
bsd-user: create a per-arch signal.c file
bsd-user/i386/target_arch_signal.h: Remove target_sigcontext
bsd-user/i386/target_arch_signal.h: use new target_os_ucontext.h
bsd-user/i386/target_arch_signal.h: Update mcontext_t to match FreeBSD
bsd-user/i386: Move the inlines into signal.c
bsd-user/x86_64/target_arch_signal.h: Remove target_sigcontext
bsd-user/x86_64/target_arch_signal.h: use new target_os_ucontext.h
bsd-user/x86_64/target_arch_signal.h: Fill in mcontext_t
bsd-user/x86_64: Move functions into signal.c
bsd-user/arm/target_arch_sysarch.h: Use consistent include guards
bsd-user/arm/target_syscall.h: Add copyright and update name
bsd-user/arm/target_arch_cpu.c: Target specific TLS routines
bsd-user/arm/target_arch_cpu.h: CPU Loop definitions
bsd-user/arm/target_arch_cpu.h: Implement target_cpu_clone_regs
bsd-user/arm/target_arch_cpu.h: Dummy target_cpu_loop implementation
bsd-user/arm/target_arch_cpu.h: Implement trivial EXCP exceptions
bsd-user/arm/target_arch_cpu.h: Implement data abort exceptions
bsd-user/arm/target_arch_cpu.h: Implement system call dispatch
bsd-user/arm/target_arch_reg.h: Implement core dump register copying
bsd-user/arm/target_arch_vmparam.h: Parameters for arm address space
bsd-user/arm/target_arch_sigtramp.h: Signal Trampoline for arm
bsd-user/arm/target_arch_thread.h: Routines to create and switch to a
thread
bsd-user/arm/target_arch_elf.h: arm defines for ELF
bsd-user/arm/target_arch_elf.h: arm get hwcap
bsd-user/arm/target_arch_elf.h: arm get_hwcap2 impl
bsd-user/arm/target_arch_signal.h: arm specific signal registers and
stack
bsd-user/arm/target_arch_signal.h: arm machine context and trapframe
for signals
bsd-user/arm/target_arch_signal.h: Define size of *context_t
bsd-user/arm/target_arch_signal.c: arm set_sigtramp_args
bsd-user/arm/target_arch_signal.c: arm get_mcontext
bsd-user/arm/target_arch_signal.c: arm set_mcontext
bsd-user/arm/target_arch_signal.c: arm get_ucontext_sigreturn
bsd-user/freebsd/target_os_ucontext.h: Require TARGET_*CONTEXT_SIZE
bsd-user: add arm target build
bsd-user/arm/signal.c | 199 ++++++++++++++++++++++++
bsd-user/arm/target_arch.h | 28 ++++
bsd-user/arm/target_arch_cpu.c | 39 +++++
bsd-user/arm/target_arch_cpu.h | 211 ++++++++++++++++++++++++++
bsd-user/arm/target_arch_elf.h | 128 ++++++++++++++++
bsd-user/arm/target_arch_reg.h | 60 ++++++++
bsd-user/arm/target_arch_signal.h | 97 ++++++++++++
bsd-user/arm/target_arch_sigtramp.h | 49 ++++++
bsd-user/arm/target_arch_sysarch.h | 6 +-
bsd-user/arm/target_arch_thread.h | 82 ++++++++++
bsd-user/arm/target_arch_vmparam.h | 48 ++++++
bsd-user/arm/target_syscall.h | 27 +++-
bsd-user/freebsd/target_os_signal.h | 3 -
bsd-user/freebsd/target_os_ucontext.h | 33 ++++
bsd-user/i386/signal.c | 55 +++++++
bsd-user/i386/target_arch_signal.h | 102 +++++++------
bsd-user/mips/target_arch_sysarch.h | 69 ---------
bsd-user/mips/target_syscall.h | 52 -------
bsd-user/mips64/target_arch_sysarch.h | 69 ---------
bsd-user/mips64/target_syscall.h | 53 -------
bsd-user/x86_64/signal.c | 55 +++++++
bsd-user/x86_64/target_arch_signal.h | 110 ++++++++------
configs/targets/arm-bsd-user.mak | 2 +
meson.build | 2 +-
24 files changed, 1231 insertions(+), 348 deletions(-)
create mode 100644 bsd-user/arm/signal.c
create mode 100644 bsd-user/arm/target_arch.h
create mode 100644 bsd-user/arm/target_arch_cpu.c
create mode 100644 bsd-user/arm/target_arch_cpu.h
create mode 100644 bsd-user/arm/target_arch_elf.h
create mode 100644 bsd-user/arm/target_arch_reg.h
create mode 100644 bsd-user/arm/target_arch_signal.h
create mode 100644 bsd-user/arm/target_arch_sigtramp.h
create mode 100644 bsd-user/arm/target_arch_thread.h
create mode 100644 bsd-user/arm/target_arch_vmparam.h
create mode 100644 bsd-user/freebsd/target_os_ucontext.h
create mode 100644 bsd-user/i386/signal.c
delete mode 100644 bsd-user/mips/target_arch_sysarch.h
delete mode 100644 bsd-user/mips/target_syscall.h
delete mode 100644 bsd-user/mips64/target_arch_sysarch.h
delete mode 100644 bsd-user/mips64/target_syscall.h
create mode 100644 bsd-user/x86_64/signal.c
create mode 100644 configs/targets/arm-bsd-user.mak
--
2.33.0
- [PATCH v4 00/36] bsd-user: arm (32-bit) support,
Warner Losh <=
- [PATCH v4 02/36] bsd-user/freebsd: Create common target_os_ucontext.h file, Warner Losh, 2021/11/04
- [PATCH v4 04/36] bsd-user/i386/target_arch_signal.h: Remove target_sigcontext, Warner Losh, 2021/11/04
- [PATCH v4 03/36] bsd-user: create a per-arch signal.c file, Warner Losh, 2021/11/04
- [PATCH v4 01/36] bsd-user/mips*: Remove, Warner Losh, 2021/11/04
- [PATCH v4 07/36] bsd-user/i386: Move the inlines into signal.c, Warner Losh, 2021/11/04