NG2page.S 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. /* NG2page.S: Niagara-2 optimized clear and copy page.
  2. *
  3. * Copyright (C) 2007 (davem@davemloft.net)
  4. */
  5. #include <asm/asi.h>
  6. #include <asm/page.h>
  7. #include <asm/visasm.h>
  8. .text
  9. .align 32
  10. /* This is heavily simplified from the sun4u variants
  11. * because Niagara-2 does not have any D-cache aliasing issues.
  12. */
  13. NG2copy_user_page: /* %o0=dest, %o1=src, %o2=vaddr */
  14. prefetch [%o1 + 0x00], #one_read
  15. prefetch [%o1 + 0x40], #one_read
  16. VISEntryHalf
  17. set PAGE_SIZE, %g7
  18. sub %o0, %o1, %g3
  19. 1: stxa %g0, [%o1 + %g3] ASI_BLK_INIT_QUAD_LDD_P
  20. subcc %g7, 64, %g7
  21. ldda [%o1] ASI_BLK_P, %f0
  22. stda %f0, [%o1 + %g3] ASI_BLK_P
  23. add %o1, 64, %o1
  24. bne,pt %xcc, 1b
  25. prefetch [%o1 + 0x40], #one_read
  26. membar #Sync
  27. VISExitHalf
  28. retl
  29. nop
  30. #define BRANCH_ALWAYS 0x10680000
  31. #define NOP 0x01000000
  32. #define NG_DO_PATCH(OLD, NEW) \
  33. sethi %hi(NEW), %g1; \
  34. or %g1, %lo(NEW), %g1; \
  35. sethi %hi(OLD), %g2; \
  36. or %g2, %lo(OLD), %g2; \
  37. sub %g1, %g2, %g1; \
  38. sethi %hi(BRANCH_ALWAYS), %g3; \
  39. sll %g1, 11, %g1; \
  40. srl %g1, 11 + 2, %g1; \
  41. or %g3, %lo(BRANCH_ALWAYS), %g3; \
  42. or %g3, %g1, %g3; \
  43. stw %g3, [%g2]; \
  44. sethi %hi(NOP), %g3; \
  45. or %g3, %lo(NOP), %g3; \
  46. stw %g3, [%g2 + 0x4]; \
  47. flush %g2;
  48. .globl niagara2_patch_pageops
  49. .type niagara2_patch_pageops,#function
  50. niagara2_patch_pageops:
  51. NG_DO_PATCH(copy_user_page, NG2copy_user_page)
  52. NG_DO_PATCH(_clear_page, NGclear_page)
  53. NG_DO_PATCH(clear_user_page, NGclear_user_page)
  54. retl
  55. nop
  56. .size niagara2_patch_pageops,.-niagara2_patch_pageops