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