mirror of
https://github.com/torvalds/linux.git
synced 2026-05-30 10:04:04 +02:00
Add an assembly implementation of strchr() for RISC-V. By eliminating stack frame management (prologue/epilogue) and optimizing the function entries, the assembly version provides significant relative gains for short strings where the fixed overhead of the C function is most prominent. As string length increases, performance converges with the generic C implementation. Benchmark results (QEMU TCG, rv64): Length | Original (MB/s) | Optimized (MB/s) | Improvement -------|-----------------|------------------|------------ 1 B | 21 | 22 | +4.8% 7 B | 113 | 121 | +7.1% 16 B | 195 | 202 | +3.6% 512 B | 376 | 389 | +3.5% 4096 B | 394 | 393 | -0.3% Signed-off-by: Feng Jiang <jiangfeng@kylinos.cn> Tested-by: Joel Stanley <joel@jms.id.au> Link: https://patch.msgid.link/20260130025018.172925-8-jiangfeng@kylinos.cn Signed-off-by: Paul Walmsley <pjw@kernel.org>
36 lines
600 B
ArmAsm
36 lines
600 B
ArmAsm
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
|
|
/*
|
|
* Copyright (C) 2025 Feng Jiang <jiangfeng@kylinos.cn>
|
|
*/
|
|
|
|
#include <linux/linkage.h>
|
|
#include <asm/asm.h>
|
|
|
|
/* char *strchr(const char *s, int c) */
|
|
SYM_FUNC_START(strchr)
|
|
/*
|
|
* Parameters
|
|
* a0 - The string to be searched
|
|
* a1 - The character to search for
|
|
*
|
|
* Returns
|
|
* a0 - Address of first occurrence of 'c' or 0
|
|
*
|
|
* Clobbers
|
|
* t0
|
|
*/
|
|
andi a1, a1, 0xff
|
|
1:
|
|
lbu t0, 0(a0)
|
|
beq t0, a1, 2f
|
|
addi a0, a0, 1
|
|
bnez t0, 1b
|
|
li a0, 0
|
|
2:
|
|
ret
|
|
SYM_FUNC_END(strchr)
|
|
|
|
SYM_FUNC_ALIAS_WEAK(__pi_strchr, strchr)
|
|
EXPORT_SYMBOL(strchr)
|