2
1
Fork 0
mirror of https://git.savannah.gnu.org/git/gnuboot.git synced 2025-01-21 06:46:29 +01:00
gnuboot/site/docs/install/index.md
Leah Rowe 501e77d996 libreboot site
new one
2021-05-23 22:34:47 +01:00

16 KiB


title: Installation instructions x-toc-enable: true ...

This section relates to installing Libreboot on supported targets.

NOTE: if running flashrom -p internal for software based flashing, and you get an error related to /dev/mem access, you should reboot with iomem=relaxed kernel parameter before running flashrom, or use a kernel that has CONFIG_STRICT_DEVMEM not enabled.

Libreboot flashing can be risky business. Please ensure that you have external flashing equipment, in case anything goes wrong. The general rule of thumb with firmware is this: if it's non-free, replace it, but if you're already running free firmware and it works nicely for you, you do not need to update it. However, you might want to tweak it or try out newer releases of Libreboot if they have bug fixes for your board, and/or new security fixes.

If you're already running libre firmware on your board, you should decide for sure whether you wish to risk it. See changelogs on the release logs and decide for yourself.

Which systems are supported?

Refer to the hardware compatibility page

MAC address on GM45+ICH9M hardware (ThinkPad X200/R400/T400/T500/W500)

The MAC address is stored in a region of the boot flashed called GbE NVM which is short for gigabit ethernet non-volatile memory. Refer to the following article:

ich9utils documentation

Libreboot puts a default MAC address in the available ROM images, but this is a generic MAC address and it's identical on every ROM image. Technically, you can use it but if you encounter other Libreboot users on the same ethernet switch, using the same physical network as you, you will encounter a MAC address conflict.

NOTE: R500 thinkpads do not have an Intel gigabit ethernet NIC, so on that laptop you can just flash the default ROM and you do not have to worry.

There are also some Intel X4X platforms that use an ICH10 southbridge, supported in Libreboot, but these are flashed in a descriptorless setup, which means that the MAC address is irrelevant (either there will be an Intel PHY module that is now unusable, and you use an add-on card, or it doesn't use an Intel PHY module and the onboard NIC is usable).

Install via host CPU (internal flashing)

On all mainboards is a built-in programmer, which can read, erase and rewrite the boot flash. However, it is not always usable by default. For example, it may be configured to restrict write privileges by the host CPU.

In some situations, the host CPU can rewrite/erase/dump the boot flash. This is called internal flashing. This means that you will run software, namely flashrom, to read/erase/write the contents of the boot flash from a running operating system on the target device.

NOTE: please also read the sections further down this page. On some systems, external flashing is required. This means that you power the system down and use a special tool that connects to and reprograms the boot flash.

NOTE: in some cases, external flashing is possible but special steps are required. This depends on your mainboard. Again, please read this page carefully.

Run flashrom on host CPU

You can simply take any ROM image from the Libreboot project, and flash it. Boot a GNU+Linux distribution on the target device, and install flashrom.

In some cases, this is not possible or there are other considerations. Please read this section carefully.

Flash chip size

Use this to find out:

flashrom -p internal

In the output will be information pertaining to your boot flash.

Howto: read/write/erase the boot flash (PLEASE CHECK LIST OF EXCEPTIONS BELOW BEFORE YOU ATTEMPT THIS!!!!)

How to read the current chip contents:

sudo flashrom -p internal:laptop=force_I_want_a_brick,boardmismatch=force -r dump.bin

You should still make several dumps, even if you're flashing internally, to ensure that you get the same checksums. Check each dump using sha1sum

How to erase and rewrite the chip contents:

sudo flashrom -p internal:laptop=force_I_want_a_brick,boardmismatch=force -w libreboot.rom

If successful, it will either say VERIFIED or it will say that the chip contents are identical to the requested image.

NOTE: there are exceptions where the above is not possible. Read about them in the sections below:

Exceptions

If your boot flash is currently write-protected

You must flash it externally

ASUS Chromebook C201 (regardless of firmware)

Ignore this section. Instead, refer to the following guide:

ASUS Chromebook C201 installation guide

NOTE: C201 is dropped in recent Libreboot releases, but will be added later with u-boot instead of the depthcharge bootloader. For now, use Libreboot 20160907 on this machine.

Lenovo ThinkPad X200/X200S/X200T/T400/T400S/T500/W500/R400/R500 running non-free Lenovo BIOS

If you're running one of these, it cannot be flashed internally if you're still running the non-free Lenovo BIOS firmware.

You must flash it externally

See notes further down on this page. We have guides for specific thinkpads, related to disassembly and reassembly so that you can access the flash.

Please also see notes about the built-in MAC address inside the boot flash, for the onboard NIC (ethernet one); not relevant on R500, which doesn't use an Intel NIC.

Intel D510MO and D410PT running non-free Intel BIOS

You must flash it externally

D410PT is more or less the same board as D510MO, but we would like more info about this board. If you have a D410PT mainboard, please contact the Libreboot project via IRC and ping leah before you flash it. When you do so, please reference this paragraph on this web page.

Gigabyte GA-G41M-ES2l (any firmware)

Ignore this section. Internal flashing is possible, but there are two chips and you must flash both chips. Refer to the guide:
Gigabyte GA-G41M-ES2L installation guide

Macbook1,1 running non-free Apple EFI firmware

This laptop requires external flashing. Remove the mainboard and refer to the external flashing guide; if Libreboot is already running, you can flash internally.

MacBook2,1 can be flashed internally.

ASUS KFSN4-DRE?

Simply boot GNU+Linux with the default vendor firmware, and flash it internally, but before you do: take a push pin, remove the metal pin, and superglue the plastic part to the chip. Then remove the chip after you booting your GNU+Linux system. Install a new chip, and flash that.

This board uses LPC flash in a PLCC32 socket. This coreboot page shows an example of the push pin as a proof of concept: http://www.coreboot.org/Developer_Manual/Tools#Chip_removal_tools

ASUS KGPE-D16 running non-free ASUS BIOS

You must flash it externally

ASUS KCMA-D8 running non-free ASUS BIOS

You must flash it externally

ASUS D945GCLF running non-free Intel BIOS

You must flash it externally

ThinkPad X60/X60S/X60T/T60 with Lenovo BIOS

Here are a list of targets:

  • ThinkPad X60/X60S/X60T: flash the X60 ROM
  • ThinkPad T60 with Intel GPU: flash the T60 ROM
  • ThinkPad T60 with ATI GPU: flash the Headless T60 ROM (no video init, but you can get a serial console on the RS232 port if you use the Advanced Dock or Advanced Mini Dock. Connect to it from another machine, using null modem cable and USB serial adapter; GNU Screen can connect to the serial console and you will run it at 115200 baud rate. agetty/fgetty in GNU+Linux can give you a serial console in your OS)

Download and build flashrom, using the instructions on the Git page, and download the bucts software using the notes on that very same page.

You can replace Lenovo BIOS with Libreboot, using flashrom running on the host CPU. However, there are some considerations.

Firstly, make sure that the yellow CMOS battery is installed, and functioning correctly. You could check the voltage. The battery is a CR2032 coin cell and it should be providing a 3V signal. You should check this while it is connected to the board, because this will give a more accurate reading (if the battery is weak, it will have severe voltage drop when there is any load on it, which there will be. This coincell powers the real-time clock and CMOS memory).

Lenovo BIOS restricts write access, but there is a weakness in it. With a specially patched flashrom binary, you can easily flash it but the top 64KiB region of the boot flash, containing your bootblock, cannot be flashed just yet. However, there is a register called the Backup Control or BUC register and in that register is a status bit called Top Swap or TS.

There are 2 bootblocks possible. The other bootblock is below the upper 64KiB one, which can't be flashed, but the lower one can. By using bucts, you can set the machine to boot using that lower 64KiB bootblock, which is read-write. You do this by setting the BUC.TS register to 1, using the bucts program referenced below.

Libreboot ROM images already have the upper 64KiB bootblock copied to the lower one, so you don't have to worry about copying it yourself.

If you build flashrom using the libreboot build system, there will be three binaries:

  • flashrom
  • flashrom_i945_sst
  • flashrom_i945_mx

It's these last two binaries that you should use. Now compile bucts (just run make in the bucts source directory).

Run the bucts tool:

sudo ./bucts 1

Ensure that your CMOS battery is connected too. Now you must determine whether you have Macronix or SST. An X60/T60 thinkpad will have either an SST or a Macronix chip. The Macronix chip will have "MX" written on the chip. You will use flashrom_i945_sst for the SST chip, and flashrom_i945_mx for the Macronix chip.

Now run flashrom (for SST):

sudo ./flashrom_i945_sst -p internal -w coreboot.rom

Or Macronix:

sudo ./flashrom_i945_mx -p internal -w coreboot.rom

NOTE: you can just run both. One of them will succeed. It is perfectly harmless to run both versions of flashrom. In fact, you should do so!

You'll see a lot of errors. This is normal. You should see something like:

Reading old flash chip contents... done.
Erasing and writing flash chip... spi_block_erase_20 failed during command execution at address 0x0
Reading current flash chip contents... done. Looking for another erase function.
spi_block_erase_52 failed during command execution at address 0x0
Reading current flash chip contents... done. Looking for another erase function.
Transaction error!
spi_block_erase_d8 failed during command execution at address 0x1f0000
Reading current flash chip contents... done. Looking for another erase function.
spi_chip_erase_60 failed during command execution
Reading current flash chip contents... done. Looking for another erase function.
spi_chip_erase_c7 failed during command execution
Looking for another erase function.
No usable erase functions left.
FAILED!
Uh oh. Erase/write failed. Checking if anything has changed.
Reading current flash chip contents... done.
Apparently at least some data has changed.
Your flash chip is in an unknown state.

If you see this, rejoice! It means that the flash was successful. Please do not panic. Shut down now, and wait a few seconds, then turn back on again.

Flash the ROM for a second time. For this second flashing attempt, the upper 64KiB bootblock is now read-write. Use the unpatched flashrom binary:

sudo ./flashrom -p internal -w libreboot.rom

To reset bucts, do this:

sudo ./bucts 0

ONLY set bucts back to 0 if you're sure that the upper 64KiB bootblock is flashed. It is flashed if flashrom said VERIFIED when running the above command.

If it said VERIFIED, shut down. If it didn't say VERIFIED, make sure bucts is still set to 1, and consult the libreboot project on IRC for advice, and avoid shutting down your system until you get help.

If all went well, Libreboot should now be booting and you should be able to boot into your operating system.

If you messed up, there are external flashing instructions. See main navigation menu on this page. These "external" instructions teach you how to flash externally, using special equipment (requires disassembling your laptop and removing the mainboard).

Install using external flashing equipment

In many situations, the host CPU is restricted from rewriting/erasing/dumping the boot flash. In this situations, you must re-flash the chip (containing the boot firmware) externally. This is called external flashing.

DO NOT buy CH341A! Read the above link, which explains why you shouldn't use it. CH341A will damage your flash chip, and other components on your mainboard.

How to use external flashing equipment

Refer to the following article:
Externally rewrite 25xx NOR flash via SPI protocol

ASUS KFSN4-DRE

TODO: Document PLCC32 (LPC) flashing. The only Libreboot target that uses this is ASUS KFSN4-DRE. On that one, internal flashing is possible from the vendor firmware, with flashrom running on the host CPU (it is recommended to hotswap a new chip and flash the new chip, after booting into a GNU+Linux system).

TARGET: Apple Macbook2,1, Macbook1,1 and iMac5,2 (i945 platform)

iMac5,2 is essentially the same board as Macbook2,1, and it is compatible with Libreboot.

Refer to the following article:
Macbook2,1 and MacBook1,1 installation guide

iMac5,2 isn't documented but you can find the flash chip on that board quite easily. See the generic flashing guide:
Externally rewrite 25xx NOR flash via SPI protocol

TARGET: Gigabyte GA-G41M-ES2L mainboard

Refer to the following article:
Gigabyte GA-G41M-ES2L

TARGET: Intel D510MO and D410PT mainboards

Refer to the following article:
Intel D510MO and D410PT boards

TARGET: Intel D945GCLF mainboard

Refer to the following article:
Intel D945GCLF

TARGET: ASUS KGPE-D16 mainboard

Refer to the following article:
ASUS KGPE-D16

TARGET: ASUS KCMA-D8 mainboard

Refer to the following article:
ASUS KCMA-D8

TARGET: ASUS Chromebook C201 laptop

Refer to the following article:
ASUS Chromebook C201

TARGET: Lenovo ThinkPad X60 laptop

Refer to the following article:
ThinkPad X60

TARGET: Lenovo ThinkPad X60 Tablet laptop

Refer to the following article:
ThinkPad X60 Tablet

TARGET: Lenovo ThinkPad T60 laptop

Refer to the following article:
ThinkPad T60

TARGET: Lenovo ThinkPad X200 laptop

Refer to the following article:
ThinkPad X200

TARGET: Lenovo ThinkPad X200S or X200 Tablet laptop

Software-wise, identical to regular X200 but SMD rework skills are required. You must de-solder the default flash chip, and replace it with another one.

Refer to the following article:
25xx NOR flashing guide

That guide, linked above, has instructions for how to deal with these machines.

TARGET: Lenovo ThinkPad T400 laptop

Refer to the following article:
ThinkPad T400

TARGET: Lenovo ThinkPad T400S laptop

Software-wise, identical to regular T400 but SMD rework skills are required. You must de-solder the default flash chip, and replace it with another one.

Refer to the following article:
25xx NOR flashing guide

TARGET: Lenovo ThinkPad R400 laptop

Refer to the following article:
ThinkPad R400

TARGET: Lenovo ThinkPad T500 or W500 laptop

These two laptops have identical mainboard, except for a few minor changes.

Refer to the following article:
ThinkPad T500/W500

TARGET: Lenovo ThinkPad R500 laptop

Refer to the following laptop:
ThinkPad R500