From 75ee5e97c9be6c94ffa6ddf5f8e882bc4b1701b1 Mon Sep 17 00:00:00 2001
From: Francis Rowe
+ These are saved as two configs, because there are 2 size flash chips: 4MB or 8MB. +
++ Go back and disable option ROMs: +
++ The resulting .config file was saved as resources/libreboot/config/t500_8mb/config and + resources/libreboot/config/t500_4mb/config and is used by the build + scripts for this machine. +
+diff --git a/docs/hcl/gm45_remove_me.html b/docs/hcl/gm45_remove_me.html index 5b2d4ff..b1ab1f0 100644 --- a/docs/hcl/gm45_remove_me.html +++ b/docs/hcl/gm45_remove_me.html @@ -18,7 +18,7 @@
This sections relates to disabling and removing the ME (Intel Management Engine) on - GM45. This was originally done on the ThinkPad X200, and later adapted for the ThinkPad R400/T400. It can + GM45. This was originally done on the ThinkPad X200, and later adapted for the ThinkPad R400/T400/T500. It can in principle be done on any GM45 or GS45 machine.
diff --git a/docs/hcl/index.html b/docs/hcl/index.html index d593c20..42be8d6 100644 --- a/docs/hcl/index.html +++ b/docs/hcl/index.html @@ -41,6 +41,7 @@
+ It is believed that all or most T500 laptops are compatible. + See notes about CPU compatibility + and switchable graphics for + potential incompatibilities. +
+ ++ There are two possible flash chip sizes for the R400: 4MiB (32Mbit) or 8MiB (64Mbit). + This can be identified by the type of flash chip below the palmrest: 4MiB is SOIC-8, 8MiB + is SOIC-16. +
+ ++ The T500 laptops come with the ME (and sometimes AMT in addition) before flashing libreboot. Libreboot disables and removes it + by using a modified descriptor: see gm45_remove_me.html (contains notes, plus + instructions) +
+ ++ Flashing instructions can be found at ../install/index.html#flashrom +
+ + ++ Thi T500 is almost identical to the X200, code-wise. See x200.html. +
+ ++ See + ../future/dumps/t500_x200_descriptor/descriptor_diff_t500_x200.txt + and + ../future/dumps/t500_x200_descriptor/gbe_diff_t500_x200.txt +
+ +
+ The patches above are based on the output from ich9deblob on a factory.rom image dumped from the T500
+ with a SOIC-8 4MiB flash chip. The patch re-creates the X200 descriptor/gbe source, so the commands were
+ something like:
+ $ diff -u t500gbe x200gbe
+ $ diff -u t500descriptor x200descriptor
+
+ ME VSCC table is in a different place and a different size on the T500. Libreboot disables and removes the ME + anyway, so it doesn't matter. +
+ ++ The very same descriptor/gbe used on the X200 (generated by ich9gen) + was re-used on the T500, and it still worked. +
+ ++ The coreboot wiki shows + how to collect various logs useful in porting to new + boards. Following are outputs from the T500: +
+ +
+ Copyright © 2015 Francis Rowe <info@gluglug.org.uk>
+ This document is released under the Creative Commons Attribution-ShareAlike 4.0 International Public License and all future versions.
+ A copy of the license can be found at ../license.txt.
+
+ This document is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See ../license.txt for more information. +
+ +@@ -139,18 +141,19 @@
- X200/R400/T400 users running Lenovo BIOS should refer to x200_external.html, - r400_external.html or - t400_external.html. These machines contain the hard coded + X200/R400/T400/T500 users running Lenovo BIOS should refer to x200_external.html, + r400_external.html, + t400_external.html or + t500_external.html. These machines contain the hard coded MAC address for the onboard ethernet chipset, directly inside the SPI flash; ich9gen shows how to change it (the default libreboot ROM images for these machines contain a generic MAC address).
- X200/R400/T400 users should also note, that it is possible for the user to write-protect whole regions + X200/R400/T400/T500 users should also note, that it is possible for the user to write-protect whole regions of the SPI flash by using a modified descriptor. Locked regions must be flashed externally; - see x200_external.html, r400_external.html - or t400_external.html. + see x200_external.html, r400_external.html, + t400_external.html or t500_external.html. Libreboot unlocks all regions, by default.
+ If you have a WWAN/3G card and/or sim card reader, remove them permanently. + The WWAN-3G card has DMA, and proprietary firmware inside; the technology is + identical to what is used in mobile phones, so it can also track your movements. +
++ Not to be confused with wifi (wifi is fine). +
+ ++ If you have a WWAN/3G card and/or sim card reader, remove them permanently. + The WWAN-3G card has DMA, and proprietary firmware inside; the technology is + identical to what is used in mobile phones, so it can also track your movements. +
++ Not to be confused with wifi (wifi is fine). +
+ +Initial flashing instructions for T500.
++ This guide is for those who want libreboot on their ThinkPad T500 + while they still have the original Lenovo BIOS present. This guide + can also be followed (adapted) if you brick your T500, to know how + to recover. +
+ + ++ ThinkWiki has a list of CPUs + for this system. The Core 2 Duo P8400, P8600 and P8700 are believed to work in libreboot. + The T9400, T9500, T9550 and T9600 are untested! +
+ ++ This guide currently assumes that you have an Intel GPU (non-switchable). + Some T500 have switchable graphics (ATI), which means that you can choose between ATI or Intel + in the BIOS setup. When switching to Intel, is lenovobios not enabling ATI + (where ATI is disabled by default and the system uses the Intel chip), or are they + disabling it (where the system uses the ATI chip by default)? +
+ ++ Basically, switchable graphics is untested, but it should be easy to get it working + (if it doesn't already work). +
+ ++ See #paste. +
+ ++ The T500 will use an 8MiB or 64Mb SOIC-16 chip (rare models + will use a 4MiB or 32Mb SOIC-8 chip). +
+ + + ++ On the T500, the MAC address for the onboard + gigabit ethernet chipset is stored inside the flash chip, + along with other configuration data. +
++ Keep a note of the MAC address before disassembly; this is + very important, because you will need to insert this into + the libreboot ROM image before flashing it. + It will be written in one of these locations: +
+ ++ + + +
+ ++ Refer to bbb_setup.html for how to + configure the BBB for flashing. +
+ ++ The following shows how to connect clip to the BBB (on the P9 header), for SOIC-16 (clip: Pomona 5252): +
++POMONA 5252 (correlate with the BBB guide) +=== ethernet jack and VGA port ==== + NC - - 21 + 1 - - 17 + NC - - NC + NC - - NC + NC - - NC + NC - - NC + 18 - - 3.3V PSU RED + 22 - - NC - this is pin 1 on the flash chip +=== SATA port === +This is how you will connect. Numbers refer to pin numbers on the BBB, on the plugs near the DC jack.+
+ +
+ The following shows how to connect clip to the BBB (on the P9 header), for SOIC-8 (clip: Pomona 5250): +
++POMONA 5250 (correlate with the BBB guide) +=== RAM slots ==== + 18 - - 1 + 22 - - NC + NC - - 21 + 3.3V PSU RED - - 17 - this is pin 1 on the flash chip +=== slot where the AC jack is connected ===+ +
+ +
+ Remove all screws:
+
+ It is also advisable to, throughout the disassembly,
+ place any screws and/or components that you removed in
+ the same layout or arrangement. The follow photos demonstrate
+ this:
+
+
+
+ Remove the HDD/SSD and optical drive:
+
+
+
+ Remove the palm rest:
+
+
+
+ Remove the keyboard and rear bezel:
+
+
+
+
+
+
+
+ If you have a WWAN/3G card and/or sim card reader,
+ remove them permanently. The WWAN-3G card has DMA, and
+ proprietary firmware inside; the technology is identical
+ to what is used in mobile phones, so it can also track
+ your movements:
+
+
+
+
+ Remove this frame, and then remove the wifi chip:
+
+
+
+
+ Remove the speakers:
+
+
+
+
+
+
+
+
+ Remove the NVRAM battery (already removed in this photo):
+
+
+ When you re-assemble, you will be replacing the wifi chip
+ with another. These two screws don't hold anything together,
+ but they are included in your machine because the screw
+ holes for half-height cards are a different size, so
+ use these if you will be installing a half-height card:
+
+
+ Unroute the antenna wires:
+
+
+
+
+
+ Disconnect the LCD cable from the motherboard:
+
+
+
+ Remove the LCD assembly hinge screws, and then remove the LCD
+ assembly:
+
+
+
+
+ Remove the fan and heatsink:
+
+
+
+
+ Remove this screw:
+
+
+ Remove these cables, keeping note of how and in what
+ arrangement they are connected:
+
+
+
+
+
+
+
+
+
+
+ Disconnect the power jack:
+
+
+
+ Remove the motherboard and cage from the base
+ (the marked hole is where those cables were routed through):
+
+
+
+ Remove all screws, arranging them in the same layout
+ when placing the screws on a surface and marking each screw
+ hole (this is to reduce the possibility of putting them
+ back in the wrong holes):
+
+
+
+ Also remove this:
+
+
+
+ Separate the motherboard from the cage:
+
+
+
+ The flash chip is next to the memory slots. On this
+ machine, it was a SOIC-8 (4MiB or 32Mb) flash chip:
+
+
+ Connect your programmer, then connect GND and 3.3V
+
+
+
+
+
+
+ A dedicated 3.3V PSU was used to create this guide, but
+ at ATX PSU is also fine:
+
+
+ Of course, make sure to turn on your PSU:
+
+
+ Now, you should be ready to install libreboot. +
+ ++ Flashrom binaries for ARM (tested on a BBB) are distributed in libreboot_util. Alternatively, + libreboot also distributes flashrom source code which can be built. +
++ Log in as root on your BBB, using the instructions in bbb_setup.html#bbb_access. +
+
+ Test that flashrom works:
+ # ./flashrom -p linux_spi:dev=/dev/spidev1.0,spispeed=512
+ In this case, the output was:
+
+flashrom v0.9.7-r1854 on Linux 3.8.13-bone47 (armv7l) +flashrom is free software, get the source code at http://www.flashrom.org +Calibrating delay loop... OK. +Found Macronix flash chip "MX25L6405(D)" (8192 kB, SPI) on linux_spi. +Found Macronix flash chip "MX25L6406E/MX25L6436E" (8192 kB, SPI) on linux_spi. +Found Macronix flash chip "MX25L6445E/MX25L6473E" (8192 kB, SPI) on linux_spi. +Multiple flash chip definitions match the detected chip(s): "MX25L6405(D)", "MX25L6406E/MX25L6436E", "MX25L6445E/MX25L6473E" +Please specify which chip definition to use with the -c <chipname> option. ++
+ How to backup factory.rom (change the -c option as neeed, for your flash chip):
+ # ./flashrom -p linux_spi:dev=/dev/spidev1.0,spispeed=512 -r factory.rom
+ # ./flashrom -p linux_spi:dev=/dev/spidev1.0,spispeed=512 -r factory1.rom
+ # ./flashrom -p linux_spi:dev=/dev/spidev1.0,spispeed=512 -r factory2.rom
+ Note: the -c option is not required in libreboot's patched flashrom, because
+ the redundant flash chip definitions in flashchips.c have been removed.
+ Now compare the 3 images:
+ # sha512sum factory*.rom
+ If the hashes match, then just copy one of them (the factory.rom) to a safe place (on a drive connected to another machine, not
+ the BBB). This is useful for reverse engineering work, if there is a desirable behaviour in the original firmware
+ that could be replicated in coreboot and libreboot.
+
+ Follow the instructions at ../hcl/gm45_remove_me.html#ich9gen + to change the MAC address inside the libreboot ROM image, before flashing it. + Although there is a default MAC address inside the ROM image, this is not what you want. Make sure + to always change the MAC address to one that is correct for your system. +
+
+ Now flash it:
+ # ./flashrom -p linux_spi:dev=/dev/spidev1.0,spispeed=512 -w path/to/libreboot/rom/image.rom -V
+
+ +
++ You might see errors, but if it says Verifying flash... VERIFIED at the end, then it's flashed and should boot. + If you see errors, try again (and again, and again); the message Chip content is identical to the requested image + is also an indication of a successful installation. +
++ Example output from running the command (see above): +
++flashrom v0.9.7-r1854 on Linux 3.8.13-bone47 (armv7l) +flashrom is free software, get the source code at http://www.flashrom.org +Calibrating delay loop... OK. +Found Macronix flash chip "MX25L6405(D)" (8192 kB, SPI) on linux_spi. +Reading old flash chip contents... done. +Erasing and writing flash chip... FAILED at 0x00001000! Expected=0xff, Found=0x00, failed byte count from 0x00000000-0x0000ffff: 0xd716 +ERASE FAILED! +Reading current flash chip contents... done. Looking for another erase function. +Erase/write done. +Verifying flash... VERIFIED. ++ + + +
+ Because part of this procedure involved removing the heatsink, you will need to apply new paste. + Arctic Silver 5 is ok. You will also need isopropyl alcohol and an anti-static cloth to clean with. +
+ ++ When re-installing the heatsink, you must first clean off all old paste with the alcohol/cloth. + Then apply new paste. AS5 is also much better than the default paste used on these machines. +
+ ++ +
+ ++ The T500 typically comes with an Intel wifi chipset, which does not + work without proprietary software. For a list of wifi chipsets that + work without proprietary software, see + ../hcl/index.html#recommended_wifi. +
+ ++ Some T500 laptops might come with an Atheros chipset, but this is 802.11g only. +
+ ++ It is recommended that you install a new wifi chipset. This can only + be done after installing libreboot, because the original firmware has + a whitelist of approved chips, and it will refuse to boot if you + use an 'unauthorized' wifi card. +
+ +
+ The following photos show an Atheros AR5B95 being installed, to
+ replace the Intel chip that this T500 came with:
+
+
+
+ If you have a WWAN/3G card and/or sim card reader, remove them permanently. + The WWAN-3G card has DMA, and proprietary firmware inside; the technology is + identical to what is used in mobile phones, so it can also track your movements. +
++ Not to be confused with wifi (wifi is fine). +
+ ++ You need DDR3 SODIMM PC3-8500 RAM installed, in matching pairs + (speed/size). Non-matching pairs won't work. You can also install a + single module (meaning, one of the slots will be empty) in slot 0. +
+ +
+ The following photo shows 8GiB (2x4GiB) of RAM installed:
+
+
+ Copyright © 2015 Francis Rowe <info@gluglug.org.uk>
+ This document is released under the Creative Commons Attribution-ShareAlike 4.0 International Public License and all future versions.
+ A copy of the license can be found at ../license.txt.
+
+ This document is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See ../license.txt for more information. +
+ ++ If you have a WWAN/3G card and/or sim card reader, remove them permanently. + The WWAN-3G card has DMA, and proprietary firmware inside; the technology is + identical to what is used in mobile phones, so it can also track your movements. +
++ Not to be confused with wifi (wifi is fine). +
+ +diff --git a/docs/release.html b/docs/release.html index f5e11e5..fbeb1d5 100644 --- a/docs/release.html +++ b/docs/release.html @@ -50,7 +50,7 @@