xref: /titanic_52/usr/src/uts/intel/sys/acpica.h (revision 0e7515250c8395f368aa45fb9acae7c4f8f8b786)
17c478bd9Sstevel@tonic-gate /*
28e56767dSsmall  * CDDL HEADER START
38e56767dSsmall  *
48e56767dSsmall  * The contents of this file are subject to the terms of the
59e26e16fSrs90106  * Common Development and Distribution License (the "License").
69e26e16fSrs90106  * You may not use this file except in compliance with the License.
78e56767dSsmall  *
88e56767dSsmall  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
98e56767dSsmall  * or http://www.opensolaris.org/os/licensing.
108e56767dSsmall  * See the License for the specific language governing permissions
118e56767dSsmall  * and limitations under the License.
128e56767dSsmall  *
138e56767dSsmall  * When distributing Covered Code, include this CDDL HEADER in each
148e56767dSsmall  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
158e56767dSsmall  * If applicable, add the following below this CDDL HEADER, with the
168e56767dSsmall  * fields enclosed by brackets "[]" replaced with your own identifying
178e56767dSsmall  * information: Portions Copyright [yyyy] [name of copyright owner]
188e56767dSsmall  *
198e56767dSsmall  * CDDL HEADER END
208e56767dSsmall  */
218e56767dSsmall /*
22*0e751525SEric Saxe  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
237c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
247c478bd9Sstevel@tonic-gate  */
257c478bd9Sstevel@tonic-gate 
267c478bd9Sstevel@tonic-gate #ifndef _SYS_ACPICA_H
277c478bd9Sstevel@tonic-gate #define	_SYS_ACPICA_H
287c478bd9Sstevel@tonic-gate 
297c478bd9Sstevel@tonic-gate #ifdef __cplusplus
307c478bd9Sstevel@tonic-gate extern "C" {
317c478bd9Sstevel@tonic-gate #endif
327c478bd9Sstevel@tonic-gate 
337c478bd9Sstevel@tonic-gate typedef struct {
347c478bd9Sstevel@tonic-gate 	dev_info_t		*dip;
357c478bd9Sstevel@tonic-gate 	kmutex_t		mutex;
367c478bd9Sstevel@tonic-gate 	ddi_iblock_cookie_t	iblock_cookie;
377c478bd9Sstevel@tonic-gate } AcpiCA;
387c478bd9Sstevel@tonic-gate 
397c478bd9Sstevel@tonic-gate /* acpi-user-options options property */
407c478bd9Sstevel@tonic-gate extern unsigned int acpi_options_prop;
417c478bd9Sstevel@tonic-gate #define	ACPI_OUSER_MASK		0x0003
427c478bd9Sstevel@tonic-gate #define	ACPI_OUSER_DFLT		0x0000
437c478bd9Sstevel@tonic-gate #define	ACPI_OUSER_ON		0x0001
447c478bd9Sstevel@tonic-gate #define	ACPI_OUSER_OFF		0x0002
457c478bd9Sstevel@tonic-gate #define	ACPI_OUSER_MADT		0x0004
467c478bd9Sstevel@tonic-gate #define	ACPI_OUSER_LEGACY	0x0008
477c478bd9Sstevel@tonic-gate 
487c478bd9Sstevel@tonic-gate 
497c478bd9Sstevel@tonic-gate /*
507c478bd9Sstevel@tonic-gate  * Initialization state of the ACPI CA subsystem
517c478bd9Sstevel@tonic-gate  */
527c478bd9Sstevel@tonic-gate #define	ACPICA_NOT_INITIALIZED	(0)
537c478bd9Sstevel@tonic-gate #define	ACPICA_INITIALIZED	(1)
547c478bd9Sstevel@tonic-gate 
557c478bd9Sstevel@tonic-gate extern int acpica_init(void);
567c478bd9Sstevel@tonic-gate extern void acpica_ec_init(void);
577c478bd9Sstevel@tonic-gate 
58f7534bc1Ssmall /*
59f7534bc1Ssmall  * acpi_status property values
60f7534bc1Ssmall  */
61f7534bc1Ssmall #define	ACPI_BOOT_INIT		0x00000001
62f7534bc1Ssmall #define	ACPI_BOOT_ENABLE	0x00000002
63f7534bc1Ssmall #define	ACPI_BOOT_BOOTCONF	0x00000010
64f7534bc1Ssmall 
657c478bd9Sstevel@tonic-gate #define	SCI_IPL	(LOCK_LEVEL-1)
667c478bd9Sstevel@tonic-gate 
677c478bd9Sstevel@tonic-gate /*
687c478bd9Sstevel@tonic-gate  * definitions of Bus Type
697c478bd9Sstevel@tonic-gate  */
707c478bd9Sstevel@tonic-gate #define	BUS_CBUS	1
717c478bd9Sstevel@tonic-gate #define	BUS_CBUSII	2
727c478bd9Sstevel@tonic-gate #define	BUS_EISA	3
737c478bd9Sstevel@tonic-gate #define	BUS_FUTURE	4
747c478bd9Sstevel@tonic-gate #define	BUS_INTERN	5
757c478bd9Sstevel@tonic-gate #define	BUS_ISA		6
767c478bd9Sstevel@tonic-gate #define	BUS_MBI		7
777c478bd9Sstevel@tonic-gate #define	BUS_MBII	8
789e26e16fSrs90106 #define	BUS_PCIE	9
797c478bd9Sstevel@tonic-gate #define	BUS_MPI		10
807c478bd9Sstevel@tonic-gate #define	BUS_MPSA	11
817c478bd9Sstevel@tonic-gate #define	BUS_NUBUS	12
827c478bd9Sstevel@tonic-gate #define	BUS_PCI		13
837c478bd9Sstevel@tonic-gate #define	BUS_PCMCIA	14
847c478bd9Sstevel@tonic-gate #define	BUS_TC		15
857c478bd9Sstevel@tonic-gate #define	BUS_VL		16
867c478bd9Sstevel@tonic-gate #define	BUS_VME		17
877c478bd9Sstevel@tonic-gate #define	BUS_XPRESS	18
887c478bd9Sstevel@tonic-gate 
897c478bd9Sstevel@tonic-gate 
907c478bd9Sstevel@tonic-gate /*
917c478bd9Sstevel@tonic-gate  * intr_po - polarity definitions
927c478bd9Sstevel@tonic-gate  */
937c478bd9Sstevel@tonic-gate #define	INTR_PO_CONFORM		0x00
947c478bd9Sstevel@tonic-gate #define	INTR_PO_ACTIVE_HIGH	0x01
957c478bd9Sstevel@tonic-gate #define	INTR_PO_RESERVED	0x02
967c478bd9Sstevel@tonic-gate #define	INTR_PO_ACTIVE_LOW	0x03
977c478bd9Sstevel@tonic-gate 
987c478bd9Sstevel@tonic-gate /*
997c478bd9Sstevel@tonic-gate  * intr_el edge or level definitions
1007c478bd9Sstevel@tonic-gate  */
1017c478bd9Sstevel@tonic-gate #define	INTR_EL_CONFORM		0x00
1027c478bd9Sstevel@tonic-gate #define	INTR_EL_EDGE		0x01
1037c478bd9Sstevel@tonic-gate #define	INTR_EL_RESERVED	0x02
1047c478bd9Sstevel@tonic-gate #define	INTR_EL_LEVEL		0x03
1057c478bd9Sstevel@tonic-gate 
1067c478bd9Sstevel@tonic-gate /*
1077c478bd9Sstevel@tonic-gate  * interrupt flags structure
1087c478bd9Sstevel@tonic-gate  */
1097c478bd9Sstevel@tonic-gate typedef struct iflag {
1107c478bd9Sstevel@tonic-gate 	uchar_t	intr_po: 2,
1117c478bd9Sstevel@tonic-gate 		intr_el: 2,
1127c478bd9Sstevel@tonic-gate 		bustype: 4;
1137c478bd9Sstevel@tonic-gate } iflag_t;
1147c478bd9Sstevel@tonic-gate 
1157c478bd9Sstevel@tonic-gate /* _HID for PCI bus object */
1167c478bd9Sstevel@tonic-gate #define	HID_PCI_BUS		0x30AD041
1177c478bd9Sstevel@tonic-gate #define	HID_PCI_EXPRESS_BUS	0x080AD041
1187c478bd9Sstevel@tonic-gate 
1197c478bd9Sstevel@tonic-gate /*
1205cff7825Smh27603  * Function prototypes
1217c478bd9Sstevel@tonic-gate  */
1225cff7825Smh27603 extern ACPI_STATUS acpica_get_sci(int *, iflag_t *);
1235cff7825Smh27603 extern int acpica_get_bdf(dev_info_t *, int *, int *, int *);
1245cff7825Smh27603 extern ACPI_STATUS acpica_get_devinfo(ACPI_HANDLE, dev_info_t **);
1255cff7825Smh27603 extern ACPI_STATUS acpica_get_handle(dev_info_t *, ACPI_HANDLE *);
126*0e751525SEric Saxe extern ACPI_STATUS acpica_get_handle_cpu(int, ACPI_HANDLE *);
1275cff7825Smh27603 extern ACPI_STATUS acpica_eval_int(ACPI_HANDLE, char *, int *);
128b6917abeSmishra extern void acpica_map_cpu(processorid_t, UINT32);
1295cff7825Smh27603 extern void acpica_build_processor_map();
1302df1fe9cSrandyf extern void acpica_ddi_save_resources(dev_info_t *);
1312df1fe9cSrandyf extern void acpica_ddi_restore_resources(dev_info_t *);
132*0e751525SEric Saxe extern void acpica_get_global_FADT(ACPI_TABLE_FADT **);
1337c478bd9Sstevel@tonic-gate 
1347c478bd9Sstevel@tonic-gate #ifdef __cplusplus
1357c478bd9Sstevel@tonic-gate }
1367c478bd9Sstevel@tonic-gate #endif
1377c478bd9Sstevel@tonic-gate 
1387c478bd9Sstevel@tonic-gate #endif /* _SYS_ACPICA_H */
139