2019-06-03 07:44:50 +02:00
/* SPDX-License-Identifier: GPL-2.0-only */
2012-03-05 11:49:32 +00:00
/ *
* Copy f r o m u s e r s p a c e t o u s e r s p a c e
*
* Copyright ( C ) 2 0 1 2 A R M L t d .
* /
# include < l i n u x / l i n k a g e . h >
2015-07-22 19:05:54 +01:00
2016-12-26 04:10:19 -05:00
# include < a s m / a s m - u a c c e s s . h >
2018-12-07 18:08:20 +00:00
# include < a s m / a s s e m b l e r . h >
# include < a s m / c a c h e . h >
2012-03-05 11:49:32 +00:00
/ *
* Copy f r o m u s e r s p a c e t o u s e r s p a c e ( a l i g n m e n t h a n d l e d b y t h e h a r d w a r e )
*
* Parameters :
* x0 - t o
* x1 - f r o m
* x2 - n
* Returns :
* x0 - b y t e s n o t c o p i e d
* /
2015-09-23 11:55:39 -07:00
.macro ldrb1 ptr, r e g B , v a l
2016-02-05 14:58:48 +00:00
uao_ u s e r _ a l t e r n a t i v e 9 9 9 8 f , l d r b , l d t r b , \ p t r , \ r e g B , \ v a l
2015-09-23 11:55:39 -07:00
.endm
.macro strb1 ptr, r e g B , v a l
2016-02-05 14:58:48 +00:00
uao_ u s e r _ a l t e r n a t i v e 9 9 9 8 f , s t r b , s t t r b , \ p t r , \ r e g B , \ v a l
2015-09-23 11:55:39 -07:00
.endm
.macro ldrh1 ptr, r e g B , v a l
2016-02-05 14:58:48 +00:00
uao_ u s e r _ a l t e r n a t i v e 9 9 9 8 f , l d r h , l d t r h , \ p t r , \ r e g B , \ v a l
2015-09-23 11:55:39 -07:00
.endm
.macro strh1 ptr, r e g B , v a l
2016-02-05 14:58:48 +00:00
uao_ u s e r _ a l t e r n a t i v e 9 9 9 8 f , s t r h , s t t r h , \ p t r , \ r e g B , \ v a l
2015-09-23 11:55:39 -07:00
.endm
.macro ldr1 ptr, r e g B , v a l
2016-02-05 14:58:48 +00:00
uao_ u s e r _ a l t e r n a t i v e 9 9 9 8 f , l d r , l d t r , \ p t r , \ r e g B , \ v a l
2015-09-23 11:55:39 -07:00
.endm
.macro str1 ptr, r e g B , v a l
2016-02-05 14:58:48 +00:00
uao_ u s e r _ a l t e r n a t i v e 9 9 9 8 f , s t r , s t t r , \ p t r , \ r e g B , \ v a l
2015-09-23 11:55:39 -07:00
.endm
.macro ldp1 ptr, r e g B , r e g C , v a l
2016-02-05 14:58:48 +00:00
uao_ l d p 9 9 9 8 f , \ p t r , \ r e g B , \ r e g C , \ v a l
2015-09-23 11:55:39 -07:00
.endm
.macro stp1 ptr, r e g B , r e g C , v a l
2016-02-05 14:58:48 +00:00
uao_ s t p 9 9 9 8 f , \ p t r , \ r e g B , \ r e g C , \ v a l
2015-09-23 11:55:39 -07:00
.endm
end . r e q x5
2018-02-05 15:34:23 +00:00
ENTRY( _ _ a r c h _ c o p y _ i n _ u s e r )
2017-08-10 13:58:16 +01:00
uaccess_ e n a b l e _ n o t _ u a o x3 , x4 , x5
2015-09-23 11:55:39 -07:00
add e n d , x0 , x2
# include " c o p y _ t e m p l a t e . S "
2018-01-10 13:18:30 +00:00
uaccess_ d i s a b l e _ n o t _ u a o x3 , x4
2015-09-23 11:55:39 -07:00
mov x0 , #0
2012-03-05 11:49:32 +00:00
ret
2018-02-05 15:34:23 +00:00
ENDPROC( _ _ a r c h _ c o p y _ i n _ u s e r )
2018-12-07 18:08:20 +00:00
EXPORT_ S Y M B O L ( _ _ a r c h _ c o p y _ i n _ u s e r )
2012-03-05 11:49:32 +00:00
.section .fixup , " ax"
.align 2
2015-09-23 11:55:39 -07:00
9998 : sub x0 , e n d , d s t / / b y t e s n o t c o p i e d
2012-03-05 11:49:32 +00:00
ret
.previous