2024-12-05 17:30:33 +00:00
|
|
|
---
|
2024-12-09 11:05:02 +00:00
|
|
|
title: Lenovo ThinkPad T480/T480s information
|
2024-12-05 17:30:33 +00:00
|
|
|
x-toc-enable: true
|
|
|
|
...
|
|
|
|
|
2024-12-09 11:05:02 +00:00
|
|
|
Libreboot supports both the T480 and T480s variants. It is available in
|
2024-12-06 10:00:37 +00:00
|
|
|
the *Libreboot 20241206* release or later.
|
2024-12-05 17:30:33 +00:00
|
|
|
|
|
|
|
**[PLEASE READ THESE INSTRUCTIONS BEFORE INSTALLING](../../news/safety.md),
|
|
|
|
OR YOU MIGHT BRICK YOUR MACHINE: [SAFETY PRECAUTIONS](../../news/safety.md)**
|
|
|
|
|
|
|
|
<div class="specs">
|
|
|
|
<center>
|
|
|
|
<img tabindex=1 alt="ThinkPad T480" class="p" src="https://av.libreboot.org/t480/t480.jpg" /><span class="f"><img src="https://av.libreboot.org/t480/t480.jpg" /></span>
|
|
|
|
</center>
|
|
|
|
|
|
|
|
| ***Specifications*** | |
|
|
|
|
|----------------------------|------------------------------------------------|
|
2024-12-09 11:05:02 +00:00
|
|
|
| **Manufacturer** | Lenovo |
|
|
|
|
| **Name** | ThinkPad T480 |
|
|
|
|
| **Variants** | ThinkPad T480, ThinkPad T480s |
|
2024-12-05 17:30:33 +00:00
|
|
|
| **Released** | 2018 |
|
2024-12-09 11:05:02 +00:00
|
|
|
| **Chipset** | Intel Kaby Lake Refresh |
|
|
|
|
| **CPU** | Intel Kaby Lake Refresh |
|
|
|
|
| **Graphics** | Intel or Intel+Nvidia |
|
|
|
|
| **Memory** | DDR4 DIMMs; max 40GB (T480s), 64GB(T480) |
|
|
|
|
| **Architecture** | x86\_64 |
|
|
|
|
| **Original boot firmware** | Lenovo UEFI firmware |
|
|
|
|
| **Intel ME/AMD PSP** | Present. Can be disabled with me\_cleaner. |
|
|
|
|
| **Intel Boot Guard** | [Pwned](deguard.md). Disabled using the deguard utility.|
|
|
|
|
| **Flash chip** | SOIC-8 16MB/128Mbit system firmware |
|
2024-12-05 17:30:33 +00:00
|
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
W+: Works without blobs;
|
|
|
|
N: Doesn't work;
|
|
|
|
W*: Works with blobs;
|
|
|
|
U: Untested;
|
|
|
|
P+: Partially works;
|
|
|
|
P*: Partially works with blobs
|
|
|
|
?: UNKNOWN AT THIS TIME
|
|
|
|
```
|
|
|
|
|
|
|
|
| ***Features*** | |
|
|
|
|
|---------------------------------------------------|----|
|
2024-12-09 11:05:02 +00:00
|
|
|
| **Internal flashing with original boot firmware** | N |
|
2024-12-05 17:30:33 +00:00
|
|
|
| **Display (if Intel GPU)** | W+ |
|
2024-12-09 11:05:02 +00:00
|
|
|
| **Display (discrete CPU, SeaBIOS payload only)** | N |
|
2024-12-05 17:30:33 +00:00
|
|
|
| **Audio** | W+ |
|
|
|
|
| **RAM Init** | W* |
|
|
|
|
|
|
|
|
| ***Payloads supported*** | |
|
|
|
|
|----------------------------|-----------|
|
|
|
|
| **GRUB (libgfxinit only)** | Works |
|
|
|
|
| **SeaBIOS** | Works |
|
|
|
|
| **SeaBIOS with GRUB** | Works |
|
|
|
|
</div>
|
|
|
|
|
2024-12-09 11:05:02 +00:00
|
|
|
Regarding memory: T480s (S model) has 8GB onboard RAM, and an available DIMM
|
2024-12-05 17:30:33 +00:00
|
|
|
slot on which an additional 32GB SODIMM can be installed. The regular T480
|
|
|
|
has two DIMM slots, allowing 2x32GB DDR4 SODIMMs.
|
|
|
|
|
2024-12-05 17:44:12 +00:00
|
|
|
Thanks go to *Mate Kukri* who implemented both of these excellent coreboot
|
|
|
|
ports; he is also the author of the deguard utility, which is used to disable
|
|
|
|
the Intel Boot Guard on these machines; disabling the Boot Guard was necessary
|
|
|
|
in order to get coreboot working!
|
|
|
|
|
2024-12-13 04:30:19 +00:00
|
|
|
Buy pre-installed
|
|
|
|
=================
|
|
|
|
|
|
|
|
**ThinkPad T480/T480S is available to purchase with Libreboot pre-installed. See:
|
|
|
|
<https://minifree.org/product/libreboot-t480/>**
|
|
|
|
|
2024-12-05 17:30:33 +00:00
|
|
|
Introduction
|
|
|
|
============
|
|
|
|
|
|
|
|
**Unavailable in Libreboot 20241008 or earlier. You must [compile from
|
2024-12-06 10:00:37 +00:00
|
|
|
source](../build/), or alternatively an image from Libreboot 20241206 or higher.
|
2024-12-05 17:30:33 +00:00
|
|
|
|
|
|
|
Official information about the T480 can be found here:\
|
|
|
|
<https://psref.lenovo.com/syspool/Sys/PDF/ThinkPad/ThinkPad_T480/ThinkPad_T480_Spec.PDF>
|
|
|
|
|
2024-12-09 11:05:02 +00:00
|
|
|
...and information about the T480s can be found here:\
|
2024-12-05 17:30:33 +00:00
|
|
|
<https://psref.lenovo.com/syspool/Sys/PDF/ThinkPad/ThinkPad_T480s/ThinkPad_T480s_Spec.pdf>
|
|
|
|
|
2024-12-09 11:05:02 +00:00
|
|
|
This port is implemented in Libreboot by merging Mate Kukri's T480/T480s
|
2024-12-05 22:06:36 +00:00
|
|
|
patchset. See: <https://review.coreboot.org/c/coreboot/+/83274> - as of 5
|
|
|
|
December 2024, Libreboot's code matches that of patchset 22.
|
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
Absolutely unsigned Intel ME!
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
Libreboot already disables the Intel ME by default, using `me_cleaner`, but
|
|
|
|
the T480/T480s specifically have an additional quirk:
|
|
|
|
|
|
|
|
One of the benefits of [deguard](deguard.md) for Intel MEv11 is that it sets
|
|
|
|
the ME in such a state where you can run unsigned code in there. This is how
|
|
|
|
the Intel Boot Guard was disabled, because it is the ME that enforces such
|
|
|
|
restrictions; more information about deguard is available on a dedicated page.
|
|
|
|
|
|
|
|
The deguard utility could also be used to enable the red-unlock hack, which
|
|
|
|
would permit unsigned execution of new CPU microcode, though much more
|
|
|
|
research is needed. Because of these two facts, this makes the T480/T480s the
|
|
|
|
most freedom-feasible of all relatively modern x86 laptops.
|
|
|
|
|
|
|
|
With deguard, you have complete control of the flash. This is unprecedented on
|
|
|
|
recent Intel systems in Libreboot, so it's certainly a very interesting port!
|
|
|
|
|
|
|
|
Libreboot uses both `me_cleaner` *and* `deguard` on the T480/T480s.
|
|
|
|
|
2024-12-05 22:03:35 +00:00
|
|
|
What works in this port:
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
Intel graphics, internal screen, ethernet, USB, WLAN, HDA verbs (e.g. headphone
|
|
|
|
jack), S3 suspend/resume, M2 NVMe SSDs and SATA, **all works perfectly**.
|
|
|
|
External video outputs and webcam also work. Microphone works, line-out works...
|
|
|
|
everything works. UART also available via line-out jack (jumpers required on
|
|
|
|
the mainboard).
|
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
There *are* a few minor exceptions as to what works; this will be covered in
|
|
|
|
other sections of this page. This port is *almost* perfect, but with some caveats.
|
2024-12-05 22:03:35 +00:00
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
Build images from source
|
|
|
|
========================
|
2024-12-05 22:03:35 +00:00
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
Please refer to the standard [build instructions](../build/) first.
|
2024-12-05 17:30:33 +00:00
|
|
|
|
|
|
|
The build target, when building from source, is thus:
|
|
|
|
|
2024-12-29 16:56:19 +00:00
|
|
|
./mk -b coreboot t480_vfsp_16mb
|
|
|
|
./mk -b coreboot t480s_vfsp_16mb
|
2024-12-05 17:30:33 +00:00
|
|
|
|
2024-12-09 11:05:02 +00:00
|
|
|
**NOTE: The T480 and T480s may be similar, but they do have several critical
|
2024-12-05 17:30:33 +00:00
|
|
|
differences in their wiring, so you MUST flash the correct image. Please
|
|
|
|
choose one of the above build targets accordingly.**
|
|
|
|
|
|
|
|
Installation
|
|
|
|
============
|
|
|
|
|
2024-12-06 20:25:36 +00:00
|
|
|
**Insert binary files (DO THIS FIRST)**
|
2024-12-05 17:30:33 +00:00
|
|
|
-------------------
|
|
|
|
|
2024-12-06 20:25:36 +00:00
|
|
|
**If you're using a release ROM**, please ensure that you've inserted extra firmware
|
|
|
|
required. Refer to the [guide](../install/ivy_has_common.md) for that. **(failure
|
2024-12-05 17:30:33 +00:00
|
|
|
to adhere to this advice will result in a BRICKED machine)**
|
|
|
|
|
|
|
|
Libreboot's build system automatically downloads and processes these files if
|
|
|
|
you build Libreboot from source, but the same logic that it uses must be re-run
|
|
|
|
if you're using a release image. This is to bypass certain restrictions on
|
|
|
|
direct distribution, for files such as the Intel Management Engine firmware.
|
|
|
|
|
2024-12-06 20:25:36 +00:00
|
|
|
The pre-compiled images do not contain an Intel ME, so you must first insert it
|
|
|
|
using the above guide. Libreboot's build system automatically grabs it, disables
|
|
|
|
it after boot with `me_cleaner`, and configures it with [deguard](deguard.md)
|
|
|
|
to disable the Intel Boot Guard - this automation is either applied at build
|
|
|
|
time, or you can use it on release images.
|
|
|
|
|
|
|
|
Again:
|
|
|
|
|
|
|
|
If you're [building from source](../build/) via Libreboot's build system, these
|
|
|
|
files are inserted during build. You only need to manually insert them, using
|
|
|
|
the above linked guide, on the pre-compiled release images!
|
|
|
|
|
2024-12-05 17:30:33 +00:00
|
|
|
Set MAC address
|
|
|
|
---------------
|
|
|
|
|
|
|
|
This platform uses an Intel Flash Descriptor, and defines an Intel GbE NVM
|
|
|
|
region. As such, release/build ROMs will contain the same MAC address. To
|
|
|
|
change the MAC address, please read [nvmutil documentation](../install/nvmutil.md).
|
|
|
|
|
|
|
|
**NOTE: If changing the MAC address, please give `ifdtool` the following
|
|
|
|
argument when using it: `--platform sklkbl`** - otherwise, ifdtool will
|
|
|
|
handle the IFD incorrectly!
|
|
|
|
|
|
|
|
Thunderbolt issue (READ THIS BEFORE FLASHING)
|
|
|
|
------------------
|
|
|
|
|
|
|
|
The thunderbolt firmware on launch units had a bug where certain debug
|
|
|
|
info is written on certain events, such as plugging in a charger to the USB-C
|
|
|
|
connector. This logging is stored in the Thunderbolt firmware's own SPI flash,
|
|
|
|
which is separate from the main SPI flash containing the system firmware
|
|
|
|
e.g. coreboot.
|
|
|
|
|
|
|
|
If that flash gets full, thunderbolt (on factory firmware) stops working and
|
|
|
|
fast charging stops working. It can be prevented by updating the Thunderbolt
|
|
|
|
firmware. You can do this from Lenovo's firmware, using these instructions:
|
|
|
|
|
|
|
|
<https://pcsupport.lenovo.com/gb/en/products/laptops-and-netbooks/thinkpad-t-series-laptops/thinkpad-t480s-type-20l7-20l8/solutions/ht508988-critical-intel-thunderbolt-software-and-firmware-updates-thinkpad>
|
|
|
|
|
|
|
|
If you're already affected by the bug, you can restore it to a working state
|
|
|
|
by flashing the Thunderbolt firmware externally. For example this is where its
|
|
|
|
NOR flash is on a T480:
|
|
|
|
|
|
|
|
<img tabindex=1 alt="ThinkPad T480 NOR flash (thunderbolt firmware)" class="p" src="https://av.libreboot.org/t480/t480tbspi.jpg" /><span class="f"><img src="https://av.libreboot.org/t480/t480tbspi.jpg" /></span>
|
|
|
|
|
|
|
|
This page shows how to do that:
|
|
|
|
|
2024-12-18 05:40:30 +00:00
|
|
|
<https://gitlab.com/MobileAZN/lenovo-t480-thunderbolt-firmware-fixes>\
|
|
|
|
**WARNING! Please follow the guide PRECISELY, if you follow it, but please
|
|
|
|
only follow it if your ThunderBolt is already broken. If it isn't, use
|
|
|
|
Lenovo's software-based updater. If you do the external method, you MUST be
|
|
|
|
very careful; the guide there for example says to disable ThunderBolt assist.
|
|
|
|
It also says to erase first, then flash the `null.bin` (file with zeroes in
|
|
|
|
it), then BOOT, and when it boots, power off and re-connect clip again and
|
|
|
|
then flash the padded TBT.bin - whereas, for example, if you simply flashed
|
|
|
|
a padded TBT.bin and nothing else first, and boot, it will be perma-bricked,
|
|
|
|
in that the CPU won't come out of reset (it'll bootloop). We don't yet know
|
|
|
|
how to recover from this brick scenario. So all of this is to say: flashing
|
|
|
|
the ThunderBolt externally is EXTREMELY HAZARDOUS, and should be done with
|
|
|
|
the UTMOST CARE, ideally NOT AT ALL. -- ALSO: the guide only covers T480,
|
|
|
|
but should be similar on T480s and other ThinkPad models.**
|
2024-12-05 17:30:33 +00:00
|
|
|
|
|
|
|
You unbrick the Thunderbolt controller by pulling the firmware from Lenovo's
|
|
|
|
update, from Lenovo's update utility. Once extracted, you then pad it properly
|
|
|
|
so that it can be flashed manually, using a normal SPI flasher (the same one
|
|
|
|
that you would use to flash Libreboot).
|
|
|
|
|
|
|
|
Use the [25XX NOR flashing guide](spi.md) if you need to flash this chip. It's
|
|
|
|
the same guide that you will use for the main system flash, which is a separate
|
|
|
|
flash IC.
|
|
|
|
|
|
|
|
AGAIN: This is not the Libreboot flash IC. This is separate to the system flash.
|
|
|
|
Read on to know how to reprogram the main system flash!
|
|
|
|
|
2024-12-18 05:40:30 +00:00
|
|
|
**AGAIN: It is extremely easy to permanently brick the ThunderBolt controller,
|
|
|
|
rendering your system completely unbootable, if you use the external recovery
|
|
|
|
method. If you're still able to fix it with a software-based flasher like the
|
|
|
|
one Lenovo provides, please use that at all - or simply don't fix it at all,
|
|
|
|
because the machine will at least still charge while it has the ThunderBolt
|
|
|
|
issue, where older firmware is used.**
|
|
|
|
|
2024-12-06 20:25:36 +00:00
|
|
|
Flash a ROM image (software)
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
If you're already running Libreboot, and you don't have flash protection
|
|
|
|
turned on, [internal flashing](../install/) is possible.
|
|
|
|
|
|
|
|
The default Libreboot setup removes all flash restrictions, allowing you to
|
|
|
|
flash internally, from a Linux or BSD systems running on the T480/T480. You must
|
|
|
|
also [disable /dev/mem protections](devmem.md) for internal flashing to work.
|
|
|
|
|
|
|
|
Flash a ROM image (hardware)
|
2024-12-05 17:30:33 +00:00
|
|
|
-----------------
|
|
|
|
|
2024-12-06 20:25:36 +00:00
|
|
|
**First, please assimilate all knowledge in
|
|
|
|
the [25XX NOR flashing guide](spi.md) - it shows how to program these flash
|
|
|
|
chips, using a dedicated flash programmer, which is something that you will
|
|
|
|
physically connect to the flash chip.**
|
|
|
|
|
|
|
|
Again: this is only necessary if you have Lenovo BIOS, or if you enabled [flash
|
|
|
|
write protections](../linux/grub_hardening.md) on an existing Libreboot setup.
|
|
|
|
|
|
|
|
**MAKE SURE to update the Lenovo UEFI firmware before installing Libreboot.
|
2024-12-05 17:30:33 +00:00
|
|
|
You must also make a dump of the NOR flash, before updating Lenovo's firmware,
|
2024-12-06 20:25:36 +00:00
|
|
|
and once again before flashing Libreboot, being sure you have good dumps.**
|
2024-12-05 17:30:33 +00:00
|
|
|
|
2024-12-17 14:37:36 +00:00
|
|
|
**T480: Make sure to use the `n24ur39w` release, when updating Lenovo firmware.
|
|
|
|
Or downgrade to this version. This is because the EC UART support in coreboot
|
|
|
|
specifically taps into the EC code of that release. See:\
|
|
|
|
<https://download.lenovo.com/pccbbs/mobiles/n24ur39w.html>\
|
|
|
|
and it can be downloaded here:\
|
|
|
|
<https://support.lenovo.com/us/en/downloads/ds502355-bios-update-utility-bootable-cd-for-windows-10-64-bit-linux-thinkpad-t480>\
|
|
|
|
NOTE: T480s (S model) doesn't have EC UART support yet, so it doesn't matter
|
|
|
|
yet which version you update to on the S model.**
|
|
|
|
|
2024-12-18 06:16:24 +00:00
|
|
|
Prep a USB stick with it:
|
|
|
|
|
|
|
|
geteltorito -o t480_bios_update.img /path/to/your/downloaded.iso
|
|
|
|
|
|
|
|
Now DD it to the raw USB flash device:
|
|
|
|
|
|
|
|
dd if=t480_bios_update.img of=/dev/sdX bs=4M conv=fsync status=progress
|
|
|
|
|
|
|
|
You must disable SecureBoot, and enable legacy/CSM boot, and boot it in BIOS
|
|
|
|
mode, not UEFI mode. Make sure your battery is well-charged, and boot it with
|
|
|
|
a battery and with the power supply plugged in. Select *option 2* in the menu,
|
|
|
|
to update your BIOS, which also updates the EC firmware. This is the Lenovo
|
|
|
|
BIOS/UEFI updater. Once you've updated, you can flash Libreboot.
|
|
|
|
|
2024-12-06 20:25:36 +00:00
|
|
|
Please ensure also that you've already dealt with the Thunderbolt issue, which
|
2024-12-18 06:16:24 +00:00
|
|
|
is described above. After all of this, you can flash Libreboot.
|
2024-12-05 17:30:33 +00:00
|
|
|
|
|
|
|
Find videos online of how to disassemble this, and/or find Lenovo's own
|
|
|
|
service manual online. Otherwise, observe:
|
|
|
|
|
|
|
|
<img tabindex=1 alt="ThinkPad T480 underside chassis" class="p" src="https://av.libreboot.org/t480/t480bottom.jpg" /><span class="f"><img src="https://av.libreboot.org/t480/t480bottom.jpg" /></span>
|
|
|
|
|
|
|
|
Remove all screws, and you can gently pry off the lower chassis and remove,
|
|
|
|
which then allows you to see the inner mainboard:
|
|
|
|
|
|
|
|
<img tabindex=1 alt="ThinkPad T480 PCB" class="p" src="https://av.libreboot.org/t480/t480pcb.jpg" /><span class="f"><img src="https://av.libreboot.org/t480/t480pcb.jpg" /></span>
|
|
|
|
|
|
|
|
**WARNING: PLEASE MAKE SURE to remove the battery before flashing. The T480
|
2024-12-09 11:05:02 +00:00
|
|
|
and T480s can both contain INTERNAL batteries, and the T480 has an additional
|
2024-12-05 17:30:33 +00:00
|
|
|
external battery. Remove the internal battery via the connector, like so (T480):**
|
|
|
|
|
|
|
|
<img tabindex=1 alt="ThinkPad T480 internal battery" class="p" src="https://av.libreboot.org/t480/t480battery.jpg" /><span class="f"><img src="https://av.libreboot.org/t480/t480battery.jpg" /></span>
|
|
|
|
|
2024-12-09 11:05:02 +00:00
|
|
|
On the T480s (S model) the internal battery is much larger, and the connector
|
2024-12-05 17:30:33 +00:00
|
|
|
on it is built into the battery, so it is necessary to carefully remove the
|
|
|
|
entire battery; on regular T480 (non-S model) the internal battery can be
|
|
|
|
isolated via the connector as depicted above.
|
|
|
|
|
|
|
|
This photo shows the flash:
|
|
|
|
|
|
|
|
<img tabindex=1 alt="ThinkPad T480 NOR flash (system firmware)" class="p" src="https://av.libreboot.org/t480/t480spi.jpg" /><span class="f"><img src="https://av.libreboot.org/t480/t480spi.jpg" /></span>
|
|
|
|
|
|
|
|
There is another flash, for the Thunderbolt firmware, which you are to briefly
|
|
|
|
ignore; we'll cover it later:
|
|
|
|
|
|
|
|
<img tabindex=1 alt="ThinkPad T480 NOR flash (thunderbolt firmware)" class="p" src="https://av.libreboot.org/t480/t480tbspi.jpg" /><span class="f"><img src="https://av.libreboot.org/t480/t480tbspi.jpg" /></span>
|
|
|
|
|
|
|
|
To be clear: the system flash (16MB) is what you put Libreboot on. The
|
|
|
|
Thunderbolt firmware flash is much smaller, so you'll know because flashprog
|
|
|
|
will complain about wrong flash size if you're trying to flash the wrong one.
|
|
|
|
|
2024-12-09 11:05:02 +00:00
|
|
|
On the T480s (S model), the flashes are in slightly different places but in
|
2024-12-05 17:30:33 +00:00
|
|
|
both machines, the system flash (for Libreboot) is toward the centre, near
|
|
|
|
the memory.
|
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
Post-installation
|
|
|
|
=================
|
|
|
|
|
|
|
|
These next sections will tell you how to use certain hardware features, which
|
|
|
|
work a little bit differently due to idiosyncrasies of coreboot.
|
|
|
|
|
|
|
|
How to use the headphone jack
|
|
|
|
--------------
|
|
|
|
|
|
|
|
Sometimes the headphone jack might not work automatically. Simply install
|
|
|
|
the `pavucontrol` program. Under Output Devices, you can select the headphones
|
|
|
|
you've inserted manually.
|
|
|
|
|
|
|
|
If it says "Unplugged", try it anyway. The HDA Verb may be incorrect. This
|
|
|
|
will be investigated and a hotfix patch made to the Libreboot 20241206 images.
|
|
|
|
|
|
|
|
How to use HDMI audio
|
|
|
|
------------------
|
|
|
|
|
|
|
|
You can get audio from Displayport/HDMI, but you must select it manually.
|
|
|
|
For example, you can select it in `pavucontrol` if you're using PulseAudio or
|
|
|
|
PipeWire.
|
2024-12-05 17:30:33 +00:00
|
|
|
|
2024-12-18 05:45:29 +00:00
|
|
|
Touchscreen on T480
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
The touchscreen was tested, and confirmed working. Not all models have it,
|
|
|
|
but it does indeed work perfectly on ones that do.
|
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
How to use backlight controls
|
|
|
|
-----------------------------
|
2024-12-05 17:30:33 +00:00
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
Backlight controls work, via software control (e.g. `xbacklight` utility), but
|
|
|
|
the Fn keys for it don't currently work, as of 6 December 2024.
|
|
|
|
|
|
|
|
You can set the backlight manually, or use a hotkey, depending on your window
|
|
|
|
manager or desktop environment.
|
2024-12-05 17:30:33 +00:00
|
|
|
|
2024-12-29 15:12:25 +00:00
|
|
|
UART (T480 only. Not T480S)
|
2024-12-05 17:30:33 +00:00
|
|
|
----
|
|
|
|
|
2024-12-29 15:12:25 +00:00
|
|
|
**NOT supported on the S model (T480s). Please only do it on a T480.**
|
2024-12-10 23:27:51 +00:00
|
|
|
|
2024-12-29 15:12:25 +00:00
|
|
|
The EC on ThinkPad T480 has a UART available, and it is enabled in coreboot,
|
|
|
|
as used by Libreboot. However, you must use a *specific* EC firmware version.
|
|
|
|
Please read notes elsewhere in this page regarding Lenovo UEFI/EC BIOS updates;
|
|
|
|
an exact version number is referenced, which you must install prior to Libreboot
|
|
|
|
installation.
|
2024-12-05 17:30:33 +00:00
|
|
|
|
2024-12-29 15:12:25 +00:00
|
|
|
Ways to flash the EC firmware from Libreboot have not yet been established. Now,
|
|
|
|
please observe the following photo:
|
2024-12-05 17:30:33 +00:00
|
|
|
|
2024-12-29 15:12:25 +00:00
|
|
|
<img tabindex=1 alt="ThinkPad T480 UART jumpers" class="p" src="https://av.libreboot.org/t480/t480uart.jpg" /><span class="f"><img src="https://av.libreboot.org/t480/t480uart.jpg" /></span>
|
2024-12-05 17:30:33 +00:00
|
|
|
|
2024-12-29 15:15:17 +00:00
|
|
|
You will solder zero-ohm jumpers on the indicated footprints. These correspond
|
2024-12-29 15:12:25 +00:00
|
|
|
to TX and RX, which are connected to the R and L lines on the headphone jack,
|
|
|
|
respectively; a ground will also be available.
|
2024-12-05 17:30:33 +00:00
|
|
|
|
2024-12-29 15:33:54 +00:00
|
|
|
You must solder the zero-ohm jumpers, for UART to work. They are *0201* type
|
|
|
|
jumpers, which are extremely small. Please only do this if you have *excellent*
|
|
|
|
soldering skills because it's easy to goof this up if you're not careful.
|
|
|
|
|
2024-12-29 15:12:25 +00:00
|
|
|
You can hook this up to any 3.3v TTL UART dongle, to get a serial console.
|
2024-12-05 17:30:33 +00:00
|
|
|
|
|
|
|
Idea for 2nd NVMe mod
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
Interestingly, on boards without the Nvidia graphics, the solder pads for all
|
|
|
|
the componentry (including the GPU) is still present, so you could theoretically
|
|
|
|
design a QSB that solders to the right pads, and use it to wire a 2nd NVMe SSD;
|
|
|
|
the port is still enabled in Libreboot even if nothing is plugged into it, so it
|
|
|
|
should just work. (this doesn't actually exist yet, but it is electrically
|
|
|
|
possible, quite feasible to design/manufacture and already supported in the
|
|
|
|
Libreboot firmware in principle, since than PCI-E lane is enabled in the devicetree)
|
|
|
|
|
|
|
|
Mate Kukri came up with this idea. It's a great idea, so it's written here.
|
2024-12-09 11:05:02 +00:00
|
|
|
This mod is possible on both the T480 and T480s, though on T480s there would
|
2024-12-05 17:30:33 +00:00
|
|
|
be less clearance; using a smaller internal battery and having a makeshift
|
|
|
|
NVMe caddy in the remaining space would be how to go about it there. On the
|
|
|
|
regular T480, the existing caddy area could easily fit two NVMe drives.
|
|
|
|
|
2024-12-09 02:23:17 +00:00
|
|
|
Errata
|
|
|
|
======
|
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
Some features either don't work, or are untested, when running Libreboot on
|
|
|
|
the ThinkPad T480 or T480s.
|
|
|
|
|
2024-12-29 14:52:45 +00:00
|
|
|
TPM disabled
|
|
|
|
------------
|
|
|
|
|
|
|
|
The TPM is disabled on this device, to prevent hanging/boot delay in SeaBIOS,
|
|
|
|
due to buggy TPM drivers there.
|
|
|
|
|
|
|
|
Legacy 8254 timer
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
Legacy 8254 timer enabled in coreboot, to prevent SeaBIOS from hanging.
|
|
|
|
|
|
|
|
HyperThreading on T480/T480s
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
Also called SMT. This is a feature where you get 2 threads on a single core.
|
|
|
|
It can improve performance in some workloads, but is actually a performance
|
|
|
|
liability in others, depending on your OS kernel/scheduler and the actual
|
|
|
|
workload.
|
|
|
|
|
|
|
|
It is a security liability, due to the Spectre/Meltdown attacks, so we
|
|
|
|
recommend turning it off, at the very least from your running operating system.
|
|
|
|
On *this* platform, you can easily turn it off from coreboot.
|
|
|
|
|
|
|
|
**Libreboot disables HyperThreading by default**, from Libreboot 20241206 rev8
|
|
|
|
onward, on this board. To turn it back on, please [build from source](../build/)
|
|
|
|
and before running the build command, do this:
|
|
|
|
|
|
|
|
./mk -m coreboot t480_vfsp_16mb # replace t480 with t480s if needed
|
|
|
|
|
|
|
|
In the menu that appears, go *Chipset -> Enable Hyperthreading* and turn it on.
|
|
|
|
Then exit from the menu, saving the config where prompted. You will see this
|
|
|
|
menu twice, because there are *two* configs for each of these boards.
|
|
|
|
|
|
|
|
SMT is rarely of benefit in practise, but can be useful in some circumstances.
|
|
|
|
For example, if you're compiling a large codebase from source that takes hours,
|
|
|
|
SMT increases the building speed by about 15 percent; for example, a 3 hour
|
|
|
|
build job might take about 2 hours and 40 minutes instead.
|
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
NFC support in T480
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
Some T480 models might have NFC support but this is untested in Libreboot, and
|
|
|
|
probably dosen't work in current Libreboot releases.
|
|
|
|
|
|
|
|
The PCH's NFC device is unsupported in Linux anyway.
|
|
|
|
|
|
|
|
Smartcard reader
|
|
|
|
----------------
|
|
|
|
|
|
|
|
The smartcard reader is enabled but it is still untested. If you have one,
|
|
|
|
please test it and report back to the Libreboot project.
|
|
|
|
|
|
|
|
Thunderbolt not supported yet
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
Thunderbolt is a way to get PCI-E on a USB port. With it, you can use
|
|
|
|
high-bandwidth devices such as 10Gbps network interfaces.
|
|
|
|
|
|
|
|
The thunderbolt controller is currently unconfigured, so you can't use
|
|
|
|
Thunderbolt, but the thunderbolt and regular USB-C connector can both be
|
|
|
|
used for charging, and both can be used for video output (it shows up in xrandr
|
|
|
|
as a DisplayPort).
|
|
|
|
|
2024-12-10 23:43:48 +00:00
|
|
|
[This patch](t480-thunderbolt-20241206-unstable.patch) can be added, enabling
|
2024-12-10 23:27:51 +00:00
|
|
|
Thunderbolt, but be warned: it is completely untested, as of Libreboot 20241206.
|
|
|
|
This patch is *NOT* included in the release, because it breaks on S3 resume,
|
|
|
|
and may cause a kernel panic. Also: currently testing only reveals that the
|
2024-12-18 05:50:01 +00:00
|
|
|
ThunderBolt controller shows up.
|
2024-12-10 23:27:51 +00:00
|
|
|
|
|
|
|
You also need the [gerrit patch](https://review.coreboot.org/c/coreboot/+/75286)
|
|
|
|
adding a Thunderbolt driver to coreboot.
|
|
|
|
|
2024-12-10 23:42:48 +00:00
|
|
|
To apply these patches, do the following in a fresh clone of `lbmk.git` and do:
|
|
|
|
|
|
|
|
```
|
|
|
|
git checkout 20241206-t480-thunderbolt-unstable
|
|
|
|
```
|
|
|
|
|
|
|
|
In it, you'll find this commit:
|
|
|
|
|
|
|
|
```
|
|
|
|
commit 3881160b863ff53df9064a29a25aab55c76ee9c4 (HEAD -> 20241206-t480-thunderbolt-unstable)
|
|
|
|
Author: Leah Rowe <leah@libreboot.org>
|
|
|
|
Date: Tue Dec 10 23:35:47 2024 +0000
|
|
|
|
|
|
|
|
experimental/unstable t480 thunderbolt support
|
|
|
|
|
|
|
|
Signed-off-by: Leah Rowe <leah@libreboot.org>
|
|
|
|
```
|
|
|
|
|
|
|
|
This was created by the following steps, applying the patches referenced above
|
|
|
|
and amending the coreboot configs for T480/T480s, within lbmk, from a fresh
|
|
|
|
clone of lbmk (Git repository):
|
2024-12-10 23:27:51 +00:00
|
|
|
|
|
|
|
```
|
|
|
|
git reset --hard b910424b5df8ed7c931a7b8f5cc8e34eacf0ca3e # 20241206rev2
|
|
|
|
./mk -f coreboot next
|
|
|
|
cd src/coreboot/next
|
|
|
|
wget https://libreboot.org/docs/install/t480-thunderbolt-20241206-unstable.patch
|
|
|
|
git fetch https://review.coreboot.org/coreboot refs/changes/86/75286/12 && git cherry-pick FETCH_HEAD
|
|
|
|
git am t480-thunderbolt-20241206-unstable.patch
|
2024-12-10 23:42:48 +00:00
|
|
|
git format-patch -n2
|
|
|
|
mv 0001-drivers-intel-dtbt-Add-discrete-Thunderbolt-driver.patch ../../../config/coreboot/next/patches/0010-drivers-intel-dtbt-Add-discrete-Thunderbolt-driver.patch
|
|
|
|
mv 0002-thunderbolt-fix-ish.patch ../../../config/coreboot/next/patches/0011-thunderbolt-fix-ish.patch
|
2024-12-10 23:27:51 +00:00
|
|
|
cd -
|
|
|
|
./mk -u coreboot t480s_fsp_16mb
|
|
|
|
./mk -u coreboot t480_fsp_16mb
|
2024-12-10 23:42:48 +00:00
|
|
|
git add config/coreboot/next/patches/
|
|
|
|
git add config/coreboot/t480_fsp_16mb/
|
|
|
|
git add config/coreboot/t480s_fsp_16mb/
|
|
|
|
git commit -s -m "experimental/unstable t480 thunderbolt support"
|
2024-12-10 23:27:51 +00:00
|
|
|
```
|
|
|
|
|
2024-12-29 16:56:19 +00:00
|
|
|
**NOTE: With the above change, or if using the branch referenced below,
|
|
|
|
the build targets will be `t480_fsp_16mb` and `t480s_fsp_16mb`,
|
|
|
|
not `t480_vfsp_16mb` and `t480s_vfsp_16mb`; see notes regarding fsp/vfsp
|
|
|
|
elsewhere on this page. This branch also does not contain other fixes from
|
|
|
|
Libreboot 20231206 rev8/newer, since it's based on 20241206 rev2. A rebase will
|
|
|
|
not be conducted; instead, ThunderBolt PCI-E support will simply be added in
|
|
|
|
a subsequent release, and revision to the 20241206 release.**
|
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
You can now follow standard [build instructions](../build/).
|
|
|
|
|
|
|
|
The branch named `20241206-t480-thunderbolt-unstable` already has the above
|
|
|
|
patches applied, including the configuration changes made by `./mk -u`, and
|
|
|
|
you can follow the same build instructions. In this lbmk branch, that
|
|
|
|
gerrit patch above (`refs/changes/86/75286/12`) is already included.
|
2024-12-09 02:23:17 +00:00
|
|
|
|
2024-12-10 23:27:51 +00:00
|
|
|
Whether you use the lbmk branch, or you add the patches manually as above,
|
|
|
|
you can then flash the resulting image and boot it.
|
|
|
|
|
|
|
|
**AGAIN: This will likely cause kernel panics, and it will break on resume
|
|
|
|
from S3 (resume from sleep). If you do test this, please report whether
|
|
|
|
the Thunderbolt devices actually work, but remember that you must NOT suspend
|
|
|
|
or put your machine to sleep.**
|
|
|
|
|
|
|
|
Nvidia dGPU not supported
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
Nvidia dGPU doesn't work and is disabled as of 6 December 2024; the Intel graphics
|
|
|
|
are still available even on Nvidia models, so Intel graphics are used.
|
|
|
|
|
|
|
|
WWAN slot untested.
|
|
|
|
|
|
|
|
`thinkpad_acpi` issues {#thinkpad-acpi}
|
|
|
|
---------------------------------------
|
|
|
|
|
|
|
|
It has been reported that `thinkpad_acpi` does not load correctly on the T480.
|
|
|
|
This should also be the case for the T480s.
|
|
|
|
|
|
|
|
If you encounter this issue, check\
|
|
|
|
[this page](../../faq.md#thinkpad-acpi)
|
|
|
|
for details as to how to fix this.
|
2024-12-09 02:23:17 +00:00
|
|
|
|
2024-12-29 16:56:19 +00:00
|
|
|
Intel FSP copyright
|
|
|
|
===================
|
|
|
|
|
|
|
|
Abstract
|
|
|
|
--------
|
|
|
|
|
|
|
|
The initial Libreboot 20241206 release included Intel FSP directly inside the
|
|
|
|
ROM images. Intel provides the FSP under a license which states (and I
|
|
|
|
paraphrase): you must not modify it, but you can redistribute it freely, so
|
|
|
|
long as the license notice is retained.
|
|
|
|
|
|
|
|
The FSP is a concatenation of three modules: FSP-T, FSP-S and FSP-M. T basically
|
|
|
|
does CAR, S is essentially romstage components, and M is raminit. Due to how
|
|
|
|
coreboot works, these components must be split into single components. Coreboot
|
|
|
|
doesn't use T by default (it implements CAR itself), but has the option to
|
|
|
|
use it. It will use M and S, only.
|
|
|
|
|
|
|
|
Technically, the process of splitting FSP into these three files counts as
|
|
|
|
a modification. Furthermore, coreboot also rebases the M module by modifying
|
|
|
|
certain pointers, so that it can integrate with coreboot to provide raminit.
|
|
|
|
|
|
|
|
Intel *themselves* own the copyright to the tool for splitting FSP,
|
|
|
|
at `3rdparty/fsp/Tools/SplitFspBin.py`, and it seems that they do intend for
|
|
|
|
the FSP to be used this way. However, until now, those using the Intel FSP
|
|
|
|
have built coreboot images from source, so the issue of modified distributions
|
|
|
|
didn't come up.
|
|
|
|
|
|
|
|
By the strictest possible interpretation of Intel's licensing, Libreboot was
|
|
|
|
technically in violation. To mitigate this, Libreboot 20241206 *revision 8* and
|
|
|
|
newer, will no longer include the Intel FSP inside images. Instead, the vendor
|
|
|
|
inject script is used for inserting the FSP into release images, which is what
|
|
|
|
we already do for several other components.
|
|
|
|
|
|
|
|
`_fsp` vs `_vfsp` targets
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
The original 20241206 release images had `_fsp` in the file name. From rev8
|
|
|
|
onward, `_vfsp` is specified instead.
|
|
|
|
|
|
|
|
Libreboot's inject script verifies checksums on files, when inserting into the
|
|
|
|
images. Because of this, if we inject FSP after the fact, that means anyone
|
|
|
|
using the old images will find errors when they try.
|
|
|
|
|
|
|
|
To mitigate this, the build targets containing `_fsp` in the name have been
|
|
|
|
retained, but these targets are set `release="n"` so that no ROM images are
|
|
|
|
provided in releases. The `_vfsp` images are provided pre-compiled, instead.
|
|
|
|
|
|
|
|
With this re-design, modern lbmk (from Libreboot 20241206 rev8 onward) can still
|
|
|
|
reliably inject Intel ME into the old `_fsp` images, if you already downloaded
|
|
|
|
those before.
|
|
|
|
|
|
|
|
Therefore, you must be especially careful to get this right. If you're running
|
|
|
|
the inject script into a tarball, it will generally detect the right one, but
|
|
|
|
inserting manually into individual image files is also possible; if you do this,
|
|
|
|
you must remember to correctly specify `t480_vfsp_16mb` or `t480s_vfsp_16mb`,
|
|
|
|
or to specify the `_fsp` targets if you're doing this on older images.
|
|
|
|
|
|
|
|
It is extremely unlikely that Intel would have ever cracked down on Libreboot
|
|
|
|
for its previous mistake, since many other projects exist that include FSP
|
|
|
|
directly in coreboot images, even commercially. However, Libreboot wishes to
|
|
|
|
respect Intel's license, in the
|
|
|
|
most [technically correct](https://www.youtube.com/watch?v=0ZEuWJ4muYc) way
|
|
|
|
possible.
|