Lenovo ThinkPad T490s: a Battery Review Under Linux
It’s been a while since I decided to get a new laptop and, finally, the replacement to my MacBook Pro mid-2014 came in the mail last Monday (April 21st, 2020). The selected laptop has been a Lenovo ThinkPad T490s, and I decided to use it entirely with Linux.
In this post I will link some power management tweaks and explain them, as well as some other tips and resources, and analyse how this laptop battery performs using Ubuntu 20.04.
TL;DR – Too Long; Didn’t Read
The battery life of this integrated GPU laptop can comfortably last a whole 9 to 5 day for a developer-like job, with CPU demand peaks here and there, like building binaries and running automated tests. That kind of usage also includes browsing static documentation and not very fancy sites like Stack Overflow connected to a WiFi, and streaming music to a bluetooth headset to get in the flow.
When it comes to browser-based jobs, like online publishing or editing, the battery life can drop a bit but I still believe that it can make the day if we are not too much into graphics and animation-oriented web publishing.
We have to be careful about the choices we make with regards to the browser we use, and take some precautions against parasitic browser code like tracking and advertising. These things are draining our battery and making our laptop work for someone else, and that’s definitely something to avoid.
Hardware and OS in Brief
This laptop has the following configuration:
Item | Value |
---|---|
Processor | Intel i7-8665U @ 1.9 GHz |
Memory | 32 GB DDR4 at 2400 MHz, soldered |
Storage | 1 TB M.2 2280 NVMe TLC OPAL |
Graphics | Integrated Intel UDH Graphics 620 |
Display | 14”, 1920 x 1080, IPS Mate, 250 Nit |
Batteru | 3 cell 57W |
OS Shipped | Windows 10 Pro |
OS Used | Ubuntu 20.4 LTS (no dual boot) |
Kernel | 5.4.0-26-generic |
Undervolt | No |
Here’s the neofetch
output with the laptop totally idle, hence the 400MHz frequency for the processor (with turbos, pedal to the metal, and so, it can scale up to 4.8 GHz):
The laptop came with Windows 10 Pro, which is an operating system that I like. The reason I switched to Linux is the nature of my work with the laptop, which is more inclined towards Unix.
The initial configuration was a dual boot between elementary OS and Windows 10. After a week of not booting Windows more than for a few tests, and suffering some very annoying 3 year old bugs when connecting an external display to the laptop, I decided to change the layout of my disk to 100% Linux, switch to Ubuntu to avoid bugs, and no Windows.
Energy Configuration
Linux has evolved quite nicely when it comes to manage the power consumption of a laptop. The packages tlp
and powertop
give a lot of control over the energy management of modern computers, and some nice specific extensions for the ThinkPads.
Although out of the box those packages give a nice performance, it is recommended to tweak their configuration a little and the ThinkPad subreddit has a very useful wiki page with instructions to follow.
For my laptop, at the moment of writing this post, this is the scripted configuration I applied right after installing the system. It is just an automation over the aforementioned wiki, to most of its extent, only omiting the packages and modules that don’t work for this model.
#!/bin/bash
# THIS IS SPECIFIC FOR THINKPAD LAPTOPS.
if [ $EUID != 0 ]; then
sudo "$0" "$@"
exit $?
fi
apt update
apt -y install software-properties-common
# PPA for TLPUI
add-apt-repository ppa:linuxuprising/apps
apt update
apt -y install tlp tlpui acpi-call-dkms tlp-rdw powertop
powertop calibrate
rm -f /etc/systemd/system/powertop.service
echo "[Unit] " >> /etc/systemd/system/powertop.service
echo "Description=Powertop tunings " >> /etc/systemd/system/powertop.service
echo " " >> /etc/systemd/system/powertop.service
echo "[Service] " >> /etc/systemd/system/powertop.service
echo "Type=idle " >> /etc/systemd/system/powertop.service
echo "ExecStart=/usr/sbin/powertop --auto-tune " >> /etc/systemd/system/powertop.service
echo " " >> /etc/systemd/system/powertop.service
echo "[Install] " >> /etc/systemd/system/powertop.service
echo "WantedBy=multi-user.target " >> /etc/systemd/system/powertop.service
systemctl enable --now powertop
systemctl enable --now tlp.service
You can find a bunch of scripts in one of my GitHub repos. They are not a software masterpiece, just automation to ease the set up of a new Linux installation.
After doing this, as my script-fu is not as good as needed to automate the patching of a file, I modified the tlp
configuration by hand to apply the following:
- Set up
MAX_LOST_WORK_SECS_ON_BAT
to 15, with either TLPUI under “Disks”, or with a configuration file that will depend on the Linux distribution used. In case of Ubuntu, these files are:/etc/default/tlp
for Ubuntu 18.04 LTS/etc/tlp.conf
for Ubuntu 20.04 LTS
- Set up some battery thresholds for my target usage. More on this later; it won’t affect the figures.
That is, fundamentally, the energy configuration of my laptop.
Final Preparation: a Few Days of Battery Warm-Up
I used the laptop for a total of 4 cycles, that is, an equivalent of 4 full discharges and charges back to 100%. One of them was a recalibration of the battery gauge, something that is supported by the hardware of the ThinkPads and that works at follows:
- Plug the ThinkPad with the AC Adapter to a power outlet.
- Open a terminal and run
sudo tlp recalibrate BAT0
- The terminal will clear and some statistics will show during the process.
- Do not close the terminal
- Do not unplug the laptop
- The laptop, despite being plugged, will make use of the battery to force a full discharge.
- Use the laptop normally.
- When discharged completely:
- The laptop won’t power off
- It will automatically begin to charge the battery, as it is plugged in.
- The terminal will notice it, and it will ask to not unplug the laptop until it reaches 100% charge.
At that moment I left it alone, powered on and with the lid closed, and I just did other things. I suppose that you can use the laptop normally, though.
In Windows 10, battery gauge recalibration can be done with Lenovo Vantage.
The Measures
I set up the brightness to 25% (comfortable for dark themes), connected my headset, and went on a battery ride. What I did was to run some scenarios for a number of minutes (2 to 5) in order to stabilize the measures by getting to a sort of “permanent regime”, and then check the power drain with sudo powertop
in a terminal. With that drainage measured in Watts, I did some basic arithmetic with the battery total capacity (57 W nominal).
This ThinkPad has the following power behaviour on a battery:
Scenario | Drain | Comments |
---|---|---|
Suspended | 0.7%/hour | About 5 times a new Macbook Pro. Not so good. |
Idle | 2.98 W | That’s an impressive 19:07 hours (57/2.98) |
Browser, VS Code, Bluetooth Audio | 5.5 W | This offers 10:21 hours and is my blogging set up. Check below |
PyCharm, Browser, Bluetooth Audio | 4.8 W | This offers about 11:50 hours |
Twitter scroll, Bluetooth Audio | 8 W | Down to 7 hours |
Bulding a Linux Kernel | 17.6 W | 3:13 hours. This is not the kind of thing you’d do on battery |
The table in this section is just to give you an idea about the toll of a single scenario when the laptop has achieved “its flow” while doing it: programs loaded, caches are stable, memory has been allocated, and then the power regime gets stable. It doesn’t mean that you will stay within one of these scenarios for the whole day, because we jump from one to another. And also covers a very specific usage, developer oriented.
The first row is worth to mention. I come from using a MacBook Pro from mid-2014, and I remember being able to close the lid and have pretty much the same battery the next day, or maybe 1% or 2% less after a whole night suspended. That was possible for about 3 years, but not since Mojave due to (I suppose) Apple’s shift of attention to newer models. The ThinkPad T490s does a not so good 5% to 10%, depending on how much you sleep, and when did you close the lid the previous day. A point would be to be able to further research whether this is due to the laptop design or Linux’.
A few considerations about my blogging set up so you can compare it to some scenarios of yours. I use Jekyll to prepare a static blog that gets uploaded to GitHub Pages by means of git. Jekyll is a static webite framework written in Ruby, and it is based on the usage of Markdown. To edit, I use Visual Studio Code with a preview panel always there, and I have running bundle exec jekyll serve
in the background. That rebuilds the whole site every time I save a Markdown file. That way I can check the posts on a browser that points to my machine. Here’s how it looks:
It’s a bit nerdy and quite power efficient.
If you are in different scenarios, you can try to get the measures using the same method and draw your own conclusions, but to me the above measures mean that the laptop will keep up with the whole day in many cases.
Network Factors that will Influence the Battery Life
The network traffic is very energy-hungry. Nowadays, the network cards manage the power very efficiently to reduce their standby power usage, but when they have to intensely download information in a non-optimised way (e.g., many HTTP requests are much worse than streaming a Spotify playlist), they use their fair amount of energy.
Try to reduce your network-intensive activity while on a battery. Examples, more or less obvious, are:
- Do not update the system on a battery (clearly!)
- Do not update or refresh the dependencies of your software proyects while on the go
- Do not decide that it’s a good time to synchronize a lot of new folders from your cloud provider
- Do not clear caches. Also, incognito windows are more energy-expensive.
- Be very careful with scripted software repositories that, if need something from the internet, will download a stupid amount of libraries, one by one, to build that something.
rvm
is one of them, I use it to blog in this site (runs on Jekyll), and when it does that, the laptop fans literally go bananas.
I very aggressively block all the advertisement at my home network with a Pi-hole. Also, I use Firefox with the shields up for any website that works well with all the blockers that the browser includes out of the box.
These last two factors will have a dramatic impact on the energy that each of the browser tabs will drain from the battery, and it’s something I recommend: block the advertisement, save battery and reduce your emissions.
Extending the Life of the Battery with the Charge Thresholds
Most consumer laptops will stop charging the battery at 100%, and won’t charge it back unless the battery charge level drops below a slightly smaller percentage, often 96%.
While those thresholds are also the factory configurations of the ThinkPads, these laptops allow the user to establish a different charge thresholds. This is useful for extending the life of the battery as a component; Li-Ion batteries are known to be best preserved when the charge level is between 60% and 80%. Therefore, if you are not going to use the laptop on battery that much, this is a good thing to do.
When you set a different set of thresholds for a ThinkPad, like 60% and 80%:
- The battery won’t charge unless the battery charge level falls below 60%, hence, if your battery level is 67% and you plug AC adapter, the laptop will switch to AC power mode, but the battery won’t charge at all.
- When a charge is triggered because the carge falls below 60% and you plug the AC adapter, it will charge all the way to 80% and stop there.
- All the rest of the time, the laptop works on AC: if the battery level anything higher than 60%, the machine will use the adapter power, and the battery will be… just disconnected.
This is very useful, kind to the battery, and definitely another very nice perk of these laptops.
To do this under Linux, you can manage these values with either TLPUI, or with the tlp
configuration file. These files are:
/etc/default/tlp
for Ubuntu 18.04 LTS/etc/tlp.conf
for Ubuntu 20.04 LTS
Check your distribution documentation in any other case.
The values you want to uncomment and tweak are the following for the internal battery, BAT0
(BAT1
is a specific external one):
START_CHARGE_THRESH_BAT0="60"
STOP_CHARGE_THRESH_BAT0="80"
These values can be temporally modified by commands like sudo tlp fullcharge BAT0
or sudo tlp START_CHARGE BAT0 75
. If you want the defaults to be restored every time you go on a battery ride, keep going and uncomment the following and set it to 1:
RESTORE_THRESHOLDS_ON_BAT="1"
Once you do this, these values will be configured system-wide, at some place external to the OS; I’m not sure if it is the UEFI, the system’s NVRAM or a NVRAM in the battery or in the power subsystem, but they will affect other Operating Systems in the machine.
As for the battery recalibration, in Windows 10 all these changes are done with Lenovo Vantage.