dcr-low.S 983 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. /*
  2. * "Indirect" DCR access
  3. *
  4. * Copyright (c) 2004 Eugene Surovegin <ebs@ebshome.net>
  5. *
  6. * This program is free software; you can redistribute it and/or modify it
  7. * under the terms of the GNU General Public License as published by the
  8. * Free Software Foundation; either version 2 of the License, or (at your
  9. * option) any later version.
  10. */
  11. #include <asm/ppc_asm.h>
  12. #include <asm/processor.h>
  13. #include <asm/bug.h>
  14. #define DCR_ACCESS_PROLOG(table) \
  15. cmpli cr0,r3,1024; \
  16. rlwinm r3,r3,4,18,27; \
  17. lis r5,table@h; \
  18. ori r5,r5,table@l; \
  19. add r3,r3,r5; \
  20. bge- 1f; \
  21. mtctr r3; \
  22. bctr; \
  23. 1: trap; \
  24. EMIT_BUG_ENTRY 1b,__FILE__,__LINE__,0; \
  25. blr
  26. _GLOBAL(__mfdcr)
  27. DCR_ACCESS_PROLOG(__mfdcr_table)
  28. _GLOBAL(__mtdcr)
  29. DCR_ACCESS_PROLOG(__mtdcr_table)
  30. __mfdcr_table:
  31. mfdcr r3,0; blr
  32. __mtdcr_table:
  33. mtdcr 0,r4; blr
  34. dcr = 1
  35. .rept 1023
  36. mfdcr r3,dcr; blr
  37. mtdcr dcr,r4; blr
  38. dcr = dcr + 1
  39. .endr