Blame view

include/acpi/platform/aclinux.h 5.54 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
  /******************************************************************************
   *
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
3
   * Name: aclinux.h - OS specific defines, etc. for Linux
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
4
5
6
7
   *
   *****************************************************************************/
  
  /*
b4e104eae   Bob Moore   ACPICA: Update al...
8
   * Copyright (C) 2000 - 2011, Intel Corp.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
   * All rights reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions, and the following disclaimer,
   *    without modification.
   * 2. Redistributions in binary form must reproduce at minimum a disclaimer
   *    substantially similar to the "NO WARRANTY" disclaimer below
   *    ("Disclaimer") and any redistribution must be conditioned upon
   *    including a substantially similar Disclaimer requirement for further
   *    binary redistribution.
   * 3. Neither the names of the above-listed copyright holders nor the names
   *    of any contributors may be used to endorse or promote products derived
   *    from this software without specific prior written permission.
   *
   * Alternatively, this software may be distributed under the terms of the
   * GNU General Public License ("GPL") version 2 as published by the Free
   * Software Foundation.
   *
   * NO WARRANTY
   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
   * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
   * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
   * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
   * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
   * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
   * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
   * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
   * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
   * POSSIBILITY OF SUCH DAMAGES.
   */
  
  #ifndef __ACLINUX_H__
  #define __ACLINUX_H__
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
46
  /* Common (in-kernel/user-space) ACPICA configuration */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
47
48
  #define ACPI_USE_SYSTEM_CLIBRARY
  #define ACPI_USE_DO_WHILE_0
1685bd404   Bob Moore   ACPICA: Add ACPI_...
49
  #define ACPI_MUTEX_TYPE             ACPI_BINARY_SEMAPHORE
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
50

e0c437bcc   Bob Moore   ACPICA: Linux OSL...
51

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
52
  #ifdef __KERNEL__
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
53
54
55
  #include <linux/string.h>
  #include <linux/kernel.h>
  #include <linux/ctype.h>
8bd108d14   Alexey Starikovskiy   ACPICA: add preem...
56
  #include <linux/sched.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
57
  #include <asm/system.h>
60063497a   Arun Sharma   atomic: use <linu...
58
  #include <linux/atomic.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
59
60
  #include <asm/div64.h>
  #include <asm/acpi.h>
8313524a0   Bob Moore   ACPI: ACPICA 2006...
61
  #include <linux/slab.h>
967440e3b   Bob Moore   ACPI: ACPICA 2006...
62
  #include <linux/spinlock_types.h>
ab8aa06a5   Len Brown   ACPI: acpi_os_get...
63
  #include <asm/current.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
64

e0c437bcc   Bob Moore   ACPICA: Linux OSL...
65
  /* Host-dependent types and defines for in-kernel ACPICA */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
66

8313524a0   Bob Moore   ACPI: ACPICA 2006...
67
  #define ACPI_MACHINE_WIDTH          BITS_PER_LONG
8313524a0   Bob Moore   ACPI: ACPICA 2006...
68
69
  #define ACPI_EXPORT_SYMBOL(symbol)  EXPORT_SYMBOL(symbol);
  #define strtoul                     simple_strtoul
73459f73e   Robert Moore   ACPICA 20050617-0...
70

e0c437bcc   Bob Moore   ACPICA: Linux OSL...
71
72
73
  #define acpi_cache_t                        struct kmem_cache
  #define acpi_spinlock                       spinlock_t *
  #define acpi_cpu_flags                      unsigned long
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
74
75
  
  #else /* !__KERNEL__ */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
76
77
78
79
80
81
  
  #include <stdarg.h>
  #include <string.h>
  #include <stdlib.h>
  #include <ctype.h>
  #include <unistd.h>
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
82
83
84
  /* Host-dependent types and defines for user-space ACPICA */
  
  #define ACPI_FLUSH_CPU_CACHE()
28eb3fcf8   Lin Ming   ACPICA: Make acpi...
85
  #define ACPI_CAST_PTHREAD_T(pthread) ((acpi_thread_id) (pthread))
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
86

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
87
88
89
90
91
92
93
94
95
96
  #if defined(__ia64__) || defined(__x86_64__)
  #define ACPI_MACHINE_WIDTH          64
  #define COMPILER_DEPENDENT_INT64    long
  #define COMPILER_DEPENDENT_UINT64   unsigned long
  #else
  #define ACPI_MACHINE_WIDTH          32
  #define COMPILER_DEPENDENT_INT64    long long
  #define COMPILER_DEPENDENT_UINT64   unsigned long long
  #define ACPI_USE_NATIVE_DIVIDE
  #endif
a0a3f6c69   Bob Moore   ACPICA: Changes f...
97
  #ifndef __cdecl
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
98
  #define __cdecl
a0a3f6c69   Bob Moore   ACPICA: Changes f...
99
  #endif
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
100
  #endif /* __KERNEL__ */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
101
102
103
104
  
  /* Linux uses GCC */
  
  #include "acgcc.h"
ec7381d6b   Len Brown   ACPI: inline triv...
105

e0c437bcc   Bob Moore   ACPICA: Linux OSL...
106
  #ifdef __KERNEL__
28eb3fcf8   Lin Ming   ACPICA: Make acpi...
107
  #include <acpi/actypes.h>
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
108
109
110
  /*
   * Overrides for in-kernel ACPICA
   */
fd3509436   Len Brown   ACPICA: Lindent
111
112
  static inline acpi_thread_id acpi_os_get_thread_id(void)
  {
28eb3fcf8   Lin Ming   ACPICA: Make acpi...
113
  	return (acpi_thread_id)(unsigned long)current;
fd3509436   Len Brown   ACPICA: Lindent
114
  }
ec7381d6b   Len Brown   ACPI: inline triv...
115

e21c1ca3f   Len Brown   ACPI: acpi_os_all...
116
117
118
119
120
121
  /*
   * The irqs_disabled() check is for resume from RAM.
   * Interrupts are off during resume, just like they are for boot.
   * However, boot has  (system_state != SYSTEM_RUNNING)
   * to quiet __might_sleep() in kmalloc() and resume does not.
   */
fd3509436   Len Brown   ACPICA: Lindent
122
123
  static inline void *acpi_os_allocate(acpi_size size)
  {
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
124
  	return kmalloc(size, irqs_disabled() ? GFP_ATOMIC : GFP_KERNEL);
e21c1ca3f   Len Brown   ACPI: acpi_os_all...
125
  }
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
126

fd3509436   Len Brown   ACPICA: Lindent
127
128
  static inline void *acpi_os_allocate_zeroed(acpi_size size)
  {
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
129
  	return kzalloc(size, irqs_disabled() ? GFP_ATOMIC : GFP_KERNEL);
e21c1ca3f   Len Brown   ACPI: acpi_os_all...
130
  }
fd3509436   Len Brown   ACPICA: Lindent
131
132
133
  static inline void *acpi_os_acquire_object(acpi_cache_t * cache)
  {
  	return kmem_cache_zalloc(cache,
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
134
  		irqs_disabled() ? GFP_ATOMIC : GFP_KERNEL);
e21c1ca3f   Len Brown   ACPI: acpi_os_all...
135
  }
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
136
137
138
  #define ACPI_ALLOCATE(a)        acpi_os_allocate(a)
  #define ACPI_ALLOCATE_ZEROED(a) acpi_os_allocate_zeroed(a)
  #define ACPI_FREE(a)            kfree(a)
e21c1ca3f   Len Brown   ACPI: acpi_os_all...
139

0a7992c90   Thomas Gleixner   acpi: fix bogus p...
140
141
142
143
144
  #ifndef CONFIG_PREEMPT
  /*
   * Used within ACPICA to show where it is safe to preempt execution
   * when CONFIG_PREEMPT=n
   */
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
145
146
  #define ACPI_PREEMPTION_POINT() \
  	do { \
0a7992c90   Thomas Gleixner   acpi: fix bogus p...
147
  		if (!irqs_disabled()) \
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
148
  			cond_resched(); \
abe1dfab6   Wu Fengguang   ACPI: don't cond_...
149
  	} while (0)
0a7992c90   Thomas Gleixner   acpi: fix bogus p...
150
  #endif
8bd108d14   Alexey Starikovskiy   ACPICA: add preem...
151

07e49a7a3   Rafael J. Wysocki   ACPI: Fix lockdep...
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
  /*
   * When lockdep is enabled, the spin_lock_init() macro stringifies it's
   * argument and uses that as a name for the lock in debugging.
   * By executing spin_lock_init() in a macro the key changes from "lock" for
   * all locks to the name of the argument of acpi_os_create_lock(), which
   * prevents lockdep from reporting false positives for ACPICA locks.
   */
  #define acpi_os_create_lock(__handle)				\
  ({								\
  	spinlock_t *lock = ACPI_ALLOCATE(sizeof(*lock));	\
  								\
  	if (lock) {						\
  		*(__handle) = lock;				\
  		spin_lock_init(*(__handle));			\
  	}							\
  	lock ? AE_OK : AE_NO_MEMORY;				\
  })
e0c437bcc   Bob Moore   ACPICA: Linux OSL...
169
170
171
  #endif /* __KERNEL__ */
  
  #endif /* __ACLINUX_H__ */