The goal is to kill the massive target ifdef ladder in elfload.c.

The functions get moved to linux-user/target/elfload.c.
Define weak functions to provide a default value, or a
weak reference to determine if the function is provided.

The core dump types and functions are moved to
linux-user/target/target_coredump.h.

The macros get moved to linux-user/target/target_elf.h.
These are mostly use to parameterize include/elf.h, but
there are some other outliers.

The init_thread functions, storing into target_pt_regs, have been
merged with target_cpu_copy_regs, copying out of target_pt_regs
into CPUArchState.  Merging these found a few bits of silliness
where pt_regs fields were initialized but not used.  To encourage
this never to return, remove most target_pt_regs and hide the rest
within the relevant signal.c.


r~


Richard Henderson (89):
  linux-user: Create target/elfload.c files
  linux-user: Move get_elf_hwcap to {i386,x86_64}/elfload.c
  linux-user: Move hwcap functions to {arm,aarch64}/elfload.c
  linux-user: Move get_elf_hwcap to sparc/elfload.c
  linux-user: Move hwcap functions to ppc/elfload.c
  linux-user: Move get_elf_hwcap to loongarch64/elfload.c
  linux-user: Move get_elf_hwcap to mips/elfload.c
  linux-user: Move get_elf_hwcap to sh4/elfload.c
  linux-user: Move hwcap functions to s390x/elfload.c
  linux-user: Move get_elf_hwcap to riscv/elfload.c
  linux-user: Remove ELF_HWCAP
  linux-user: Remove ELF_HWCAP2
  linux-user: Move get_elf_platform to {i386,x86_64}/elfload.c
  linux-user/i386: Return const data from get_elf_platform
  linux-user: Move get_elf_platform to arm/elfload.c
  linux-user/loongarch64: Create get_elf_platform
  linux-user/hppa: Create get_elf_platform
  linux-user: Remove ELF_PLATFORM
  linux-user: Move get_elf_base_platform to mips/elfload.c
  linux-user: Move target_cpu_copy_regs decl to qemu.h
  linux-user: Unify init of semihosting fields in TaskState
  linux-user: Create do_init_main_thread
  linux-user/i386: Create init_main_thread
  linux-user/arm: Create init_main_thread
  linux-user/aarch64: Create init_main_thread
  linux-user/sparc: Create init_main_thread
  linux-user/ppc: Create init_main_thread
  linux-user/loongarch64: Create init_main_thread
  linux-user/mips: Create init_main_thread
  linux-user/microblaze: Create init_main_thread
  linux-user/openrisc: Create init_main_thread
  linux-user/sh4: Create init_main_thread
  linux-user/m68k: Create init_main_thread
  linux-user/alpha: Create init_main_thread
  linux-user/s390x: Create init_main_thread
  linux-user/riscv: Create init_main_thread
  linux-user/hppa: Create init_main_thread
  linux-user/xtensa: Create init_main_thread
  linux-user/hexagon: Create init_main_thread
  linux-user: Remove do_init_main_thread
  linux-user/x86_64: Split out target_coredump.c.inc
  linux-user/i386: Split out target_coredump.c.inc
  linux-user/arm: Split out target_coredump.c.inc
  linux-user/aarch64: Split out target_coredump.c.inc
  linux-user/ppc: Split out target_coredump.c.inc
  linux-user/loongarch64: Split out target_coredump.c.inc
  linux-user/mips: Split out target_coredump.c.inc
  linux-user/microblaze: Split out target_coredump.c.inc
  target/openrisc: Split out target_coredump.c.inc
  target/sh4: Split out target_coredump.c.inc
  linux-user/m68k: Split out target_coredump.c.inc
  linux-user/s390x: Split out target_coredump.c.inc
  linux-user/xtensa: Split out target_coredump.c.inc
  linux-user: Unify the include of target_coredump.c.inc
  linux-user: Move init_guest_commpage to x86_64/elfload.c
  linux-user: Move init_guest_commpage to arm/elfload.c
  linux-user: Move init_guest_commpage to hppa/elfload.c
  linux-user: Remove INIT_GUEST_COMMPAGE
  linux-user: Move get_vdso_image_info to arm/elfload.c
  linux-user: Remove ELF_EXEC_PAGESIZE
  linux-user: Move get_elf_cpu_model to target/elfload.c
  linux-user: Move ppc uabi/asm/elf.h workaround to osdep.h
  linux-user: Move elf parameters to {i386,x86_64}/target_elf.h
  linux-user: Move elf parameters to {arm,aarch64}/target_elf.h
  linux-user: Move elf parameters to sparc/target_elf.h
  linux-user: Move elf parameters to ppc/target_elf.h
  linux-user: Move elf parameters to loongarch64/target_elf.h
  linux-user: Move elf parameters to {mips,mips64}/target_elf.h
  linux-user: Move elf parameters to microblaze/target_elf.h
  linux-user: Move elf parameters to openrisc/target_elf.h
  linux-user: Move elf parameters to sh4/target_elf.h
  linux-user: Move elf parameters to m68k/target_elf.h
  linux-user: Move elf parameters to alpha/target_elf.h
  linux-user: Move elf parameters to s390x/target_elf.h
  linux-user: Move elf parameters to riscv/target_elf.h
  linux-user: Move elf parameters to hppa/target_elf.h
  linux-user: Move elf parameters to xtensa/target_elf.h
  linux-user: Move elf parameters to hexagon/target_elf.h
  linux-user: Standardize on ELF_MACHINE not ELF_ARCH
  linux-user: Rename elf_check_arch
  linux-user: Remove ELIBBAD from elfload.c
  linux-user: Remove MAP_DENYWRITE from elfload.c
  linux-user: Move arch_parse_elf_property to aarch64/elfload.c
  linux-user: Remove a.out declarations from elfload.c
  linux-user/sparc: Move target_pt_regs to signal.c
  linux-user/microblaze: Move target_pt_regs to signal.c
  linux-user/openrisc: Move target_pt_regs to signal.c
  linux-user/s390x: Move target_psw_t to signal.c
  linux-user: Remove struct target_pt_regs from target_syscall.h

 include/qemu/osdep.h                         |    8 +
 include/user/cpu_loop.h                      |    4 -
 linux-user/aarch64/target_elf.h              |   16 +-
 linux-user/aarch64/target_syscall.h          |    7 -
 linux-user/alpha/target_elf.h                |    8 +-
 linux-user/alpha/target_syscall.h            |   40 -
 linux-user/arm/target_elf.h                  |   12 +-
 linux-user/arm/target_proc.h                 |    4 +-
 linux-user/arm/target_syscall.h              |    8 -
 linux-user/hexagon/target_elf.h              |   30 +-
 linux-user/hexagon/target_syscall.h          |    5 -
 linux-user/hppa/target_elf.h                 |   13 +-
 linux-user/hppa/target_syscall.h             |   18 -
 linux-user/i386/target_elf.h                 |   28 +-
 linux-user/i386/target_syscall.h             |   18 -
 linux-user/loader.h                          |   33 +-
 linux-user/loongarch64/target_elf.h          |   11 +-
 linux-user/loongarch64/target_syscall.h      |   23 -
 linux-user/m68k/target_elf.h                 |   13 +-
 linux-user/m68k/target_syscall.h             |   16 -
 linux-user/microblaze/target_elf.h           |   10 +-
 linux-user/microblaze/target_syscall.h       |   44 -
 linux-user/mips/target_elf.h                 |   16 +-
 linux-user/mips/target_syscall.h             |   19 -
 linux-user/mips64/target_elf.h               |   39 +-
 linux-user/mips64/target_syscall.h           |   16 -
 linux-user/openrisc/target_elf.h             |    9 +-
 linux-user/openrisc/target_syscall.h         |   11 -
 linux-user/ppc/target_elf.h                  |   45 +-
 linux-user/ppc/target_syscall.h              |   28 -
 linux-user/qemu.h                            |    6 +-
 linux-user/riscv/target_elf.h                |   15 +-
 linux-user/riscv/target_syscall.h            |   35 -
 linux-user/s390x/target_elf.h                |   11 +-
 linux-user/s390x/target_proc.h               |    2 +-
 linux-user/s390x/target_syscall.h            |   22 -
 linux-user/sh4/target_elf.h                  |    9 +-
 linux-user/sh4/target_syscall.h              |   11 -
 linux-user/sparc/target_elf.h                |   16 +-
 linux-user/sparc/target_syscall.h            |   19 -
 linux-user/x86_64/target_elf.h               |   10 +-
 linux-user/x86_64/target_syscall.h           |   28 -
 linux-user/xtensa/target_elf.h               |    7 +-
 linux-user/xtensa/target_syscall.h           |   35 -
 linux-user/aarch64/cpu_loop.c                |   22 +-
 linux-user/aarch64/elfload.c                 |  367 +++
 linux-user/alpha/cpu_loop.c                  |   11 +-
 linux-user/alpha/elfload.c                   |   11 +
 linux-user/arm/cpu_loop.c                    |   80 +-
 linux-user/arm/elfload.c                     |  267 +++
 linux-user/elfload.c                         | 2116 +-----------------
 linux-user/hexagon/cpu_loop.c                |    8 +-
 linux-user/hexagon/elfload.c                 |   35 +
 linux-user/hppa/cpu_loop.c                   |   18 +-
 linux-user/hppa/elfload.c                    |   47 +
 linux-user/i386/cpu_loop.c                   |   31 +-
 linux-user/i386/elfload.c                    |   25 +
 linux-user/linuxload.c                       |    6 +-
 linux-user/loongarch64/cpu_loop.c            |   11 +-
 linux-user/loongarch64/elfload.c             |   63 +
 linux-user/m68k/cpu_loop.c                   |   32 +-
 linux-user/m68k/elfload.c                    |   18 +
 linux-user/main.c                            |   18 +-
 linux-user/microblaze/cpu_loop.c             |   39 +-
 linux-user/microblaze/elfload.c              |   11 +
 linux-user/microblaze/signal.c               |   44 +
 linux-user/mips/cpu_loop.c                   |   16 +-
 linux-user/mips/elfload.c                    |  124 +
 linux-user/mips64/elfload.c                  |    1 +
 linux-user/openrisc/cpu_loop.c               |   11 +-
 linux-user/openrisc/elfload.c                |   11 +
 linux-user/openrisc/signal.c                 |   12 +
 linux-user/ppc/cpu_loop.c                    |   26 +-
 linux-user/ppc/elfload.c                     |  131 ++
 linux-user/riscv/cpu_loop.c                  |   15 +-
 linux-user/riscv/elfload.c                   |   23 +
 linux-user/s390x/cpu_loop.c                  |   15 +-
 linux-user/s390x/elfload.c                   |   68 +
 linux-user/s390x/signal.c                    |    5 +
 linux-user/sh4/cpu_loop.c                    |   10 +-
 linux-user/sh4/elfload.c                     |   38 +
 linux-user/sparc/cpu_loop.c                  |   16 +-
 linux-user/sparc/elfload.c                   |   42 +
 linux-user/sparc/signal.c                    |   20 +
 linux-user/x86_64/elfload.c                  |   41 +
 linux-user/xtensa/cpu_loop.c                 |   22 +-
 linux-user/xtensa/elfload.c                  |   11 +
 linux-user/aarch64/target_coredump.c.inc     |   14 +
 linux-user/arm/target_coredump.c.inc         |   28 +
 linux-user/i386/target_coredump.c.inc        |   32 +
 linux-user/loongarch64/target_coredump.c.inc |   24 +
 linux-user/m68k/target_coredump.c.inc        |   30 +
 linux-user/microblaze/target_coredump.c.inc  |   21 +
 linux-user/mips/target_coredump.c.inc        |   46 +
 linux-user/mips64/target_coredump.c.inc      |    1 +
 linux-user/openrisc/target_coredump.c.inc    |   15 +
 linux-user/ppc/target_coredump.c.inc         |   24 +
 linux-user/s390x/target_coredump.c.inc       |   31 +
 linux-user/sh4/target_coredump.c.inc         |   32 +
 linux-user/x86_64/target_coredump.c.inc      |   42 +
 linux-user/xtensa/target_coredump.c.inc      |   38 +
 meson.build                                  |    6 +-
 102 files changed, 2259 insertions(+), 2841 deletions(-)
 create mode 100644 linux-user/aarch64/elfload.c
 create mode 100644 linux-user/alpha/elfload.c
 create mode 100644 linux-user/arm/elfload.c
 create mode 100644 linux-user/hexagon/elfload.c
 create mode 100644 linux-user/hppa/elfload.c
 create mode 100644 linux-user/i386/elfload.c
 create mode 100644 linux-user/loongarch64/elfload.c
 create mode 100644 linux-user/m68k/elfload.c
 create mode 100644 linux-user/microblaze/elfload.c
 create mode 100644 linux-user/mips/elfload.c
 create mode 100644 linux-user/mips64/elfload.c
 create mode 100644 linux-user/openrisc/elfload.c
 create mode 100644 linux-user/ppc/elfload.c
 create mode 100644 linux-user/riscv/elfload.c
 create mode 100644 linux-user/s390x/elfload.c
 create mode 100644 linux-user/sh4/elfload.c
 create mode 100644 linux-user/sparc/elfload.c
 create mode 100644 linux-user/x86_64/elfload.c
 create mode 100644 linux-user/xtensa/elfload.c
 create mode 100644 linux-user/aarch64/target_coredump.c.inc
 create mode 100644 linux-user/arm/target_coredump.c.inc
 create mode 100644 linux-user/i386/target_coredump.c.inc
 create mode 100644 linux-user/loongarch64/target_coredump.c.inc
 create mode 100644 linux-user/m68k/target_coredump.c.inc
 create mode 100644 linux-user/microblaze/target_coredump.c.inc
 create mode 100644 linux-user/mips/target_coredump.c.inc
 create mode 100644 linux-user/mips64/target_coredump.c.inc
 create mode 100644 linux-user/openrisc/target_coredump.c.inc
 create mode 100644 linux-user/ppc/target_coredump.c.inc
 create mode 100644 linux-user/s390x/target_coredump.c.inc
 create mode 100644 linux-user/sh4/target_coredump.c.inc
 create mode 100644 linux-user/x86_64/target_coredump.c.inc
 create mode 100644 linux-user/xtensa/target_coredump.c.inc

-- 
2.43.0


Reply via email to