acpi.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. /*
  2. * asm-i386/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. #include <acpi/pdc_intel.h>
  29. #include <asm/system.h> /* defines cmpxchg */
  30. #define COMPILER_DEPENDENT_INT64 long long
  31. #define COMPILER_DEPENDENT_UINT64 unsigned long long
  32. /*
  33. * Calling conventions:
  34. *
  35. * ACPI_SYSTEM_XFACE - Interfaces to host OS (handlers, threads)
  36. * ACPI_EXTERNAL_XFACE - External ACPI interfaces
  37. * ACPI_INTERNAL_XFACE - Internal ACPI interfaces
  38. * ACPI_INTERNAL_VAR_XFACE - Internal variable-parameter list interfaces
  39. */
  40. #define ACPI_SYSTEM_XFACE
  41. #define ACPI_EXTERNAL_XFACE
  42. #define ACPI_INTERNAL_XFACE
  43. #define ACPI_INTERNAL_VAR_XFACE
  44. /* Asm macros */
  45. #define ACPI_ASM_MACROS
  46. #define BREAKPOINT3
  47. #define ACPI_DISABLE_IRQS() local_irq_disable()
  48. #define ACPI_ENABLE_IRQS() local_irq_enable()
  49. #define ACPI_FLUSH_CPU_CACHE() wbinvd()
  50. static inline int
  51. __acpi_acquire_global_lock (unsigned int *lock)
  52. {
  53. unsigned int old, new, val;
  54. do {
  55. old = *lock;
  56. new = (((old & ~0x3) + 2) + ((old >> 1) & 0x1));
  57. val = cmpxchg(lock, old, new);
  58. } while (unlikely (val != old));
  59. return (new < 3) ? -1 : 0;
  60. }
  61. static inline int
  62. __acpi_release_global_lock (unsigned int *lock)
  63. {
  64. unsigned int old, new, val;
  65. do {
  66. old = *lock;
  67. new = old & ~0x3;
  68. val = cmpxchg(lock, old, new);
  69. } while (unlikely (val != old));
  70. return old & 0x1;
  71. }
  72. #define ACPI_ACQUIRE_GLOBAL_LOCK(GLptr, Acq) \
  73. ((Acq) = __acpi_acquire_global_lock((unsigned int *) GLptr))
  74. #define ACPI_RELEASE_GLOBAL_LOCK(GLptr, Acq) \
  75. ((Acq) = __acpi_release_global_lock((unsigned int *) GLptr))
  76. /*
  77. * Math helper asm macros
  78. */
  79. #define ACPI_DIV_64_BY_32(n_hi, n_lo, d32, q32, r32) \
  80. asm("divl %2;" \
  81. :"=a"(q32), "=d"(r32) \
  82. :"r"(d32), \
  83. "0"(n_lo), "1"(n_hi))
  84. #define ACPI_SHIFT_RIGHT_64(n_hi, n_lo) \
  85. asm("shrl $1,%2;" \
  86. "rcrl $1,%3;" \
  87. :"=r"(n_hi), "=r"(n_lo) \
  88. :"0"(n_hi), "1"(n_lo))
  89. #ifdef CONFIG_ACPI
  90. extern int acpi_lapic;
  91. extern int acpi_ioapic;
  92. extern int acpi_noirq;
  93. extern int acpi_strict;
  94. extern int acpi_disabled;
  95. extern int acpi_ht;
  96. extern int acpi_pci_disabled;
  97. static inline void disable_acpi(void)
  98. {
  99. acpi_disabled = 1;
  100. acpi_ht = 0;
  101. acpi_pci_disabled = 1;
  102. acpi_noirq = 1;
  103. }
  104. /* Fixmap pages to reserve for ACPI boot-time tables (see fixmap.h) */
  105. #define FIX_ACPI_PAGES 4
  106. extern int acpi_gsi_to_irq(u32 gsi, unsigned int *irq);
  107. #ifdef CONFIG_X86_IO_APIC
  108. extern int skip_ioapic_setup;
  109. extern int acpi_skip_timer_override;
  110. extern void check_acpi_pci(void);
  111. static inline void disable_ioapic_setup(void)
  112. {
  113. skip_ioapic_setup = 1;
  114. }
  115. static inline int ioapic_setup_disabled(void)
  116. {
  117. return skip_ioapic_setup;
  118. }
  119. #else
  120. static inline void disable_ioapic_setup(void) { }
  121. static inline void check_acpi_pci(void) { }
  122. #endif
  123. static inline void acpi_noirq_set(void) { acpi_noirq = 1; }
  124. static inline void acpi_disable_pci(void)
  125. {
  126. acpi_pci_disabled = 1;
  127. acpi_noirq_set();
  128. }
  129. extern int acpi_irq_balance_set(char *str);
  130. #else /* !CONFIG_ACPI */
  131. #define acpi_lapic 0
  132. #define acpi_ioapic 0
  133. static inline void acpi_noirq_set(void) { }
  134. static inline void acpi_disable_pci(void) { }
  135. #endif /* !CONFIG_ACPI */
  136. #ifdef CONFIG_ACPI_SLEEP
  137. /* routines for saving/restoring kernel state */
  138. extern int acpi_save_state_mem(void);
  139. extern void acpi_restore_state_mem(void);
  140. extern unsigned long acpi_wakeup_address;
  141. /* early initialization routine */
  142. extern void acpi_reserve_bootmem(void);
  143. #endif /*CONFIG_ACPI_SLEEP*/
  144. extern u8 x86_acpiid_to_apicid[];
  145. #define ARCH_HAS_POWER_PDC_INIT 1
  146. #endif /*__KERNEL__*/
  147. #endif /*_ASM_ACPI_H*/