Difference between revisions of "PHC"

From ArchWiki
Jump to: navigation, search
(Undo revision 227153 by Stqn (talk))
m (add ja link)
 
(20 intermediate revisions by 12 users not shown)
Line 1: Line 1:
 
[[Category:CPU]]
 
[[Category:CPU]]
 
[[Category:Power management]]
 
[[Category:Power management]]
 +
[[ja:PHC]]
 
[[ru:PHC]]
 
[[ru:PHC]]
 
{{Translateme}}
 
{{Translateme}}
{{Article summary start}}
+
{{Related articles start}}
{{Article summary text | Provides a guide to installing, configuring and using a PHC.}}
+
{{Related| Laptop}}
{{Article summary heading | Related articles}}
+
{{Related| Pm-utils}}
{{Article summary wiki | Laptop}}
+
{{Related|CPU frequency scaling}}
{{Article summary wiki | Pm-utils}}
+
{{Related articles end}}
{{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==
 
+
===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.
+
{{AUR|cpupowerd}}{{Broken package link|{{aur-mirror|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.
  
 
==Supported CPUs==
 
==Supported CPUs==
Line 26: Line 20:
  
 
===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 39: Line 33:
 
==Installing the necessary packages==
 
==Installing the necessary packages==
  
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 from the [[AUR]] either {{AUR|phc-intel}} 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 (but see the section below on using DKMS to automate this).
  
Next you need to compile the module for your kernel; this will also be necessary after a kernel update.
 
  
 
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#Loading|this]] wiki article 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}}.}}
 +
 +
=== 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).
 +
 +
To enable the systemd service, type:
 +
# systemctl enable dkms-phc-intel
  
 
==Configuring PHC==
 
==Configuring PHC==
Line 58: Line 61:
 
===Finding safe low voltages===
 
===Finding safe low voltages===
  
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.
+
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.
  
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}}.
+
You can also try {{AUR|linux-phc-optimize}}{{Broken package link|{{aur-mirror|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}}.
  
 
===Editing the configuration===
 
===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/conf.d/phc-intel}} or {{ic|/etc/conf.d/phc-k8}}.
+
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 73:
 
  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==

Latest revision as of 10:17, 30 November 2015

Tango-preferences-desktop-locale.pngThis article or section needs to be translated.Tango-preferences-desktop-locale.png

Notes: please use the first argument of the template to provide more detailed indications. (Discuss in Talk:PHC#)

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.

Alternative to PHC

cpupowerdAUR[broken link: archived in aur-mirror] 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.

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

Installing the necessary packages

Install from the AUR either phc-intelAUR 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 this wiki article 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

Configuring PHC

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.

You can also try linux-phc-optimizeAUR[broken link: archived in aur-mirror], although it has produced unsafe vids on 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 /usr/share/linux-phc-optimize/phc_tweaked_vids.

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