tcg/arm: Fix SIGILL in tcg_out_qemu_st_direct
tcg/s390x: Fix encoding of VRIc, VRSa, VRSc insns tcg: Clean up error paths in alloc_code_gen_buffer_splitwx_memfd linux-user/riscv: Adjust vdso signal frame cfa offsets linux-user: Fixed cpu restore with pc 0 on SIGBUS -----BEGIN PGP SIGNATURE----- iQFRBAABCgA7FiEEekgeeIaLTbaoWgXAZN846K9+IV8FAmWvk08dHHJpY2hhcmQu aGVuZGVyc29uQGxpbmFyby5vcmcACgkQZN846K9+IV+hSQf6A2h1vn0eVk+GaIUP 1WN1xaqvN5DmZm8AcQkdqZxdmMZO+zq592zHcZ4RNWlyq8NU93cPCLpMkw4RltLU NkHkqXcYIXUx12StJQ4EKuGNyBSu+emkPbkd31KBMM69zDXbugAmPGH7VGn5Mw7R 8D02D8dvsG/iqmvI8L/ZJFjkrbO3A0AaSdb1Ynkwl6vlLLjpWCqoSFtwv+ZMYyWn q9eLzrJ2pUtoO/CDq3WFnODdAh/QUMHKmgj/4YYvGylPIti7eoM24LXGJWQOeUkX c0soBB24DEd92jJWjCsYUokcUVQOITOGbNdlhRGrxICNdIapUvVhvLW/IYxeBTlV s5zl+g== =rNAP -----END PGP SIGNATURE----- Merge tag 'pull-tcg-20240123' of https://gitlab.com/rth7680/qemu into staging tcg/arm: Fix SIGILL in tcg_out_qemu_st_direct tcg/s390x: Fix encoding of VRIc, VRSa, VRSc insns tcg: Clean up error paths in alloc_code_gen_buffer_splitwx_memfd linux-user/riscv: Adjust vdso signal frame cfa offsets linux-user: Fixed cpu restore with pc 0 on SIGBUS # -----BEGIN PGP SIGNATURE----- # # iQFRBAABCgA7FiEEekgeeIaLTbaoWgXAZN846K9+IV8FAmWvk08dHHJpY2hhcmQu # aGVuZGVyc29uQGxpbmFyby5vcmcACgkQZN846K9+IV+hSQf6A2h1vn0eVk+GaIUP # 1WN1xaqvN5DmZm8AcQkdqZxdmMZO+zq592zHcZ4RNWlyq8NU93cPCLpMkw4RltLU # NkHkqXcYIXUx12StJQ4EKuGNyBSu+emkPbkd31KBMM69zDXbugAmPGH7VGn5Mw7R # 8D02D8dvsG/iqmvI8L/ZJFjkrbO3A0AaSdb1Ynkwl6vlLLjpWCqoSFtwv+ZMYyWn # q9eLzrJ2pUtoO/CDq3WFnODdAh/QUMHKmgj/4YYvGylPIti7eoM24LXGJWQOeUkX # c0soBB24DEd92jJWjCsYUokcUVQOITOGbNdlhRGrxICNdIapUvVhvLW/IYxeBTlV # s5zl+g== # =rNAP # -----END PGP SIGNATURE----- # gpg: Signature made Tue 23 Jan 2024 10:22:07 GMT # gpg: using RSA key 7A481E78868B4DB6A85A05C064DF38E8AF7E215F # gpg: issuer "richard.henderson@linaro.org" # gpg: Good signature from "Richard Henderson <richard.henderson@linaro.org>" [full] # Primary key fingerprint: 7A48 1E78 868B 4DB6 A85A 05C0 64DF 38E8 AF7E 215F * tag 'pull-tcg-20240123' of https://gitlab.com/rth7680/qemu: tcg/arm: Fix SIGILL in tcg_out_qemu_st_direct linux-user/elfload: check PR_GET_DUMPABLE before creating coredump linux-user/elfload: test return value of getrlimit linux-user/riscv: Adjust vdso signal frame cfa offsets tcg/s390x: Fix encoding of VRIc, VRSa, VRSc insns linux-user: Fixed cpu restore with pc 0 on SIGBUS tcg: Make the cleanup-on-error path unique tcg: Remove unreachable code Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
b3a5dd0604
@ -2,6 +2,7 @@
|
|||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
|
|
||||||
|
#include <sys/prctl.h>
|
||||||
#include <sys/resource.h>
|
#include <sys/resource.h>
|
||||||
#include <sys/shm.h>
|
#include <sys/shm.h>
|
||||||
|
|
||||||
@ -4667,9 +4668,14 @@ static int elf_core_dump(int signr, const CPUArchState *env)
|
|||||||
init_note_info(&info);
|
init_note_info(&info);
|
||||||
|
|
||||||
errno = 0;
|
errno = 0;
|
||||||
getrlimit(RLIMIT_CORE, &dumpsize);
|
|
||||||
if (dumpsize.rlim_cur == 0)
|
if (prctl(PR_GET_DUMPABLE) == 0) {
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (getrlimit(RLIMIT_CORE, &dumpsize) == 0 && dumpsize.rlim_cur == 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
corefile = core_dump_filename(ts);
|
corefile = core_dump_filename(ts);
|
||||||
|
|
||||||
|
Binary file not shown.
Binary file not shown.
@ -101,12 +101,12 @@ endf __vdso_flush_icache
|
|||||||
.cfi_startproc simple
|
.cfi_startproc simple
|
||||||
.cfi_signal_frame
|
.cfi_signal_frame
|
||||||
|
|
||||||
#define sizeof_reg (__riscv_xlen / 4)
|
#define sizeof_reg (__riscv_xlen / 8)
|
||||||
#define sizeof_freg 8
|
#define sizeof_freg 8
|
||||||
#define B_GR (offsetof_uc_mcontext - sizeof_rt_sigframe)
|
#define B_GR 0
|
||||||
#define B_FR (offsetof_uc_mcontext - sizeof_rt_sigframe + offsetof_freg0)
|
#define B_FR offsetof_freg0
|
||||||
|
|
||||||
.cfi_def_cfa 2, sizeof_rt_sigframe
|
.cfi_def_cfa 2, offsetof_uc_mcontext
|
||||||
|
|
||||||
/* Return address */
|
/* Return address */
|
||||||
.cfi_return_column 64
|
.cfi_return_column 64
|
||||||
|
@ -925,7 +925,7 @@ static void host_sigsegv_handler(CPUState *cpu, siginfo_t *info,
|
|||||||
cpu_loop_exit_sigsegv(cpu, guest_addr, access_type, maperr, pc);
|
cpu_loop_exit_sigsegv(cpu, guest_addr, access_type, maperr, pc);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void host_sigbus_handler(CPUState *cpu, siginfo_t *info,
|
static uintptr_t host_sigbus_handler(CPUState *cpu, siginfo_t *info,
|
||||||
host_sigcontext *uc)
|
host_sigcontext *uc)
|
||||||
{
|
{
|
||||||
uintptr_t pc = host_signal_pc(uc);
|
uintptr_t pc = host_signal_pc(uc);
|
||||||
@ -947,6 +947,7 @@ static void host_sigbus_handler(CPUState *cpu, siginfo_t *info,
|
|||||||
sigprocmask(SIG_SETMASK, host_signal_mask(uc), NULL);
|
sigprocmask(SIG_SETMASK, host_signal_mask(uc), NULL);
|
||||||
cpu_loop_exit_sigbus(cpu, guest_addr, access_type, pc);
|
cpu_loop_exit_sigbus(cpu, guest_addr, access_type, pc);
|
||||||
}
|
}
|
||||||
|
return pc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void host_signal_handler(int host_sig, siginfo_t *info, void *puc)
|
static void host_signal_handler(int host_sig, siginfo_t *info, void *puc)
|
||||||
@ -974,7 +975,7 @@ static void host_signal_handler(int host_sig, siginfo_t *info, void *puc)
|
|||||||
host_sigsegv_handler(cpu, info, uc);
|
host_sigsegv_handler(cpu, info, uc);
|
||||||
return;
|
return;
|
||||||
case SIGBUS:
|
case SIGBUS:
|
||||||
host_sigbus_handler(cpu, info, uc);
|
pc = host_sigbus_handler(cpu, info, uc);
|
||||||
sync_sig = true;
|
sync_sig = true;
|
||||||
break;
|
break;
|
||||||
case SIGILL:
|
case SIGILL:
|
||||||
|
@ -1662,6 +1662,9 @@ static void tcg_out_qemu_st_direct(TCGContext *s, MemOp opc, TCGReg datalo,
|
|||||||
} else {
|
} else {
|
||||||
tcg_out_strd_r(s, h.cond, datalo, h.base, h.index);
|
tcg_out_strd_r(s, h.cond, datalo, h.base, h.index);
|
||||||
}
|
}
|
||||||
|
} else if (h.index < 0) {
|
||||||
|
tcg_out_st32_12(s, h.cond, datalo, h.base, 0);
|
||||||
|
tcg_out_st32_12(s, h.cond, datahi, h.base, 4);
|
||||||
} else if (h.index_scratch) {
|
} else if (h.index_scratch) {
|
||||||
tcg_out_st32_rwb(s, h.cond, datalo, h.index, h.base);
|
tcg_out_st32_rwb(s, h.cond, datalo, h.index, h.base);
|
||||||
tcg_out_st32_12(s, h.cond, datahi, h.index, 4);
|
tcg_out_st32_12(s, h.cond, datahi, h.index, 4);
|
||||||
|
10
tcg/region.c
10
tcg/region.c
@ -584,7 +584,9 @@ static int alloc_code_gen_buffer_splitwx_memfd(size_t size, Error **errp)
|
|||||||
|
|
||||||
buf_rx = mmap(NULL, size, host_prot_read_exec(), MAP_SHARED, fd, 0);
|
buf_rx = mmap(NULL, size, host_prot_read_exec(), MAP_SHARED, fd, 0);
|
||||||
if (buf_rx == MAP_FAILED) {
|
if (buf_rx == MAP_FAILED) {
|
||||||
goto fail_rx;
|
error_setg_errno(errp, errno,
|
||||||
|
"failed to map shared memory for execute");
|
||||||
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
close(fd);
|
close(fd);
|
||||||
@ -594,12 +596,8 @@ static int alloc_code_gen_buffer_splitwx_memfd(size_t size, Error **errp)
|
|||||||
|
|
||||||
return PROT_READ | PROT_WRITE;
|
return PROT_READ | PROT_WRITE;
|
||||||
|
|
||||||
fail_rx:
|
|
||||||
error_setg_errno(errp, errno, "failed to map shared memory for execute");
|
|
||||||
fail:
|
fail:
|
||||||
if (buf_rx != MAP_FAILED) {
|
/* buf_rx is always equal to MAP_FAILED here and does not require cleanup */
|
||||||
munmap(buf_rx, size);
|
|
||||||
}
|
|
||||||
if (buf_rw) {
|
if (buf_rw) {
|
||||||
munmap(buf_rw, size);
|
munmap(buf_rw, size);
|
||||||
}
|
}
|
||||||
|
@ -683,7 +683,7 @@ static void tcg_out_insn_VRIc(TCGContext *s, S390Opcode op,
|
|||||||
tcg_debug_assert(is_vector_reg(v3));
|
tcg_debug_assert(is_vector_reg(v3));
|
||||||
tcg_out16(s, (op & 0xff00) | ((v1 & 0xf) << 4) | (v3 & 0xf));
|
tcg_out16(s, (op & 0xff00) | ((v1 & 0xf) << 4) | (v3 & 0xf));
|
||||||
tcg_out16(s, i2);
|
tcg_out16(s, i2);
|
||||||
tcg_out16(s, (op & 0x00ff) | RXB(v1, 0, v3, 0) | (m4 << 12));
|
tcg_out16(s, (op & 0x00ff) | RXB(v1, v3, 0, 0) | (m4 << 12));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tcg_out_insn_VRRa(TCGContext *s, S390Opcode op,
|
static void tcg_out_insn_VRRa(TCGContext *s, S390Opcode op,
|
||||||
@ -738,7 +738,7 @@ static void tcg_out_insn_VRSa(TCGContext *s, S390Opcode op, TCGReg v1,
|
|||||||
tcg_debug_assert(is_vector_reg(v3));
|
tcg_debug_assert(is_vector_reg(v3));
|
||||||
tcg_out16(s, (op & 0xff00) | ((v1 & 0xf) << 4) | (v3 & 0xf));
|
tcg_out16(s, (op & 0xff00) | ((v1 & 0xf) << 4) | (v3 & 0xf));
|
||||||
tcg_out16(s, b2 << 12 | d2);
|
tcg_out16(s, b2 << 12 | d2);
|
||||||
tcg_out16(s, (op & 0x00ff) | RXB(v1, 0, v3, 0) | (m4 << 12));
|
tcg_out16(s, (op & 0x00ff) | RXB(v1, v3, 0, 0) | (m4 << 12));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tcg_out_insn_VRSb(TCGContext *s, S390Opcode op, TCGReg v1,
|
static void tcg_out_insn_VRSb(TCGContext *s, S390Opcode op, TCGReg v1,
|
||||||
@ -762,7 +762,7 @@ static void tcg_out_insn_VRSc(TCGContext *s, S390Opcode op, TCGReg r1,
|
|||||||
tcg_debug_assert(is_vector_reg(v3));
|
tcg_debug_assert(is_vector_reg(v3));
|
||||||
tcg_out16(s, (op & 0xff00) | (r1 << 4) | (v3 & 0xf));
|
tcg_out16(s, (op & 0xff00) | (r1 << 4) | (v3 & 0xf));
|
||||||
tcg_out16(s, b2 << 12 | d2);
|
tcg_out16(s, b2 << 12 | d2);
|
||||||
tcg_out16(s, (op & 0x00ff) | RXB(0, 0, v3, 0) | (m4 << 12));
|
tcg_out16(s, (op & 0x00ff) | RXB(0, v3, 0, 0) | (m4 << 12));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tcg_out_insn_VRX(TCGContext *s, S390Opcode op, TCGReg v1,
|
static void tcg_out_insn_VRX(TCGContext *s, S390Opcode op, TCGReg v1,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user