sie64a.S 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /*
  2. * sie64a.S - low level sie call
  3. *
  4. * Copyright IBM Corp. 2008,2010
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License (version 2 only)
  8. * as published by the Free Software Foundation.
  9. *
  10. * Author(s): Heiko Carstens <heiko.carstens@de.ibm.com>
  11. * Christian Ehrhardt <ehrhardt@linux.vnet.ibm.com>
  12. */
  13. #include <linux/errno.h>
  14. #include <asm/asm-offsets.h>
  15. #include <asm/setup.h>
  16. #include <asm/asm-offsets.h>
  17. #include <asm/ptrace.h>
  18. #include <asm/thread_info.h>
  19. _TIF_EXIT_SIE = (_TIF_SIGPENDING | _TIF_NEED_RESCHED | _TIF_MCCK_PENDING)
  20. /*
  21. * offsets into stackframe
  22. * SP_ = offsets into stack sie64 is called with
  23. * SPI_ = offsets into irq stack
  24. */
  25. SP_GREGS = __SF_EMPTY
  26. SP_HOOK = __SF_EMPTY+8
  27. SP_GPP = __SF_EMPTY+16
  28. SPI_PSW = STACK_FRAME_OVERHEAD + __PT_PSW
  29. .macro SPP newpp
  30. #ifdef CONFIG_KVM_AWARE_CMF
  31. tm __LC_MACHINE_FLAGS+6,0x20 # MACHINE_FLAG_SPP
  32. jz 0f
  33. .insn s,0xb2800000,\newpp
  34. 0:
  35. #endif
  36. .endm
  37. sie_irq_handler:
  38. SPP __LC_CMF_HPP # set host id
  39. larl %r2,sie_inst
  40. clg %r2,SPI_PSW+8(0,%r15) # intercepted sie
  41. jne 1f
  42. xc __LC_SIE_HOOK(8),__LC_SIE_HOOK
  43. lg %r2,__LC_THREAD_INFO # pointer thread_info struct
  44. tm __TI_flags+7(%r2),_TIF_EXIT_SIE
  45. jz 0f
  46. larl %r2,sie_exit # work pending, leave sie
  47. stg %r2,__LC_RETURN_PSW+8
  48. br %r14
  49. 0: larl %r2,sie_reenter # re-enter with guest id
  50. stg %r2,__LC_RETURN_PSW+8
  51. 1: br %r14
  52. /*
  53. * sie64a calling convention:
  54. * %r2 pointer to sie control block
  55. * %r3 guest register save area
  56. */
  57. .globl sie64a
  58. sie64a:
  59. stg %r3,SP_GREGS(%r15) # save guest register save area
  60. stmg %r6,%r14,__SF_GPRS(%r15) # save registers on entry
  61. lgr %r14,%r2 # pointer to sie control block
  62. larl %r5,sie_irq_handler
  63. stg %r2,SP_GPP(%r15)
  64. stg %r5,SP_HOOK(%r15) # save hook target
  65. lmg %r0,%r13,0(%r3) # load guest gprs 0-13
  66. sie_reenter:
  67. mvc __LC_SIE_HOOK(8),SP_HOOK(%r15)
  68. SPP SP_GPP(%r15) # set guest id
  69. sie_inst:
  70. sie 0(%r14)
  71. xc __LC_SIE_HOOK(8),__LC_SIE_HOOK
  72. SPP __LC_CMF_HPP # set host id
  73. sie_exit:
  74. lg %r14,SP_GREGS(%r15)
  75. stmg %r0,%r13,0(%r14) # save guest gprs 0-13
  76. lghi %r2,0
  77. lmg %r6,%r14,__SF_GPRS(%r15)
  78. br %r14
  79. sie_err:
  80. xc __LC_SIE_HOOK(8),__LC_SIE_HOOK
  81. SPP __LC_CMF_HPP # set host id
  82. lg %r14,SP_GREGS(%r15)
  83. stmg %r0,%r13,0(%r14) # save guest gprs 0-13
  84. lghi %r2,-EFAULT
  85. lmg %r6,%r14,__SF_GPRS(%r15)
  86. br %r14
  87. .section __ex_table,"a"
  88. .quad sie_inst,sie_err
  89. .previous