~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/arm64/lib/clear_user.S

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0-only */
  2 /*
  3  * Copyright (C) 2021 Arm Ltd.
  4  */
  5 
  6 #include <linux/linkage.h>
  7 #include <asm/asm-uaccess.h>
  8 
  9         .text
 10 
 11 /* Prototype: int __arch_clear_user(void *addr, size_t sz)
 12  * Purpose  : clear some user memory
 13  * Params   : addr - user memory address to clear
 14  *          : sz   - number of bytes to clear
 15  * Returns  : number of bytes NOT cleared
 16  *
 17  * Alignment fixed up by hardware.
 18  */
 19 
 20         .p2align 4
 21         // Alignment is for the loop, but since the prologue (including BTI)
 22         // is also 16 bytes we can keep any padding outside the function
 23 SYM_FUNC_START(__arch_clear_user)
 24         add     x2, x0, x1
 25         subs    x1, x1, #8
 26         b.mi    2f
 27 1:
 28 USER(9f, sttr   xzr, [x0])
 29         add     x0, x0, #8
 30         subs    x1, x1, #8
 31         b.hi    1b
 32 USER(9f, sttr   xzr, [x2, #-8])
 33         mov     x0, #0
 34         ret
 35 
 36 2:      tbz     x1, #2, 3f
 37 USER(9f, sttr   wzr, [x0])
 38 USER(8f, sttr   wzr, [x2, #-4])
 39         mov     x0, #0
 40         ret
 41 
 42 3:      tbz     x1, #1, 4f
 43 USER(9f, sttrh  wzr, [x0])
 44 4:      tbz     x1, #0, 5f
 45 USER(7f, sttrb  wzr, [x2, #-1])
 46 5:      mov     x0, #0
 47         ret
 48 
 49         // Exception fixups
 50 7:      sub     x0, x2, #5      // Adjust for faulting on the final byte...
 51 8:      add     x0, x0, #4      // ...or the second word of the 4-7 byte case
 52 9:      sub     x0, x2, x0
 53         ret
 54 SYM_FUNC_END(__arch_clear_user)
 55 EXPORT_SYMBOL(__arch_clear_user)

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php