-
Notifications
You must be signed in to change notification settings - Fork 29
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Laptop Hardware Security #244
Draft
TommyTran732
wants to merge
60
commits into
main
Choose a base branch
from
Laptop-Hardware-Security
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Draft
Changes from all commits
Commits
Show all changes
60 commits
Select commit
Hold shift + click to select a range
c4fefac
Laptop Hardware Security
TommyTran732 846bec0
Finish the sentence
TommyTran732 ad00063
Update layout
TommyTran732 62bbf51
Update layout
TommyTran732 4f27657
RYF
TommyTran732 ad183cc
Typo fix
TommyTran732 87ccf0f
Typo fix
TommyTran732 009b9ab
Reword
TommyTran732 141fe62
Typo fix
TommyTran732 f98c309
Update text
TommyTran732 e81a6cd
Update text
TommyTran732 3a9069e
Update text
TommyTran732 e90a7c3
Finish up the AMT and DASH section
TommyTran732 e279057
Add fsf nonsense
TommyTran732 ea4e667
Seucre boot
TommyTran732 5ee78d5
Grammar fix
TommyTran732 6bb69fe
Typo fix
TommyTran732 5eddf19
Minor fixes
TommyTran732 c58426d
More fixes
TommyTran732 0929372
Clarify intel locker is vpro enterprise
TommyTran732 907f919
Explanation for heads
TommyTran732 6e6834b
Reword
TommyTran732 792cd99
Purism icon
TommyTran732 fe2794e
Typo fix
TommyTran732 772ed6c
Change format
TommyTran732 39c4d15
Fix pictures
TommyTran732 b85e7a1
Clean up
TommyTran732 57ea302
New librem 14 image
TommyTran732 15b442f
rythm
TommyTran732 a88a421
Update
TommyTran732 df3dda8
Update
TommyTran732 e59e97e
Update
TommyTran732 b40f066
Add Lenovo BIOS simulator
TommyTran732 cfbf1df
Grammar fix
TommyTran732 c6fffcb
Add links to update schedule
TommyTran732 c8642b4
Link to AMD DASH
TommyTran732 e24e107
Update post
TommyTran732 319e671
Add periods
TommyTran732 625db93
Elaborate on Purism
TommyTran732 c5a21e4
Change formatting
TommyTran732 c1dffec
Better formatting
TommyTran732 66b1e52
Move to the FSF section
TommyTran732 5e8aa62
Add link
TommyTran732 82b0c9c
Update
TommyTran732 9ee9792
Change formatting
TommyTran732 a1d9506
Clean up
TommyTran732 8293961
Clean up more
TommyTran732 f38445b
Typo fixes
TommyTran732 4b33134
Add Lenovo section
TommyTran732 038cdf4
Reword
TommyTran732 82655e0
Add Dell section
TommyTran732 5b88ffc
Add thinkpad picture
TommyTran732 e09b1b5
Laptops without firmware protection
TommyTran732 69b20b0
Add Framework
TommyTran732 3d93d8a
Stallman and his thinkpad
TommyTran732 0f1cffa
New purism picture
TommyTran732 51684a2
Clean up
TommyTran732 573c527
Clean up
TommyTran732 1f2c330
Clean up
TommyTran732 6ff18d4
Typo fix
TommyTran732 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
199 changes: 199 additions & 0 deletions
199
content/posts/knowledge/Laptop Hardware Security/index.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,199 @@ | ||
--- | ||
title: "Laptop Hardware Security" | ||
date: 2024-06-10 | ||
tags: ['Knowledge base', 'Hardware', 'Security'] | ||
author: Tommy | ||
--- | ||
|
||
While browsing privacy forums, I often see a lot discussions regarding laptop hardware security, especially in regards to resistance against physical attacks. Unfortunately, most of the advice given on these forums are incorrect, recommending people to buy overpriced products that are significantly less secure than standard laptops. | ||
|
||
In this post, I will walk you through a quick overview of how hardware security is generally implemented for laptops, what to look for, and what to avoid. We will not discuss MacBooks or Chromebooks, as they are vastly different from normal x86 Windows/Linux hardware. | ||
|
||
![Dell Laptop](dell.png) | ||
|
||
## The Benchmark | ||
|
||
To start off, the best laptops I have found are modern the Dell Latitude/Precision laptops with an Intel vPro Enterprise CPU. The second best group of laptops I have found are modern Lenovo Thinkpads with Intel vPro Enterprise or AMD Ryzen Pro CPUs. These are relatively easy to acquire and share these common security properties: | ||
|
||
- Have Intel Boot Guard or AMD Platform Secure Boot to protect the firmware | ||
- Have regular firmware updates ([monthly updates for Dell](https://www.dell.com/support/kbdoc/en-us/000197092/dell-drivers-and-downloads-update-release-schedule), and [bi-monthly updates for Thinkpads](https://support.lenovo.com/us/en/solutions/ht515365-thinkpad-driver-and-firmware-update-release-schedule)) | ||
- Support firmware updates via the [Linux Vendor Firmware Service](https://www.fwupd.org/) | ||
- Support custom Secure Boot key enrollment | ||
- Support disabling Microsoft third-party certificate authoritity | ||
- Support memory encryption | ||
- Support [kernel DMA protection](https://learn.microsoft.com/en-us/windows/security/hardware-security/kernel-dma-protection-for-thunderbolt) | ||
- Support SMM Mitigation | ||
- Support DRTM technologies | ||
- Meet [Secure-cored requirements](https://learn.microsoft.com/en-us/windows-hardware/design/device-experiences/oem-highly-secure-11) for Windows | ||
- Meet [HSI-4](https://fwupd.github.io/libfwupdplugin/hsi.html#hsi-level4) for Linux | ||
- Still recieve Microcode updates from Intel and AMD | ||
|
||
As such, I will be comparing everything else in this post against these laptops, | ||
|
||
## Boot Security | ||
|
||
For boot security, there are 2 different technologies: Static Root of Trust Measurement (SRTM) and Dynamic Root of Trust Measurement (DRTM). I will primarily discuss SRTM here, but I will quickly go over DRTM as well. | ||
|
||
### SRTM | ||
|
||
In general, SRTM works as follows: | ||
- The public key for the firmware by the OEM is fused into an immutable Root of Trust. With Intel Boot Guard, this will be in the chipset (PCH). With AMD Platform Secure Boot, this will be in the CPU. | ||
- The CPU ensures that a significant portion of firmware from the EEPROM (BIOS chip) is signed by the OEM. This includes the Boot Block. | ||
- The Boot Block performs measurements of the firmware and its settings and submit those measurements to PCR 0. | ||
- The next stages measures things like the firmware configuration, boot loader, partition table, Secure Boot state, and so on. These are submitted to PCR 2,3,5,7, and so on. | ||
- UEFI Secure Boot validates the signature of the bootloader against the Secure Boot database. | ||
- The boot loader submits additional measurements to other PCRs. In the case of GRUB, it will use PCR 8 or 9 for instance. | ||
|
||
After the user has set up disk encryption, they can seal a encryption key protector to the TPM against certain PCRs, and optionally protect it with a PIN. | ||
|
||
Should an attacker attempt to flash malicious firmware onto the EEPROM, the laptop will refuse to boot, and will throw a Boot Guard / Platform Secure Boot violation. Should they try to downgrade the firmware version, change firmware settings or disable UEFI Secure Boot, PCR 0, 1, and 7 will change respectively. The TPM will not recieve the correct measurements and will not release the encryption key protector. | ||
|
||
This is not perfect, and the user still needs to set up additional protection for the boot stages after the boot loader, but it is an okay start and is significantly better than how some vendors try to do it as we will discuss down below. | ||
|
||
### DRTM | ||
|
||
In general, DRTM works by loading in an ACM binary signed by the CPU vendor along what the system is trying to boot. The ACM binary will perform measurements of the environment and submit the results to certain PCRs. In the case of Intel TXT, PCR 17 and 18 are used. The measurements then can be used to for remote attestation or to release a secret stored in the TPM if it matches the TPM policy. | ||
|
||
On Windows, DRTM is implemented with [System Guard](https://learn.microsoft.com/en-us/windows/security/hardware-security/how-hardware-based-root-of-trust-helps-protect-windows) for attestation and reducing trust in the UEFI firmware. On Linux, DRTM is not widely used yet, but [TrenchBoot](https://trenchboot.org/) is being developed to address that. | ||
|
||
It is important to note that DRTM technologies can be bypassed via the System Management Mode (SMM), so you still need to have some level of trust in your firmware to implement SMM mitigations. In essence, you still need to rely on SRTM to some extent. | ||
|
||
## Common Misinformation | ||
|
||
### Intel CSME and AMD PSP | ||
|
||
A very common misinformation among privacy communities is that the Intel Management Engine (ME), its sucessor - Intel Converged Security and Management Engine (CSME), and AMD Platform Security Processor (PSP) are some sort of evil backdoor. Some may go so far as to tell the user to "disable the ME", either out of paranoia or for "attack surface reduction". | ||
|
||
The problem with these recommendations are as follows: | ||
|
||
Intel CSME provides critical security features, including but not limited to: | ||
- Boot Guard (The basis of SRTM, as discussed above) | ||
- Firmware TPM (Generally better than dedicated TPMs by being not being vulnerable to bus sniffing) | ||
wj25czxj47bu6q marked this conversation as resolved.
Show resolved
Hide resolved
|
||
- Memory Encryption (on Intel vPro Enterprise systems) | ||
- Intel Locker (A nice vPro Enterprise mechanism to purge the encryption key from memory after early boot - not widely used on Linux yet, but is implemented on ChromeOS) | ||
|
||
AMD PSP provides similar security features: | ||
- Firmware TPM | ||
- Memory Encryption (on Ryzen Pro and EPYC systems) | ||
|
||
By disabling Intel CSME, you are **increasing the attack surface** by crippling security features. Additionally, if you buy hardware so old that you can run `me_cleaner` to disable the ME yourself, it means that these hardware do not have Boot Guard and it is impossible to implement any kind of boot security. | ||
|
||
This excercise also achieves nothing to protect against a hypothetical scenario where Intel and AMD are malicious. Intel and AMD do not need the co-processor to implement a backdoor - they can simply introduce CPU vulnerabilities like Spectre and Meltdown if they want to. If you do not trust a CPU vendor, the only mitigation is to not use said vendor. | ||
|
||
### Intel AMT and AMD DASH | ||
|
||
Another misinformation regarding CSME is that it is provides some kind of [shady "remote management" system](https://www.fsf.org/blogs/community/active-management-technology) for your computer. In reality, this is the AMT component which only exists on Intel vPro CPUs. It is meant for IT teams to manage systems with technologies like Serial over LAN, Solarwind, etc. | ||
|
||
Here are some facts about it: | ||
- You can disable it firmware settings. | ||
- Certain firmware allows you to permanently disable it by blowing an eFuse. | ||
- It is detectable. An easy way is to just go visit port 16992/tcp on your device. | ||
- To be extra sure, you can also run `nmap` to scan the port from a different device. | ||
|
||
This is not something hidden, people have accidentally [run into AMT](https://mastodon.lilysthings.org/@i_lost_my_bagel/112228352384742242) on social media. | ||
|
||
For attack surface reduction, you should absolutely disable it. If you do not have a vPro laptop and are wondering what it looks like, have a look at the [BIOS Simulator for the Thinkpad T14 Gen 5](https://download.lenovo.com/bsco/#/graphicalsimulator/ThinkPad%20T14%20Gen%205%20(21ML,21MM)). | ||
|
||
With that said, don't let the scary claims about "remote management" by the Free Software Foundation spook you - if some sort of hypothetical backdoor is actually implemented this way, it will not be hard to detect it. There are better ways to implement a backdoor as discussed above, and if you don't trust the CPU vendor you should avoid them as a whole, not just the vPro model. | ||
|
||
Some people recommend buying AMD instead of Intel to avoid the possibility of having Intel AMT. However, they also miss a very simple fact that AMD has an equivalent technology for their Ryzen Pro CPU - [AMD DASH](https://www.amd.com/system/files/documents/out-of-band-client-management-overview.pdf). | ||
|
||
### Restricted Boot | ||
|
||
Another false claim regarding Secure Boot by the Free Software Foundation is that UEFI Secure Boot is somehow Microsoft's evil attempt to lock users out of their computer by [only allowing it to run Microsoft approved software](https://www.fsf.org/campaigns/secure-boot-vs-restricted-boot/whitepaper-web). | ||
|
||
In reality, most if not all laptops with UEFI Secure Boot allows you to disable it - you can run whichever operating system you want. While it is true that certain lines of laptops like Razer do not allow custom key enrollment, proper business laptops like Dell Latitude/Precision and Lenovo Thinkpad do. You can enroll your own Secure Boot key and tell your laptop to boot only the system you trust. | ||
|
||
Another benefit of laptops with Microsoft's Secure-cored certification is that you can have the **Freedom** to disable the Microsoft Secure Boot Third-Party Certificate Authority and still have the laptop function normally. This is especially handy if you plan to run Windows as your operating system. | ||
|
||
UEFI Secure Boot is not Restricted Boot. It is a building block of SRTM and how you can build a secure boot environment. | ||
|
||
## Insecure Products | ||
|
||
Now that we have covered SRTM and common misconceptions, let's discuss some insecure products. | ||
|
||
### Heads, PureBoot, and Purism | ||
|
||
#### Heads | ||
|
||
Heads is built around the desire for the signing key for the firmware to be in the posession of the user instead of the OEM. They also want the user to be able to change the key in case they lose access to it. In general, this is how Heads works: | ||
|
||
- The user enrolls their GPG public key into the firmware. | ||
- The user signs the files /boot with their GPG key. | ||
- The firmware performs measurements of itself and seal HOTP and TOTP secrets into the TPM against certain PCRs. | ||
- When the system boots, the firmware measures itself, starting with the boot block doing measurements. | ||
- If the measurements match what the TPM expects, the HOTP or TOTP secret will be released. | ||
- The HOTP secret can be checked against a NitroKey, or the TOTP secret can be checked against an authenticator app on the user's phone. | ||
- The firmware checks if the files in /boot are signed by the GPG key. | ||
- If everything is as expected, the system will boot normally. | ||
|
||
The problem with this design is that everything hinges on the boot block doing its initial measurements truthfully. Since the user is supposed be able to change the key, no key can be set up with Boot Guard to protect the boot block. The result is that there is nothing stopping an attacker from flashing a piece of malicious firmware that will just lie about the measurements. At best, Heads can protect against tampering of the disk, but it cannot protect against tampering of the firmware. | ||
|
||
#### PureBoot & Purism | ||
|
||
Purism sells their laptops with PureBoot, a fork of Heads. It works in pretty much the same way, with a few extra features. | ||
|
||
Let's go through some of their claims and contrast that against reality. | ||
|
||
> PureBoot can protect against firmware tampering. | ||
|
||
It cannot protect against firmware tampering as discussed in the [Heads](#heads) section. It does not even work conceptually, and the bypass will always be there. Just to be clear, this is not a vulnerability - this is an inherent flaw in the design that cannot be fixed. | ||
|
||
> [The ME is disabled (HAP set to 1), and mostly wiped with `me_cleaner`](https://puri.sm/learn/intel-me/). | ||
|
||
They only set the HAP field now, but you have to find that out through a [forum post](https://forums.puri.sm/t/librem-14s-me-disabled-but-not-neutralized/12238). Regardless, they crippled critical security features including the ones described in the [Intel CSME and AMD PSP](#intel-csme-and-amd-psp) section. | ||
|
||
> PureBoot is [not vulnerable](https://puri.sm/posts/pureboot-not-vulnerable-to-uefi-exploits-again/) to UEFI firmware vulnerabilities which lead to Boot Guard bypasses. | ||
|
||
They referenced the LogoFail vulnerability where the firmware's image parser can be exploited to make the firmware run arbitary code despite of being verified by Boot Guard. In Purism's case, they do not even use Boot Guard to begin with, so there is no basic protection to even bypass. They are just vulnerable by design. | ||
|
||
> There is a special ["blob jail"](https://puri.sm/posts/intel-ax200-wi-fi-bluetooth-shipping-for-new-orders/) for the Wifi card. | ||
|
||
The "blob jail" is not special. It is an imitation of how the `linux-firmware` package works, and it only exists because they are refusing to ship firmware updates through PureOS. The blobs inside of the "blob jail" are not any more isolated than the blobs provided by `linux-firmware`. It is much more proper to just ship firmware for peripherals through the OS like normal distributions than shipping it through a boot firmware that requires manual updates. | ||
|
||
The harshest reality of all, is that because of how much they have crippled hardware security, [Librem laptops are at HSI level 0](https://www.fwupd.org/lvfs/hsireports/device?host_vendor=Purism&host_family=Librem+14&host_product=Librem+14). You should avoid all Heads laptops and Purism products. | ||
|
||
### Laptops without Firmware Protection | ||
|
||
Unfortunately, much like Purism, a lot of "Linux-focused" laptop vendors either do not set up Boot Guard, or set it up incorrectly. These include, but not limited to: | ||
|
||
- [StarLabs](https://www.fwupd.org/lvfs/hsireports/device?host_vendor=Star+Labs&host_family=I3&host_product=Lite) | ||
- [System76](https://www.fwupd.org/lvfs/hsireports/device?host_vendor=System76&host_family=&host_product=Darter+Pro). They also say that their UEFI Secure Boot [is only intended for Windows installation checks to pass and not proper](https://github.com/system76/firmware-open/blob/3e19b73397c27cf88b048902a3f080f584d0f851/docs/uefi.md#secure-boot). | ||
- [Tuxedo](https://www.fwupd.org/lvfs/hsireports/device?host_vendor=TUXEDO&host_family=&host_product=TUXEDO+InfinityBook+Pro+14+Gen6) | ||
|
||
You should avoid buying from these vendors as well, as it is impossible to have any kind of firmware security without Boot Guard. They all have HSI level 0. | ||
|
||
### Laptops with Insufficient Firmware Updates | ||
|
||
Some laptop brands may set up Boot Guard correctly and meet a high HSI level, but do not ship firmware frequently enough to fix critical vulnerabilities. These include, but not limited to: | ||
|
||
- Framework. vPro Enterprise Framework devices actually meet [HSI level 4](https://www.fwupd.org/lvfs/hsireports/device?host_vendor=Framework&host_family=13in+Laptop&host_product=Laptop+(13th+Gen+Intel+Core)), but they unfortunately do not handle firmware updates properly. They have not shipped a single firmware for their 13th generation over a year since its release date, and over 6 months since the disclosure of LogoFail. While they do ship some updates for other devices, how they have been handling so far is not acceptable if you need a secure device. | ||
|
||
### Older Generation Laptops | ||
|
||
In general, you should avoid buying laptops with end of life CPUs. They do not get microcode updates from the CPU vendor, and it is impossible to keep them secure even if you install alternative firmware. Currently, this means that you should not buy any laptops older than Intel Coffee Lake or AMD Zen 1. | ||
|
||
There are a few generation of hardware that you should avoid as well: | ||
- AMD Zen 2. These are vulnerable to FaultTPM. You shouldn't buy them unless you know you have a dedicated TPM that comes with the laptop. | ||
- MSI generation before 11th gen. Generally you should not buy MSI for security as they are a gaming brand and does not focus on security, but you should really avoid 11th gen MSI and earlier. These have leaked Boot Guard keys which makes any kind of firmware security impossible. | ||
|
||
## Better Products | ||
|
||
![Thinkpad](thinkpad.jpg) | ||
|
||
### Dell Latitude/Precision | ||
|
||
Dell business laptops have the best firmware security among all laptops I have personally evaluated. However, they are not without faults that you should be aware of: | ||
|
||
- There is a default BIOS recovery password tied to the device serial number. You can disable this by enabling the [Master Password Lockout](https://www.dell.com/support/kbdoc/en-us/000180749/dell-client-products-unauthorized-bios-password-reset-tools) setting. | ||
- Dell sometimes forget to update the firmware for certain products like the Latitude 9440 and Latitude 9450 to LVFS. Be sure to check your device [update history](https://www.fwupd.org/lvfs/devices/) before purchasing any device, especially from Dell. | ||
- The microphone toggle in the firmware does not actually turn off the mic. I have verified that this is the case by booting into a fresh Linux installation and recorded myself despite of the mic being set to off. | ||
- Some settings like Hyper Threading do not have their values measured by the firmware. | ||
|
||
### Lenovo ThinkPad | ||
|
||
In my opinion, vPro Enterprise Thinkpad laptops security are generally acceptable for the product class. However, there is a big gotcha with their firmware: **the "prevent BIOS downgrade" toggle does not actually work**. This toggle only nicely asks Windows to not downgrade the firmware, but if a tool like fwupd tries to downgrade it, the firmware will allow the downgrade. | ||
|
||
The implication of this is that if you have the UEFI update capsule enabled, a compromised OS can downgrade your firmware to a version vulnerable with something like LogoFail, and the malware can then gain persistent in the firmware. The problem can theoratically be solved if Lenovo blows Boot Guard fuses to prevent downgrade, but in reality they do it even less often than Dell. | ||
|
||
For this reason, I recommend buying Dell Latitude/Precision over Lenovo products. If you have to use a Lenovo laptop anyways, consider disabling the UEFI capsule, and use a different, trusted computer to create a USB stick for firmware updates. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It seems it's not strictly one update per month. Sometimes there's several months without updates.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also Dell and Lenovo never promised how long they would support their PCs
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, its a general rule. It doesn't always hold.
They typically support them for years and years. Even 8th gen Dell and Lenovo are still getting updates.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Lenovo's Product Specification Reference does have an ‘End of Support’ column: https://psref.lenovo.com/Product/ThinkPad/ThinkPad_T14_Gen_5_Intel?tab=model.