blob: 66464b3e364984d4234f991f406b24e83cffaa68 [file] [log] [blame]
Babu Mogerb3a04ed2017-08-07 17:52:51 -06001/*
2 * M7copy_from_user.S: SPARC M7 optimized copy from userspace.
3 *
4 * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
5 */
6
7
Babu Moger34060b82017-08-07 17:52:52 -06008#define EX_LD(x, y) \
Babu Mogerb3a04ed2017-08-07 17:52:51 -0600998: x; \
10 .section __ex_table,"a"; \
11 .align 4; \
Babu Moger34060b82017-08-07 17:52:52 -060012 .word 98b, y; \
Babu Mogerb3a04ed2017-08-07 17:52:51 -060013 .text; \
14 .align 4;
15
Babu Moger34060b82017-08-07 17:52:52 -060016#define EX_LD_FP(x, y) \
Babu Mogerb3a04ed2017-08-07 17:52:51 -06001798: x; \
18 .section __ex_table,"a"; \
19 .align 4; \
Babu Moger34060b82017-08-07 17:52:52 -060020 .word 98b, y##_fp; \
Babu Mogerb3a04ed2017-08-07 17:52:51 -060021 .text; \
22 .align 4;
23
Babu Mogerb3a04ed2017-08-07 17:52:51 -060024#ifndef ASI_AIUS
25#define ASI_AIUS 0x11
26#endif
27
28#define FUNC_NAME M7copy_from_user
29#define LOAD(type,addr,dest) type##a [addr] %asi, dest
30#define EX_RETVAL(x) 0
31
32#ifdef __KERNEL__
33#define PREAMBLE \
34 rd %asi, %g1; \
35 cmp %g1, ASI_AIUS; \
36 bne,pn %icc, raw_copy_in_user; \
Babu Moger34060b82017-08-07 17:52:52 -060037 nop
Babu Mogerb3a04ed2017-08-07 17:52:51 -060038#endif
39
40#include "M7memcpy.S"