acpi.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. /*
  2. * asm-x86_64/acpi.h
  3. *
  4. * Copyright (C) 2001 Paul Diefenbaugh <paul.s.diefenbaugh@intel.com>
  5. * Copyright (C) 2001 Patrick Mochel <mochel@osdl.org>
  6. *
  7. * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation; either version 2 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License
  20. * along with this program; if not, write to the Free Software
  21. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  22. *
  23. * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  24. */
  25. #ifndef _ASM_ACPI_H
  26. #define _ASM_ACPI_H
  27. #ifdef __KERNEL__
  28. #define COMPILER_DEPENDENT_INT64 long long
  29. #define COMPILER_DEPENDENT_UINT64 unsigned long long
  30. /*
  31. * Calling conventions:
  32. *
  33. * ACPI_SYSTEM_XFACE - Interfaces to host OS (handlers, threads)
  34. * ACPI_EXTERNAL_XFACE - External ACPI interfaces
  35. * ACPI_INTERNAL_XFACE - Internal ACPI interfaces
  36. * ACPI_INTERNAL_VAR_XFACE - Internal variable-parameter list interfaces
  37. */
  38. #define ACPI_SYSTEM_XFACE
  39. #define ACPI_EXTERNAL_XFACE
  40. #define ACPI_INTERNAL_XFACE
  41. #define ACPI_INTERNAL_VAR_XFACE
  42. /* Asm macros */
  43. #define ACPI_ASM_MACROS
  44. #define BREAKPOINT3
  45. #define ACPI_DISABLE_IRQS() local_irq_disable()
  46. #define ACPI_ENABLE_IRQS() local_irq_enable()
  47. #define ACPI_FLUSH_CPU_CACHE() wbinvd()
  48. static inline int
  49. __acpi_acquire_global_lock (unsigned int *lock)
  50. {
  51. unsigned int old, new, val;
  52. do {
  53. old = *lock;
  54. new = (((old & ~0x3) + 2) + ((old >> 1) & 0x1));
  55. val = cmpxchg(lock, old, new);
  56. } while (unlikely (val != old));
  57. return (new < 3) ? -1 : 0;
  58. }
  59. static inline int
  60. __acpi_release_global_lock (unsigned int *lock)
  61. {
  62. unsigned int old, new, val;
  63. do {
  64. old = *lock;
  65. new = old & ~0x3;
  66. val = cmpxchg(lock, old, new);
  67. } while (unlikely (val != old));
  68. return old & 0x1;
  69. }
  70. #define ACPI_ACQUIRE_GLOBAL_LOCK(GLptr, Acq) \
  71. ((Acq) = __acpi_acquire_global_lock((unsigned int *) GLptr))
  72. #define ACPI_RELEASE_GLOBAL_LOCK(GLptr, Acq) \
  73. ((Acq) = __acpi_release_global_lock((unsigned int *) GLptr))
  74. /*
  75. * Math helper asm macros
  76. */
  77. #define ACPI_DIV_64_BY_32(n_hi, n_lo, d32, q32, r32) \
  78. asm("divl %2;" \
  79. :"=a"(q32), "=d"(r32) \
  80. :"r"(d32), \
  81. "0"(n_lo), "1"(n_hi))
  82. #define ACPI_SHIFT_RIGHT_64(n_hi, n_lo) \
  83. asm("shrl $1,%2;" \
  84. "rcrl $1,%3;" \
  85. :"=r"(n_hi), "=r"(n_lo) \
  86. :"0"(n_hi), "1"(n_lo))
  87. /*
  88. * Refer Intel ACPI _PDC support document for bit definitions
  89. */
  90. #define ACPI_PDC_EST_CAPABILITY_SMP 0xa
  91. #define ACPI_PDC_EST_CAPABILITY_MSR 0x1
  92. #ifdef CONFIG_ACPI_BOOT
  93. extern int acpi_lapic;
  94. extern int acpi_ioapic;
  95. extern int acpi_noirq;
  96. extern int acpi_strict;
  97. extern int acpi_disabled;
  98. extern int acpi_pci_disabled;
  99. extern int acpi_ht;
  100. static inline void disable_acpi(void)
  101. {
  102. acpi_disabled = 1;
  103. acpi_ht = 0;
  104. acpi_pci_disabled = 1;
  105. acpi_noirq = 1;
  106. }
  107. /* Fixmap pages to reserve for ACPI boot-time tables (see fixmap.h) */
  108. #define FIX_ACPI_PAGES 4
  109. extern int acpi_gsi_to_irq(u32 gsi, unsigned int *irq);
  110. #else /* !CONFIG_ACPI_BOOT */
  111. #define acpi_lapic 0
  112. #define acpi_ioapic 0
  113. #endif /* !CONFIG_ACPI_BOOT */
  114. extern int acpi_numa;
  115. extern int acpi_scan_nodes(unsigned long start, unsigned long end);
  116. #define NR_NODE_MEMBLKS (MAX_NUMNODES*2)
  117. #ifdef CONFIG_ACPI_PCI
  118. static inline void acpi_noirq_set(void) { acpi_noirq = 1; }
  119. static inline void acpi_disable_pci(void)
  120. {
  121. acpi_pci_disabled = 1;
  122. acpi_noirq_set();
  123. }
  124. extern int acpi_irq_balance_set(char *str);
  125. #else
  126. static inline void acpi_noirq_set(void) { }
  127. static inline void acpi_disable_pci(void) { }
  128. static inline int acpi_irq_balance_set(char *str) { return 0; }
  129. #endif
  130. #ifdef CONFIG_ACPI_SLEEP
  131. /* routines for saving/restoring kernel state */
  132. extern int acpi_save_state_mem(void);
  133. extern void acpi_restore_state_mem(void);
  134. extern unsigned long acpi_wakeup_address;
  135. /* early initialization routine */
  136. extern void acpi_reserve_bootmem(void);
  137. #endif /*CONFIG_ACPI_SLEEP*/
  138. #define boot_cpu_physical_apicid boot_cpu_id
  139. extern int acpi_disabled;
  140. extern int acpi_pci_disabled;
  141. extern u8 x86_acpiid_to_apicid[];
  142. extern int acpi_skip_timer_override;
  143. #endif /*__KERNEL__*/
  144. #endif /*_ASM_ACPI_H*/