xref: /dflybsd-src/sys/platform/pc64/acpica/acpi_cpu_machdep.c (revision 6645e30f706ad4e4768c4ccde89afa97bda79db2)
1*6645e30fSSascha Wildner /*-
2*6645e30fSSascha Wildner  * Copyright (c) 2011 The DragonFly Project.  All rights reserved.
3*6645e30fSSascha Wildner  *
4*6645e30fSSascha Wildner  * Redistribution and use in source and binary forms, with or without
5*6645e30fSSascha Wildner  * modification, are permitted provided that the following conditions
6*6645e30fSSascha Wildner  * are met:
7*6645e30fSSascha Wildner  *
8*6645e30fSSascha Wildner  * 1. Redistributions of source code must retain the above copyright
9*6645e30fSSascha Wildner  *    notice, this list of conditions and the following disclaimer.
10*6645e30fSSascha Wildner  * 2. Redistributions in binary form must reproduce the above copyright
11*6645e30fSSascha Wildner  *    notice, this list of conditions and the following disclaimer in
12*6645e30fSSascha Wildner  *    the documentation and/or other materials provided with the
13*6645e30fSSascha Wildner  *    distribution.
14*6645e30fSSascha Wildner  * 3. Neither the name of The DragonFly Project nor the names of its
15*6645e30fSSascha Wildner  *    contributors may be used to endorse or promote products derived
16*6645e30fSSascha Wildner  *    from this software without specific, prior written permission.
17*6645e30fSSascha Wildner  *
18*6645e30fSSascha Wildner  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19*6645e30fSSascha Wildner  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20*6645e30fSSascha Wildner  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
21*6645e30fSSascha Wildner  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE
22*6645e30fSSascha Wildner  * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
23*6645e30fSSascha Wildner  * INCIDENTAL, SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING,
24*6645e30fSSascha Wildner  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25*6645e30fSSascha Wildner  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
26*6645e30fSSascha Wildner  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
27*6645e30fSSascha Wildner  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
28*6645e30fSSascha Wildner  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29*6645e30fSSascha Wildner  * SUCH DAMAGE.
30*6645e30fSSascha Wildner  */
31*6645e30fSSascha Wildner 
325db2f26eSSascha Wildner #include <sys/param.h>
335db2f26eSSascha Wildner #include <sys/bus.h>
345db2f26eSSascha Wildner #include <sys/kernel.h>
355db2f26eSSascha Wildner #include <sys/systm.h>
365db2f26eSSascha Wildner #include <sys/sysctl.h>
375db2f26eSSascha Wildner 
385db2f26eSSascha Wildner #include <machine/cpufunc.h>
395db2f26eSSascha Wildner #include <machine/cputypes.h>
405db2f26eSSascha Wildner #include <machine/md_var.h>
415db2f26eSSascha Wildner #include <machine/specialreg.h>
425db2f26eSSascha Wildner 
435db2f26eSSascha Wildner #include "acpi.h"
445db2f26eSSascha Wildner #include "acpivar.h"
455db2f26eSSascha Wildner #include "acpi_cpu.h"
465db2f26eSSascha Wildner 
475db2f26eSSascha Wildner uint32_t
acpi_cpu_md_features(void)485db2f26eSSascha Wildner acpi_cpu_md_features(void)
495db2f26eSSascha Wildner {
505764e125SSepherosa Ziehau 	uint32_t features = 0;
515764e125SSepherosa Ziehau 
525db2f26eSSascha Wildner 	if (cpu_vendor_id == CPU_VENDOR_INTEL) {
535db2f26eSSascha Wildner 		if (cpu_feature2 & CPUID2_EST) {
545764e125SSepherosa Ziehau 			features |= ACPI_PDC_PX_MSR |
555db2f26eSSascha Wildner 			    ACPI_PDC_MP_PX_SWCOORD |
565764e125SSepherosa Ziehau 			    ACPI_PDC_PX_HWCOORD;
575764e125SSepherosa Ziehau 		}
585764e125SSepherosa Ziehau 		if ((cpu_feature2 & CPUID2_MON) &&
595764e125SSepherosa Ziehau 		    (cpu_mwait_feature &
605764e125SSepherosa Ziehau 		     (CPUID_MWAIT_EXT | CPUID_MWAIT_INTBRK)) ==
615764e125SSepherosa Ziehau 		    (CPUID_MWAIT_EXT | CPUID_MWAIT_INTBRK)) {
625764e125SSepherosa Ziehau 			features |= ACPI_PDC_MP_C1_NATIVE |
635764e125SSepherosa Ziehau 			    ACPI_PDC_MP_C2C3_NATIVE;
645db2f26eSSascha Wildner 		}
655db2f26eSSascha Wildner 	}
665764e125SSepherosa Ziehau 	return features;
675db2f26eSSascha Wildner }
68