Skip to content

Thinkfan-extreme, a script to ensure that any T480 with MX150 doesn't reach the temperature of the sun

License

Notifications You must be signed in to change notification settings

BrunoGrande/Thinkfan-Ex

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 

Repository files navigation

Thinkfan-Extreme Deployment Script

Overview

This script automates the deployment and configuration of a custom fan control solution for ThinkPad laptops. It performs the following actions:

  • Root Access & ACPI Verification: Ensures the script runs as root and that the ThinkPad ACPI module is configured with fan_control=1.
  • GRUB Boot Parameter Update: Adds thinkpad_acpi.fan_control=1 to the kernel boot parameters and runs update-grub.
  • Kernel Module Reloading: Attempts to reload the thinkpad_acpi module (or advises a reboot if it’s built into the kernel).
  • Installation of Custom Fan Control Script: Installs thinkfan-ex which:
    • Monitors temperature sensor files.
    • Maps temperatures to fan levels.
    • Supports command-line options:
      • -status: Displays current fan status and sensor temperature readings.
      • -config: Opens the configuration file (/etc/thinkfan-extreme.conf) for editing.
      • -uninstall: Removes the fan control setup (script, systemd service, GRUB changes, and bash completion).
      • -help / --help: Displays usage information.
  • Systemd Service Unit & Bash Completion: Creates and enables a systemd service (thinkfan-extreme.service) and installs bash completion for ease of use.
  • Logging: Detailed logs are written to /var/log/thinkfan-extreme.log.

Installation

  1. Download the Script: Save the deployment script (for example, as /home/$USER/Downloads/thinkfan-extreme.sh).
  2. Make It Executable:
    sudo chmod +x /home/$USER/Downloads/thinkfan-extreme.sh
  3. Run the Script as Root:
    sudo /home/$USER/Downloads/thinkfan-extreme.sh
  4. Reboot the System: A reboot is recommended to ensure all kernel and module changes are applied.

Exemple of config file

# Exemple of how to set up your config file

# Critical temperature in millidegrees Celsius (75000 = 75°C) #CRITICAL_TEMP=75000

# Temperature thresholds for each fan level (in millidegrees Celsius). #declare -A level_threshold #level_threshold[0]=40000 #level_threshold[1]=45000 #level_threshold[2]=50000 #level_threshold[3]=55000 #level_threshold[4]=60000 #level_threshold[5]=65000 #level_threshold[6]=70000 #level_threshold[7]=75000

# Critical temperature in millidegrees Celsius (76000 = 76°C) CRITICAL_TEMP=76000

# Temperature thresholds for each fan level (in millidegrees Celsius). declare -A level_threshold level_threshold[0]=40000 level_threshold[1]=45000 level_threshold[2]=50000 level_threshold[3]=55000 level_threshold[5]=65000 level_threshold[6]=70000 level_threshold[7]=76000

Thinkfan-Extreme Deep Dive

This Bash script automates the deployment and configuration of a custom fan control solution for ThinkPad laptops. It ensures proper ACPI settings and installs a custom fan control script (thinkfan-ex), a systemd service unit, and bash completion for enhanced command-line usability.

Features

  • Root Privilege Verification: The script checks that it’s run as root.
  • ACPI Configuration: Ensures /etc/modprobe.d/thinkpad_acpi.conf contains fan_control=1 (with backup creation if needed).
  • GRUB Boot Parameter Update: Appends thinkpad_acpi.fan_control=1 to the kernel boot parameters and runs update-grub.
  • Kernel Module Management: Reloads the thinkpad_acpi module if possible, or advises a reboot if the module is built into the kernel.
  • Custom Fan Control Script: Installs thinkfan-ex which:
    • Dynamically reads temperature sensor files.
    • Maps temperatures to discrete fan levels (0 to 7, or “level disengaged” for critical temperatures).
    • Supports command-line options:
      • -status: Displays current fan status and sensor temperature readings.
      • -config: Opens the configuration file (/etc/thinkfan-extreme.conf) for editing.
      • -uninstall: Uninstalls the fan control setup, disables its systemd service, reverts GRUB changes, and removes bash completion.
      • -help or --help: Shows usage information.
  • Systemd Service Unit: Creates and enables thinkfan-extreme.service to run thinkfan-ex continuously at boot.
  • Bash Completion: Installs a bash completion file for streamlined command usage.
  • Logging: Detailed events are logged to /var/log/thinkfan-extreme.log for troubleshooting.

Requirements

  • ThinkPad ACPI Kernel Module: Must be loaded with fan_control=1.
  • Root Access: Both the deployment script and the installed components require root privileges.
  • GRUB Update: Kernel boot parameter changes will need a reboot to take effect.

Usage

Once installed, the custom fan control script (thinkfan-ex) will run as a service at boot. It continuously monitors temperature sensors and adjusts fan speeds accordingly.

Command-Line Options for thinkfan-ex

  • -status: Display the current fan control status and sensor temperature readings.
  • -config: Open the configuration file (/etc/thinkfan-extreme.conf) for editing.
  • -uninstall: Uninstall thinkfan-ex, disable its systemd service, revert GRUB changes, and remove bash completion.
  • -help or --help: Show usage information and available options.

Uninstallation

To remove the fan control setup, run:

sudo thinkfan-ex -uninstall

This command will:

  • Stop and disable the systemd service.
  • Remove the thinkfan-ex script and bash completion.
  • Revert the GRUB boot parameter changes.

Logging

All events during deployment are logged to /var/log/thinkfan-extreme.log. Check this file for troubleshooting or to verify successful configuration. To continuously monitor the log, use:

tail -f /var/log/thinkfan-extreme.log

Notes

  • Module Reloading: If the thinkpad_acpi module is built into your kernel (and thus cannot be reloaded), a reboot is required for configuration changes to take effect.
  • Fan Control Verification: After configuration, the script displays current fan settings from /proc/acpi/ibm/fan.

License

This project is licensed under the MIT License.

Author

Bruno Bellizzi Grande

Last updated: March 10, 2025

About

Thinkfan-extreme, a script to ensure that any T480 with MX150 doesn't reach the temperature of the sun

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages