dcr-low.S 844 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /* SPDX-License-Identifier: GPL-2.0-or-later */
  2. /*
  3. * "Indirect" DCR access
  4. *
  5. * Copyright (c) 2004 Eugene Surovegin <[email protected]>
  6. */
  7. #include <asm/ppc_asm.h>
  8. #include <asm/processor.h>
  9. #include <asm/bug.h>
  10. #include <asm/export.h>
  11. #define DCR_ACCESS_PROLOG(table) \
  12. cmplwi cr0,r3,1024; \
  13. rlwinm r3,r3,4,18,27; \
  14. lis r5,table@h; \
  15. ori r5,r5,table@l; \
  16. add r3,r3,r5; \
  17. bge- 1f; \
  18. mtctr r3; \
  19. bctr; \
  20. 1: trap; \
  21. EMIT_BUG_ENTRY 1b,__FILE__,__LINE__,0; \
  22. blr
  23. _GLOBAL(__mfdcr)
  24. DCR_ACCESS_PROLOG(__mfdcr_table)
  25. EXPORT_SYMBOL(__mfdcr)
  26. _GLOBAL(__mtdcr)
  27. DCR_ACCESS_PROLOG(__mtdcr_table)
  28. EXPORT_SYMBOL(__mtdcr)
  29. __mfdcr_table:
  30. mfdcr r3,0; blr
  31. __mtdcr_table:
  32. mtdcr 0,r4; blr
  33. dcr = 1
  34. .rept 1023
  35. mfdcr r3,dcr; blr
  36. mtdcr dcr,r4; blr
  37. dcr = dcr + 1
  38. .endr