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