Difference between revisions of "PHC"

From ArchWiki
Jump to: navigation, search
(Undo revision 227153 by Stqn (talk))
(simplification and beautification of wikilinks (interactive))
(Tag: wiki-scripts)
 
(29 intermediate revisions by 14 users not shown)
Line 1: Line 1:
 
[[Category:CPU]]
 
[[Category:CPU]]
 
[[Category:Power management]]
 
[[Category:Power management]]
 +
[[ja:PHC]]
 
[[ru:PHC]]
 
[[ru:PHC]]
{{Translateme}}
+
{{Related articles start}}
{{Article summary start}}
+
{{Related| Laptop}}
{{Article summary text | Provides a guide to installing, configuring and using a PHC.}}
+
{{Related| Pm-utils}}
{{Article summary heading | Related articles}}
+
{{Related|CPU frequency scaling}}
{{Article summary wiki | Laptop}}
+
{{Related articles end}}
{{Article summary wiki | Pm-utils}}
+
{{Article summary wiki | CPU Frequency Scaling}}
+
{{Article summary end}}
+
 
+
==Introduction==
+
 
+
 
PHC is an acpi-cpufreq patch built with the purpose of enabling undervolting on your processor. This can potentially divide the power consumption of your processor by two or more, and in turn increase battery life and reduce fan noise noticiably. PHC works only if your processor's architecture supports undervolting.
 
PHC is an acpi-cpufreq patch built with the purpose of enabling undervolting on your processor. This can potentially divide the power consumption of your processor by two or more, and in turn increase battery life and reduce fan noise noticiably. PHC works only if your processor's architecture supports undervolting.
 
For a complete power management suite see ''Related articles'' in top-right of the page.
 
 
===Alternative to PHC===
 
 
{{AUR|cpupowerd}} is a userland solution to replace the in-kernel cpufreq governors and also enable undervolting, only on AMD processors. Like PHC, it requires the user to find safe voltages by himself.
 
  
 
==Supported CPUs==
 
==Supported CPUs==
Line 26: Line 15:
  
 
===Intel===
 
===Intel===
 
+
{{note|Current Intel core i CPUs use Intel P-states instead of acpi_cpufreq and are therefor not compatible with PHC.}}
 
*Mobile Centrino
 
*Mobile Centrino
 
*Atom (N2xx)
 
*Atom (N2xx)
 
*Core / Core2 (T and P Series)
 
*Core / Core2 (T and P Series)
*Core i (tested on Core i3 550)
+
*Core i (2nd generation and older, tested on Core i3 550)
 
{{note|Frequency locking does not seem to be working on Core i3 with the current stable 0.3.2 release of PHC, so finding the best vids for all but the highest frequency might be difficult or impossible.}}
 
{{note|Frequency locking does not seem to be working on Core i3 with the current stable 0.3.2 release of PHC, so finding the best vids for all but the highest frequency might be difficult or impossible.}}
  
Line 37: Line 26:
 
*K8 series
 
*K8 series
  
==Installing the necessary packages==
+
== Installation ==
  
Install from the [[Arch User Repository|AUR]] either {{AUR|phc-intel}} if you have an Intel processor, or {{AUR|phc-k8}} if you have an AMD-K8-series one.
+
[[Install]] the {{AUR|phc-intel}} package if you have an Intel processor, or {{AUR|phc-k8}} if you have an AMD-K8-series one.
  
Next you need to compile the module for your kernel; this will also be necessary after a kernel update.
+
Next you need to compile the module for your kernel; this will also be necessary after a kernel update (but see the section below on using DKMS to automate this).
  
 
You need to have {{pkg|linux-headers}} and/or {{pkg|linux-lts-headers}} installed to be able to build the module.
 
You need to have {{pkg|linux-headers}} and/or {{pkg|linux-lts-headers}} installed to be able to build the module.
  
 
Type:
 
Type:
  # rc.d setup phc-intel
+
  # phc-intel setup
 
or
 
or
  # rc.d setup phc-k8
+
  # phc-k8 setup
 +
depending on processor.
  
If the [[CPU_Frequency_Scaling#CPU_frequency_driver|''acpi-cpufreq'']] module is not already being loaded at boot, create the appropriate file in {{ic|/etc/modules-load.d/}}. See [[Kernel_modules#Loading|this]] wiki article for more information.
+
If the [[CPU frequency scaling#CPU_frequency_driver|''acpi-cpufreq'']] module is not already being loaded at boot, create the appropriate file in {{ic|/etc/modules-load.d/}}. See [[Kernel modules]] for more information.
  
 
{{Note|In the case of {{AUR|phc-intel}}, the ''acpi-cpufreq'' module is automatically loaded by {{ic|/usr/lib/modprobe.d/phc-intel.conf}}.}}
 
{{Note|In the case of {{AUR|phc-intel}}, the ''acpi-cpufreq'' module is automatically loaded by {{ic|/usr/lib/modprobe.d/phc-intel.conf}}.}}
  
==Configuring PHC==
+
=== Automatic module generation with DKMS ===
 +
The {{AUR|dkms-phc-intel}} package uses DKMS to automatically update the module after a kernel update.  This is done at shutdown time to ensure that the kernel and kernel-headers are in sync (which is not necessarily the case during a system upgrade, depending on the order at which updates are installed).
  
===Finding safe low voltages===
+
To enable the systemd service, type:
 +
# systemctl enable dkms-phc-intel
  
To automatically find the best voltages, you can use the [https://bbs.archlinux.org/viewtopic.php?pid=1141702#p1141702 mprime-phc-setup] script. Just copy the code into a text file, chmod +x it to make it executable and run it. You need to install {{AUR|mprime}} first (it is used to check that the CPU is stable). This script has not been tested on many systems yet, but should be safe.
+
== Configuration ==
  
You can also try {{AUR|linux-phc-optimize}}, although it has produced unsafe vids on [https://bbs.archlinux.org/viewtopic.php?pid=1044323#p1044323 some setups]. The script progressively lowers the values until the system crashes, and adds two to the values for stability. Because the system will crash, do not do anything else during the tests. Run it once for each value, then check {{ic|/usr/share/linux-phc-optimize/phc_tweaked_vids}}.
+
=== Finding safe low voltages ===
  
===Editing the configuration===
+
To automatically find the best voltages, you can use the [https://bbs.archlinux.org/viewtopic.php?pid=1141702#p1141702 mprime-phc-setup] script ([https://bitbucket.org/stqn/shell-tools/src/ source-code]). Just copy the code into a text file, chmod +x it to make it executable and run it. You need to install {{AUR|mprime}} or {{AUR|mprime-bin}} first (it is used to check that the CPU is stable). This script has not been tested on many systems yet, but should be safe.
  
After the phc module is compiled and the lowest voltages are found, they need to be added to the configuration file at {{ic|/etc/conf.d/phc-intel}} or {{ic|/etc/conf.d/phc-k8}}.
+
=== Editing the configuration ===
 +
 
 +
After the phc module is compiled and the lowest voltages are found, they need to be added to the configuration file at {{ic|/etc/default/phc-intel}} or {{ic|/etc/default/phc-k8}}.
  
 
For example:
 
For example:
Line 70: Line 64:
 
  VIDS="25 22 15 8 5"
 
  VIDS="25 22 15 8 5"
  
Then just restart the phc daemon:
+
Simply restart the system and the modules will be loaded automatically by systemd.
 
+
# rc.d start phc-intel
+
or
+
# rc.d start phc-k8
+
  
==Troubleshooting==
+
== Troubleshooting ==
  
===Module loading===
+
=== Module loading ===
  
 
Run:
 
Run:
Line 86: Line 76:
 
If you see errors regarding this module, something has gone wrong OR you cannot use PHC.
 
If you see errors regarding this module, something has gone wrong OR you cannot use PHC.
  
===Hardware recognition===
+
=== Hardware recognition ===
  
 
There should be some files in {{ic|/sys/devices/system/cpu/cpu0/cpufreq/}} beginning with "phc_".
 
There should be some files in {{ic|/sys/devices/system/cpu/cpu0/cpufreq/}} beginning with "phc_".
Line 95: Line 85:
 
you should read some values. If the values do not appear, then PHC is probably not supported by your CPU.
 
you should read some values. If the values do not appear, then PHC is probably not supported by your CPU.
  
===Voltage controlling===
+
=== Voltage controlling ===
  
 
You can easily check whether PHC is working or not by looking at the cpu voltages: if the voltages are lower than the normal ones, then PHC has done its job. You can also manually set voltages, for example:
 
You can easily check whether PHC is working or not by looking at the cpu voltages: if the voltages are lower than the normal ones, then PHC has done its job. You can also manually set voltages, for example:
 
  # echo 34 26 18 12 8 5 > /sys/devices/system/cpu/cpu0/cpufreq/phc_vids
 
  # echo 34 26 18 12 8 5 > /sys/devices/system/cpu/cpu0/cpufreq/phc_vids
  
===System stability===
+
=== System stability ===
  
 
To make sure that your undervolted CPU is stable, you can run long sessions of {{AUR|mprime}} and/or {{AUR|linpack}} (Intel-only).
 
To make sure that your undervolted CPU is stable, you can run long sessions of {{AUR|mprime}} and/or {{AUR|linpack}} (Intel-only).

Latest revision as of 20:03, 14 August 2016

PHC is an acpi-cpufreq patch built with the purpose of enabling undervolting on your processor. This can potentially divide the power consumption of your processor by two or more, and in turn increase battery life and reduce fan noise noticiably. PHC works only if your processor's architecture supports undervolting.

Supported CPUs

PHC supports the following processor families:

Intel

Note: Current Intel core i CPUs use Intel P-states instead of acpi_cpufreq and are therefor not compatible with PHC.
  • Mobile Centrino
  • Atom (N2xx)
  • Core / Core2 (T and P Series)
  • Core i (2nd generation and older, tested on Core i3 550)
Note: Frequency locking does not seem to be working on Core i3 with the current stable 0.3.2 release of PHC, so finding the best vids for all but the highest frequency might be difficult or impossible.

AMD

  • K8 series

Installation

Install the phc-intelAUR package if you have an Intel processor, or phc-k8AUR if you have an AMD-K8-series one.

Next you need to compile the module for your kernel; this will also be necessary after a kernel update (but see the section below on using DKMS to automate this).

You need to have linux-headers and/or linux-lts-headers installed to be able to build the module.

Type:

# phc-intel setup

or

# phc-k8 setup

depending on processor.

If the acpi-cpufreq module is not already being loaded at boot, create the appropriate file in /etc/modules-load.d/. See Kernel modules for more information.

Note: In the case of phc-intelAUR, the acpi-cpufreq module is automatically loaded by /usr/lib/modprobe.d/phc-intel.conf.

Automatic module generation with DKMS

The dkms-phc-intelAUR package uses DKMS to automatically update the module after a kernel update. This is done at shutdown time to ensure that the kernel and kernel-headers are in sync (which is not necessarily the case during a system upgrade, depending on the order at which updates are installed).

To enable the systemd service, type:

# systemctl enable dkms-phc-intel

Configuration

Finding safe low voltages

To automatically find the best voltages, you can use the mprime-phc-setup script (source-code). Just copy the code into a text file, chmod +x it to make it executable and run it. You need to install mprimeAUR or mprime-binAUR first (it is used to check that the CPU is stable). This script has not been tested on many systems yet, but should be safe.

Editing the configuration

After the phc module is compiled and the lowest voltages are found, they need to be added to the configuration file at /etc/default/phc-intel or /etc/default/phc-k8.

For example:

VIDS="25 22 15 8 5"

Simply restart the system and the modules will be loaded automatically by systemd.

Troubleshooting

Module loading

Run:

$ dmesg | grep acpi-cpufreq

If you see errors regarding this module, something has gone wrong OR you cannot use PHC.

Hardware recognition

There should be some files in /sys/devices/system/cpu/cpu0/cpufreq/ beginning with "phc_". To check whether PHC is working or not, just type:

$ cat /sys/devices/system/cpu/cpu0/cpufreq/phc_controls

you should read some values. If the values do not appear, then PHC is probably not supported by your CPU.

Voltage controlling

You can easily check whether PHC is working or not by looking at the cpu voltages: if the voltages are lower than the normal ones, then PHC has done its job. You can also manually set voltages, for example:

# echo 34 26 18 12 8 5 > /sys/devices/system/cpu/cpu0/cpufreq/phc_vids

System stability

To make sure that your undervolted CPU is stable, you can run long sessions of mprimeAUR and/or linpackAUR (Intel-only).

Links