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

TOMOYO Linux Cross Reference
Linux/arch/sparc/lib/GENpage.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 */
  2 /* GENpage.S: Generic clear and copy page.
  3  *
  4  * Copyright (C) 2007 (davem@davemloft.net)
  5  */
  6 #include <asm/page.h>
  7 
  8         .text
  9         .align  32
 10 
 11 GENcopy_user_page:
 12         set     PAGE_SIZE, %g7
 13 1:      ldx     [%o1 + 0x00], %o2
 14         ldx     [%o1 + 0x08], %o3
 15         ldx     [%o1 + 0x10], %o4
 16         ldx     [%o1 + 0x18], %o5
 17         stx     %o2, [%o0 + 0x00]
 18         stx     %o3, [%o0 + 0x08]
 19         stx     %o4, [%o0 + 0x10]
 20         stx     %o5, [%o0 + 0x18]
 21         ldx     [%o1 + 0x20], %o2
 22         ldx     [%o1 + 0x28], %o3
 23         ldx     [%o1 + 0x30], %o4
 24         ldx     [%o1 + 0x38], %o5
 25         stx     %o2, [%o0 + 0x20]
 26         stx     %o3, [%o0 + 0x28]
 27         stx     %o4, [%o0 + 0x30]
 28         stx     %o5, [%o0 + 0x38]
 29         subcc   %g7, 64, %g7
 30         add     %o1, 64, %o1
 31         bne,pt  %xcc, 1b
 32          add    %o0, 64, %o0
 33         retl
 34          nop
 35 
 36 GENclear_page:
 37 GENclear_user_page:
 38         set     PAGE_SIZE, %g7
 39 1:      stx     %g0, [%o0 + 0x00]
 40         stx     %g0, [%o0 + 0x08]
 41         stx     %g0, [%o0 + 0x10]
 42         stx     %g0, [%o0 + 0x18]
 43         stx     %g0, [%o0 + 0x20]
 44         stx     %g0, [%o0 + 0x28]
 45         stx     %g0, [%o0 + 0x30]
 46         stx     %g0, [%o0 + 0x38]
 47         subcc   %g7, 64, %g7
 48         bne,pt  %xcc, 1b
 49          add    %o0, 64, %o0
 50 
 51 #define BRANCH_ALWAYS   0x10680000
 52 #define NOP             0x01000000
 53 #define GEN_DO_PATCH(OLD, NEW)  \
 54         sethi   %hi(NEW), %g1; \
 55         or      %g1, %lo(NEW), %g1; \
 56         sethi   %hi(OLD), %g2; \
 57         or      %g2, %lo(OLD), %g2; \
 58         sub     %g1, %g2, %g1; \
 59         sethi   %hi(BRANCH_ALWAYS), %g3; \
 60         sll     %g1, 11, %g1; \
 61         srl     %g1, 11 + 2, %g1; \
 62         or      %g3, %lo(BRANCH_ALWAYS), %g3; \
 63         or      %g3, %g1, %g3; \
 64         stw     %g3, [%g2]; \
 65         sethi   %hi(NOP), %g3; \
 66         or      %g3, %lo(NOP), %g3; \
 67         stw     %g3, [%g2 + 0x4]; \
 68         flush   %g2;
 69 
 70         .globl  generic_patch_pageops
 71         .type   generic_patch_pageops,#function
 72 generic_patch_pageops:
 73         GEN_DO_PATCH(copy_user_page, GENcopy_user_page)
 74         GEN_DO_PATCH(_clear_page, GENclear_page)
 75         GEN_DO_PATCH(clear_user_page, GENclear_user_page)
 76         retl
 77          nop
 78         .size   generic_patch_pageops,.-generic_patch_pageops

~ [ 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