Blame sysdeps/sparc/sparc32/memset.S

Packit 6c4009
/* Set a block of memory to some byte value.
Packit 6c4009
   For SPARC v7.
Packit 6c4009
   Copyright (C) 1996-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
   Contributed by David S. Miller <davem@caip.rutgers.edu> and
Packit 6c4009
                  Jakub Jelinek <jj@ultra.linux.cz>.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library; if not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
#include <sysdep.h>
Packit 6c4009
Packit 6c4009
	/* Store 64 bytes at (BASE + OFFSET) using value SOURCE. */
Packit 6c4009
#define ZERO_BIG_BLOCK(base, offset, source)    	\
Packit 6c4009
	std		source, [base + offset + 0x00]; \
Packit 6c4009
	std		source, [base + offset + 0x08]; \
Packit 6c4009
	std		source, [base + offset + 0x10]; \
Packit 6c4009
	std		source, [base + offset + 0x18]; \
Packit 6c4009
	std		source, [base + offset + 0x20]; \
Packit 6c4009
	std		source, [base + offset + 0x28]; \
Packit 6c4009
	std		source, [base + offset + 0x30]; \
Packit 6c4009
	std		source, [base + offset + 0x38];
Packit 6c4009
Packit 6c4009
#define ZERO_LAST_BLOCKS(base, offset, source)		\
Packit 6c4009
	std		source, [base - offset - 0x38]; \
Packit 6c4009
	std		source, [base - offset - 0x30]; \
Packit 6c4009
	std		source, [base - offset - 0x28]; \
Packit 6c4009
	std		source, [base - offset - 0x20]; \
Packit 6c4009
	std		source, [base - offset - 0x18]; \
Packit 6c4009
	std		source, [base - offset - 0x10]; \
Packit 6c4009
	std		source, [base - offset - 0x08]; \
Packit 6c4009
	std		source, [base - offset - 0x00];
Packit 6c4009
Packit 6c4009
	.text
Packit 6c4009
	.align 4
Packit 6c4009
ENTRY(__bzero)
Packit 6c4009
	b		1f
Packit 6c4009
	 mov		%g0, %g3
Packit 6c4009
Packit 6c4009
3:	cmp		%o2, 3
Packit 6c4009
	be		2f
Packit 6c4009
	 stb		%g3, [%o0]
Packit 6c4009
Packit 6c4009
	cmp		%o2, 2
Packit 6c4009
	be		2f
Packit 6c4009
	 stb		%g3, [%o0 + 0x01]
Packit 6c4009
Packit 6c4009
	stb		%g3, [%o0 + 0x02]
Packit 6c4009
2:	sub		%o2, 4, %o2
Packit 6c4009
	add		%o1, %o2, %o1
Packit 6c4009
	b		4f
Packit 6c4009
	 sub		%o0, %o2, %o0
Packit 6c4009
END(__bzero)
Packit 6c4009
Packit 6c4009
ENTRY(memset)
Packit 6c4009
	and		%o1, 0xff, %g3
Packit 6c4009
	sll		%g3, 8, %g2
Packit 6c4009
	or		%g3, %g2, %g3
Packit 6c4009
	sll		%g3, 16, %g2
Packit 6c4009
	or		%g3, %g2, %g3
Packit 6c4009
	orcc		%o2, %g0, %o1
Packit 6c4009
1:	cmp		%o1, 7
Packit 6c4009
	bleu		7f
Packit 6c4009
	 mov		%o0, %g1
Packit 6c4009
Packit 6c4009
	andcc		%o0, 3, %o2
Packit 6c4009
	bne		3b
Packit 6c4009
4:	 andcc		%o0, 4, %g0
Packit 6c4009
Packit 6c4009
	be		2f
Packit 6c4009
	 mov		%g3, %g2
Packit 6c4009
Packit 6c4009
	st		%g3, [%o0]
Packit 6c4009
	sub		%o1, 4, %o1
Packit 6c4009
	add		%o0, 4, %o0
Packit 6c4009
2:	andcc		%o1, 0xffffff80, %o3
Packit 6c4009
	be		9f
Packit 6c4009
	 andcc		%o1, 0x78, %o2
Packit 6c4009
4:	ZERO_BIG_BLOCK	(%o0, 0x00, %g2)
Packit 6c4009
	subcc		%o3, 128, %o3
Packit 6c4009
	ZERO_BIG_BLOCK	(%o0, 0x40, %g2)
Packit 6c4009
	bne		4b
Packit 6c4009
	 add		%o0, 128, %o0
Packit 6c4009
Packit 6c4009
	orcc		%o2, %g0, %g0
Packit 6c4009
9:	be		6f
Packit 6c4009
	 andcc		%o1, 7, %o1
Packit 6c4009
Packit 6c4009
	mov		%o7, %g4
Packit 6c4009
101:	call		100f
Packit 6c4009
	 srl		%o2, 1, %o3
Packit 6c4009
	mov		%g4, %o7
Packit 6c4009
	jmpl		%o4 + (20f + 64 - 101b), %g0
Packit 6c4009
	 add		%o0, %o2, %o0
Packit 6c4009
Packit 6c4009
100:	retl
Packit 6c4009
	 sub		%o7, %o3, %o4
Packit 6c4009
Packit 6c4009
20:	ZERO_LAST_BLOCKS(%o0, 0x48, %g2)
Packit 6c4009
	ZERO_LAST_BLOCKS(%o0, 0x08, %g2)
Packit 6c4009
Packit 6c4009
6:	be		8f
Packit 6c4009
	 andcc		%o1, 4, %g0
Packit 6c4009
	be		1f
Packit 6c4009
	 andcc		%o1, 2, %g0
Packit 6c4009
	st		%g3, [%o0]
Packit 6c4009
	add		%o0, 4, %o0
Packit 6c4009
1:	be		1f
Packit 6c4009
	 andcc		%o1, 1, %g0
Packit 6c4009
	sth		%g3, [%o0]
Packit 6c4009
	add		%o0, 2, %o0
Packit 6c4009
1:	bne,a		8f
Packit 6c4009
	 stb		%g3, [%o0]
Packit 6c4009
8:	retl
Packit 6c4009
	 mov		%g1, %o0
Packit 6c4009
7:	orcc		%o1, 0, %g0
Packit 6c4009
	be		0f
Packit 6c4009
	 subcc		%o1, 1, %o1
Packit 6c4009
	stb		%g3, [%o0]
Packit 6c4009
	be		0f
Packit 6c4009
	 subcc		%o1, 1, %o1
Packit 6c4009
	stb		%g3, [%o0 + 1]
Packit 6c4009
	be		0f
Packit 6c4009
	 subcc		%o1, 1, %o1
Packit 6c4009
	stb		%g3, [%o0 + 2]
Packit 6c4009
	be		0f
Packit 6c4009
	 subcc		%o1, 1, %o1
Packit 6c4009
	stb		%g3, [%o0 + 3]
Packit 6c4009
	be		0f
Packit 6c4009
	 subcc		%o1, 1, %o1
Packit 6c4009
	stb		%g3, [%o0 + 4]
Packit 6c4009
	be		0f
Packit 6c4009
	 subcc		%o1, 1, %o1
Packit 6c4009
	stb		%g3, [%o0 + 5]
Packit 6c4009
	be		0f
Packit 6c4009
	 subcc		%o1, 1, %o1
Packit 6c4009
	stb		%g3, [%o0 + 6]
Packit 6c4009
0:	retl
Packit 6c4009
	 nop
Packit 6c4009
END(memset)
Packit 6c4009
libc_hidden_builtin_def (memset)
Packit 6c4009
Packit 6c4009
weak_alias (__bzero, bzero)