Merge tag 'block-6.0-2022-09-22' of git://git.kernel.dk/linux
[linux-block.git] / arch / sparc / lib / U3copy_to_user.S
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
1da177e4
LT
2/* U3copy_to_user.S: UltraSparc-III optimized copy to userspace.
3 *
4 * Copyright (C) 1999, 2000, 2004 David S. Miller (davem@redhat.com)
5 */
6
ee841d0a 7#define EX_ST(x,y) \
1da177e4 898: x; \
4d000d5b 9 .section __ex_table,"a";\
1da177e4 10 .align 4; \
ee841d0a 11 .word 98b, y; \
1da177e4
LT
12 .text; \
13 .align 4;
14
ee841d0a 15#define EX_ST_FP(x,y) \
a7c5724b
RG
1698: x; \
17 .section __ex_table,"a";\
18 .align 4; \
ee841d0a 19 .word 98b, y##_fp; \
a7c5724b
RG
20 .text; \
21 .align 4;
22
1da177e4
LT
23#define FUNC_NAME U3copy_to_user
24#define STORE(type,src,addr) type##a src, [addr] ASI_AIUS
25#define STORE_BLK(src,addr) stda src, [addr] ASI_BLK_AIUS
26#define EX_RETVAL(x) 0
27
28 /* Writing to %asi is _expensive_ so we hardcode it.
29 * Reading %asi to check for KERNEL_DS is comparatively
30 * cheap.
31 */
32#define PREAMBLE \
33 rd %asi, %g1; \
34 cmp %g1, ASI_AIUS; \
31af2f36 35 bne,pn %icc, raw_copy_in_user; \
1da177e4
LT
36 nop; \
37
38#include "U3memcpy.S"