mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-16 18:26:42 +00:00
f3c78e949d
Commit ddb5cdbafaaa ("kbuild: generate KSYMTAB entries by modpost") deprecated <asm/export.h>, which is now a wrapper of <linux/export.h>. Replace #include <asm/export.h> with #include <linux/export.h>. After all the <asm/export.h> lines are converted, <asm/export.h> and <asm-generic/export.h> will be removed. Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
84 lines
1.5 KiB
ArmAsm
84 lines
1.5 KiB
ArmAsm
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* arch/alpha/lib/strncpy.S
|
|
* Contributed by Richard Henderson (rth@tamu.edu)
|
|
*
|
|
* Copy no more than COUNT bytes of the null-terminated string from
|
|
* SRC to DST. If SRC does not cover all of COUNT, the balance is
|
|
* zeroed.
|
|
*
|
|
* Or, rather, if the kernel cared about that weird ANSI quirk. This
|
|
* version has cropped that bit o' nastiness as well as assuming that
|
|
* __stxncpy is in range of a branch.
|
|
*/
|
|
#include <linux/export.h>
|
|
.set noat
|
|
.set noreorder
|
|
|
|
.text
|
|
|
|
.align 4
|
|
.globl strncpy
|
|
.ent strncpy
|
|
strncpy:
|
|
.frame $30, 0, $26
|
|
.prologue 0
|
|
|
|
mov $16, $0 # set return value now
|
|
beq $18, $zerolen
|
|
unop
|
|
bsr $23, __stxncpy # do the work of the copy
|
|
|
|
unop
|
|
bne $18, $multiword # do we have full words left?
|
|
subq $24, 1, $3 # nope
|
|
subq $27, 1, $4
|
|
|
|
or $3, $24, $3 # clear the bits between the last
|
|
or $4, $27, $4 # written byte and the last byte in COUNT
|
|
andnot $3, $4, $4
|
|
zap $1, $4, $1
|
|
|
|
stq_u $1, 0($16)
|
|
ret
|
|
|
|
.align 4
|
|
$multiword:
|
|
subq $27, 1, $2 # clear the final bits in the prev word
|
|
or $2, $27, $2
|
|
zapnot $1, $2, $1
|
|
subq $18, 1, $18
|
|
|
|
stq_u $1, 0($16)
|
|
addq $16, 8, $16
|
|
unop
|
|
beq $18, 1f
|
|
|
|
nop
|
|
unop
|
|
nop
|
|
blbc $18, 0f
|
|
|
|
stq_u $31, 0($16) # zero one word
|
|
subq $18, 1, $18
|
|
addq $16, 8, $16
|
|
beq $18, 1f
|
|
|
|
0: stq_u $31, 0($16) # zero two words
|
|
subq $18, 2, $18
|
|
stq_u $31, 8($16)
|
|
addq $16, 16, $16
|
|
bne $18, 0b
|
|
|
|
1: ldq_u $1, 0($16) # clear the leading bits in the final word
|
|
subq $24, 1, $2
|
|
or $2, $24, $2
|
|
|
|
zap $1, $2, $1
|
|
stq_u $1, 0($16)
|
|
$zerolen:
|
|
ret
|
|
|
|
.end strncpy
|
|
EXPORT_SYMBOL(strncpy)
|