From: "Edgar E. Iglesias" <edgar.iglesias@amd.com>
To: Jan Beulich <jbeulich@suse.com>
Cc: sstabellini@kernel.org, julien@xen.org, bertrand.marquis@arm.com,
michal.orzel@amd.com, Volodymyr_Babchuk@epam.com,
xen-devel@lists.xenproject.org
Subject: Re: [PATCH v1 1/1] arm64: Fix strrchr() matching of null terminator
Date: Tue, 19 May 2026 17:24:24 +0200 [thread overview]
Message-ID: <agyAqDWWYUunmYFW@zapote> (raw)
In-Reply-To: <9b8ec97f-02ae-4a1a-9abe-59873d574a64@suse.com>
On Tue, May 19, 2026 at 08:40:54AM +0200, Jan Beulich wrote:
> On 19.05.2026 01:43, Edgar E. Iglesias wrote:
> > The generic Xen strrchr() implementation returns a pointer to the string
> > terminator when searching for '\0', matching the standard C semantics.
> >
> > The ARM64 assembly version stopped as soon as it loaded the terminator and
> > returned the previous match pointer instead. This made strrchr("", '\0')
> > return NULL.
>
> I wonder though: Why would one pass '\0' to strrchr()? If you want to find
> the end of a string, more efficient (at least in the general case) options
> exist (strchr(), memchr(), strlen()).
Right, this came from a fuzzer checking standard strrchr() behavior, not
from an explicit end-of-string use case.
I agree strlen() or strchr(s, '\0') would be better for that, but
strrchr(s, '\0') is valid input, so we should handle it to avoid
surprises for existing or future callers.
>
> > Compare the loaded byte against the requested character before deciding
> > whether to stop at the terminator, so the terminator itself can be returned
> > when it is the requested character.
>
> Nit: "..., so a pointer to the terminator ...".
Updated, thanks.
>
> > Fixes: 42c4eb6a83 ("xen: arm64: assembly optimised mem* and str*")
> > Signed-off-by: Edgar E. Iglesias <edgar.iglesias@amd.com>
>
> Reviewed-by: Jan Beulich <jbeulich@suse.com>
>
> However, the function having come from Linux, imo the patch wants to go to
> Linux (ideally first, but at the very least also).
Yes, sounds good.
>
> Additionally, looking at strchr() - couldn't the code here be written in a
> similar way, allowing to get away with just a single branch? (Arm32's pair
> of functions is also pretty similar in this regard.)
Hm, good point. I had a closer look and came up with a couple of options
that look better. This one is not quite the same shape as strchr(), but it
eliminates one branch and shortens the inner loop from 5 to 4 insns...
FUNC(strrchr)
mov x3, #0 /* Last match, or NULL */
sub x0, x0, #1 /* For the pre-indexed load */
and w1, w1, #0xff
1: ldrb w2, [x0, #1]! /* Load next byte */
cmp w2, w1
csel x3, x0, x3, eq /* Remember match */
cbnz w2, 1b /* Keep going until NUL */
mov x0, x3
ret
END(strrchr)
Cheers,
Edgar
>
> Jan
>
> > --- a/xen/arch/arm/arm64/lib/strrchr.S
> > +++ b/xen/arch/arm/arm64/lib/strrchr.S
> > @@ -30,11 +30,10 @@ FUNC(strrchr)
> > mov x3, #0
> > and w1, w1, #0xff
> > 1: ldrb w2, [x0], #1
> > - cbz w2, 2f
> > cmp w2, w1
> > - b.ne 1b
> > + b.ne 2f
> > sub x3, x0, #1
> > - b 1b
> > -2: mov x0, x3
> > +2: cbnz w2, 1b
> > + mov x0, x3
> > ret
> > END(strrchr)
>
next prev parent reply other threads:[~2026-05-19 15:24 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-18 23:43 [PATCH v1 0/1] arm64: Fix strrchr() matching of null terminator Edgar E. Iglesias
2026-05-18 23:43 ` [PATCH v1 1/1] " Edgar E. Iglesias
2026-05-19 6:40 ` Jan Beulich
2026-05-19 7:47 ` Julien Grall
2026-05-19 15:28 ` Edgar E. Iglesias
2026-05-19 15:24 ` Edgar E. Iglesias [this message]
2026-05-19 12:45 ` Andrew Cooper
2026-05-19 16:27 ` Edgar E. Iglesias
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=agyAqDWWYUunmYFW@zapote \
--to=edgar.iglesias@amd.com \
--cc=Volodymyr_Babchuk@epam.com \
--cc=bertrand.marquis@arm.com \
--cc=jbeulich@suse.com \
--cc=julien@xen.org \
--cc=michal.orzel@amd.com \
--cc=sstabellini@kernel.org \
--cc=xen-devel@lists.xenproject.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.