blob: ff630dcb273c9649de6fc9e145fce42e72667787 [file] [log] [blame]
David S. Miller398d1082006-03-05 16:41:56 -08001/* NGcopy_to_user.S: Niagara optimized copy to userspace.
2 *
David S. Miller25e55662007-10-02 01:03:09 -07003 * Copyright (C) 2006, 2007 David S. Miller (davem@davemloft.net)
David S. Miller398d1082006-03-05 16:41:56 -08004 */
5
6#define EX_ST(x) \
798: x; \
David S. Miller398d1082006-03-05 16:41:56 -08008 .section __ex_table,"a";\
9 .align 4; \
David S. Miller40bdac72009-02-08 22:00:55 -080010 .word 98b, __ret_one_asi;\
David S. Miller398d1082006-03-05 16:41:56 -080011 .text; \
12 .align 4;
13
14#ifndef ASI_AIUS
15#define ASI_AIUS 0x11
16#endif
17
18#define FUNC_NAME NGcopy_to_user
19#define STORE(type,src,addr) type##a src, [addr] ASI_AIUS
20#define STORE_ASI ASI_BLK_INIT_QUAD_LDD_AIUS
David S. Miller25e55662007-10-02 01:03:09 -070021#define EX_RETVAL(x) %g0
David S. Miller398d1082006-03-05 16:41:56 -080022
23#ifdef __KERNEL__
24 /* Writing to %asi is _expensive_ so we hardcode it.
25 * Reading %asi to check for KERNEL_DS is comparatively
26 * cheap.
27 */
28#define PREAMBLE \
29 rd %asi, %g1; \
30 cmp %g1, ASI_AIUS; \
David S. Milleraeb39872009-02-08 22:32:31 -080031 bne,pn %icc, ___copy_in_user; \
David S. Miller398d1082006-03-05 16:41:56 -080032 nop
33#endif
34
David S. Miller0d4bc952006-02-11 10:30:41 -080035#include "NGmemcpy.S"