2016-08-31 09:45:05 +02:00
mbpfan
2012-06-09 16:40:12 +02:00
====================
2019-01-21 14:20:00 +01:00
[![Build Status ](https://travis-ci.org/dgraziotin/mbpfan.svg?branch=master )](https://travis-ci.org/dgraziotin/mbpfan)
2012-08-23 22:32:49 +02:00
This is an enhanced version of [Allan McRae mbpfan ](http://allanmcrae.com/2010/05/simple-macbook-pro-fan-daemon/ )
2012-06-09 16:25:28 +02:00
2017-08-10 15:46:56 -04:00
mbpfan is a daemon that uses input from coretemp module and sets the fan speed using the applesmc module.
2012-06-09 16:25:28 +02:00
This enhanced version assumes any number of processors and fans (max. 10).
2018-08-20 22:05:12 -07:00
* It only uses the temperatures from the processors as input.
* It requires coretemp and applesmc kernel modules to be loaded.
* It requires root use
* It daemonizes or stays in foreground
* Verbose mode for both syslog and stdout
* Users can configure it using the file /etc/mbpfan.conf
2012-06-09 16:25:28 +02:00
2017-08-10 15:46:56 -04:00
**Table Of Contents**
- [Supported GNU/Linux Distributions ](#supported-gnulinux-distributions )
2018-08-20 22:05:12 -07:00
- [Tested MacBook Models ](#tested-macbook-models )
- [Tested iMac/Mac mini Models ](#tested-imacmac-mini-models )
2017-08-10 15:46:56 -04:00
- [Requirements ](#requirements )
- [Installation ](#installation )
- [Arch Linux ](#arch-linux )
2019-07-09 02:40:35 +02:00
- [CRUX Linux ](#crux-linux )
2019-04-28 15:13:45 +09:00
- [Debian ](#debian )
2017-08-10 15:46:56 -04:00
- [Gentoo ](#gentoo )
2019-04-28 15:13:45 +09:00
- [Ubuntu ](#ubuntu )
2017-08-10 15:46:56 -04:00
- [Generic Install Instructions (All Other Operating Systems) ](#generic-install-instructions-all-other-operating-systems )
- [Run Instructions ](#run-instructions )
- [Starting at boot ](#starting-at-boot )
- [Usage ](#usage )
- [License ](#license )
2017-08-14 18:02:12 +04:30
- [Credits ](#credits )
2017-08-10 15:46:56 -04:00
## Supported GNU/Linux Distributions
2012-06-09 16:25:28 +02:00
2012-08-23 11:08:17 +02:00
We provide scripts to to load mbpfan daemon at system boot for many distros.
2012-10-20 17:18:30 +02:00
Please note that the support is provided by volunteers. mbpfan needs tests and bug reports.
2012-08-23 11:08:17 +02:00
Supported distributions:
- Ubuntu
- Debian
2013-10-13 18:18:17 +02:00
- Archlinux
2012-08-23 11:08:17 +02:00
- Fedora
- RedHat
- CentOS
- Gentoo
2017-03-27 11:44:34 -04:00
- Alpine
- Trisquel
2017-08-10 15:46:56 -04:00
- Solus
2018-08-20 22:05:12 -07:00
## Tested MacBook Models
2012-08-23 11:08:17 +02:00
2017-08-10 15:46:56 -04:00
This section reports those models where mbpfan was tested successfully. It does not necessarily mean that the daemon does not work on non-listed models.
2014-05-14 09:14:26 +02:00
2015-12-20 23:22:52 +08:00
- MacBook Pro 12,1 13" (Intel i5 - Linux 4.20)
2017-08-10 15:46:56 -04:00
- MacBook Pro 11,4 15" (Intel i7 - Linux 4.9.41)
2014-06-21 19:35:56 +02:00
- MacBook Pro 11,1 13" (Intel i5 - Linux 3.14, Linux 3.15)
2013-10-13 18:18:17 +02:00
- MacBook Pro 9,2 13" (Intel i5/i7 - Linux 3.10)
2014-06-23 11:00:18 +02:00
- MacBook Pro 8,2 15" (Intel i7 - Linux 3.6.2)
2012-10-24 22:37:53 +02:00
- MacBook Pro 8,1 13" (Intel i7 - Linux 3.2.0)
2014-06-23 11:00:18 +02:00
- MacBook Pro 7,1 15" (Intel Core 2 Duo - Linux 3.13)
- MacBook Pro 6,2 15" (Intel i7 - Linux 3.5.0)
2012-10-24 22:37:53 +02:00
- MacBook Pro 6,2 15" (Intel i7 - Linux 3.2.0)
2019-05-02 00:42:22 -04:00
- MacBook Pro 3,1 17" (Intel Core 2 Duo - Linux 5.0.7)
2012-08-23 11:08:17 +02:00
- MacBook Pro 2,2 15" (Intel Core 2 Duo - Linux 3.4.4)
2017-07-12 17:56:05 -07:00
- MacBook Air 6,1 13" (Intel i7 - Linux 3.13)
2016-10-11 13:43:20 +02:00
- MacBook Air 5,2 13" (Intel i5 - Linux 3.16)
2016-12-27 23:20:08 +01:00
- MacBook Air 1,1 13" (Intel Core Duo - Linux 4.4, Linux 4.8)
2017-04-03 03:45:36 +08:00
- MacBook Air 7,2 13" (Intel Core Duo - Linux 4.10)
2016-02-25 11:37:08 +01:00
- MacBook 1,1 (Intel Core Duo - Linux 3.16)
2012-08-23 11:08:17 +02:00
2018-08-20 22:05:12 -07:00
## Tested iMac/Mac mini Models
2017-08-10 15:46:56 -04:00
2018-08-20 22:05:12 -07:00
This section reports the iMac/Mac mini models where mbpfan was tested successfully.
2015-08-30 22:04:01 -04:00
2018-08-20 22:05:12 -07:00
- iMac Retina 16.2 21.5" (Intel i5 - Linux 4.4.0 Ubuntu 16.04)
2016-07-21 14:01:47 +02:00
- iMac 12,1 21.5" (Intel i7 - Linux 4.6.4)
2016-07-21 13:37:52 +02:00
- iMac 5,1 17" (Intel T7400 (Core 2 Duo) - Linux 14.04 Ubuntu)
2018-08-20 22:05:12 -07:00
- Mac mini 2,1 (Core 2 Duo - Linux 4.4.0)
- Mac mini 5,3 (Core i7 2.0 - Linux 4.4.0 elementary/Ubuntu)
- Mac mini 6,1 (Core i7 2.3 - Linux 4.7.3-4-ck Archlinux)
2012-06-09 16:40:12 +02:00
2019-01-22 23:20:55 +00:00
## Tested Mac Pro Models
This section reports the Mac Pro models where mbpfan was tested successfully.
- Mac Pro 3,1
- Mac Pro 4,1 (with 5,1 firmware and hex-core Xeon X5690 mod - Linux 4.14)
2017-08-10 15:46:56 -04:00
## Requirements
2012-08-23 11:08:17 +02:00
Be sure to load the kernel modules **applesmc** and **coretemp** .
2017-08-10 15:46:56 -04:00
These modules are often automatically loaded when booting up GNU/Linux on a MacBook. If that is not the case, you should make sure to load them at system startup.
**How do I know if applesmc and coretemp are loaded?**
In most distributions, you can run the following command:
2018-08-20 22:05:12 -07:00
```bash
lsmod | grep -e applesmc -e coretemp
```
2017-08-10 15:46:56 -04:00
If you see `coretemp` and `applesmc` listed, you are all set.
**If you do not see `coretemp` and `applesmc` listed, you must load them.**
This is _usually_ achieved by inserting the following two lines in the file `/etc/modules`
2015-02-08 09:42:25 +01:00
```
coretemp
applesmc
```
2012-08-23 11:08:17 +02:00
2015-02-08 09:42:25 +01:00
Please check the relevant documentation of your GNU/Linux distribution.
2012-08-23 11:08:17 +02:00
2017-08-10 15:46:56 -04:00
## Installation
### Arch Linux
2013-10-13 18:27:52 +02:00
See [mbpfan-git at AUR ](https://aur.archlinux.org/packages/mbpfan-git/ ).
Otherwise, please refer to the Generic Instructions.
2019-07-09 02:40:35 +02:00
### CRUX Linux
Follow the instructions on [jolupalabs REPO ](https://github.com/jolupa/jolupalabs ) for installation.
2019-04-28 15:13:45 +09:00
### Debian
2013-10-13 18:27:52 +02:00
2019-04-28 15:13:45 +09:00
On Debian 10 or later install via:
2013-10-13 18:27:52 +02:00
2019-04-28 15:13:45 +09:00
```
sudo apt-get install mbpfan
```
2016-01-30 17:36:45 +01:00
2017-08-10 15:46:56 -04:00
### Gentoo
2016-03-31 19:12:35 +03:00
2017-04-02 16:16:32 -04:00
Install the ```mbpfan` `` package with:
2013-10-13 18:27:52 +02:00
2017-04-02 16:16:32 -04:00
sudo emerge -av app-laptop/mbpfan
2016-12-28 16:40:21 +00:00
2019-05-14 03:53:39 -04:00
### Solus
On Solus, install the package with:
```
sudo eopkg install mbpfan
```
then enable the service.
2019-04-28 15:13:45 +09:00
### Ubuntu
On Ubuntu 18.04 or later install via:
```
sudo apt-get install mbpfan
```
2017-08-10 15:46:56 -04:00
### Generic Install Instructions (All Other Operating Systems)
2012-06-09 16:25:28 +02:00
Compile with
2012-08-23 11:08:17 +02:00
make
2012-06-09 16:40:12 +02:00
2012-06-15 21:12:51 +02:00
Install with
2012-06-15 21:47:23 +02:00
2012-08-23 11:08:17 +02:00
sudo make install
2012-06-15 21:47:23 +02:00
2017-08-10 15:46:56 -04:00
It copies mbpfan to /usr/sbin, mbpfan.conf to /etc (and overwrites existing files),
2016-08-31 09:45:05 +02:00
README.md to /usr/share/doc/mbpfan, and mbpfan.8.gz to /usr/share/man/man8
2012-06-15 21:47:23 +02:00
2016-12-28 16:40:21 +00:00
Run the tests now, see two sections below.
2017-03-19 13:54:29 -04:00
If you would like to compile with Clang instead of GCC, simply set your system's
2017-03-27 13:03:02 -04:00
default compiler to be Clang. Tested with Clang 3.8 and 3.9. Tested with Clang
2017-08-10 15:46:56 -04:00
4.0 along with llvm-lld (The LLVM Linker).
2016-12-28 16:40:21 +00:00
2012-06-15 21:12:51 +02:00
2012-08-22 15:05:52 +02:00
Run The Tests (Recommended)
---------------------------
2016-03-17 11:11:23 +01:00
It is recommended to run the tests after installing the program. Please run the following command _from within the source directory_ .
2012-07-31 19:09:20 +02:00
2012-08-23 11:08:17 +02:00
sudo ./bin/mbpfan -t
2012-08-22 15:05:52 +02:00
or
2012-06-09 16:25:28 +02:00
2012-08-23 11:08:17 +02:00
sudo make tests
2012-08-22 15:05:52 +02:00
2012-06-15 21:12:51 +02:00
2017-08-10 15:46:56 -04:00
## Run Instructions
2012-06-15 21:47:23 +02:00
If not installed, run with
2012-08-23 11:08:17 +02:00
sudo bin/mbpfan
2012-06-09 16:40:12 +02:00
2012-06-15 21:47:23 +02:00
If installed, manually run with
2012-08-23 11:08:17 +02:00
sudo mbpfan
2012-06-15 21:47:23 +02:00
If installed and using the init file, run with (Ubuntu example)
2012-08-23 11:08:17 +02:00
sudo service mbpfan start
2012-06-15 21:47:23 +02:00
2012-08-22 15:05:52 +02:00
2017-08-10 15:46:56 -04:00
## Starting at boot
2012-08-22 15:53:07 +02:00
**Ubuntu**
2016-05-02 11:26:29 +02:00
2017-11-05 10:57:49 +11:00
For systemd based init systems (Ubuntu 16.04+), see the systemd section below.
2016-05-02 11:26:29 +02:00
2017-08-10 15:46:56 -04:00
For upstart based init systems (Ubuntu before 16.04), an example upstart job has been provided.
2016-05-02 11:26:29 +02:00
For using it, execute:
2012-08-23 11:08:17 +02:00
sudo cp mbpfan.upstart /etc/init/mbpfan.conf
sudo start mbpfan
2012-08-22 15:53:07 +02:00
**Debian**
2017-08-10 15:46:56 -04:00
An init file suitable for /lib/lsb/init-functions (Debian)
2012-08-22 15:05:52 +02:00
is located in the main folder of the source files, called mbpfan.init.debian
Rename it to mbpfan, give it execution permissions (chmod +x mbpfan)
and move it to /etc/init.d
2012-08-23 11:08:17 +02:00
Then, add it to the default runlevels with (as root):
sudo update-rc.d mbpfan defaults
2012-08-22 15:05:52 +02:00
2012-08-22 15:53:07 +02:00
**Redhat, CentOS, Fedora**
An init file suitable for /etc/rc.d/init.d/functions
2012-08-22 15:05:52 +02:00
(RHEL/CentOS & Fedora) is also located at the same place, this file is called
mbpfan.init.redhat. Also rename it to mbpfan, give it execution permissions
and move it to /etc/init.d
To add the script to the default runlevels, run the following as root:
2012-08-23 11:08:17 +02:00
chkconfig --level 2345 mbpfan on & & chkconfig --level 016 mbpfan off
**Gentoo**
To automatically run mbpfan at boot, run as root:
rc-update add mbpfan default
2012-08-22 15:05:52 +02:00
2012-08-22 15:53:07 +02:00
**systemd**
2012-08-22 15:05:52 +02:00
As a special bonus, a service file for systemd is also included. To use it,
2012-08-23 11:08:17 +02:00
execute the following (as root):
2015-10-22 14:33:30 +02:00
sudo cp mbpfan.service /etc/systemd/system/
2016-03-17 11:15:16 +01:00
sudo systemctl enable mbpfan.service
2012-08-23 11:08:17 +02:00
sudo systemctl daemon-reload
sudo systemctl start mbpfan.service
2012-08-22 15:53:07 +02:00
2017-08-10 15:46:56 -04:00
## Usage
2012-07-03 10:39:30 +02:00
2012-08-23 11:08:17 +02:00
Usage: ./mbpfan OPTION(S)
-h Show the help screen
-f Run in foreground
-t Run the tests
-v Be (a lot) verbose
2012-07-03 10:39:30 +02:00
2012-06-09 16:40:12 +02:00
2017-08-10 15:46:56 -04:00
## License
2012-06-09 16:40:12 +02:00
GNU General Public License version 3
2012-06-09 16:25:28 +02:00
2012-01-25 10:26:01 -05:00
2017-08-10 15:46:56 -04:00
**This Project Is Based On:**
2012-06-11 21:43:53 +02:00
* http://allanmcrae.com/2010/05/simple-macbook-pro-fan-daemon/
* http://allanmcrae.com/2011/08/mbp-fan-daemon-update/
* https://launchpad.net/macfanctld
* http://paste2.org/p/862259
2013-10-13 18:18:17 +02:00
* http://www.lobotomo.com/products/FanControl/
2017-08-14 18:02:12 +04:30
## Credits
**This Project uses following library:**
2018-08-20 22:05:12 -07:00
* [ANSI C Application Settings Management ](http://pokristensson.com/settings.html ) by Per Ola Kristensson.