^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) // SPDX-License-Identifier: GPL-2.0
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) * Support for n32 Linux/MIPS ELF binaries.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) * Author: Ralf Baechle (ralf@linux-mips.org)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) * Copyright (C) 1999, 2001 Ralf Baechle
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7) * Copyright (C) 1999, 2001 Silicon Graphics, Inc.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) * Heavily inspired by the 32-bit Sparc compat code which is
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) * Copyright (C) 1995, 1996, 1997, 1998 David S. Miller (davem@redhat.com)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) * Copyright (C) 1995, 1996, 1997, 1998 Jakub Jelinek (jj@ultra.linux.cz)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) #define ELF_ARCH EM_MIPS
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) #define ELF_CLASS ELFCLASS32
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) #ifdef __MIPSEB__
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) #define ELF_DATA ELFDATA2MSB;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) #else /* __MIPSEL__ */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) #define ELF_DATA ELFDATA2LSB;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) /* ELF register definitions */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) #define ELF_NGREG 45
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) #define ELF_NFPREG 33
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) typedef unsigned long elf_greg_t;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) typedef elf_greg_t elf_gregset_t[ELF_NGREG];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) typedef double elf_fpreg_t;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) typedef elf_fpreg_t elf_fpregset_t[ELF_NFPREG];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) * This is used to ensure we don't load something for the wrong architecture.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) #define elf_check_arch elfn32_check_arch
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) #define TASK32_SIZE 0x7fff8000UL
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) #undef ELF_ET_DYN_BASE
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) #define ELF_ET_DYN_BASE (TASK32_SIZE / 3 * 2)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) #include <asm/processor.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) #include <linux/elfcore.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) #include <linux/compat.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) #include <linux/math64.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) #define elf_prstatus elf_prstatus32
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) struct elf_prstatus32
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) struct elf_siginfo pr_info; /* Info associated with signal */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) short pr_cursig; /* Current signal */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) unsigned int pr_sigpend; /* Set of pending signals */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) unsigned int pr_sighold; /* Set of held signals */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) pid_t pr_pid;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) pid_t pr_ppid;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55) pid_t pr_pgrp;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) pid_t pr_sid;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) struct old_timeval32 pr_utime; /* User time */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) struct old_timeval32 pr_stime; /* System time */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) struct old_timeval32 pr_cutime;/* Cumulative user time */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) struct old_timeval32 pr_cstime;/* Cumulative system time */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61) elf_gregset_t pr_reg; /* GP registers */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) int pr_fpvalid; /* True if math co-processor being used. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) #define elf_prpsinfo elf_prpsinfo32
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 66) struct elf_prpsinfo32
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 67) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 68) char pr_state; /* numeric process state */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 69) char pr_sname; /* char for pr_state */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 70) char pr_zomb; /* zombie */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 71) char pr_nice; /* nice val */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 72) unsigned int pr_flag; /* flags */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 73) __kernel_uid_t pr_uid;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 74) __kernel_gid_t pr_gid;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 75) pid_t pr_pid, pr_ppid, pr_pgrp, pr_sid;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 76) /* Lots missing */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 77) char pr_fname[16]; /* filename of executable */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 78) char pr_psargs[ELF_PRARGSZ]; /* initial part of arg list */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 79) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 80)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 81) #define elf_caddr_t u32
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 82) #define init_elf_binfmt init_elfn32_binfmt
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 83)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 84) #define jiffies_to_timeval jiffies_to_old_timeval32
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 85) static __inline__ void
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 86) jiffies_to_old_timeval32(unsigned long jiffies, struct old_timeval32 *value)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 87) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 88) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 89) * Convert jiffies to nanoseconds and separate with
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 90) * one divide.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 91) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 92) u64 nsec = (u64)jiffies * TICK_NSEC;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 93) u32 rem;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 94) value->tv_sec = div_u64_rem(nsec, NSEC_PER_SEC, &rem);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 95) value->tv_usec = rem / NSEC_PER_USEC;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 96) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 97)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 98) #define ELF_CORE_EFLAGS EF_MIPS_ABI2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 99)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 100) #undef TASK_SIZE
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 101) #define TASK_SIZE TASK_SIZE32
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 102)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 103) #undef ns_to_kernel_old_timeval
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 104) #define ns_to_kernel_old_timeval ns_to_old_timeval32
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 105)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 106) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 107) * Some data types as stored in coredump.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 108) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 109) #define user_long_t compat_long_t
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 110) #define user_siginfo_t compat_siginfo_t
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 111) #define copy_siginfo_to_external copy_siginfo_to_external32
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 112)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 113) #include "../../../fs/binfmt_elf.c"