2019-06-03 07:44:50 +02:00
/* SPDX-License-Identifier: GPL-2.0-only */
2012-03-05 11:49:32 +00:00
/ *
* 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 a k e r n e l b u f f e r ( 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
strb \ p t r , [ \ r e g B ] , \ v a l
.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
strh \ p t r , [ \ r e g B ] , \ v a l
.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
str \ p t r , [ \ r e g B ] , \ v a l
.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
stp \ p t r , \ r e g B , [ \ r e g C ] , \ v a l
.endm
end . r e q x5
2020-01-06 19:58:17 +00:00
SYM_ F U N C _ S T A R T ( _ _ a r c h _ c o p y _ f r o m _ u s e r )
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 "
mov x0 , #0 / / N o t h i n g t o c o p y
2012-03-05 11:49:32 +00:00
ret
2020-01-06 19:58:17 +00:00
SYM_ F U N C _ E N D ( _ _ a r c h _ c o p y _ f r o m _ 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 _ f r o m _ u s e r )
2012-03-05 11:49:32 +00:00
.section .fixup , " ax"
.align 2
2016-09-10 16:50:00 -04: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