1
2
3
4
5
6
7
8
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#ifndef __ACTYPES_H__
45#define __ACTYPES_H__
46
47
48
49
50
51
52
53
54#ifndef ACPI_MACHINE_WIDTH
55#error ACPI_MACHINE_WIDTH not defined
56#endif
57
58
59
60
61
62
63
64#define ACPI_UINT8_MAX (u8) (~((u8) 0))
65#define ACPI_UINT16_MAX (u16)(~((u16) 0))
66#define ACPI_UINT32_MAX (u32)(~((u32) 0))
67#define ACPI_UINT64_MAX (u64)(~((u64) 0))
68#define ACPI_ASCII_MAX 0x7F
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124#ifndef ACPI_USE_SYSTEM_INTTYPES
125
126typedef unsigned char u8;
127typedef unsigned char u8;
128typedef unsigned short u16;
129typedef short s16;
130typedef COMPILER_DEPENDENT_UINT64 u64;
131typedef COMPILER_DEPENDENT_INT64 s64;
132
133#endif
134
135
136
137
138
139
140
141
142
143#define acpi_thread_id u64
144
145
146
147
148
149
150
151#if ACPI_MACHINE_WIDTH == 64
152
153#ifndef ACPI_USE_SYSTEM_INTTYPES
154
155typedef unsigned int u32;
156typedef int s32;
157
158#endif
159
160typedef s64 acpi_native_int;
161
162typedef u64 acpi_size;
163typedef u64 acpi_io_address;
164typedef u64 acpi_physical_address;
165
166#define ACPI_MAX_PTR ACPI_UINT64_MAX
167#define ACPI_SIZE_MAX ACPI_UINT64_MAX
168
169#define ACPI_USE_NATIVE_DIVIDE
170
171
172
173
174
175
176
177
178
179
180#if defined (__IA64__) || defined (__ia64__)
181#define ACPI_MISALIGNMENT_NOT_SUPPORTED
182#endif
183
184
185
186
187
188
189
190#elif ACPI_MACHINE_WIDTH == 32
191
192#ifndef ACPI_USE_SYSTEM_INTTYPES
193
194typedef unsigned int u32;
195typedef int s32;
196
197#endif
198
199typedef s32 acpi_native_int;
200
201typedef u32 acpi_size;
202typedef u32 acpi_io_address;
203typedef u32 acpi_physical_address;
204
205#define ACPI_MAX_PTR ACPI_UINT32_MAX
206#define ACPI_SIZE_MAX ACPI_UINT32_MAX
207
208#else
209
210
211
212#error unknown ACPI_MACHINE_WIDTH
213#endif
214
215
216
217
218
219
220
221
222
223
224
225
226#ifndef acpi_cpu_flags
227#define acpi_cpu_flags acpi_size
228#endif
229
230
231
232#ifndef acpi_cache_t
233#ifdef ACPI_USE_LOCAL_CACHE
234#define acpi_cache_t struct acpi_memory_list
235#else
236#define acpi_cache_t void *
237#endif
238#endif
239
240
241
242
243#if (ACPI_MUTEX_TYPE == ACPI_BINARY_SEMAPHORE)
244
245
246
247
248#define acpi_mutex acpi_semaphore
249#define acpi_os_create_mutex(out_handle) acpi_os_create_semaphore (1, 1, out_handle)
250#define acpi_os_delete_mutex(handle) (void) acpi_os_delete_semaphore (handle)
251#define acpi_os_acquire_mutex(handle,time) acpi_os_wait_semaphore (handle, 1, time)
252#define acpi_os_release_mutex(handle) (void) acpi_os_signal_semaphore (handle, 1)
253#endif
254
255
256
257#ifndef acpi_spinlock
258#define acpi_spinlock void *
259#endif
260
261#ifndef acpi_semaphore
262#define acpi_semaphore void *
263#endif
264
265#ifndef acpi_mutex
266#define acpi_mutex void *
267#endif
268
269
270
271
272
273
274
275
276
277
278
279
280#ifndef acpi_uintptr_t
281#define acpi_uintptr_t void *
282#endif
283
284
285
286
287
288#ifndef ACPI_PRINTF_LIKE
289#define ACPI_PRINTF_LIKE(c)
290#endif
291
292
293
294
295
296
297
298#ifndef ACPI_UNUSED_VAR
299#define ACPI_UNUSED_VAR
300#endif
301
302
303
304
305
306
307
308
309
310
311#ifndef ACPI_EXPORT_SYMBOL_INIT
312#define ACPI_EXPORT_SYMBOL_INIT(symbol)
313#endif
314
315#ifndef ACPI_EXPORT_SYMBOL
316#define ACPI_EXPORT_SYMBOL(symbol)
317#endif
318
319
320
321
322
323#ifndef ACPI_DEBUG_INITIALIZE
324#define ACPI_DEBUG_INITIALIZE()
325#endif
326
327
328
329
330
331
332
333#ifdef ACPI_NO_MEM_ALLOCATIONS
334
335#define ACPI_ALLOCATE(a) NULL
336#define ACPI_ALLOCATE_ZEROED(a) NULL
337#define ACPI_FREE(a)
338#define ACPI_MEM_TRACKING(a)
339
340#else
341
342#ifdef ACPI_DBG_TRACK_ALLOCATIONS
343
344
345
346#define ACPI_MEM_PARAMETERS _COMPONENT, _acpi_module_name, __LINE__
347#define ACPI_ALLOCATE(a) acpi_ut_allocate_and_track ((acpi_size) (a), ACPI_MEM_PARAMETERS)
348#define ACPI_ALLOCATE_ZEROED(a) acpi_ut_allocate_zeroed_and_track ((acpi_size) (a), ACPI_MEM_PARAMETERS)
349#define ACPI_FREE(a) acpi_ut_free_and_track (a, ACPI_MEM_PARAMETERS)
350#define ACPI_MEM_TRACKING(a) a
351
352#else
353
354
355
356#define ACPI_ALLOCATE(a) acpi_os_allocate ((acpi_size) (a))
357#define ACPI_ALLOCATE_ZEROED(a) acpi_os_allocate_zeroed ((acpi_size) (a))
358#define ACPI_FREE(a) acpi_os_free (a)
359#define ACPI_MEM_TRACKING(a)
360
361#endif
362
363#endif
364
365
366
367
368
369
370
371
372
373#define ACPI_MAX_GPE_BLOCKS 2
374
375
376
377#define ACPI_GPE_REGISTER_WIDTH 8
378#define ACPI_PM1_REGISTER_WIDTH 16
379#define ACPI_PM2_REGISTER_WIDTH 8
380#define ACPI_PM_TIMER_WIDTH 32
381#define ACPI_RESET_REGISTER_WIDTH 8
382
383
384
385#define ACPI_NAME_SIZE 4
386#define ACPI_PATH_SEGMENT_LENGTH 5
387#define ACPI_PATH_SEPARATOR '.'
388
389
390
391#define ACPI_OEM_ID_SIZE 6
392#define ACPI_OEM_TABLE_ID_SIZE 8
393
394
395
396#define PCI_ROOT_HID_STRING "PNP0A03"
397#define PCI_EXPRESS_ROOT_HID_STRING "PNP0A08"
398
399
400
401#define ACPI_PM_TIMER_FREQUENCY 3579545
402
403
404
405
406
407
408
409
410
411#ifdef FALSE
412#undef FALSE
413#endif
414#define FALSE (1 == 0)
415
416#ifdef TRUE
417#undef TRUE
418#endif
419#define TRUE (1 == 1)
420
421#ifndef NULL
422#define NULL (void *) 0
423#endif
424
425
426
427
428typedef u32 acpi_status;
429typedef u32 acpi_name;
430typedef char *acpi_string;
431typedef void *acpi_handle;
432
433
434
435#define ACPI_MSEC_PER_SEC 1000L
436
437#define ACPI_USEC_PER_MSEC 1000L
438#define ACPI_USEC_PER_SEC 1000000L
439
440#define ACPI_100NSEC_PER_USEC 10L
441#define ACPI_100NSEC_PER_MSEC 10000L
442#define ACPI_100NSEC_PER_SEC 10000000L
443
444#define ACPI_NSEC_PER_USEC 1000L
445#define ACPI_NSEC_PER_MSEC 1000000L
446#define ACPI_NSEC_PER_SEC 1000000000L
447
448
449
450typedef u8 acpi_owner_id;
451#define ACPI_OWNER_ID_MAX 0xFF
452
453#define ACPI_INTEGER_BIT_SIZE 64
454#define ACPI_MAX_DECIMAL_DIGITS 20
455
456#if ACPI_MACHINE_WIDTH == 64
457#define ACPI_USE_NATIVE_DIVIDE
458#endif
459
460#define ACPI_MAX64_DECIMAL_DIGITS 20
461#define ACPI_MAX32_DECIMAL_DIGITS 10
462#define ACPI_MAX16_DECIMAL_DIGITS 5
463#define ACPI_MAX8_DECIMAL_DIGITS 3
464
465
466
467
468#define ACPI_ROOT_OBJECT ACPI_ADD_PTR (acpi_handle, NULL, ACPI_MAX_PTR)
469#define ACPI_WAIT_FOREVER 0xFFFF
470#define ACPI_DO_NOT_WAIT 0
471
472
473
474
475
476
477
478
479
480
481
482typedef u64 acpi_integer;
483#define ACPI_INTEGER_MAX ACPI_UINT64_MAX
484
485
486
487
488
489
490
491
492
493#define ACPI_LOBYTE(integer) ((u8) (u16)(integer))
494#define ACPI_HIBYTE(integer) ((u8) (((u16)(integer)) >> 8))
495#define ACPI_LOWORD(integer) ((u16) (u32)(integer))
496#define ACPI_HIWORD(integer) ((u16)(((u32)(integer)) >> 16))
497#define ACPI_LODWORD(integer64) ((u32) (u64)(integer64))
498#define ACPI_HIDWORD(integer64) ((u32)(((u64)(integer64)) >> 32))
499
500#define ACPI_SET_BIT(target,bit) ((target) |= (bit))
501#define ACPI_CLEAR_BIT(target,bit) ((target) &= ~(bit))
502#define ACPI_MIN(a,b) (((a)<(b))?(a):(b))
503#define ACPI_MAX(a,b) (((a)>(b))?(a):(b))
504
505
506
507#define ACPI_ARRAY_LENGTH(x) (sizeof(x) / sizeof((x)[0]))
508
509
510
511#define ACPI_CAST_PTR(t, p) ((t *) (acpi_uintptr_t) (p))
512#define ACPI_CAST_INDIRECT_PTR(t, p) ((t **) (acpi_uintptr_t) (p))
513#define ACPI_ADD_PTR(t, a, b) ACPI_CAST_PTR (t, (ACPI_CAST_PTR (u8, (a)) + (acpi_size)(b)))
514#define ACPI_PTR_DIFF(a, b) (acpi_size) (ACPI_CAST_PTR (u8, (a)) - ACPI_CAST_PTR (u8, (b)))
515
516
517
518#define ACPI_TO_POINTER(i) ACPI_ADD_PTR (void, (void *) NULL,(acpi_size) i)
519#define ACPI_TO_INTEGER(p) ACPI_PTR_DIFF (p, (void *) NULL)
520#define ACPI_OFFSET(d, f) ACPI_PTR_DIFF (&(((d *) 0)->f), (void *) NULL)
521#define ACPI_PHYSADDR_TO_PTR(i) ACPI_TO_POINTER(i)
522#define ACPI_PTR_TO_PHYSADDR(i) ACPI_TO_INTEGER(i)
523
524
525
526#ifndef ACPI_MISALIGNMENT_NOT_SUPPORTED
527#define ACPI_COMPARE_NAME(a,b) (*ACPI_CAST_PTR (u32, (a)) == *ACPI_CAST_PTR (u32, (b)))
528#define ACPI_MOVE_NAME(dest,src) (*ACPI_CAST_PTR (u32, (dest)) = *ACPI_CAST_PTR (u32, (src)))
529#else
530#define ACPI_COMPARE_NAME(a,b) (!ACPI_STRNCMP (ACPI_CAST_PTR (char, (a)), ACPI_CAST_PTR (char, (b)), ACPI_NAME_SIZE))
531#define ACPI_MOVE_NAME(dest,src) (ACPI_STRNCPY (ACPI_CAST_PTR (char, (dest)), ACPI_CAST_PTR (char, (src)), ACPI_NAME_SIZE))
532#endif
533
534
535
536#define ACPI_VALIDATE_RSDP_SIG(a) (!ACPI_STRNCMP (ACPI_CAST_PTR (char, (a)), ACPI_SIG_RSDP, 8))
537#define ACPI_MAKE_RSDP_SIG(dest) (ACPI_MEMCPY (ACPI_CAST_PTR (char, (dest)), ACPI_SIG_RSDP, 8))
538
539
540
541
542
543
544
545
546
547
548#define ACPI_FULL_INITIALIZATION 0x00
549#define ACPI_NO_ADDRESS_SPACE_INIT 0x01
550#define ACPI_NO_HARDWARE_INIT 0x02
551#define ACPI_NO_EVENT_INIT 0x04
552#define ACPI_NO_HANDLER_INIT 0x08
553#define ACPI_NO_ACPI_ENABLE 0x10
554#define ACPI_NO_DEVICE_INIT 0x20
555#define ACPI_NO_OBJECT_INIT 0x40
556
557
558
559
560#define ACPI_SUBSYSTEM_INITIALIZE 0x01
561#define ACPI_INITIALIZED_OK 0x02
562
563
564
565
566#define ACPI_STATE_UNKNOWN (u8) 0xFF
567
568#define ACPI_STATE_S0 (u8) 0
569#define ACPI_STATE_S1 (u8) 1
570#define ACPI_STATE_S2 (u8) 2
571#define ACPI_STATE_S3 (u8) 3
572#define ACPI_STATE_S4 (u8) 4
573#define ACPI_STATE_S5 (u8) 5
574#define ACPI_S_STATES_MAX ACPI_STATE_S5
575#define ACPI_S_STATE_COUNT 6
576
577#define ACPI_STATE_D0 (u8) 0
578#define ACPI_STATE_D1 (u8) 1
579#define ACPI_STATE_D2 (u8) 2
580#define ACPI_STATE_D3_HOT (u8) 3
581#define ACPI_STATE_D3 (u8) 4
582#define ACPI_STATE_D3_COLD ACPI_STATE_D3
583#define ACPI_D_STATES_MAX ACPI_STATE_D3
584#define ACPI_D_STATE_COUNT 5
585
586#define ACPI_STATE_C0 (u8) 0
587#define ACPI_STATE_C1 (u8) 1
588#define ACPI_STATE_C2 (u8) 2
589#define ACPI_STATE_C3 (u8) 3
590#define ACPI_C_STATES_MAX ACPI_STATE_C3
591#define ACPI_C_STATE_COUNT 4
592
593
594
595
596#define ACPI_SLEEP_TYPE_MAX 0x7
597#define ACPI_SLEEP_TYPE_INVALID 0xFF
598
599
600
601
602#define ACPI_NOTIFY_BUS_CHECK (u8) 0x00
603#define ACPI_NOTIFY_DEVICE_CHECK (u8) 0x01
604#define ACPI_NOTIFY_DEVICE_WAKE (u8) 0x02
605#define ACPI_NOTIFY_EJECT_REQUEST (u8) 0x03
606#define ACPI_NOTIFY_DEVICE_CHECK_LIGHT (u8) 0x04
607#define ACPI_NOTIFY_FREQUENCY_MISMATCH (u8) 0x05
608#define ACPI_NOTIFY_BUS_MODE_MISMATCH (u8) 0x06
609#define ACPI_NOTIFY_POWER_FAULT (u8) 0x07
610#define ACPI_NOTIFY_CAPABILITIES_CHECK (u8) 0x08
611#define ACPI_NOTIFY_DEVICE_PLD_CHECK (u8) 0x09
612#define ACPI_NOTIFY_RESERVED (u8) 0x0A
613#define ACPI_NOTIFY_LOCALITY_UPDATE (u8) 0x0B
614#define ACPI_NOTIFY_SHUTDOWN_REQUEST (u8) 0x0C
615#define ACPI_NOTIFY_AFFINITY_UPDATE (u8) 0x0D
616
617#define ACPI_NOTIFY_MAX 0x0D
618
619
620
621
622
623
624
625
626
627
628typedef u32 acpi_object_type;
629
630#define ACPI_TYPE_ANY 0x00
631#define ACPI_TYPE_INTEGER 0x01
632#define ACPI_TYPE_STRING 0x02
633#define ACPI_TYPE_BUFFER 0x03
634#define ACPI_TYPE_PACKAGE 0x04
635#define ACPI_TYPE_FIELD_UNIT 0x05
636#define ACPI_TYPE_DEVICE 0x06
637#define ACPI_TYPE_EVENT 0x07
638#define ACPI_TYPE_METHOD 0x08
639#define ACPI_TYPE_MUTEX 0x09
640#define ACPI_TYPE_REGION 0x0A
641#define ACPI_TYPE_POWER 0x0B
642#define ACPI_TYPE_PROCESSOR 0x0C
643#define ACPI_TYPE_THERMAL 0x0D
644#define ACPI_TYPE_BUFFER_FIELD 0x0E
645#define ACPI_TYPE_DDB_HANDLE 0x0F
646#define ACPI_TYPE_DEBUG_OBJECT 0x10
647
648#define ACPI_TYPE_EXTERNAL_MAX 0x10
649
650
651
652
653
654
655
656
657#define ACPI_TYPE_LOCAL_REGION_FIELD 0x11
658#define ACPI_TYPE_LOCAL_BANK_FIELD 0x12
659#define ACPI_TYPE_LOCAL_INDEX_FIELD 0x13
660#define ACPI_TYPE_LOCAL_REFERENCE 0x14
661#define ACPI_TYPE_LOCAL_ALIAS 0x15
662#define ACPI_TYPE_LOCAL_METHOD_ALIAS 0x16
663#define ACPI_TYPE_LOCAL_NOTIFY 0x17
664#define ACPI_TYPE_LOCAL_ADDRESS_HANDLER 0x18
665#define ACPI_TYPE_LOCAL_RESOURCE 0x19
666#define ACPI_TYPE_LOCAL_RESOURCE_FIELD 0x1A
667#define ACPI_TYPE_LOCAL_SCOPE 0x1B
668
669#define ACPI_TYPE_NS_NODE_MAX 0x1B
670
671
672
673
674
675#define ACPI_TYPE_LOCAL_EXTRA 0x1C
676#define ACPI_TYPE_LOCAL_DATA 0x1D
677
678#define ACPI_TYPE_LOCAL_MAX 0x1D
679
680
681
682#define ACPI_TYPE_INVALID 0x1E
683#define ACPI_TYPE_NOT_FOUND 0xFF
684
685#define ACPI_NUM_NS_TYPES (ACPI_TYPE_INVALID + 1)
686
687
688
689
690#define ACPI_READ 0
691#define ACPI_WRITE 1
692#define ACPI_IO_MASK 1
693
694
695
696
697typedef u32 acpi_event_type;
698
699
700
701
702#define ACPI_EVENT_PMTIMER 0
703#define ACPI_EVENT_GLOBAL 1
704#define ACPI_EVENT_POWER_BUTTON 2
705#define ACPI_EVENT_SLEEP_BUTTON 3
706#define ACPI_EVENT_RTC 4
707#define ACPI_EVENT_MAX 4
708#define ACPI_NUM_FIXED_EVENTS ACPI_EVENT_MAX + 1
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726typedef u32 acpi_event_status;
727
728#define ACPI_EVENT_FLAG_DISABLED (acpi_event_status) 0x00
729#define ACPI_EVENT_FLAG_ENABLED (acpi_event_status) 0x01
730#define ACPI_EVENT_FLAG_WAKE_ENABLED (acpi_event_status) 0x02
731#define ACPI_EVENT_FLAG_SET (acpi_event_status) 0x04
732#define ACPI_EVENT_FLAG_HAS_HANDLER (acpi_event_status) 0x08
733
734
735
736#define ACPI_GPE_ENABLE 0
737#define ACPI_GPE_DISABLE 1
738#define ACPI_GPE_CONDITIONAL_ENABLE 2
739#define ACPI_GPE_SAVE_MASK 4
740
741#define ACPI_GPE_ENABLE_SAVE (ACPI_GPE_ENABLE | ACPI_GPE_SAVE_MASK)
742#define ACPI_GPE_DISABLE_SAVE (ACPI_GPE_DISABLE | ACPI_GPE_SAVE_MASK)
743
744
745
746
747
748
749
750
751
752
753
754
755#define ACPI_GPE_DISPATCH_NONE (u8) 0x00
756#define ACPI_GPE_DISPATCH_METHOD (u8) 0x01
757#define ACPI_GPE_DISPATCH_HANDLER (u8) 0x02
758#define ACPI_GPE_DISPATCH_NOTIFY (u8) 0x03
759#define ACPI_GPE_DISPATCH_RAW_HANDLER (u8) 0x04
760#define ACPI_GPE_DISPATCH_MASK (u8) 0x07
761#define ACPI_GPE_DISPATCH_TYPE(flags) ((u8) ((flags) & ACPI_GPE_DISPATCH_MASK))
762
763#define ACPI_GPE_LEVEL_TRIGGERED (u8) 0x08
764#define ACPI_GPE_EDGE_TRIGGERED (u8) 0x00
765#define ACPI_GPE_XRUPT_TYPE_MASK (u8) 0x08
766
767#define ACPI_GPE_CAN_WAKE (u8) 0x10
768
769
770
771
772#define ACPI_NOT_ISR 0x1
773#define ACPI_ISR 0x0
774
775
776
777#define ACPI_SYSTEM_NOTIFY 0x1
778#define ACPI_DEVICE_NOTIFY 0x2
779#define ACPI_ALL_NOTIFY (ACPI_SYSTEM_NOTIFY | ACPI_DEVICE_NOTIFY)
780#define ACPI_MAX_NOTIFY_HANDLER_TYPE 0x3
781#define ACPI_NUM_NOTIFY_TYPES 2
782
783#define ACPI_MAX_SYS_NOTIFY 0x7F
784#define ACPI_MAX_DEVICE_SPECIFIC_NOTIFY 0xBF
785
786#define ACPI_SYSTEM_HANDLER_LIST 0
787#define ACPI_DEVICE_HANDLER_LIST 1
788
789
790
791typedef u8 acpi_adr_space_type;
792
793#define ACPI_ADR_SPACE_SYSTEM_MEMORY (acpi_adr_space_type) 0
794#define ACPI_ADR_SPACE_SYSTEM_IO (acpi_adr_space_type) 1
795#define ACPI_ADR_SPACE_PCI_CONFIG (acpi_adr_space_type) 2
796#define ACPI_ADR_SPACE_EC (acpi_adr_space_type) 3
797#define ACPI_ADR_SPACE_SMBUS (acpi_adr_space_type) 4
798#define ACPI_ADR_SPACE_CMOS (acpi_adr_space_type) 5
799#define ACPI_ADR_SPACE_PCI_BAR_TARGET (acpi_adr_space_type) 6
800#define ACPI_ADR_SPACE_IPMI (acpi_adr_space_type) 7
801#define ACPI_ADR_SPACE_GPIO (acpi_adr_space_type) 8
802#define ACPI_ADR_SPACE_GSBUS (acpi_adr_space_type) 9
803#define ACPI_ADR_SPACE_PLATFORM_COMM (acpi_adr_space_type) 10
804
805#define ACPI_NUM_PREDEFINED_REGIONS 11
806
807
808
809
810
811
812
813
814
815#define ACPI_ADR_SPACE_DATA_TABLE (acpi_adr_space_type) 0x7E
816#define ACPI_ADR_SPACE_FIXED_HARDWARE (acpi_adr_space_type) 0x7F
817
818
819
820#define ACPI_REG_DISCONNECT 0
821#define ACPI_REG_CONNECT 1
822
823
824
825
826
827
828
829
830
831
832
833
834#define ACPI_BITREG_TIMER_STATUS 0x00
835#define ACPI_BITREG_BUS_MASTER_STATUS 0x01
836#define ACPI_BITREG_GLOBAL_LOCK_STATUS 0x02
837#define ACPI_BITREG_POWER_BUTTON_STATUS 0x03
838#define ACPI_BITREG_SLEEP_BUTTON_STATUS 0x04
839#define ACPI_BITREG_RT_CLOCK_STATUS 0x05
840#define ACPI_BITREG_WAKE_STATUS 0x06
841#define ACPI_BITREG_PCIEXP_WAKE_STATUS 0x07
842
843
844
845#define ACPI_BITREG_TIMER_ENABLE 0x08
846#define ACPI_BITREG_GLOBAL_LOCK_ENABLE 0x09
847#define ACPI_BITREG_POWER_BUTTON_ENABLE 0x0A
848#define ACPI_BITREG_SLEEP_BUTTON_ENABLE 0x0B
849#define ACPI_BITREG_RT_CLOCK_ENABLE 0x0C
850#define ACPI_BITREG_PCIEXP_WAKE_DISABLE 0x0D
851
852
853
854#define ACPI_BITREG_SCI_ENABLE 0x0E
855#define ACPI_BITREG_BUS_MASTER_RLD 0x0F
856#define ACPI_BITREG_GLOBAL_LOCK_RELEASE 0x10
857#define ACPI_BITREG_SLEEP_TYPE 0x11
858#define ACPI_BITREG_SLEEP_ENABLE 0x12
859
860
861
862#define ACPI_BITREG_ARB_DISABLE 0x13
863
864#define ACPI_BITREG_MAX 0x13
865#define ACPI_NUM_BITREG ACPI_BITREG_MAX + 1
866
867
868
869#define ACPI_CLEAR_STATUS 1
870
871
872
873#define ACPI_ENABLE_EVENT 1
874#define ACPI_DISABLE_EVENT 0
875
876
877
878typedef acpi_status(*acpi_sleep_function) (u8 sleep_state);
879
880struct acpi_sleep_functions {
881 acpi_sleep_function legacy_function;
882 acpi_sleep_function extended_function;
883};
884
885
886
887
888
889
890
891
892
893union acpi_object {
894 acpi_object_type type;
895 struct {
896 acpi_object_type type;
897 u64 value;
898 } integer;
899
900 struct {
901 acpi_object_type type;
902 u32 length;
903 char *pointer;
904 } string;
905
906 struct {
907 acpi_object_type type;
908 u32 length;
909 u8 *pointer;
910 } buffer;
911
912 struct {
913 acpi_object_type type;
914 u32 count;
915 union acpi_object *elements;
916 } package;
917
918 struct {
919 acpi_object_type type;
920 acpi_object_type actual_type;
921 acpi_handle handle;
922 } reference;
923
924 struct {
925 acpi_object_type type;
926 u32 proc_id;
927 acpi_io_address pblk_address;
928 u32 pblk_length;
929 } processor;
930
931 struct {
932 acpi_object_type type;
933 u32 system_level;
934 u32 resource_order;
935 } power_resource;
936};
937
938
939
940
941struct acpi_object_list {
942 u32 count;
943 union acpi_object *pointer;
944};
945
946
947
948
949#define ACPI_NO_BUFFER 0
950
951#ifdef ACPI_NO_MEM_ALLOCATIONS
952
953#define ACPI_ALLOCATE_BUFFER (acpi_size) (0)
954#define ACPI_ALLOCATE_LOCAL_BUFFER (acpi_size) (0)
955
956#else
957
958#define ACPI_ALLOCATE_BUFFER (acpi_size) (-1)
959#define ACPI_ALLOCATE_LOCAL_BUFFER (acpi_size) (-2)
960
961#endif
962
963struct acpi_buffer {
964 acpi_size length;
965 void *pointer;
966};
967
968
969
970
971#define ACPI_FULL_PATHNAME 0
972#define ACPI_SINGLE_NAME 1
973#define ACPI_NAME_TYPE_MAX 1
974
975
976
977
978struct acpi_predefined_names {
979 char *name;
980 u8 type;
981 char *val;
982};
983
984
985
986
987#define ACPI_SYS_MODE_UNKNOWN 0x0000
988#define ACPI_SYS_MODE_ACPI 0x0001
989#define ACPI_SYS_MODE_LEGACY 0x0002
990#define ACPI_SYS_MODES_MASK 0x0003
991
992
993
994
995struct acpi_system_info {
996 u32 acpi_ca_version;
997 u32 flags;
998 u32 timer_resolution;
999 u32 reserved1;
1000 u32 reserved2;
1001 u32 debug_level;
1002 u32 debug_layer;
1003};
1004
1005
1006
1007
1008struct acpi_statistics {
1009 u32 sci_count;
1010 u32 gpe_count;
1011 u32 fixed_event_count[ACPI_NUM_FIXED_EVENTS];
1012 u32 method_count;
1013};
1014
1015
1016
1017#define ACPI_TABLE_EVENT_LOAD 0x0
1018#define ACPI_TABLE_EVENT_UNLOAD 0x1
1019#define ACPI_NUM_TABLE_EVENTS 2
1020
1021
1022
1023
1024typedef u32
1025 (ACPI_SYSTEM_XFACE * acpi_osd_handler) (void *context);
1026
1027typedef void
1028 (ACPI_SYSTEM_XFACE * acpi_osd_exec_callback) (void *context);
1029
1030
1031
1032
1033typedef
1034u32 (*acpi_sci_handler) (void *context);
1035
1036typedef
1037void (*acpi_gbl_event_handler) (u32 event_type,
1038 acpi_handle device,
1039 u32 event_number, void *context);
1040
1041#define ACPI_EVENT_TYPE_GPE 0
1042#define ACPI_EVENT_TYPE_FIXED 1
1043
1044typedef
1045u32(*acpi_event_handler) (void *context);
1046
1047typedef
1048u32 (*acpi_gpe_handler) (acpi_handle gpe_device, u32 gpe_number, void *context);
1049
1050typedef
1051void (*acpi_notify_handler) (acpi_handle device, u32 value, void *context);
1052
1053typedef
1054void (*acpi_object_handler) (acpi_handle object, void *data);
1055
1056typedef acpi_status(*acpi_init_handler) (acpi_handle object, u32 function);
1057
1058#define ACPI_INIT_DEVICE_INI 1
1059
1060typedef
1061acpi_status(*acpi_exception_handler) (acpi_status aml_status,
1062 acpi_name name,
1063 u16 opcode,
1064 u32 aml_offset, void *context);
1065
1066
1067
1068typedef
1069acpi_status(*acpi_table_handler) (u32 event, void *table, void *context);
1070
1071#define ACPI_TABLE_LOAD 0x0
1072#define ACPI_TABLE_UNLOAD 0x1
1073#define ACPI_NUM_TABLE_EVENTS 2
1074
1075
1076
1077typedef
1078acpi_status(*acpi_adr_space_handler) (u32 function,
1079 acpi_physical_address address,
1080 u32 bit_width,
1081 u64 *value,
1082 void *handler_context,
1083 void *region_context);
1084
1085#define ACPI_DEFAULT_HANDLER NULL
1086
1087
1088
1089struct acpi_connection_info {
1090 u8 *connection;
1091 u16 length;
1092 u8 access_length;
1093};
1094
1095typedef
1096acpi_status(*acpi_adr_space_setup) (acpi_handle region_handle,
1097 u32 function,
1098 void *handler_context,
1099 void **region_context);
1100
1101#define ACPI_REGION_ACTIVATE 0
1102#define ACPI_REGION_DEACTIVATE 1
1103
1104typedef
1105acpi_status(*acpi_walk_callback) (acpi_handle object,
1106 u32 nesting_level,
1107 void *context, void **return_value);
1108
1109typedef
1110u32 (*acpi_interface_handler) (acpi_string interface_name, u32 supported);
1111
1112
1113
1114#define ACPI_INTERRUPT_NOT_HANDLED 0x00
1115#define ACPI_INTERRUPT_HANDLED 0x01
1116
1117
1118
1119#define ACPI_REENABLE_GPE 0x80
1120
1121
1122
1123#define ACPI_EISAID_STRING_SIZE 8
1124
1125
1126
1127#define ACPI_UUID_LENGTH 16
1128
1129
1130
1131struct acpi_pnp_device_id {
1132 u32 length;
1133 char *string;
1134};
1135
1136struct acpi_pnp_device_id_list {
1137 u32 count;
1138 u32 list_size;
1139 struct acpi_pnp_device_id ids[1];
1140};
1141
1142
1143
1144
1145
1146struct acpi_device_info {
1147 u32 info_size;
1148 u32 name;
1149 acpi_object_type type;
1150 u8 param_count;
1151 u8 valid;
1152 u8 flags;
1153 u8 highest_dstates[4];
1154 u8 lowest_dstates[5];
1155 u32 current_status;
1156 u64 address;
1157 struct acpi_pnp_device_id hardware_id;
1158 struct acpi_pnp_device_id unique_id;
1159 struct acpi_pnp_device_id subsystem_id;
1160 struct acpi_pnp_device_id_list compatible_id_list;
1161};
1162
1163
1164
1165#define ACPI_PCI_ROOT_BRIDGE 0x01
1166
1167
1168
1169#define ACPI_VALID_STA 0x01
1170#define ACPI_VALID_ADR 0x02
1171#define ACPI_VALID_HID 0x04
1172#define ACPI_VALID_UID 0x08
1173#define ACPI_VALID_SUB 0x10
1174#define ACPI_VALID_CID 0x20
1175#define ACPI_VALID_SXDS 0x40
1176#define ACPI_VALID_SXWS 0x80
1177
1178
1179
1180#define ACPI_STA_DEVICE_PRESENT 0x01
1181#define ACPI_STA_DEVICE_ENABLED 0x02
1182#define ACPI_STA_DEVICE_UI 0x04
1183#define ACPI_STA_DEVICE_FUNCTIONING 0x08
1184#define ACPI_STA_DEVICE_OK 0x08
1185#define ACPI_STA_BATTERY_PRESENT 0x10
1186
1187
1188
1189struct acpi_pci_id {
1190 u16 segment;
1191 u16 bus;
1192 u16 device;
1193 u16 function;
1194};
1195
1196struct acpi_mem_space_context {
1197 u32 length;
1198 acpi_physical_address address;
1199 acpi_physical_address mapped_physical_address;
1200 u8 *mapped_logical_address;
1201 acpi_size mapped_length;
1202};
1203
1204
1205
1206
1207struct acpi_memory_list {
1208 char *list_name;
1209 void *list_head;
1210 u16 object_size;
1211 u16 max_depth;
1212 u16 current_depth;
1213
1214#ifdef ACPI_DBG_TRACK_ALLOCATIONS
1215
1216
1217
1218 u32 total_allocated;
1219 u32 total_freed;
1220 u32 max_occupied;
1221 u32 total_size;
1222 u32 current_total_size;
1223 u32 requests;
1224 u32 hits;
1225#endif
1226};
1227
1228
1229
1230#define ACPI_VENDOR_STRINGS 0x01
1231#define ACPI_FEATURE_STRINGS 0x02
1232#define ACPI_ENABLE_INTERFACES 0x00
1233#define ACPI_DISABLE_INTERFACES 0x04
1234
1235#define ACPI_DISABLE_ALL_VENDOR_STRINGS (ACPI_DISABLE_INTERFACES | ACPI_VENDOR_STRINGS)
1236#define ACPI_DISABLE_ALL_FEATURE_STRINGS (ACPI_DISABLE_INTERFACES | ACPI_FEATURE_STRINGS)
1237#define ACPI_DISABLE_ALL_STRINGS (ACPI_DISABLE_INTERFACES | ACPI_VENDOR_STRINGS | ACPI_FEATURE_STRINGS)
1238#define ACPI_ENABLE_ALL_VENDOR_STRINGS (ACPI_ENABLE_INTERFACES | ACPI_VENDOR_STRINGS)
1239#define ACPI_ENABLE_ALL_FEATURE_STRINGS (ACPI_ENABLE_INTERFACES | ACPI_FEATURE_STRINGS)
1240#define ACPI_ENABLE_ALL_STRINGS (ACPI_ENABLE_INTERFACES | ACPI_VENDOR_STRINGS | ACPI_FEATURE_STRINGS)
1241
1242#define ACPI_OSI_WIN_2000 0x01
1243#define ACPI_OSI_WIN_XP 0x02
1244#define ACPI_OSI_WIN_XP_SP1 0x03
1245#define ACPI_OSI_WINSRV_2003 0x04
1246#define ACPI_OSI_WIN_XP_SP2 0x05
1247#define ACPI_OSI_WINSRV_2003_SP1 0x06
1248#define ACPI_OSI_WIN_VISTA 0x07
1249#define ACPI_OSI_WINSRV_2008 0x08
1250#define ACPI_OSI_WIN_VISTA_SP1 0x09
1251#define ACPI_OSI_WIN_VISTA_SP2 0x0A
1252#define ACPI_OSI_WIN_7 0x0B
1253#define ACPI_OSI_WIN_8 0x0C
1254
1255
1256
1257#define ACPI_FILE_READING 0x01
1258#define ACPI_FILE_WRITING 0x02
1259#define ACPI_FILE_BINARY 0x04
1260
1261#define ACPI_FILE_BEGIN 0x01
1262#define ACPI_FILE_END 0x02
1263
1264
1265
1266#define ACPI_OPT_END -1
1267
1268#endif
1269