privop.h 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. #ifndef _ASM_IA64_XEN_PRIVOP_H
  2. #define _ASM_IA64_XEN_PRIVOP_H
  3. /*
  4. * Copyright (C) 2005 Hewlett-Packard Co
  5. * Dan Magenheimer <dan.magenheimer@hp.com>
  6. *
  7. * Paravirtualizations of privileged operations for Xen/ia64
  8. *
  9. *
  10. * inline privop and paravirt_alt support
  11. * Copyright (c) 2007 Isaku Yamahata <yamahata at valinux co jp>
  12. * VA Linux Systems Japan K.K.
  13. *
  14. */
  15. #ifndef __ASSEMBLY__
  16. #include <linux/types.h> /* arch-ia64.h requires uint64_t */
  17. #endif
  18. #include <asm/xen/interface.h>
  19. /* At 1 MB, before per-cpu space but still addressable using addl instead
  20. of movl. */
  21. #define XSI_BASE 0xfffffffffff00000
  22. /* Address of mapped regs. */
  23. #define XMAPPEDREGS_BASE (XSI_BASE + XSI_SIZE)
  24. #ifdef __ASSEMBLY__
  25. #define XEN_HYPER_RFI break HYPERPRIVOP_RFI
  26. #define XEN_HYPER_RSM_PSR_DT break HYPERPRIVOP_RSM_DT
  27. #define XEN_HYPER_SSM_PSR_DT break HYPERPRIVOP_SSM_DT
  28. #define XEN_HYPER_COVER break HYPERPRIVOP_COVER
  29. #define XEN_HYPER_ITC_D break HYPERPRIVOP_ITC_D
  30. #define XEN_HYPER_ITC_I break HYPERPRIVOP_ITC_I
  31. #define XEN_HYPER_SSM_I break HYPERPRIVOP_SSM_I
  32. #define XEN_HYPER_GET_IVR break HYPERPRIVOP_GET_IVR
  33. #define XEN_HYPER_THASH break HYPERPRIVOP_THASH
  34. #define XEN_HYPER_ITR_D break HYPERPRIVOP_ITR_D
  35. #define XEN_HYPER_SET_KR break HYPERPRIVOP_SET_KR
  36. #define XEN_HYPER_GET_PSR break HYPERPRIVOP_GET_PSR
  37. #define XEN_HYPER_SET_RR0_TO_RR4 break HYPERPRIVOP_SET_RR0_TO_RR4
  38. #define XSI_IFS (XSI_BASE + XSI_IFS_OFS)
  39. #define XSI_PRECOVER_IFS (XSI_BASE + XSI_PRECOVER_IFS_OFS)
  40. #define XSI_IFA (XSI_BASE + XSI_IFA_OFS)
  41. #define XSI_ISR (XSI_BASE + XSI_ISR_OFS)
  42. #define XSI_IIM (XSI_BASE + XSI_IIM_OFS)
  43. #define XSI_ITIR (XSI_BASE + XSI_ITIR_OFS)
  44. #define XSI_PSR_I_ADDR (XSI_BASE + XSI_PSR_I_ADDR_OFS)
  45. #define XSI_PSR_IC (XSI_BASE + XSI_PSR_IC_OFS)
  46. #define XSI_IPSR (XSI_BASE + XSI_IPSR_OFS)
  47. #define XSI_IIP (XSI_BASE + XSI_IIP_OFS)
  48. #define XSI_B1NAT (XSI_BASE + XSI_B1NATS_OFS)
  49. #define XSI_BANK1_R16 (XSI_BASE + XSI_BANK1_R16_OFS)
  50. #define XSI_BANKNUM (XSI_BASE + XSI_BANKNUM_OFS)
  51. #define XSI_IHA (XSI_BASE + XSI_IHA_OFS)
  52. #define XSI_ITC_OFFSET (XSI_BASE + XSI_ITC_OFFSET_OFS)
  53. #define XSI_ITC_LAST (XSI_BASE + XSI_ITC_LAST_OFS)
  54. #endif
  55. #ifndef __ASSEMBLY__
  56. /************************************************/
  57. /* Instructions paravirtualized for correctness */
  58. /************************************************/
  59. /* "fc" and "thash" are privilege-sensitive instructions, meaning they
  60. * may have different semantics depending on whether they are executed
  61. * at PL0 vs PL!=0. When paravirtualized, these instructions mustn't
  62. * be allowed to execute directly, lest incorrect semantics result. */
  63. extern void xen_fc(void *addr);
  64. extern unsigned long xen_thash(unsigned long addr);
  65. /* Note that "ttag" and "cover" are also privilege-sensitive; "ttag"
  66. * is not currently used (though it may be in a long-format VHPT system!)
  67. * and the semantics of cover only change if psr.ic is off which is very
  68. * rare (and currently non-existent outside of assembly code */
  69. /* There are also privilege-sensitive registers. These registers are
  70. * readable at any privilege level but only writable at PL0. */
  71. extern unsigned long xen_get_cpuid(int index);
  72. extern unsigned long xen_get_pmd(int index);
  73. #ifndef ASM_SUPPORTED
  74. extern unsigned long xen_get_eflag(void); /* see xen_ia64_getreg */
  75. extern void xen_set_eflag(unsigned long); /* see xen_ia64_setreg */
  76. #endif
  77. /************************************************/
  78. /* Instructions paravirtualized for performance */
  79. /************************************************/
  80. /* Xen uses memory-mapped virtual privileged registers for access to many
  81. * performance-sensitive privileged registers. Some, like the processor
  82. * status register (psr), are broken up into multiple memory locations.
  83. * Others, like "pend", are abstractions based on privileged registers.
  84. * "Pend" is guaranteed to be set if reading cr.ivr would return a
  85. * (non-spurious) interrupt. */
  86. #define XEN_MAPPEDREGS ((struct mapped_regs *)XMAPPEDREGS_BASE)
  87. #define XSI_PSR_I \
  88. (*XEN_MAPPEDREGS->interrupt_mask_addr)
  89. #define xen_get_virtual_psr_i() \
  90. (!XSI_PSR_I)
  91. #define xen_set_virtual_psr_i(_val) \
  92. ({ XSI_PSR_I = (uint8_t)(_val) ? 0 : 1; })
  93. #define xen_set_virtual_psr_ic(_val) \
  94. ({ XEN_MAPPEDREGS->interrupt_collection_enabled = _val ? 1 : 0; })
  95. #define xen_get_virtual_pend() \
  96. (*(((uint8_t *)XEN_MAPPEDREGS->interrupt_mask_addr) - 1))
  97. #ifndef ASM_SUPPORTED
  98. /* Although all privileged operations can be left to trap and will
  99. * be properly handled by Xen, some are frequent enough that we use
  100. * hyperprivops for performance. */
  101. extern unsigned long xen_get_psr(void);
  102. extern unsigned long xen_get_ivr(void);
  103. extern unsigned long xen_get_tpr(void);
  104. extern void xen_hyper_ssm_i(void);
  105. extern void xen_set_itm(unsigned long);
  106. extern void xen_set_tpr(unsigned long);
  107. extern void xen_eoi(unsigned long);
  108. extern unsigned long xen_get_rr(unsigned long index);
  109. extern void xen_set_rr(unsigned long index, unsigned long val);
  110. extern void xen_set_rr0_to_rr4(unsigned long val0, unsigned long val1,
  111. unsigned long val2, unsigned long val3,
  112. unsigned long val4);
  113. extern void xen_set_kr(unsigned long index, unsigned long val);
  114. extern void xen_ptcga(unsigned long addr, unsigned long size);
  115. #endif /* !ASM_SUPPORTED */
  116. #endif /* !__ASSEMBLY__ */
  117. #endif /* _ASM_IA64_XEN_PRIVOP_H */