2011-06-22 12:49:54 +04:00
|
|
|
/* $NetBSD: acpi_cpu.h,v 1.42 2011/06/22 08:49:54 jruoho Exp $ */
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
|
|
|
|
/*-
|
2011-02-25 12:16:00 +03:00
|
|
|
* Copyright (c) 2010, 2011 Jukka Ruohonen <jruohonen@iki.fi>
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _SYS_DEV_ACPI_ACPI_CPU_H
|
|
|
|
#define _SYS_DEV_ACPI_ACPI_CPU_H
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The following _PDC values are based on:
|
|
|
|
*
|
2010-08-08 20:58:41 +04:00
|
|
|
* Intel Corporation: Intel Processor-Specific ACPI
|
|
|
|
* Interface Specification, September 2006, Revision 005.
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
*/
|
|
|
|
#define ACPICPU_PDC_REVID 0x1
|
|
|
|
#define ACPICPU_PDC_SMP 0xA
|
|
|
|
#define ACPICPU_PDC_MSR 0x1
|
|
|
|
|
|
|
|
#define ACPICPU_PDC_P_FFH __BIT(0) /* SpeedStep MSRs */
|
|
|
|
#define ACPICPU_PDC_C_C1_HALT __BIT(1) /* C1 "I/O then halt" */
|
|
|
|
#define ACPICPU_PDC_T_FFH __BIT(2) /* OnDemand throttling MSRs */
|
|
|
|
#define ACPICPU_PDC_C_C1PT __BIT(3) /* SMP C1, Px, and Tx (same) */
|
|
|
|
#define ACPICPU_PDC_C_C2C3 __BIT(4) /* SMP C2 and C3 (same) */
|
|
|
|
#define ACPICPU_PDC_P_SW __BIT(5) /* SMP Px (different) */
|
|
|
|
#define ACPICPU_PDC_C_SW __BIT(6) /* SMP Cx (different) */
|
|
|
|
#define ACPICPU_PDC_T_SW __BIT(7) /* SMP Tx (different) */
|
|
|
|
#define ACPICPU_PDC_C_C1_FFH __BIT(8) /* SMP C1 native beyond halt */
|
|
|
|
#define ACPICPU_PDC_C_C2C3_FFH __BIT(9) /* SMP C2 and C2 native */
|
2011-03-04 15:10:49 +03:00
|
|
|
#define ACPICPU_PDC_P_HWF __BIT(11) /* Px hardware feedback */
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
|
2010-07-27 09:11:32 +04:00
|
|
|
#define ACPICPU_PDC_GAS_HW __BIT(0) /* HW-coordinated state */
|
|
|
|
#define ACPICPU_PDC_GAS_BM __BIT(1) /* Bus master check required */
|
2010-07-23 12:11:49 +04:00
|
|
|
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
/*
|
|
|
|
* Notify values.
|
|
|
|
*/
|
|
|
|
#define ACPICPU_P_NOTIFY 0x80 /* _PPC */
|
|
|
|
#define ACPICPU_C_NOTIFY 0x81 /* _CST */
|
|
|
|
#define ACPICPU_T_NOTIFY 0x82 /* _TPC */
|
|
|
|
|
2011-02-25 22:55:06 +03:00
|
|
|
/*
|
|
|
|
* Dependency coordination.
|
|
|
|
*/
|
2011-02-25 23:59:37 +03:00
|
|
|
#define ACPICPU_DEP_SW_ALL 0xFC /* All CPUs must set a state */
|
|
|
|
#define ACPICPU_DEP_SW_ANY 0xFD /* Any CPU can set a state */
|
|
|
|
#define ACPICPU_DEP_HW_ALL 0xFE /* HW does the coordination */
|
2011-02-25 22:55:06 +03:00
|
|
|
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
/*
|
|
|
|
* C-states.
|
|
|
|
*/
|
|
|
|
#define ACPICPU_C_C2_LATENCY_MAX 100 /* us */
|
|
|
|
#define ACPICPU_C_C3_LATENCY_MAX 1000 /* us */
|
|
|
|
|
|
|
|
#define ACPICPU_C_STATE_HALT 0x01
|
|
|
|
#define ACPICPU_C_STATE_FFH 0x02
|
|
|
|
#define ACPICPU_C_STATE_SYSIO 0x03
|
|
|
|
|
2010-07-27 09:11:32 +04:00
|
|
|
/*
|
2010-08-08 20:58:41 +04:00
|
|
|
* P-states.
|
2010-07-27 09:11:32 +04:00
|
|
|
*/
|
2010-08-11 15:48:21 +04:00
|
|
|
#define ACPICPU_P_STATE_MAX 255 /* Arbitrary upper limit */
|
2010-08-08 20:58:41 +04:00
|
|
|
#define ACPICPU_P_STATE_RETRY 100
|
|
|
|
#define ACPICPU_P_STATE_UNKNOWN 0x0
|
2010-07-27 09:11:32 +04:00
|
|
|
|
2010-08-13 20:21:50 +04:00
|
|
|
/*
|
|
|
|
* T-states.
|
|
|
|
*/
|
|
|
|
#define ACPICPU_T_STATE_MAX 0x8
|
|
|
|
#define ACPICPU_T_STATE_RETRY 0xA
|
|
|
|
#define ACPICPU_T_STATE_UNKNOWN 255
|
|
|
|
|
2010-07-27 09:11:32 +04:00
|
|
|
/*
|
|
|
|
* Flags.
|
|
|
|
*/
|
|
|
|
#define ACPICPU_FLAG_C __BIT(0) /* C-states supported */
|
|
|
|
#define ACPICPU_FLAG_P __BIT(1) /* P-states supported */
|
|
|
|
#define ACPICPU_FLAG_T __BIT(2) /* T-states supported */
|
|
|
|
|
2010-08-14 09:13:20 +04:00
|
|
|
#define ACPICPU_FLAG_PIIX4 __BIT(3) /* Broken (quirk) */
|
|
|
|
|
|
|
|
#define ACPICPU_FLAG_C_FFH __BIT(4) /* Native C-states */
|
|
|
|
#define ACPICPU_FLAG_C_FADT __BIT(5) /* C-states with FADT */
|
2011-02-25 22:55:06 +03:00
|
|
|
#define ACPICPU_FLAG_C_DEP __BIT(6) /* C-state CPU coordination */
|
|
|
|
#define ACPICPU_FLAG_C_BM __BIT(7) /* Bus master control */
|
|
|
|
#define ACPICPU_FLAG_C_BM_STS __BIT(8) /* Bus master check required */
|
|
|
|
#define ACPICPU_FLAG_C_ARB __BIT(9) /* Bus master arbitration */
|
|
|
|
#define ACPICPU_FLAG_C_TSC __BIT(10) /* TSC broken, > C1, Px, Tx */
|
|
|
|
#define ACPICPU_FLAG_C_APIC __BIT(11) /* APIC timer broken, > C1 */
|
|
|
|
#define ACPICPU_FLAG_C_C1E __BIT(12) /* AMD C1E detected */
|
|
|
|
|
|
|
|
#define ACPICPU_FLAG_P_FFH __BIT(13) /* Native P-states */
|
|
|
|
#define ACPICPU_FLAG_P_DEP __BIT(14) /* P-state CPU coordination */
|
2011-03-04 15:10:49 +03:00
|
|
|
#define ACPICPU_FLAG_P_HWF __BIT(15) /* HW feedback supported */
|
2011-02-25 22:55:06 +03:00
|
|
|
#define ACPICPU_FLAG_P_XPSS __BIT(16) /* Microsoft XPSS in use */
|
|
|
|
#define ACPICPU_FLAG_P_TURBO __BIT(17) /* Turbo Boost / Turbo Core */
|
|
|
|
#define ACPICPU_FLAG_P_FIDVID __BIT(18) /* AMD "FID/VID algorithm" */
|
|
|
|
|
|
|
|
#define ACPICPU_FLAG_T_FFH __BIT(19) /* Native throttling */
|
|
|
|
#define ACPICPU_FLAG_T_FADT __BIT(20) /* Throttling with FADT */
|
|
|
|
#define ACPICPU_FLAG_T_DEP __BIT(21) /* T-state CPU coordination */
|
2010-08-08 20:58:41 +04:00
|
|
|
|
2010-07-30 10:11:14 +04:00
|
|
|
/*
|
|
|
|
* This is AML_RESOURCE_GENERIC_REGISTER,
|
|
|
|
* included here separately for convenience.
|
|
|
|
*/
|
|
|
|
struct acpicpu_reg {
|
|
|
|
uint8_t reg_desc;
|
|
|
|
uint16_t reg_reslen;
|
|
|
|
uint8_t reg_spaceid;
|
|
|
|
uint8_t reg_bitwidth;
|
|
|
|
uint8_t reg_bitoffset;
|
|
|
|
uint8_t reg_accesssize;
|
|
|
|
uint64_t reg_addr;
|
|
|
|
} __packed;
|
|
|
|
|
2011-02-25 22:55:06 +03:00
|
|
|
struct acpicpu_dep {
|
|
|
|
uint32_t dep_domain;
|
|
|
|
uint32_t dep_type;
|
|
|
|
uint32_t dep_ncpus;
|
|
|
|
uint32_t dep_index;
|
|
|
|
};
|
|
|
|
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
struct acpicpu_cstate {
|
2010-08-10 06:42:05 +04:00
|
|
|
struct evcnt cs_evcnt;
|
|
|
|
char cs_name[EVCNT_STRING_MAX];
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
uint64_t cs_addr;
|
2010-08-16 11:38:38 +04:00
|
|
|
uint32_t cs_power;
|
|
|
|
uint32_t cs_latency;
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
int cs_method;
|
2010-07-23 12:11:49 +04:00
|
|
|
int cs_flags;
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
};
|
|
|
|
|
2010-08-16 11:38:38 +04:00
|
|
|
/*
|
|
|
|
* This structure supports both the conventional _PSS and the
|
|
|
|
* so-called extended _PSS (XPSS). For the latter, refer to:
|
|
|
|
*
|
|
|
|
* Microsoft Corporation: Extended PSS ACPI
|
|
|
|
* Method Specification, April 2, 2007.
|
|
|
|
*/
|
2010-08-08 20:58:41 +04:00
|
|
|
struct acpicpu_pstate {
|
2010-08-10 06:42:05 +04:00
|
|
|
struct evcnt ps_evcnt;
|
|
|
|
char ps_name[EVCNT_STRING_MAX];
|
2010-08-16 11:38:38 +04:00
|
|
|
uint32_t ps_freq;
|
|
|
|
uint32_t ps_power;
|
|
|
|
uint32_t ps_latency;
|
|
|
|
uint32_t ps_latency_bm;
|
|
|
|
uint64_t ps_control;
|
|
|
|
uint64_t ps_control_addr;
|
|
|
|
uint64_t ps_control_mask;
|
|
|
|
uint64_t ps_status;
|
|
|
|
uint64_t ps_status_addr;
|
|
|
|
uint64_t ps_status_mask;
|
|
|
|
int ps_flags;
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
};
|
|
|
|
|
2010-08-13 20:21:50 +04:00
|
|
|
struct acpicpu_tstate {
|
|
|
|
struct evcnt ts_evcnt;
|
|
|
|
char ts_name[EVCNT_STRING_MAX];
|
2010-08-16 11:38:38 +04:00
|
|
|
uint32_t ts_percent;
|
|
|
|
uint32_t ts_power;
|
|
|
|
uint32_t ts_latency;
|
2010-08-13 20:21:50 +04:00
|
|
|
uint32_t ts_control;
|
|
|
|
uint32_t ts_status;
|
|
|
|
};
|
|
|
|
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
struct acpicpu_object {
|
|
|
|
uint32_t ao_procid;
|
|
|
|
uint32_t ao_pblklen;
|
|
|
|
uint32_t ao_pblkaddr;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct acpicpu_softc {
|
|
|
|
device_t sc_dev;
|
2011-02-25 09:18:02 +03:00
|
|
|
struct cpu_info *sc_ci;
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
struct acpi_devnode *sc_node;
|
|
|
|
struct acpicpu_object sc_object;
|
2010-07-30 10:11:14 +04:00
|
|
|
|
2010-07-30 02:42:58 +04:00
|
|
|
struct acpicpu_cstate sc_cstate[ACPI_C_STATE_COUNT];
|
2011-02-25 22:55:06 +03:00
|
|
|
struct acpicpu_dep sc_cstate_dep;
|
2010-07-30 10:11:14 +04:00
|
|
|
uint32_t sc_cstate_sleep;
|
|
|
|
|
2010-08-08 20:58:41 +04:00
|
|
|
struct acpicpu_pstate *sc_pstate;
|
2011-02-25 22:55:06 +03:00
|
|
|
struct acpicpu_dep sc_pstate_dep;
|
2010-08-08 20:58:41 +04:00
|
|
|
struct acpicpu_reg sc_pstate_control;
|
|
|
|
struct acpicpu_reg sc_pstate_status;
|
2011-02-25 12:16:00 +03:00
|
|
|
uint64_t sc_pstate_aperf; /* ACPICPU_FLAG_P_HW */
|
|
|
|
uint64_t sc_pstate_mperf; /* ACPICPU_FLAG_P_HW*/
|
2010-08-08 20:58:41 +04:00
|
|
|
uint32_t sc_pstate_current;
|
2011-03-17 18:59:36 +03:00
|
|
|
uint32_t sc_pstate_saved;
|
2010-08-08 20:58:41 +04:00
|
|
|
uint32_t sc_pstate_count;
|
|
|
|
uint32_t sc_pstate_max;
|
2010-08-17 14:17:52 +04:00
|
|
|
uint32_t sc_pstate_min;
|
2010-08-08 20:58:41 +04:00
|
|
|
|
2010-08-13 20:21:50 +04:00
|
|
|
struct acpicpu_tstate *sc_tstate;
|
2011-02-25 22:55:06 +03:00
|
|
|
struct acpicpu_dep sc_tstate_dep;
|
2010-08-13 20:21:50 +04:00
|
|
|
struct acpicpu_reg sc_tstate_control;
|
|
|
|
struct acpicpu_reg sc_tstate_status;
|
|
|
|
uint32_t sc_tstate_current;
|
|
|
|
uint32_t sc_tstate_count;
|
|
|
|
uint32_t sc_tstate_max;
|
|
|
|
uint32_t sc_tstate_min;
|
|
|
|
|
2010-07-30 10:11:14 +04:00
|
|
|
kmutex_t sc_mtx;
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
uint32_t sc_cap;
|
2011-02-25 22:55:06 +03:00
|
|
|
uint32_t sc_ncpus;
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
uint32_t sc_flags;
|
2010-07-30 02:42:58 +04:00
|
|
|
bool sc_cold;
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
};
|
|
|
|
|
2011-02-27 21:32:53 +03:00
|
|
|
void acpicpu_cstate_attach(device_t);
|
2011-06-22 12:49:54 +04:00
|
|
|
void acpicpu_cstate_detach(device_t);
|
2011-02-27 21:32:53 +03:00
|
|
|
void acpicpu_cstate_start(device_t);
|
2011-03-19 15:57:30 +03:00
|
|
|
void acpicpu_cstate_suspend(void *);
|
|
|
|
void acpicpu_cstate_resume(void *);
|
2011-02-27 21:32:53 +03:00
|
|
|
void acpicpu_cstate_callback(void *);
|
|
|
|
void acpicpu_cstate_idle(void);
|
|
|
|
|
|
|
|
void acpicpu_pstate_attach(device_t);
|
2011-06-22 12:49:54 +04:00
|
|
|
void acpicpu_pstate_detach(device_t);
|
2011-02-27 21:32:53 +03:00
|
|
|
void acpicpu_pstate_start(device_t);
|
2011-03-19 15:57:30 +03:00
|
|
|
void acpicpu_pstate_suspend(void *);
|
|
|
|
void acpicpu_pstate_resume(void *);
|
2011-02-27 21:32:53 +03:00
|
|
|
void acpicpu_pstate_callback(void *);
|
2011-03-01 07:35:48 +03:00
|
|
|
int acpicpu_pstate_get(struct cpu_info *, uint32_t *);
|
|
|
|
void acpicpu_pstate_set(struct cpu_info *, uint32_t);
|
2011-02-27 21:32:53 +03:00
|
|
|
|
|
|
|
void acpicpu_tstate_attach(device_t);
|
2011-06-22 12:49:54 +04:00
|
|
|
void acpicpu_tstate_detach(device_t);
|
2011-02-27 21:32:53 +03:00
|
|
|
void acpicpu_tstate_start(device_t);
|
2011-03-19 15:57:30 +03:00
|
|
|
void acpicpu_tstate_suspend(void *);
|
|
|
|
void acpicpu_tstate_resume(void *);
|
2011-02-27 21:32:53 +03:00
|
|
|
void acpicpu_tstate_callback(void *);
|
2011-03-01 07:35:48 +03:00
|
|
|
int acpicpu_tstate_get(struct cpu_info *, uint32_t *);
|
|
|
|
void acpicpu_tstate_set(struct cpu_info *, uint32_t);
|
2011-02-27 21:32:53 +03:00
|
|
|
|
|
|
|
struct cpu_info *acpicpu_md_match(device_t, cfdata_t, void *);
|
|
|
|
struct cpu_info *acpicpu_md_attach(device_t, device_t, void *);
|
|
|
|
|
|
|
|
uint32_t acpicpu_md_flags(void);
|
|
|
|
void acpicpu_md_quirk_c1e(void);
|
|
|
|
int acpicpu_md_cstate_start(struct acpicpu_softc *);
|
|
|
|
int acpicpu_md_cstate_stop(void);
|
|
|
|
void acpicpu_md_cstate_enter(int, int);
|
|
|
|
int acpicpu_md_pstate_start(struct acpicpu_softc *);
|
|
|
|
int acpicpu_md_pstate_stop(void);
|
2011-03-05 12:47:19 +03:00
|
|
|
int acpicpu_md_pstate_init(struct acpicpu_softc *);
|
2011-03-24 08:10:05 +03:00
|
|
|
uint8_t acpicpu_md_pstate_hwf(struct cpu_info *);
|
2011-02-27 21:32:53 +03:00
|
|
|
int acpicpu_md_pstate_get(struct acpicpu_softc *, uint32_t *);
|
|
|
|
int acpicpu_md_pstate_set(struct acpicpu_pstate *);
|
|
|
|
int acpicpu_md_tstate_get(struct acpicpu_softc *, uint32_t *);
|
|
|
|
int acpicpu_md_tstate_set(struct acpicpu_tstate *);
|
Merge a driver for ACPI CPUs with basic support for processor power states,
also known as C-states. The code is modular and provides an easy way to add
the remaining functionality later (namely throttling and P-states).
Remarks:
1. Commented out in the GENERICs; more testing exposure is needed.
2. The C3-state is disabled for the time being because it turns off
timers, among them the local APIC timer. This may not be universally
true on all x86 processors; define ACPICPU_ENABLE_C3 to test.
3. The algorithm used to choose a power state may need tuning. When
evaluating the appropriate state, the implementation uses the
previous sleep time as an indicator. Additional hints would include
for example the system load.
Also bus master activity is evaluated when choosing a state. The
usb(4) stack is notorious for such activity even when unused.
Typically it must be disabled in order to reach the C3-state,
but it may also prevent the use of C2.
4. While no extensive empirical measurements have been carried out, the
power savings are somewhere between 1-2 W with C1 and C2, depending
on the processor, firmware, and load. With C3 even up to 4 W can be
saved. The less something ticks, the more power is saved.
ok jmcneill@, joerg@, and discussed with various people.
2010-07-18 13:29:11 +04:00
|
|
|
|
|
|
|
#endif /* !_SYS_DEV_ACPI_ACPI_CPU_H */
|