qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Warner Losh <imp@bsdimp.com>
To: Richard Henderson <richard.henderson@linaro.org>
Cc: Stacey Son <sson@freebsd.org>,
	QEMU Trivial <qemu-trivial@nongnu.org>,
	Kyle Evans <kevans@freebsd.org>, Michael Tokarev <mjt@tls.msk.ru>,
	Philippe Mathieu-Daude <f4bug@amsat.org>,
	QEMU Developers <qemu-devel@nongnu.org>,
	Laurent Vivier <laurent@vivier.eu>
Subject: Re: [PATCH v3 23/29] bsd-user/arm/target_arch_signal.h: arm set_mcontext
Date: Thu, 4 Nov 2021 17:59:43 -0600	[thread overview]
Message-ID: <CANCZdfru-o2tX_AJWOCxmBjpXTEbCpb-nHk8t1dGpxrhUv-29A@mail.gmail.com> (raw)
In-Reply-To: <a4809133-bdae-8c06-511c-0aa9af6f3362@linaro.org>

[-- Attachment #1: Type: text/plain, Size: 1227 bytes --]

On Thu, Nov 4, 2021 at 12:43 PM Richard Henderson <
richard.henderson@linaro.org> wrote:

> On 11/4/21 10:05 AM, Warner Losh wrote:
> > +    /*
> > +     * Make sure T mode matches the PC's notion of thumb mode, although
> > +     * FreeBSD lets the processor sort this out, so we may need remove
> > +     * this check, or generate a signal...
> > +     */
> > +    if (!!(tswap32(gr[TARGET_REG_PC]) & 1) != !!(cpsr & CPSR_T)) {
> > +        return -TARGET_EINVAL;
> > +    }
>
> I've had a read through the Arm ARM for "movs pc, lr", which is how
> swi_exit returns to
> userspace:
>
>      CPSRWriteByInstr(SPSR[], '1111', TRUE);
>      ...
>      BranchWritePC(result);
>
> So the CPSR gets written first, which sets the T bit, and thus the result
> of
> CurrentInstrSet(), then
>
> BranchWritePC(bits(32) address)
>    if CurrentInstrSet() == InstrSet_ARM then
>      if ArchVersion() < 6 && address<1:0> != '00' then UNPREDICTABLE;
>      BranchTo(address<31:2>:'00');
>    ...
>    else
>      BranchTo(address<31:1>:'0');
>
> > +    env->regs[15] = tswap32(gr[TARGET_REG_PC]);
>
> So this should mask the low 1 or 2 bits depending on cpsr & CPSR_T.
>

Will do. Thanks for all the patient explanations.

Warner


> r~
>

[-- Attachment #2: Type: text/html, Size: 1999 bytes --]

  reply	other threads:[~2021-11-05  0:01 UTC|newest]

Thread overview: 37+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-11-04 14:05 [PATCH v3 00/29] bsd-user: arm (32-bit) support Warner Losh
2021-11-04 14:05 ` [PATCH v3 01/29] bsd-user/arm/target_arch_sysarch.h: Use consistent include guards Warner Losh
2021-11-04 14:05 ` [PATCH v3 02/29] bsd-user/arm/target_syscall.h: Add copyright and update name Warner Losh
2021-11-04 14:05 ` [PATCH v3 03/29] bsd-user/arm/target_arch_cpu.c: Target specific TLS routines Warner Losh
2021-11-04 14:05 ` [PATCH v3 04/29] bsd-user/arm/target_arch_cpu.h: CPU Loop definitions Warner Losh
2021-11-04 14:05 ` [PATCH v3 05/29] bsd-user/arm/target_arch_cpu.h: Implement target_cpu_clone_regs Warner Losh
2021-11-04 14:05 ` [PATCH v3 06/29] bsd-user/arm/target_arch_cpu.h: Dummy target_cpu_loop implementation Warner Losh
2021-11-04 14:05 ` [PATCH v3 07/29] bsd-user/arm/target_arch_cpu.h: Implement trivial EXCP exceptions Warner Losh
2021-11-04 17:44   ` Richard Henderson
2021-11-04 14:05 ` [PATCH v3 08/29] bsd-user/arm/target_arch_cpu.h: Implement data abort exceptions Warner Losh
2021-11-04 14:05 ` [PATCH v3 09/29] bsd-user/arm/target_arch_cpu.h: Implement system call dispatch Warner Losh
2021-11-04 14:05 ` [PATCH v3 10/29] bsd-user/arm/target_arch_reg.h: Implement core dump register copying Warner Losh
2021-11-04 14:05 ` [PATCH v3 11/29] bsd-user/arm/target_arch_vmparam.h: Parameters for arm address space Warner Losh
2021-11-04 14:05 ` [PATCH v3 12/29] bsd-user/arm/target_arch_sigtramp.h: Signal Trampoline for arm Warner Losh
2021-11-04 14:05 ` [PATCH v3 13/29] bsd-user/arm/target_arch_thread.h: Routines to create and switch to a thread Warner Losh
2021-11-04 14:05 ` [PATCH v3 14/29] bsd-user/arm/target_arch_elf.h: arm defines for ELF Warner Losh
2021-11-04 14:05 ` [PATCH v3 15/29] bsd-user/arm/target_arch_elf.h: arm get hwcap Warner Losh
2021-11-04 14:05 ` [PATCH v3 16/29] bsd-user/arm/target_arch_elf.h: arm get_hwcap2 impl Warner Losh
2021-11-04 14:05 ` [PATCH v3 17/29] bsd-user/freebsd: Create common target_os_ucontext.h file Warner Losh
2021-11-04 14:05 ` [PATCH v3 18/29] bsd-user/arm/target_arch_signal.h: arm specific signal registers and stack Warner Losh
2021-11-04 14:05 ` [PATCH v3 19/29] bsd-user/arm/target_arch_signal.h: arm machine context for signals Warner Losh
2021-11-04 17:48   ` Richard Henderson
2021-11-04 17:58     ` Warner Losh
2021-11-04 18:26       ` Warner Losh
2021-11-04 20:56       ` Warner Losh
2021-11-04 14:05 ` [PATCH v3 20/29] bsd-user/arm/target_arch_signal.h: arm user context and trapframe " Warner Losh
2021-11-04 14:05 ` [PATCH v3 21/29] bsd-user/arm/target_arch_signal.h: arm set_sigtramp_args Warner Losh
2021-11-04 14:05 ` [PATCH v3 22/29] bsd-user/arm/target_arch_signal.h: arm get_mcontext Warner Losh
2021-11-04 14:05 ` [PATCH v3 23/29] bsd-user/arm/target_arch_signal.h: arm set_mcontext Warner Losh
2021-11-04 18:41   ` Richard Henderson
2021-11-04 23:59     ` Warner Losh [this message]
2021-11-04 14:05 ` [PATCH v3 24/29] bsd-user/arm/target_arch_signal.h: arm get_ucontext_sigreturn Warner Losh
2021-11-04 14:05 ` [PATCH v3 25/29] bsd-user: add arm target build Warner Losh
2021-11-04 14:05 ` [PATCH v3 26/29] bsd-user/i386/target_arch_signal.h: Remove target_sigcontext Warner Losh
2021-11-04 14:05 ` [PATCH v3 27/29] bsd-user/x86_64/target_arch_signal.h: " Warner Losh
2021-11-04 14:05 ` [PATCH v3 28/29] bsd-user/i386/target_arch_signal.h: use new target_os_ucontext.h Warner Losh
2021-11-04 14:05 ` [PATCH v3 29/29] bsd-user/x86_64/target_arch_signal.h: " Warner Losh

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=CANCZdfru-o2tX_AJWOCxmBjpXTEbCpb-nHk8t1dGpxrhUv-29A@mail.gmail.com \
    --to=imp@bsdimp.com \
    --cc=f4bug@amsat.org \
    --cc=kevans@freebsd.org \
    --cc=laurent@vivier.eu \
    --cc=mjt@tls.msk.ru \
    --cc=qemu-devel@nongnu.org \
    --cc=qemu-trivial@nongnu.org \
    --cc=richard.henderson@linaro.org \
    --cc=sson@freebsd.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
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;
as well as URLs for NNTP newsgroup(s).