1 /* NGpage.S: Niagara optimize clear and copy page.
 
   3  * Copyright (C) 2006 (davem@davemloft.net)
 
  12         /* This is heavily simplified from the sun4u variants
 
  13          * because Niagara does not have any D-cache aliasing issues
 
  14          * and also we don't need to use the FPU in order to implement
 
  15          * an optimal page copy/clear.
 
  18 NGcopy_user_page:       /* %o0=dest, %o1=src, %o2=vaddr */
 
  19         prefetch        [%o1 + 0x00], #one_read
 
  25 1:      ldda            [%o1 + %g0] ASI_BLK_INIT_QUAD_LDD_P, %o2
 
  26         ldda            [%o1 + %g2] ASI_BLK_INIT_QUAD_LDD_P, %o4
 
  27         prefetch        [%o1 + 0x40], #one_read
 
  29         stxa            %o2, [%o0 + %g0] ASI_BLK_INIT_QUAD_LDD_P
 
  30         stxa            %o3, [%o0 + %g1] ASI_BLK_INIT_QUAD_LDD_P
 
  31         ldda            [%o1 + %g0] ASI_BLK_INIT_QUAD_LDD_P, %o2
 
  32         stxa            %o4, [%o0 + %g2] ASI_BLK_INIT_QUAD_LDD_P
 
  33         stxa            %o5, [%o0 + %g3] ASI_BLK_INIT_QUAD_LDD_P
 
  34         ldda            [%o1 + %g2] ASI_BLK_INIT_QUAD_LDD_P, %o4
 
  37         stxa            %o2, [%o0 + %g0] ASI_BLK_INIT_QUAD_LDD_P
 
  38         stxa            %o3, [%o0 + %g1] ASI_BLK_INIT_QUAD_LDD_P
 
  39         stxa            %o4, [%o0 + %g2] ASI_BLK_INIT_QUAD_LDD_P
 
  40         stxa            %o5, [%o0 + %g3] ASI_BLK_INIT_QUAD_LDD_P
 
  48         .globl          NGclear_page, NGclear_user_page
 
  49 NGclear_page:           /* %o0=dest */
 
  50 NGclear_user_page:      /* %o0=dest, %o1=vaddr */
 
  56 1:      stxa            %g0, [%o0 + %g0] ASI_BLK_INIT_QUAD_LDD_P
 
  57         stxa            %g0, [%o0 + %g1] ASI_BLK_INIT_QUAD_LDD_P
 
  58         stxa            %g0, [%o0 + %g2] ASI_BLK_INIT_QUAD_LDD_P
 
  59         stxa            %g0, [%o0 + %g3] ASI_BLK_INIT_QUAD_LDD_P
 
  61         stxa            %g0, [%o0 + %g0] ASI_BLK_INIT_QUAD_LDD_P
 
  62         stxa            %g0, [%o0 + %g1] ASI_BLK_INIT_QUAD_LDD_P
 
  63         stxa            %g0, [%o0 + %g2] ASI_BLK_INIT_QUAD_LDD_P
 
  64         stxa            %g0, [%o0 + %g3] ASI_BLK_INIT_QUAD_LDD_P
 
  72 #define BRANCH_ALWAYS   0x10680000
 
  73 #define NOP             0x01000000
 
  74 #define NG_DO_PATCH(OLD, NEW)   \
 
  75         sethi   %hi(NEW), %g1; \
 
  76         or      %g1, %lo(NEW), %g1; \
 
  77         sethi   %hi(OLD), %g2; \
 
  78         or      %g2, %lo(OLD), %g2; \
 
  80         sethi   %hi(BRANCH_ALWAYS), %g3; \
 
  82         srl     %g1, 11 + 2, %g1; \
 
  83         or      %g3, %lo(BRANCH_ALWAYS), %g3; \
 
  86         sethi   %hi(NOP), %g3; \
 
  87         or      %g3, %lo(NOP), %g3; \
 
  88         stw     %g3, [%g2 + 0x4]; \
 
  91         .globl  niagara_patch_pageops
 
  92         .type   niagara_patch_pageops,#function
 
  93 niagara_patch_pageops:
 
  94         NG_DO_PATCH(copy_user_page, NGcopy_user_page)
 
  95         NG_DO_PATCH(_clear_page, NGclear_page)
 
  96         NG_DO_PATCH(clear_user_page, NGclear_user_page)
 
  99         .size   niagara_patch_pageops,.-niagara_patch_pageops