Add support for Intel Turbo Boost feature
[coreboot.git] / src / include / cpu / intel / turbo.h
1 /*
2  * This file is part of the coreboot project.
3  *
4  * Copyright (C) 2011 The ChromiumOS Authors. All rights reserved.
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License as
8  * published by the Free Software Foundation; version 2 of
9  * the License.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
19  * MA 02110-1301 USA
20  */
21
22 #ifndef _CPU_INTEL_TURBO_H
23 #define _CPU_INTEL_TURBO_H
24
25 #define CPUID_LEAF_PM           6
26 #define PM_CAP_TURBO_MODE       (1 << 1)
27
28 #define MSR_IA32_MISC_ENABLES   0x1a0
29 #define H_MISC_DISABLE_TURBO    (1 << 6)
30
31 enum {
32         TURBO_UNKNOWN,
33         TURBO_UNAVAILABLE,
34         TURBO_DISABLED,
35         TURBO_ENABLED,
36 };
37
38 /* Return current turbo state */
39 int get_turbo_state(void);
40
41 /* Enable turbo */
42 void enable_turbo(void);
43
44 #endif