Difference between revisions of "BIOS Upgrade"

From ThinkWiki
Jump to: navigation, search
(Booting using GRUB)
 
(259 intermediate revisions by more than 100 users not shown)
Line 1: Line 1:
__TOC__
+
{| width="100%"
 +
|style="vertical-align:top;padding-right:20px;width:10px;white-space:nowrap;" | __TOC__
 +
|style="vertical-align:top" |
 +
This page is meant to describe ways to update the BIOS on a ThinkPad that only runs Linux for users that don't have ready access to Windows. If you have Windows on your ThinkPad you can just boot into it and follow instructions on the Lenovo website.
  
This page is meant to describe ways to update the BIOS on a ThinkPad that only runs Linux for users that don't have ready access to Windows. If you have Windows on your ThinkPad you can just boot into it and follow instructions on the IBM website.
+
Updating the BIOS in Linux (with few exceptions) '''is not officially supported''' by Lenovo. However there are work arounds.
  
{{NOTE| In one case ([[APM setup on a type 2379 ThinkPad T40]]) it was not possible to upgrade the BIOS from Windows XP; a downgrade to Windows 98 was required to successfully run the BIOS upgrade app. The symptoms in this case were that, once the files had been extracted to the hard disk, and the machine was to reboot into the upgrade app, it would beep and hang just before reboot, requiring a power cycle. Once the power was cycled, it would simply reboot back into XP without performing any BIOS upgrade actions. So even if you have Windows, you may still need to use the info on this page.}}
+
<BR>
 +
{{WARN|By following any of the instructions here you are accepting the '''very real risk''' of turning your ThinkPad into a big expensive paper weight, as a firmware update gone wrong can create unfix-able problems.
  
----
+
'''Proceed at your own risk!'''}}
==Before You Begin==
+
|}
Updating the BIOS in Linux (with few exceptions) '''is not officially supported''' by IBM. However there are work arounds.
+
 
 +
= [[Custom BIOS]] =
 +
 
 +
Some ThinkPad fans have created Custom BIOSes to remove whitelists, disable annoying errors, do Fn-Ctrl keyswaps, and add more functionality. Check the [[Custom BIOS]] wikipage for more information.
 +
 
 +
* '''X200, X60, T60, Macbook 2,1''' - [http://libreboot.org Libreboot] - Based on Coreboot, this BIOS (approved by the FSF) removes all proprietary blobs to create Free Libre Open Source Laptops, where everything from the motherboard to the computer can use Open Source Software. Richard Stallman famously uses a Libreboot X60.
 +
* Sovem's Whitelist Removed BIOSes - A famous user from BIOS-mods.com, that removes mPCI whitelists from BIOSes upon request.
 +
* '''T61, R61, X61/X61s/X61T, X300''' - [[Middleton's BIOS]] - Enables SATAII, removes whitelist, thermal fixes, Fn-Ctrl swap.
 +
* '''T43/T43p, R52, X41/X41T''' - [[Problem with non-ThinkPad hard disks#Use unofficial modified BIOS|TTav134's BIOS]] - Removes Error 2010 for aftermarket hard drives, and the BIOS whitelist.
 +
 
 +
== [[Middleton's BIOS]] ==
 +
 
 +
A user on NotebookReview named 'Middleton' made these alternative BIOSes to enable SATA2 on certain Thinkpad models (X61/T61/R61/X300). These ThinkPads are limited to SATA1 in their BIOS even though the hardware is SATA2. This is a huge drawback for anyone wanting to use SSDs, because it is so much slower.
 +
 
 +
Also, it is not possible to install some wireless cards, because only certain models are whitelisted by IBM/Lenovo. [[Middleton's BIOS]] removes this limitation as well.
 +
 
 +
'''See the wikipage [[Middleton's BIOS]] for installation instructions, downloads, and more description.'''
 +
 
 +
Note: If your BIOS-Update tool says that no update is needed, then simply downgrade the Bios first: On Lenovo's drivers download page, the old Bios files are listed at the very bottom of the page.
 +
 
 +
= Downloading New Firmware =
 +
{{WARN|Flashing the wrong firmware for your hardware may cause permanent damage to your ThinkPad.  It is up to you to confirm that the firmware you are using is correct.}}
 +
 
 +
A list of links to firmware downloads can be found at [[BIOS Upgrade Downloads]] for most Thinkpad models.  You can also check the Lenovo Support website's [http://support.lenovo.com/en_US/downloads/default.page?#|ThinkPad driver matrix].
 +
 
 +
Lenovo/IBM provides firmware upgrades in a variety of packages:
 +
* Diskette
 +
* Non-diskette
 +
* Linux diskette
 +
* BIOS Utility
 +
* Bootable CD
 +
 
 +
Not every type of package is available for every model.
 +
 
 +
The ''BIOS Utility'' and ''Bootable CD'' packages combine the BIOS and ECP firmwares.  For the other packages, there is one for each firmware.
 +
{| align="right" style="width:20em;"
 +
| {{HELP|Can an image be extracted from a "Linux diskette" .exe file?}}
 +
|}
 +
 
 +
The ''Linux diskette'' is just the ''Diskette'' package that runs on Linux instead of Windows/DOS.  It's unknown if a boot image can be extracted from it. 
 +
 
 +
You may need to try different packages to find the one from which you can extract a boot image.
 +
 
 +
== Two Firmwares: BIOS and ECP ==
 +
{{WARN|Flashing incompatible firmwares, or flashing them in the wrong order, may cause permanent damage to your ThinkPad.}}
 +
 
 +
It is important to understand that Thinkpads from IBM have two separate firmwares: the BIOS, and the Embedded Controller Program (ECP).
 +
 
 +
A given BIOS version will require a certain version of the ECP.  You must read the Lenovo website and/or .txt files to confirm which BIOS is compatible with which ECP, and '''the order in which to update them'''. 
 +
 
 +
=== Update Order ===
 +
The Lenovo/IBM documentation is sometimes unclear about the order in which these two firmwares should be updated.  When in doubt (i.e. IBM didn't provide specific instructions for your model or a particular firmware update), '''update the ECP first, and then the BIOS'''.  Also, make sure to do the two updates '''immediately one after the other'''.
 +
 
 +
The EC firmware is usually much better at backwards compatibility than the BIOS.
 +
 
 +
{{NOTE|Updaters for newer models take care of both BIOS and EC, and use automatically whatever sequence is needed, so you don't have to worry about it.}}
 +
 
 +
== Installed Firmware ==
 +
You can check the current BIOS and ECP versions on your ThinkPad as detailed here: [[BIOS Version]]
 +
 
 +
===DMI IDs===
 +
Please consider updating the [[List of DMI IDs]] before (and after) updating your BIOS.
 +
 
 +
= Updating Firmware =
 +
 +
Firmware flasher program can run on DOS (Lenovo PC DOS) or Windows but, unfortunately, not Linux. So ''in theory'' there are two basic steps to update the firmware (either the BIOS or the ECP) on a ThinkPad not running Windows:
 +
# Get or create a bootable image with supported OS
 +
# Boot that image and, if not started automatically, ran flasher program
 +
 
 +
Recent Thinkpads have firmwares available as ''Bootable CD'' image, e.g., FILENAME.iso. If you have an optical drive there is no need to read this page any further: just download .iso image, burn it and boot to flash bios. If you are not that lucky, read on.
 +
 
 +
First you need to realize that there are different ways to boot DOS on PC (theoretically it is possible to boot Windows to ran flasher, but why?...): from internal hard drive, CD drive, USB Flash drive or, as the last resort, floppy drive. Easiest way is from internal hard drive, but you'd better avoid touching it until you don't want to loose files there. [[Booting from a Floppy]] is not recommended, so there are two best options to boot: CD drive or USB Flash drive.
 +
 
 +
Sparse instructions below provide you guidance how to do different parts of this pazzle but it's your duty to understand what to do and how to do that.
 +
 
 +
== Using UEFI ==
 +
 
 +
Especially usable when CDROM is not available, tested on X140e, but should work in most recent firmwares as these supports UEFI, much simpler than older methods outlined in this and other pages.
 +
 
 +
You should have a USB mass storage device you can erase.
  
{{WARN|By following any of the instructions here you are accepting the '''very real risk''' of turning your thinkpad into a big expensive paper weight, as a firmware update gone wrong can create unfixable problems.
+
{{WARN|this will erase the USB mass storage device content.}}
  
'''Proceed at your own risk!'''
+
1. Download BIOS update ISO image, we assume it is xxx.iso.
  
It is also '''important''' to understand that all newer thinkpads have 2 seperate firmwares, the BIOS and the Control Program. A specific version of the Control Program will only work with specific versions of the BIOS. The IBM documentation is sometimes confusing about the order of update. Updating the Control Program first, then the BIOS seems to be the correct order.  Make sure to do the updates immediately following each other, otherwise you
+
2. Extract bootable image using [https://userpages.uni-koblenz.de/~krienke/ftp/noarch/geteltorito/ geteltorito] tool:
risk turning your thinkpad into a very nice paper weight.}}
 
  
==BIOS Upgrade Paths==
+
{{cmduser|./geteltorito.pl -o xxx.img xxx.iso}}
  
For every firmware (either BIOS or Control Program) update on the IBM site there are two different firmware update programs provided.
+
3. Insert USB device, checkout its device, we assume /dev/sdX.
  
===The Diskette Updater===
+
4. Dump content of image to USB device.
  
This installer appears to be a 16bit dos program which asks you to accept a license agreement.  It will run in Windows, DOS, OS/2, or [http://dosemu.sf.net Dosemu] perfectly, but requires a real floppy disk attached via a real floppy control.  The USB Floppy Drive to the new Thinkpads doesn't count.
+
{{WARN|Double check the device name so you do not overwrite any other filesystem.}}
  
===The Non Diskette Updater===
+
{{cmdroot|<nowiki>dd if=xxx.img of=/dev/sdX</nowiki>}}
{{WARN|Though this process was successfully tested on one version of .exe files found on IBMs website this doesn't mean it will work for all of them.  Use at your own risk.}}
 
  
This installer appears to be a 32bit windows exe which is designed for updating the BIOS directly from a running Windows OS.  It turns out that the .exe is really a wrapper license program arround windows .cab files (this information is in [[How_to_change_the_BIOS_bootsplash_screen|BIOS-Bootsplash]]). If you install the Linux program [http://freshmeat.net/projects/cabextract/ '''cabextract'''] you can expand these files directly.  Run the following:
+
5. Reboot, enter BIOS setup, enable UEFI only (or 1st priority) at startup options, save and reboot.
  
:{{cmduser|cabextract FILENAME.exe}}
+
6. Interrupt boot, press F12 and select USB mass storage device as boot source.
  
You will get 8 files in the current directory.  One of them will be FILENAME.img. You can test that this is really a floppy image by running:
+
7. The BIOS update utility should run and you should succeed in flashing BIOS.
  
:{{cmdroot|mkdir mntfloppy}}
+
== Create a bootable image ==
:{{cmdroot|mount -o loop FILENAME.img mntfloppy}}
 
:{{cmdroot|ls -la mntfloppy}}
 
  
If the results of {{cmdroot|ls -la mntfloppy}} look like a dos floppy, and no read errors were displayed, you have a pretty good chance that the floppy image is usable.
+
In case Lenovo does not provide your laptop with ''Bootable CD'' it is possible to create one from *discket packages.
  
==Downloads==
+
=== Extracting an update image ===
 +
{{WARN|Though this process has been successfully tested on many versions of .exe files found on IBMs website, that doesn't mean it will work for all of them.  '''Proceed at your own risk'''.  Consult the testing tables farther down of this page to see other users' experience with your model Thinkpad.}}
 +
{{NOTE|Lenovo has changed the packaging format. Old bios can be extracted with [http://freshmeat.net/projects/cabextract/ '''cabextract'''], new ones with [http://innoextract.constexpr.org/ '''innoextract'''].}}
 +
Older .exe installers from Lenovo mostly appear to be just a wrapper license program around Windows .cab files (see [[How_to_change_the_BIOS_bootsplash_screen|BIOS-Bootsplash]]). If you install the Linux program [http://freshmeat.net/projects/cabextract/ '''cabextract'''] you can expand these .cab files directly.  For example, if you downloaded {{path|1iuj13us.exe}} from Lenovo:
  
{{NOTE|Firefox or Konqueror users should disable the '''Use IBM Download Director''' option when downloading files.}}
+
:{{cmduser|cabextract 1iuj13us.exe}}
  
 +
Extracting cabinet: 1iuj13us.exe
 +
  extracting 1IUJ13US.IMG
 +
  extracting BIOSUPTP.EXE
 +
  extracting DOBOOT.EXE
 +
  extracting DOSBOOT.COM
 +
  extracting DOSBOOT.SYS
 +
  extracting DOSBOOT.VXD
 +
  extracting DOSBOOT2.COM
 +
  extracting ECTLUPTP.EXE
 +
  extracting EFLASHAS.SYS
 +
  extracting HDFWUPTP.EXE
 +
  extracting IBMTPI.XML
 +
All done, no errors.
  
{| border="1" cellspacing="0" cellpadding="2"
+
The file we want is '''FILENAME.IMG''', with "FILENAME" being the .exe. you downloaded. E.g., {{path|1IUJ13US.IMG}}.
| style="background:#ffdead;" rowspan="3"| '''Models'''
 
| style="background:#ffdead;" colspan="2"| '''Non-Diskette'''
 
| style="background:#ffdead;" colspan="3"| '''Diskette (or bootable CD)'''
 
|-
 
| style="background:#ffdead;" rowspan="2"| '''BIOS'''
 
| style="background:#ffdead;" rowspan="2"| '''Embedded Controller Program'''
 
| style="background:#ffdead;" colspan="2"| '''BIOS'''
 
| style="background:#ffdead;" rowspan="2"| '''Embedded Controller Program'''
 
|-
 
| style="background:#ffdead;"| '''Windows'''
 
| style="background:#ffdead;"| '''Linux'''
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
===200 Series===
 
|-
 
| {{240}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=DSHY-42DLNW 1.18]
 
|
 
|
 
|-
 
| {{240X}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=DSHY-42DLNW 1.09]
 
|
 
|
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
===300 Series===
 
|-
 
| {{365C}}, {{365CD}}, {{365CS}}, {{365CSD}}, {{365E}}, {{365ED}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-60567 2.0.14]
 
|
 
|
 
|-
 
| {{365X}}, {{365XD}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-60567 1.10]
 
|
 
|
 
|-
 
| {{380}}, {{380D}}, {{380E}}, {{380ED}}, {{385D}}, {{385ED}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=DSHY-3XWNVG 1.14]
 
|
 
|
 
|-
 
| {{380XD}}, {{385XD}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=DSHY-3XWNVG 1.19]
 
|
 
|
 
|-
 
| {{380Z}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=DSHY-3XWNVG 1.08]
 
|
 
|
 
|-
 
| {{390}}
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1DSHY-427MCG 5.62]
 
|
 
|
 
|-
 
| {{390E}}
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1DSHY-46AKPY 1.55]
 
|
 
|
 
|-
 
| {{390X}}
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4C5UP9 0.55]
 
|
 
|
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
===500 Series===
 
|-
 
| {{560}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-60522 1.20]
 
|
 
|
 
|-
 
| {{560E}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-60522 1.13]
 
|
 
|
 
|-
 
| {{560X}}
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1DSHY-3QYK7L 1.15]
 
|
 
|
 
|-
 
| {{560Z}}
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1DSHY-3YTKKV 1.07]
 
|
 
|
 
|-
 
| {{570}}
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-47JS5Z 1.16]
 
|
 
|
 
|-
 
| {{570E}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4HT3RD 1.07]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4HA2BF 1.07]
 
|
 
|
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
===600 Series===
 
|-
 
| {{600}}
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1DSHY-3VRJPK 1.22]
 
|
 
|
 
|-
 
| {{600E}} (2645 selected models, 2646)
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1DSHY-46HLKQ 1.16]
 
|
 
|
 
|-
 
| {{600E}} (2645: 55x, 56x, 57x, 58x, A5x, A6x, Bxx [except for BAU], JJ1, JJ2, RRA)
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1DSHY-43DNQ5 1.15]
 
|
 
|
 
|-
 
| {{600X}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4HVUYL 1.11]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4FYS2U 1.11]
 
|
 
|
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
===700 Series===
 
|-
 
| {{750}}, {{750CS}}, {{755C}}, {{755CS}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-60440 1.43]
 
|
 
|
 
|-
 
| {{755CE}}, {{755CSE}}, {{755CD}}, {{755CX}}, {{755CV}}, {{755CDV}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-60440 1.44]
 
|
 
|
 
|-
 
| {{760C}}, {{760CD}}, {{760L}}, {{760LD}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-59734 1.30]
 
|
 
|
 
|-
 
| {{760E}} (XGA), {{760ED}} (XGA), {{760XD}}, {{765D}}, {{765L}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-59734 2.13]
 
|
 
|
 
|-
 
| {{760E}} (SVGA), {{760ED}} (SVGA), {{760EL}}, {{760ELD}}, {{760XL}}
 
|
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-59734 2.13]
 
|
 
|
 
|-
 
| {{770}}, {{770E}}, {{770ED}}
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1DSHY-3P2MCB 1.34]
 
|
 
|
 
|-
 
| {{770X}}
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1DSHY-42QLVU 1.10]
 
|
 
|
 
|-
 
| {{770Z}}
 
|
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-47F3VA 1.05]
 
|
 
|
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
===A Series===
 
|-
 
| {{A20m}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4MNN8Z 1.13]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4JWNTQ 1.13]
 
|
 
|
 
|-
 
| {{A20p}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4MNN8Y 1.11]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4JWNTR 1.11]
 
|
 
|
 
|-
 
| {{A21e}} (2165)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4UNQKX 1.07]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4UNRRF 1.07]
 
|
 
|
 
|-
 
| {{A21e}} (2628)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4Q2KLU 1.13]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4Q2KLV 1.13]
 
|
 
|
 
|-
 
| {{A21m}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4PJMXK 1.09]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4Q2KM4 1.09]
 
|
 
|
 
|-
 
| {{A21p}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4Q2KM3 1.11]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4PJN8X 1.11]
 
|
 
|
 
|-
 
| {{A22e}} Celeron
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4UNQKX 1.07]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4UNRRF 1.07]
 
|
 
|
 
|-
 
| {{A22e}} Pentium
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4XQKLK 1.05]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4XQL7B 1.05]
 
|
 
|
 
|-
 
| {{A22m}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4Q2KM4 1.09]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4PJMXK 1.09]
 
|
 
|
 
|-
 
| {{A22m}} (2628-Sxx)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4VXS2T 1.05]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4VXRG4 1.05]
 
|
 
|
 
|-
 
| {{A22p}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4Q2KM3 1.11]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4PJN8X 1.11]
 
|
 
|
 
|-
 
| {{A30}}, {{A30p}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-39863 1.18]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-40846 1.08]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-39861 1.18]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-40847 1.08]
 
|-
 
| {{A31}}, {{A31p}} (Bios 1G*)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-42654 1.12]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-45771 1.05]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-42660 1.12]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-45900 1.05]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-45770 1.05]
 
|-
 
| {{A31}}, {{A31p}} (Bios 1N*)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-44450 1.09]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-45662 1.05]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-44451 1.09]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-45898 1.02]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-45663 1.05]
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
===G Series===
 
|-
 
| {{G40}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50672 1.21]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50673 1.21]
 
|
 
|
 
|-
 
| {{G41}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-58127 1.14]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-58129 1.14]
 
|
 
|
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
  
===R Series===
+
If this does not work for the Non-diskette .exe, try it on the Diskette .exe. It's reported, for example, that the Non-diskette .exe for BIOS version 3.23 for the T41p was not extractable, but the Diskette .exe worked perfectly, with {{cmduser|cabextract}} delivering a .IMG file.
|-
 
| {{R30}}
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-40216 1.38]
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-40217 1.38]
 
|
 
|
 
|-
 
| {{R31}}
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-41378 3.11]
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-41535 3.11]
 
|
 
|
 
|-
 
| {{R32}}
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-43571 2.16]
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-43572 2.16]
 
|
 
|
 
|-
 
| {{R40}} (2681, 2682, 2683, 2896, 2898, 2899)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-46055 1.24]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-46143 1.14]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-46061 1.24]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-46144 1.14]
 
|-
 
| {{R40}} (2722, 2723, 2724, 2897)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50320 1.30]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-46143 1.14]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50321 1.30]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-46144 1.14]
 
|-
 
| {{R40e}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50302 1.38]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50344 1.04]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50301 1.38]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50343 1.04]
 
|-
 
| {{R50}}, {{R50p}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50273 3.21]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50279 3.04]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50275 3.21]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50277 3.04]
 
|-
 
| {{R50e}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-55000 2.08]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-54996 1.04]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-55001 2.08]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-54997 1.04]
 
|-
 
| {{R51}} (1829, 1830, 1831, 1836)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50273 3.21]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50279 3.04]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50275 3.21]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50277 3.04]
 
|-
 
| {{R51}} (2883, 2887, 2888, 2889, 2894, 2895)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-55003 1.27]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-54996 1.04]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-55004 1.27]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-54997 1.04]
 
|-
 
| {{R51e}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-61681 1.57]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-61677 1.01]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-61680 1.57]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-61675 1.01]
 
|-
 
| {{R52}} (1846, 1847, 1848, 1849, 1850, 1870)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59221 1.25]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59184 1.06]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59220 1.25]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59183 1.06]
 
|-
 
| {{R52}} (1858, 1859, 1860, 1861, 1862, 1863)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59379 1.26]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59439 1.05]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59380 1.26]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59440 1.05]
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
  
===T Series===
+
==== If cabeextract/innoextract fails ====
|-
 
| {{T20}}
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-4MNN8X 1.22]
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-4JWNJC 1.22]
 
|
 
|
 
|-
 
| {{T21}}
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-4Q2KM5 1.16]
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-4PJN8Y 1.16]
 
|
 
|
 
|-
 
| {{T22}}
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-4VWPPU 1.12]
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-4VWP54 1.12]
 
|
 
|
 
|-
 
| {{T23}}
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-39366 1.18]
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-40022 1.06a]
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-39362 1.18]
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-40021 1.06a]
 
|-
 
| {{T30}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-42694 2.10]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-42711 1.07]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-42720 2.10]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-45745 2.02]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-42725 1.07]
 
|-
 
| {{T40}}, {{T40p}}, {{T41}}, {{T41p}}, {{T42}}, {{T42p}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50275 3.21]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50279 3.04]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50273 3.21]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50277 3.04]
 
|-
 
| {{T43}} (1871, 1872, 1873, 1874, 1875, 1876)
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59379 1.26]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59439 1.05]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59380 1.26]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59440 1.05]
 
|-
 
| {{T43}} (2668, 2669, 2678, 2679, 2686, 2687), {{T43p}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59096 1.28]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59120 1.06]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59097 1.28]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59121 1.06]
 
|-
 
| {{T60}}, {{T60p}}
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-63024 1.09]
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-63027 1.09] (CD)
 
|
 
|
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
  
===X Series===
+
Diskette .exe for some older models can't be extracted using cabextract. For example for the latest BIOS of 390E one gets
|-
+
spsdilc9.exe: no valid cabinets found
| {{X20}}, {{X21}}
+
There is a simple way to solve this, by stripping the header off from the Non-diskette version. To do this, first you need to find the index for the first occurance of '''MSCF''' in the downloaded executable. This can be done with the following
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4P52BM 2.25]
+
strings -a -t d NO-DISKETT.EXE | awk 'offset=index($2,"MSCF"), (offset != 0) {print $1+offset-1}' | head --lines 1
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4VQNTP 1.36]
+
4196
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4P52BL 2.25]
+
The command adds the byte offset of the matching line plus the index for the start of the '''MSCF''' on that line, thus the byte offset of '''MSCF''', this number is usually '''4196''' Now we need to cut these header bytes off, this is done by a standard dd cut, the following cuts away the first 4196 bytes.
|
+
dd if=NO-DISKETTE.EXE of=out.cab iflag=skip_bytes skip=4196
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-4PBMCT 1.36]
+
The newly created '''out.cab''' should now work with '''cabextract'''
|-
+
cabextract out.cab
| {{X22}}, {{X23}}, {{X24}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-39672 1.32]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-39806 1.30]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-39665 1.32]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-39808 1.30]
 
|-
 
| {{X30}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-44135 1.09]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-44152 1.06]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-44131 1.09]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-44149 1.06]
 
|-
 
| {{X31}}, {{X32}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50298 3.02]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-53480 1.08]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-50308 3.02]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-53479 1.08]
 
|-
 
| {{X40}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-53881 2.06]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-53882 1.61]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-53883 2.03]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-53885 1.60]
 
|-
 
| {{X41}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59206 2.06]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59208 1.02]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59205 2.06]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-59207 1.02]
 
|-
 
| {{X41T}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-60193 2.02]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-60191 1.02]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-60194 2.02]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-60189 1.02]
 
|-
 
| {{X60}}, {{X60s}}
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-63144 1.06]
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-63145 1.06] (CD)
 
|
 
|
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
  
===Z Series===
+
A second alternative is to use Windows XP (works in VirtualBox too) together with [http://sourceforge.net/projects/vfd/ Virtual Floppy Drive]. Rund vfdwin.exe, go to the Driver tab and hit Install and Start. Then go to the Drive0 tab, click on Change and select A:. Finally, click on Open/Create, and click Create. This should give you a virtual floppy drive the .exe file will extract files to.
|-
 
| {{Z60m}}, {{Z60t}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-61687 1.19]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-61686 1.16]
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-61688 1.19]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-61685 1.16]
 
|-
 
| Z61e, {{Z61m}}, Z61p, {{Z61t}}
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-64409 1.13]
 
|
 
| [http://www.ibm.com/support/docview.wss?uid=psg1MIGR-64305 1.13] (CD)
 
|
 
|
 
|-
 
! colspan=6 style="text-align:center;background:#efefef;" |
 
  
===Other===
+
A third solution is to use QEMU with a DOS diskette image to run the disk extractor.
|-
 
| {{TransNote}}
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-4UDSMK 1.02]
 
|
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-4UDRRF 1.02]
 
|
 
|
 
|}
 
  
If you were able to create the boot floppy per the Diskette update method, and you have a Floppy with your Thinkpad, the update should be simple.
+
==== Testing the Image ====
  
==Updating an X60==
+
You can test that FILENAME.IMG is really a floppy image by running:
If there is no floppy, and no windows, but an external USB CD, then there is hope.
 
  
===Build a bootable CD with USB support===
+
{{cmdroot|mkdir /tmp/mntfloppy}}
Get the ISO Image style BIOS upgrade, and the freedos floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip)
 
  
:{{cmdroot|su # get root}}
+
{{cmdroot|mount -o loop FILENAME.IMG /tmp/mntfloppy}}
:{{cmdroot|mkdir /tmp/iso}}
 
:{{cmdroot|mkdir /tmp/cdimage}}
 
:{{cmdroot|mount -o loop <iso-bios-file> /tmp/iso}}
 
:{{cmdroot|cp /tmp/iso/* /tmp/cdimage}}
 
:{{cmdroot|cp <freedos-disk-image> /tmp/cdimage/floppy.img}}
 
:{{cmdroot|mkisofs -b floppy.img -o bootcd.iso /tmp/cdimage}}
 
  
finished.. now boot from cd and flash.
+
If a '''ls''' command on the image returns what looks like a DOS floppy, and no read errors were displayed, you have a pretty good chance that the image is usable. For example:
  
==Updating via CD/DVD Drive==
+
{{cmdroot|ls /tmp/mntfloppy}}
 +
$0195000.FL1  069580.PAT  06d2.HSH    IBMDOS.COM    TPCHKS.EXE
 +
0691.HSH      06D0.PAT    06d6.HSH    LOGO.BAT      UPDTFLSH.EXE
 +
0691.PAT      06D1.PAT    06d8.HSH    LOGO.SCR      UPDTMN.EXE
 +
0694.HSH      06D2.PAT    CHKBMP.EXE  PHLASH16.EXE  USERINT.EXE
 +
0694.PAT      06D6.PAT    COMMAND.COM  PREPARE.EXE  UTILINFO.EXE
 +
0695.HSH      06D8.PAT    CONFIG.SYS  PROD.dat      lcreflsh.bat
 +
0695.PAT      06d0.HSH    FLASH2.EXE  QKFLASH.EXE
 +
069580.HSH    06d1.HSH    IBMBIO.COM  README.TXT
  
The whole thing gets more complicated if you neither have Windows nor a floppy drive installed. This is what this page is intended to describe.
+
Unmount the image after you are done testing:
  
Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.
+
{{cmdroot|umount /tmp/mntfloppy}}
  
Be aware that IBM officially does '''not''' support this! The official statement to my support request was:
+
== Booting from update image ==
 +
Now that you have a bootable image for the correct update for you hardware, you need to do is boot from that image to install the update.
  
<blockquote style="background: white; border: 1px solid black; padding: 1em;">
+
There are different ways to do that:
<pre><nowiki>
+
* [[#Booting from a CD|Boot from a CD]]
I'm afraid we only support the options listed on our web page and no you
+
* [[#Booting_using_GRUB|Boot image using bootloader (e.g. GRUB)]]
can't burn a CD/DVD, however you can try to use an external USB FDD
+
* [[#Booting_from_a_USB_Flash_drive|Boot from a USB Flash drive]]
(floppy) drive. The experts recommend a IBM USB FDD, however they have also
+
* [[#Booting_from_a_floppy|Boot from a floppy]]
tested it with a Sony USB FDD drive.
 
  
In order to make sure the drive is recognised you can boot up the FDD with
+
=== Booting from a CD ===
a bootable dos diskette for w98
+
{| align="right" style="width:40em;"
</nowiki></pre>
+
|{{HINT|If there is a ''Bootable CD'' image available, e.g., FILENAME.iso, just download that, instead of mucking around with image files.}}
</blockquote>
+
|}
 +
If you are going to update the firmware by booting from a CD, you need to turn FILENAME.IMG that you extracted above into an .iso file.
  
But it seems to be possible as Mathias Dalheimer describes this [http://mailman.linux-thinkpad.org/pipermail/linux-thinkpad/1998-January/009743.html here].
+
The [http://en.wikipedia.org/wiki/El_Torito_%28CD-ROM_standard%29 El Torito Bootable CD Specification] is a wonderful thing.  Thanks to it, a bootable CD can be made with a bootable floppy image in such as way that the CD believes that it is a 2.88 MB floppy drive. This allows you to replace a boot floppy by a boot CD in nearly all situations.
  
Another indication that it should work is that IBM uses PHLASH16.EXE (at least on T4x/p systems) to flash the BIOS into the chip. The same tool is used by [http://www.samsungpc.com/gb/support/p35/bios/bios-instructions.html other vendors] to flash the BIOS from bootable CD-ROMs.
+
It is very easy to create such a bootable CD ISO image in Linux using the '''mkisofs''' tool{{footnote|1}}. Run a command as follows:
{{WARN|Do '''not''' use the [http://syslinux.zytor.com/ SYSLINUX] image-loader [http://syslinux.zytor.com/memdisk.php MEMDISK] to boot the images! Some flash tools crash in that situation!}}
 
  
Some interesting but very technical information about the used flash tool can be found [http://www.paul.sladen.org/thinkpad-r31/wifi-card-pci-ids.html here].
+
{{cmdroot|genisoimage -b 1WUJ25US.IMG -c boot.catalog -o bootcd.iso 1WUJ25US.IMG}} #or older mkisofs
  
===Creating a Floppy Image===
+
Where *.IMG is the name of the image file extracted above. This creates a CD with one file on it and marks that file as the boot image.
If you have created a boot floppy on another machine, you need to create an image file of that floppy. This can be easily done in linux by running a command line:
 
  
:{{cmdroot|1=dd bs=2x80x18b if=/dev/fd0 of=/tmp/floppy.img}}
+
You can now burn the {{path|bootcd.iso}} to a CD in your favorite CD-burning program.
 +
{{WARN|By following any of the instructions here you are accepting the '''very real risk''' of turning your ThinkPad into a big expensive paper weight, as a firmware update gone wrong can create unfix-able problems. '''Proceed at your own risk!'''}}
  
You can also create a floppy image by using Ken Kato's [http://chitchat.at.infoseek.co.jp/vmware/vfd.html VMware's back]. It is a free Windoze tool that creates a virtual floppy drive and allows you to produce an image file ready to be ISO'ed. Note: you might have to 'manually' (through application's interface) assign the virtual drive a volume letter in order to be seen by IBM's application (as, by default, it seems not to do it).
+
Boot from the CD to update your firmware.  Remember to have [[BIOS_Upgrade#Two_Firmwares:_BIOS_and_ECP|both BIOS and ECP firmware boot-CDs]] ready, as needed, and use them in the [[BIOS_Upgrade#Update_Order|proper order]].
  
You should verify this {{path|floppy.img}} as explained above.
+
{| align="center"
 +
| {{HELP|Please, report your success/failure with flashing BIOS from the manually cooked CD (from .IMG file) here: [[BIOS_Upgrade_success_failure#Booting_from_CD]]}}
 +
|}
  
===Creating a Bootable CD from a Floppy Image===
+
=== Booting using GRUB (Traditional) ===
Once you have your floppy image, either from imaging a real floppy, or from extracting them via the cabextract method above, you need to make a boot CD out of it.
+
{|
 +
| style="width:75%" | {{WARN|Many have warned '''not''' to use the SYSLINUX image-loader '''memdisk''' to boot firmware update images.}}
 +
| style="font-size:80%" | {{HELP|Who are these "many"?  Link to a discussion?}}
 +
|}
 +
Warning: These instructions are for 'Traditional' GRUB, not GRUB2.  Traditional GRUB uses a configuration file at /boot/grub/menu.lst.  GRUB2 uses /boot/grub/grub.cfg.  See the next section for the GRUB2 instructions.
  
The eltorito bootable CD standard is a wonderful thing. What this means is that a bootable CD can be made with a bootable floppy in such as way that the CD believes that it is a 2.88 MB floppy drive. This allows you to replace a boot floppy by a boot CD in nearly all situations.
+
Once the bootable image, FILENAME.IMG, is extracted from the .exe, it can be booted directly through GRUB without the need of burning a CD, using the [http://syslinux.zytor.com/ SYSLINUX] image-loader '''[http://syslinux.zytor.com/memdisk.php memdisk]'''.
  
It is very easy to create such a bootable CD ISO image in Linux using the mkisofs tool. To do this run a command as follows:
+
Locate the '''memdisk''' file from the syslinux package. You can search for it with '''find''':  
  
:{{cmdroot|mkisofs -b bootfloppy.img -o bootcd.iso bootfloppy.img}}
+
{{cmdroot|find /usr -name memdisk}} #or just use "dlocate memdisk" or "locate memdisk" if these programs are installed
  
Note: You don't strictly need the last {{path|bootfloppy.img}}, however some versions of mkisofs get confused about why you would want to create an iso with no contents, and thus won't let you.  You don't actually care about the contents of the CD, you only care that the <tt>-b <boot image></tt> is applied to the CD. For more info on this read {{cmduser|man mkisofs}}.
+
If {{path|/usr/.../memdisk}} is not present, syslinux is not installed.  You will need to install it to boot a .IMG from GRUB.
  
You can now burn the {{path|bootcd.iso}} in your favorite CD burning program.
+
Copy both the '''FILENAME.IMG''' and '''memdisk''' files into {{path|/boot}} directory. For example:
  
To get an overview which models have been tested with this version, here is a list:
+
{{cmdroot|cp ./FILENAME.IMG /usr/share/syslinux/memdisk /boot/}}
  
===Does work:===
+
Open {{path|/boot/grub/menu.lst}} in your favourite editor.  '''Copy''' the active section into a '''new section''', and edit the new section:
 
{| border="1" cellspacing="0" cellpadding="2"
 
{| border="1" cellspacing="0" cellpadding="2"
| '''Model''' || '''Tested by'''
+
! Parameter
 +
! Instructions
 +
! Example
 
|-
 
|-
| style="vertical-align:top;" {{600X}} (2645) ||
+
| ''title''  || Pick a name for the new section. This will show up in the GRUB boot menu. || <tt>title IBM ECP Update</tt>
*Jonathan Byrne <jonathan@RemoveThisToMailMe.yamame.org>. BIOS 1.11 from spsuit55.exe worked perfectly using cabextract/CD method.
 
 
|-
 
|-
| style="vertical-align:top;" |  {{A20p}} (2629-6VU) ||
+
| ''root''  || Do not change. This is the partition containing the {{path|/boot}} directory      || <tt>root (hd0,0)</tt>
*Chris Pickett http://www.sable.mcgill.ca/~cpicke/. BIOS 1.11 flashed fine with cabextract/CD method.
 
 
|-
 
|-
| style="vertical-align:top;" | {{A21e}} (2628-JXU) ||
+
| ''kernel'' || '''/boot/memdisk''' will allow you to boot an image file.                  || <tt>kernel /boot/memdisk</tt>
*Amit Gurdasani <gurdasani at yahoo dot com>. BIOS 1.13 flashed fine with cabextract/CD method. Alarmingly, after the BIOS update, the laptop beeped but did not shut down as was indicated onscreen -- that was frozen on the "do not shut down the laptop" screen. On power down and up again, the BIOS setup showed the newer BIOS image running, and Linux booted up fine. Linux ACPI didn't complain about the BIOS being too old either.
 
 
|-
 
|-
| style="vertical-align:top;" | {{A31p}} (2653) ||
+
| ''initrd'' || This is the name of the firmware-updater image file, e.g., 1IUJ13US.IMG    || <tt>initrd /boot/1IUJ13US.IMG</tt>
*Matthias Meinke largeeddy@gmx.at, BIOS 1.09 1NET15WW flashed fine with cabextract/CD method.
+
|}
|-
+
 
| style="vertical-align:top;" |  {{R31}} ||
+
Do '''not''' modify the original section in {{path|/boot/grub/menu.lst}}, or you might not be able to boot back to the operating system.
*[http://mailman.linux-thinkpad.org/pipermail/linux-thinkpad/1998-January/009743.html Mathias Dalheimer]
+
 
*Sebastian Sauer (with cabextract/CD method)
+
If you have [[#Two_Firmwares:_BIOS_and_ECP|two firmware updates to do]], you will need a section for each firmware's FILENAME.IMG in {{path|/boot/grub/menu.lst}}.
|-
+
 
| style="vertical-align:top;" | {{R40}} ||
+
{{NOTE|If both BIOS and ECP are to be updated, be sure to update them in the [[#Proper_Order|proper order]].}}
*Matthew Lambie, http://lambie.org
+
 
|-
+
{{WARN|By following any of the instructions here you are accepting the '''very real risk''' of turning your ThinkPad into a big expensive paper weight, as a firmware update gone wrong can create unfix-able problems'''Proceed at your own risk!'''}}
| style="vertical-align:top;" | {{R50}} (1836-3SU) ||
+
 
*jlbartos <jlbartos at hotmail dot com>
+
Reboot your computer, entering the GRUB menu and selecting ''IBM BIOS Update'', or whatever you named the new section in {{path|/boot/grub/menu.lst}}.
|-
+
 
| style="vertical-align:top;" | {{R51}} (1829) ||
+
==== Booting image with GRUB2 ====
*Robert Uhl <rob dot uhl at gmx dot de>, Jellby <jellby at yahoo dot com>
+
===== GRUB2: booting floppy Image =====
|-
+
With grub2, one would ''append'' the following to ''/boot/grub/grub.cfg'' :
| style="vertical-align:top;" | {{R51}} (1830-RM7) ||
+
menuentry "My BIOS Upgrade" {
*Will Parker <stardotstar at sourcepoint dot com dot au> successfully flashed 3.20 using existing 3.04 ECP and retained custom boot splash.
+
  set root=(hd0,0) #should match the others in your grub.cfg
|-
+
linux16 /boot/memdisk
| style="vertical-align:top;" | {{R51}} (2887) ||
+
initrd16 /boot/1WUJ25US.IMG #or whatever yours is
*Ingo van Lil <inguin at gmx dot de>
+
  }
|-
+
 
| style="vertical-align:top;" |  {{T20}} ||
+
{| align="center"
*Franz Hassels <fhassel at suse dot com>
+
| {{HELP|Please, report your success/failure with flashing BIOS from the manually cooked CD (from .IMG file) here: [[BIOS_Upgrade_success_failure#GRUB2:_Booting_floppy_Image]]}}
|-
 
| style="vertical-align:top;" |  {{T22}} ||
 
*Daniel Maier <nusse teamidiot de>
 
|-
 
| style="vertical-align:top;" |  {{T23}} ||
 
*Bart Snapp <snapp at uiuc dot edu> Note: I followed IBM's instructions to flash the BIOS *first* and the Embedded Controller *second*.
 
*Moy Easwaran: BIOS 1.18 / EC 1.06a via cabextract and CD-boot.  The BIOS-update exe generated errors in Windows 2000.
 
*Joe Renes: BIOS 1.18 / EC 1.06a on 2006-03-20 via cabextract and CD-boot. Piece of cake.
 
|-
 
| style="vertical-align:top;" | {{T40}} ||
 
*Sean Dague, http://dague.net
 
*Justin Mason, http://jmason.org
 
*Ivanhoe (Bios 3.19)
 
|-
 
| style="vertical-align:top;" |  {{T40p}} ||
 
*Lukas Krähenbühl, ismo at pop dot agri dot ch
 
*Thomas Achtemichuk, tom at tomchuk dot com. BIOS 3.15 flashed fine with cabextract/CD method
 
|-
 
| style="vertical-align:top;" | {{T41}} ||
 
*Lev Givon (Bios 3.15 / EC 3.04) <lev at columbia dot edu>
 
*Ernesto Hernández-Novich (Bios 3.19 / CP 3.04) < emhn at usb dot ve >
 
|-
 
| style="vertical-align:top;" |  {{T41p}} ||
 
*Nils Newman, work great. (Version: Bios 3.14 / Embedded Controller 3.04)
 
|-
 
| style="vertical-align:top;" |  {{T42}} ||
 
*Dan (BIOS 3.20 / EC 3.04, cabextract/CD method) <tronic171 at evilphb.org>
 
|-
 
| style="vertical-align:top;" | {{T42p}} ||
 
*Robert Schiele <rschiele@uni-mannheim.de>, Joern Heissler <joern@heissler.de>
 
|-
 
| style="vertical-align:top;" |  {{T43}}  ||
 
*Tom Heady <tom-thinkwiki.org@punch.net>
 
*Carsten Söhrens <casoe at gmx dot de> (Version: Bios 1.05 / Embedded Controller 1.03)
 
*Carsten Söhrens <casoe at gmx dot de> (Version: Bios 1.24 / Embedded Controller 1.04)
 
*Florian Boucault <florian at boucault dot ath dot cx> (Model : 1871-W34 & Version: Bios 1.23 / Embedded Controller 1.03)
 
|-
 
| style="vertical-align:top;" |  {{X20}} ||
 
*Neil Caunt <retardis at gmail dot com>
 
|-
 
| style="vertical-align:top;" |  {{X21}}  ||
 
*Patrick Leickner <ranma at web dot de>, (BIOS 2.21->2.25 / EC 1.31->1.36) via non-disk/cabextract/mkisofs/cdrecord
 
|-
 
| style="vertical-align:top;" {{X22}}  ||
 
*David Emery <dave at skiddlydee dot com>, (EC 1.30, BIOS 1.32 using non-disk/cabextract/CD method)
 
|-
 
| style="vertical-align:top;" | {{X23}}  ||
 
*Nils Faerber <nils dot faerber at kernelconcepts dot de> (Embedded Controller 1.30, BIOS 1.32 with cabextract/CD method)
 
|-
 
| style="vertical-align:top;" | {{X30}}  ||
 
*Hella Breitkopf, [http://hella.breitkopf.usr.ffb.org/en/ www]  (Embedded Controller 1.04, BIOS 1.07 with cabextract/CD method)
 
|-
 
| style="vertical-align:top;" |  {{X31}}  ||
 
*Grzegorz KuÅ›nierz <koniu at sheket dot org>  (Embedded Controller 1.08, BIOS 3.01 with cabextract/CD method)
 
|-
 
| style="vertical-align:top;" |  {{X40}}  ||
 
*Robbie Stone <robbie@serendipity.cx>
 
|-
 
| style="vertical-align:top;" |  {{Z60m}}  ||
 
*[[User:Morle|Morle]] 13:09, 20 May 2006 (CEST),  (Embedded Controller 1.14 with cabextract/CD method)
 
 
|}
 
|}
  
===Does not work:===
+
===== GRUB2: booting CD Image =====
{|
+
You must first download the bootable iso file from the Lenovo Website.
| '''Model''' || '''Tested by'''
+
 
 +
===== On Debian and Ubuntu =====  
 +
Then, on Debian and Ubuntu, you can install the grub-imageboot package, then you just have to copy the iso file in /boot/images and run update-grub:
 +
<pre>
 +
sudo apt-get install grub-imageboot
 +
sudo mkdir -p /boot/images
 +
sudo cp /home/youruser/Downloads/6uuj12uc.iso /boot/images
 +
sudo update-grub
 +
</pre>
 +
 
 +
===== Manual method =====
 +
Otherwise, copy the file 'memdisk' from the syslinux package to /boot. Also create a symlink, so you do not have to change the grub configuration for each bios upgrade:
 +
<pre>
 +
sudo su -
 +
cd /boot
 +
cp /home/youruser/Downloads/6uuj12uc.iso .
 +
cp /usr/share/syslinux/memdisk .
 +
ln -s 6uuj12uc.iso biosupgrade.iso
 +
</pre>
 +
Now create the boot entry:
 +
<pre>
 +
cat >> /etc/grub.d/40_custom <<EOF
 +
menuentry "Lenovo BIOS Upgrade" {
 +
    set root=(hd0,1)  # <-- check for correct numbering
 +
    linux16 /boot/memdisk iso
 +
    initrd16 /boot/biosupgrade.iso
 +
}
 +
EOF
 +
update-grub
 +
</pre>
 +
Reboot an Select "Lenovo BIOS Upgrade".
 +
 
 +
For the next Bios Upgrade you'll just need to copy the new iso file to /boot and adjust the symlink.
 +
 
 +
{| align="center"
 +
| {{HELP|Please, report your success/failure with flashing BIOS from the manually cooked CD (from .IMG file) here: [[BIOS_Upgrade_success_failure#GRUB2:_Booting_CD_Image]]}}
 
|}
 
|}
  
Please note that testing this is '''at your own risk'''!!!
+
=== Booting from a USB Flash drive ===
  
==Updating an X60==
+
==== Updating the BIOS in MS-DOS mode ====
If there is no floppy, and no windows, but an external USB CD, then there is hope.
+
(This process works for most Thinkpad models that has Windows XP, Windows Vista or Windows 7 OS)
===Build a bootable CD with USB support===
 
Get the ISO Image style BIOS upgrade, and the freedos floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip)
 
  
:{{cmdroot|su # get root}}
+
1. Using HP USB Boot Utility, [http://blogs.oreilly.com/digitalmedia/2004/10/utility-to-make-usb-flash-driv.html create a bootable USB flash drive [http://www.bay-wolf.com/utility/usbkey/win98boot.zip DOS using Windows 98 Boot Disk Floppy Image].
:{{cmdroot|mkdir /tmp/iso}}
 
:{{cmdroot|mkdir /tmp/cdimage}}
 
:{{cmdroot|mount -o loop <iso-bios-file> /tmp/iso}}
 
:{{cmdroot|cp /tmp/iso/* /tmp/cdimage}}
 
:{{cmdroot|cp <freedos-disk-image> /tmp/cdimage/floppy.img}}
 
:{{cmdroot|mkisofs -b floppy.img -o bootcd.iso /tmp/cdimage}}
 
  
finished.. now boot from cd and flash.
+
2. Extract the (*.ima) from the ISO BIOS image (e.g. [http://www.rarsoft.com WinRAR] will do this).
  
 +
3. Using a tool that can open .IMA files (such as [http://www.winimage.com/ WinImage]), extract all files to a temporary folder.
  
==Updating via Grub and a Floppy Image==
+
4. Run the HP tool, select the USB device, I used FAT32,  create a DOS bootable disk and point at the win98boot folder - then "Start". Warning: this '''formats''' the USB flash drive and all data will be erased!
  
{{WARN|Many have warned '''not''' to use the [http://syslinux.zytor.com/ SYSLINUX] image-loader [http://syslinux.zytor.com/memdisk.php MEMDISK] to boot the images! Some flash tools may crash in that situation!  Proceed at your own risk!}}
+
5. Once complete (you could test if it boots at this point), copy the extracted BIOS files from the temporary folder you created to the USB flash drive.
  
Floppy images may be booted from Grub via a utility called [http://syslinux.zytor.com/memdisk.php MEMDISK], which may be compiled from the [http://www.kernel.org/pub/linux/utils/boot/syslinux/ '''SYSLINUX source'''].  Copy the compiled memdisk image and the floppy image to your boot directory and configure grub as follows:
+
6. Boot from USB flash drive by pressing F11 within the BIOS boot logo. At the DOS command prompt, type "updflsh" and then follow the prompts by pressing "Y" or Enter. Make sure that you have a fully charged battery pack and the AC Adapter is firmly plugged before proceeding with the BIOS update.
 +
'''DO NOT Power off the laptop or unplug the USB flash drive while the update is in progress or else update will fail and your computer will be unable to boot and system board may need to be serviced.'''
  
<blockquote style="background: white; border: 1px solid black; padding: 1em;">
+
This process takes around 1-2 minutes. A long beep followed by a short beep will notify you that the update is complete and the system will automatically power off.
<pre><nowiki>
 
title    Bios Flash
 
kernel    /boot/memdisk
 
initrd    /boot/FILENAME.img
 
</nowiki></pre></blockquote>
 
  
Again, proceed at your own risk. This was tested on an R51 type 2888.
+
7. Power on the laptop then enter the BIOS setup by pressing F1 and Load BIOS defaults.
  
This also worked for me on a T41p type 2373. --[[User:MrStaticVoid|James Lee]] 20:55, 8 May 2006 (CEST)
+
==== Using grub4dos (also for Linux) ====
  
==Updating with Network Boot Image==
+
[http://grub4dos.sourceforge.net/wiki/ grub4dos] is a GNU GRUB fork with interesting features. One of them is the ability to boot ISO images directly off USB flash drives. Contrary to the name, GRUB for DOS works fine on Linux. Follow these steps:
 +
* Download the latest grub4dos package at http://download.gna.org/grub4dos/ (I needed 0.4.4 for my USB2 drive - 0.4.3 did not work.)
 +
* Unpack
 +
* Insert your FAT-32 formatted pendrive
 +
* Run <code>sudo ./bootlace.com /dev/sdX</code>, where /dev/sdX is the device name assigned to your pendrive (use <code>sudo fdisk -l</code> to figure this out). Be very careful to get the device correct or else you could overwrite your hard drive! This creates grub4dos boot sector in MBR of the flash drive.
 +
* Copy the files <code>grldr</code> and <code>menu.lst</code> to the root directory of your pendrive.
 +
* Convert the ThinkPad .IMG file to a .ISO file using <code>genisoimage -b 1yuj18us.img -c boot.catalog -o 1yuj18us.iso 1yuj18us.img</code>
 +
* Copy the ISO image to the root directory of your pendrive (e.g. <code>1yuj18us.iso</code>).
 +
* Edit <code>menu.lst</code> on the pendrive and include the following section (of course putting the appropriate ISO image name):
 +
<pre>
 +
title thinkpad-bios
 +
map (hd0,0)/1yuj18us.iso (hd32)
 +
map --hook
 +
chainloader (hd32)
 +
boot
 +
</pre>
 +
* Reboot and press F12 to select booting from USB.
 +
* If all went well, you should be able to boot the Thinkpad's ISO image and flash the BIOS. I tested it successfully on T400.
  
BIOS, Embedded Controller (EC), CD/DVD and Harddisk firmware disks can be booted
+
==== Manually creating a USB Flash drive in Linux ====
over the network with [http://syslinux.zytor.com/pxe.php PXELINUX] as part of the [http://syslinux.zytor.com/ SYSLINUX] package.
 
  
This requires that you have a DHCP and tftp server configured and setup properly on
+
Use "geteltorito" to extract the update image from ISO image, downloaded from Lenovo's drivers page. Write the extracted image to a USB Flash drive using dd. "geteltorito" is available in Ubuntu (at least in Trusty, 14.04) from package "genisoimage".
your network, and is probably not for the faint of heart.
+
* Install the genisoimage package: <code>sudo apt-get install genisoimage</code>
 +
* Extract the boot image from the ISO: <code>geteltorito g6uj14us.iso > biosupdate.img</code>
 +
* Install the boot image to USB Flash drive, make sure to install to the correct device! (device for me was /dev/sdb): <code>sudo dd if=biosupdate.img of=/dev/<yourusbflashdevice> bs=512K</code>
 +
* Reboot and press F12 to select booting from USB.
 +
* If all went well, you should be able to boot the Thinkpad's ISO image and flash the BIOS. Tested successfully on: X1 Carbon, X230.
  
Make sure the firmware bootdisk is in linux 'dd' format, as the self-extracting .exe disks
+
=== Booting from a Floppy ===
from the IBM website cannot be booted directly as such.
+
{{WARN|Using a floppy disk '''is NOT recommended'''.}}
  
This worked on the {{R31}}, {{X22}}, {{T21}}, {{T30}} and {{T41p}} with various firmware updates.
+
This is how IBM/Lenovo intended it.  Use their .exe files to create a bootable floppy with the flash update on it.  Boot from the floppy and there you go.
  
==Updating via "IBM Predesktop area", suitable for model X (not have CDROM and floppy)==
+
So, why is it not recommended?
It's so difficult to update BIOS and ECP without cdrom, floppy disk.
+
# If something goes wrong, your ThinkPad may be permanently damaged
Don't know the reason why I couldn't update BIOS and ECP(1QHJ08US and 1QUJ19US) for my IBM Thinkpad X31.Hmm, may be cause of the dividing partition on my hard disk, that is:
+
# Floppy disk drives are not reliable
<blockquote style="background: white; border: 1px solid black; padding: 1em;">
+
# Floppy disks are not reliable
<pre><nowiki>
+
# It only works with /dev/fd0, meaning it won't work with a USB floppy
Primary: ext3, ext3, ntfs
 
Extended: Ntsf, fat32
 
Bootloader: GRUB
 
</nowiki></pre></blockquote>
 
  
No problem, you can use this way to do it:
+
So, even though Lenovo is now offering "Linux diskette" updaters, that will create a bootable floppy under Linux, using a floppy is still not recommended.  Besides, many people don't even ''have'' a floppy drive on their ThinkPad.
* First, config in BIOS
 
In Security part:
 
# Remove all password of Subpervisor and Power on password
 
# Set Access IBM Predesktop Area to Normal
 
# Choose Enable "Flash BIOS updating by End User" in BIOS update Option.
 
  
In Config part:
+
If you really want to do it with a floppy, some tips:
# Choose Enable for Network flash over Lan
+
* Use a clean (in the physical sense) floppy drive
 +
* Use new floppies
 +
* Test floppies for errors before starting update process
 +
* Have multiple copies of the update disks ready--if one should fail, replace it with a copy
 +
* Should DOS complain of a read error, '''only''' respond wth "Retry"
  
* Second, download the newest version of BIOS update and ECP update
+
{{NOTE|Should the system encounter a disk read error during the flash process, and you select "Abort", your system could be permanently damaged.}}
Running: The program extract all files to the folder. There is a .img file (1QUJ19US.IMG, 1QUJ08US.IMG) in each folder.
 
Copy the imformation content in that img file and paste it to one FAT partition(using winimage or TotalCmd to extract)
 
  
 +
==== Using UNetbootin ====
  
as seen All files in 1QUJ19US.IMG is extracted to D:\BIOS
+
Unetbootin 422 worked with the image files unpacked with cabextract on my x31.
<blockquote style="background: white; border: 1px solid black; padding: 1em;">
 
<pre><nowiki>
 
695,764  $018E000.FL1
 
163      0691.HSH
 
2,049    0691.PAT
 
163      0694.HSH
 
2,049    0694.PAT
 
163      0695.HSH
 
2,049    0695.PAT
 
2,049    06D0.PAT
 
163      06D1.HSH
 
2,049    06D1.PAT
 
163      06D2.HSH
 
2,049    06D2.PAT
 
163      06D6.HSH
 
2,049    06D6.PAT
 
2,049    06D8.PAT
 
697      CHKBMP.EXE
 
8,128    COMMAND.COM
 
26      CONFIG.SYS
 
24,860  FLASH2.EXE
 
26      LCREFLSH.BAT
 
170      LOGO.BAT
 
330      LOGO.SCR
 
111,925  PHLASH16.EXE
 
91,648  PREPARE.EXE
 
45      PROD.DAT
 
22,252  QKFLASH.EXE
 
9,923    README.TXT
 
4,260    TPCHKS.EXE
 
39,666  UPDTFLSH.EXE
 
6,958    UPDTMN.EXE
 
12,501  USERINT.EXE
 
15,254  UTILINFO.EXE
 
</nowiki></pre></blockquote>
 
  
And all files in 1QUJ08US.IMG are: D:\ECP
+
{{HELP|How exactly did you do this? It failed for me. Does it work only with .IMG files that are converted to .ISO files, or can .ISO files provided by Lenovo also work (how?)}}
<blockquote style="background: white; border: 1px solid black; padding: 1em;">
 
<pre><nowiki>
 
315,404 $018E000.FL2
 
8,000  COMMAND.COM
 
36      CONFIG.SYS
 
16,910  ECFLASH2.EXE
 
45      PROD.DAT
 
17,812  QKFLASH.EXE
 
990    README.TXT
 
4,260  TPCHKS.EXE
 
89,738  UPDTEC.EXE
 
31,134  UPDTFLSH.EXE
 
12,501  USERINT.EXE
 
15,226  UTILINFO.EXE
 
</nowiki></pre></blockquote>
 
  
* Okie, now plug AC Adapter, charge full battery to your laptop and continue third step:
+
=== Booting from a Network Boot Image ===
 +
BIOS, ECP, CD/DVD and Harddisk firmware disks can be booted over the network with [http://syslinux.zytor.com/pxe.php PXELINX] as part of the [http://syslinux.zytor.com/ SYSLINUX] package.  This requires that you have a DHCP and tftp server configured and setup properly on your network, and is probably not for the faint of heart.
  
** '''Flash BIOS first,'''
+
Make sure the firmware bootdisk is in linux 'dd' format, as the self-extracting .exe disks from the IBM website cannot be booted directly as such.
1. Power On, press blue button on keyboard: '''Access IBM'''
 
  
2. On "Utilities", double click " Diagnostic disk"
+
This worked on the {{R31}}, {{X22}}, {{T21}}, {{T30}} and {{T41p}} with various firmware updates. On the {{X22}}, it worked with ECP 1.30 but '''not''' with BIOS 1.32
  
3. Your laptop will start PC-DOS, wait when this message appear:
+
=After updating=
<blockquote style="background: white; border: 1px solid black; padding: 1em;">
+
Lenovo recommends reseting your BIOS settings to their factory defaults after a firmware update.
<pre><nowiki>
 
Please insert the first floppy diskette and
 
Press any key to continue
 
</nowiki></pre></blockquote>
 
  
4. Press Ctrl + Break, you will see :
+
Also, please consider updating the [[List of DMI IDs]] after updating your BIOS.
<blockquote style="background: white; border: 1px solid black; padding: 1em;"><pre><nowiki>Terminate batch job (Y/N) ?</nowiki></pre></blockquote>
 
  
5. Okie, press Y, you will get DOS prompt like D:\
+
= Special Cases =
{{NOTE|D:\ is my RAMDISK, C:\ is my disk format as FAT.!}}
+
* In one case, see ([[APM setup on a type 2379 ThinkPad T40]]), it was not possible to upgrade the BIOS from Windows XP; a downgrade to Windows 98 was required to successfully run the BIOS upgrade app. The symptoms in this case were that, once the files had been extracted to the hard disk, and the machine was to reboot into the upgrade app, it would beep and hang just before reboot, requiring a power cycle. Once the power was cycled, it would simply reboot back into XP without performing any BIOS upgrade actions. So even if you have Windows, you may still need to use the info on this page.
  
6. Enter to c:\BIOS
+
== Updating Thinkpad X Series ==
<blockquote style="background: white; border: 1px solid black; padding: 1em;">
+
The special update instructions for {{X_Series}} Thinkpads are quite long. You can find them at the page [[BIOS_Upgrade/X_Series]].
<pre><nowiki>
 
c:
 
cd c:\BIOS
 
</nowiki></pre></blockquote>
 
  
7. Run FLASH2.EXE /u $018E000.FL1
+
== Updating without battery or with dead battery ==
  
8. Wait flash progress compelete and reboot.
+
This is a last-resort approach. Use this only if everything else fails.
** '''Flash ECP'''
 
Follow above instruction from step 1 to 5
 
  
6. Enter to c:\ECP
+
The BIOS updater may refuse to update a BIOS without a battery, or if the battery charge is too low. In that case, extract the disk image with cabextract as per instructions above and dd it to an usb stick. (This will destroy the data on it, of course.) Acquire a pure DOS boot cd such as Windows 98 recovery CD and boot that.
<blockquote style="background: white; border: 1px solid black; padding: 1em;">
 
<pre><nowiki>
 
c:
 
cd c:\ECP
 
</nowiki></pre></blockquote>
 
  
7. run UPDTFLSH.EXE $018E000.FL2
+
Use F8 to abort the boot sequence of a windows 98 boot CD. If you need CD-ROM support, load CD-related things but say no to everything else. In particular, avoid loading himem.sys and doskey, as the presence of either program causes Phoenix bios flash tool phlash16.exe to abort.
  
8. Follow UPDTFLSH's instructions
+
Change to the volume where flash2.exe and other tools are installed, and execute "flash2.exe /u". This should bypass the battery check and perform the flashing. If that doesn't work, check if the update disk contains a tool called "phlash16.exe". This can be used directly to flash the image, and the invocation is typically "phlash16 /exit $01c80000.fl1".
  
9. Wait flash complete and auto turn off computer.
+
Updating the ECP with a dead battery or no battery presents a similar problem. For example, on the IBM ThinkPad X31, the normal command-line command to update the ECP would be UPDTFLSH ("UPDTFLSH $018E000.FL2").  But this utility checks for an installed and charged battery and will not let you update the ECP firmware if the battery is missing or not charged.  Instead, issue "QKFLASH $018E000.FL2".  This will bypass the test for the battery and allow the ECP firmware to be updated.  The same disclaimer applies here as for the BIOS: do this only as a last resort.  If there is a power failure during the update, you will likely brick your laptop.
  
I done it on my IBM Thinkpad X31.
+
This method won't work for the Thinkpad {{560X}} (and likely other older models). Since the 560X is a bit older, it won't be a big surprise if the battery is as dead as a dodo. Here's how to update the bios in this case: download the spsdi833 bios update and create the update floppy. If you have trouble creating this disk, [http://www.mediafire.com/?36o5a8buvbjx07o download an archive with the files] and put them on a floppy. Don't worry about making it bootable. Also, you will need a DOS bootdisk. A Windows 98 bootdisk will be fine. Boot the system with the W98 bootdisk, do not load CD-rom support. Remove the W98 bootdisk and put the disk with the BIOS update in the drive. If you would now run UPDTFLSH you would get the battery message, so don't do that. If you open UPDTFLSH.exe with a text editor, you would find some lines about UPDTROM. UPDTROM is the actual flash tool, but you can't simply run it just like that. Run the following:
  
Enjoy,
+
*updtrom /np /prep1
 +
*updtrom /np /prep2
 +
*updtrom /np /prep3
 +
*updtrom /np /romcmp /romflsh /prep4
 +
*updtrom /np /h8flsh /h8img /model
  
Tested by nm.
+
Yes, you need to run updtrom five times. Hold your breath and reboot the machine. It's done.
  
==Check List==
+
Perhaps not all these lines are necessary, but to be sure I ran them all, and this worked for me. So I suggest you do the same. This could probably be done from the harddisk as well, but I did not test that.
  
The following is important to remember:
+
For the {{i1400}} follow instructions on [http://www.motherboardpoint.com/flash-ibm-thinkpad-bios-w-o-battery-t143180.html this] website. It works not only for 2611 but for 2621 types too.
# You must update '''both''' the Control Program and the BIOS at the same time if your current Control Program is not compatible with the new BIOS (see below)
+
 
# You must find versions of the Control Program and BIOS that are compatible.  Not all of them are, so follow the readmes on the IBM website carefully to determine which are.
+
----
# You must update the Control Program '''before''' you update the BIOS
 
  
When the Control Program '''and''' the BIOS need updating, have both update disks or CDs ready. Update the Control Program first and the system should switch itself off when finished. Insert the BIOS update disk and proceed to update the BIOS. When it's all finished, enter setup, reset the settings to their defaults and reboot. Enter setup again and tweak the settings as necessary.
+
{{footnotes|
 +
# For lots of detail on making and burning .iso files, see The Linux Documentation Project (tldp.org): [http://tldp.org/HOWTO/CD-Writing-HOWTO-3.html#ss3.1 3.1 Writing CD-ROMs (pure data)].
 +
}}

Latest revision as of 23:12, 26 February 2022

This page is meant to describe ways to update the BIOS on a ThinkPad that only runs Linux for users that don't have ready access to Windows. If you have Windows on your ThinkPad you can just boot into it and follow instructions on the Lenovo website.

Updating the BIOS in Linux (with few exceptions) is not officially supported by Lenovo. However there are work arounds.


ATTENTION!
By following any of the instructions here you are accepting the very real risk of turning your ThinkPad into a big expensive paper weight, as a firmware update gone wrong can create unfix-able problems. Proceed at your own risk!

Custom BIOS

Some ThinkPad fans have created Custom BIOSes to remove whitelists, disable annoying errors, do Fn-Ctrl keyswaps, and add more functionality. Check the Custom BIOS wikipage for more information.

  • X200, X60, T60, Macbook 2,1 - Libreboot - Based on Coreboot, this BIOS (approved by the FSF) removes all proprietary blobs to create Free Libre Open Source Laptops, where everything from the motherboard to the computer can use Open Source Software. Richard Stallman famously uses a Libreboot X60.
  • Sovem's Whitelist Removed BIOSes - A famous user from BIOS-mods.com, that removes mPCI whitelists from BIOSes upon request.
  • T61, R61, X61/X61s/X61T, X300 - Middleton's BIOS - Enables SATAII, removes whitelist, thermal fixes, Fn-Ctrl swap.
  • T43/T43p, R52, X41/X41T - TTav134's BIOS - Removes Error 2010 for aftermarket hard drives, and the BIOS whitelist.

Middleton's BIOS

A user on NotebookReview named 'Middleton' made these alternative BIOSes to enable SATA2 on certain Thinkpad models (X61/T61/R61/X300). These ThinkPads are limited to SATA1 in their BIOS even though the hardware is SATA2. This is a huge drawback for anyone wanting to use SSDs, because it is so much slower.

Also, it is not possible to install some wireless cards, because only certain models are whitelisted by IBM/Lenovo. Middleton's BIOS removes this limitation as well.

See the wikipage Middleton's BIOS for installation instructions, downloads, and more description.

Note: If your BIOS-Update tool says that no update is needed, then simply downgrade the Bios first: On Lenovo's drivers download page, the old Bios files are listed at the very bottom of the page.

Downloading New Firmware

ATTENTION!
Flashing the wrong firmware for your hardware may cause permanent damage to your ThinkPad. It is up to you to confirm that the firmware you are using is correct.

A list of links to firmware downloads can be found at BIOS Upgrade Downloads for most Thinkpad models. You can also check the Lenovo Support website's driver matrix.

Lenovo/IBM provides firmware upgrades in a variety of packages:

  • Diskette
  • Non-diskette
  • Linux diskette
  • BIOS Utility
  • Bootable CD

Not every type of package is available for every model.

The BIOS Utility and Bootable CD packages combine the BIOS and ECP firmwares. For the other packages, there is one for each firmware.

Help needed
Can an image be extracted from a "Linux diskette" .exe file?

The Linux diskette is just the Diskette package that runs on Linux instead of Windows/DOS. It's unknown if a boot image can be extracted from it.

You may need to try different packages to find the one from which you can extract a boot image.

Two Firmwares: BIOS and ECP

ATTENTION!
Flashing incompatible firmwares, or flashing them in the wrong order, may cause permanent damage to your ThinkPad.

It is important to understand that Thinkpads from IBM have two separate firmwares: the BIOS, and the Embedded Controller Program (ECP).

A given BIOS version will require a certain version of the ECP. You must read the Lenovo website and/or .txt files to confirm which BIOS is compatible with which ECP, and the order in which to update them.

Update Order

The Lenovo/IBM documentation is sometimes unclear about the order in which these two firmwares should be updated. When in doubt (i.e. IBM didn't provide specific instructions for your model or a particular firmware update), update the ECP first, and then the BIOS. Also, make sure to do the two updates immediately one after the other.

The EC firmware is usually much better at backwards compatibility than the BIOS.

NOTE!
Updaters for newer models take care of both BIOS and EC, and use automatically whatever sequence is needed, so you don't have to worry about it.

Installed Firmware

You can check the current BIOS and ECP versions on your ThinkPad as detailed here: BIOS Version

DMI IDs

Please consider updating the List of DMI IDs before (and after) updating your BIOS.

Updating Firmware

Firmware flasher program can run on DOS (Lenovo PC DOS) or Windows but, unfortunately, not Linux. So in theory there are two basic steps to update the firmware (either the BIOS or the ECP) on a ThinkPad not running Windows:

  1. Get or create a bootable image with supported OS
  2. Boot that image and, if not started automatically, ran flasher program

Recent Thinkpads have firmwares available as Bootable CD image, e.g., FILENAME.iso. If you have an optical drive there is no need to read this page any further: just download .iso image, burn it and boot to flash bios. If you are not that lucky, read on.

First you need to realize that there are different ways to boot DOS on PC (theoretically it is possible to boot Windows to ran flasher, but why?...): from internal hard drive, CD drive, USB Flash drive or, as the last resort, floppy drive. Easiest way is from internal hard drive, but you'd better avoid touching it until you don't want to loose files there. Booting from a Floppy is not recommended, so there are two best options to boot: CD drive or USB Flash drive.

Sparse instructions below provide you guidance how to do different parts of this pazzle but it's your duty to understand what to do and how to do that.

Using UEFI

Especially usable when CDROM is not available, tested on X140e, but should work in most recent firmwares as these supports UEFI, much simpler than older methods outlined in this and other pages.

You should have a USB mass storage device you can erase.

ATTENTION!
this will erase the USB mass storage device content.

1. Download BIOS update ISO image, we assume it is xxx.iso.

2. Extract bootable image using geteltorito tool:

$ ./geteltorito.pl -o xxx.img xxx.iso

3. Insert USB device, checkout its device, we assume /dev/sdX.

4. Dump content of image to USB device.

ATTENTION!
Double check the device name so you do not overwrite any other filesystem.

# dd if=xxx.img of=/dev/sdX

5. Reboot, enter BIOS setup, enable UEFI only (or 1st priority) at startup options, save and reboot.

6. Interrupt boot, press F12 and select USB mass storage device as boot source.

7. The BIOS update utility should run and you should succeed in flashing BIOS.

Create a bootable image

In case Lenovo does not provide your laptop with Bootable CD it is possible to create one from *discket packages.

Extracting an update image

ATTENTION!
Though this process has been successfully tested on many versions of .exe files found on IBMs website, that doesn't mean it will work for all of them. Proceed at your own risk. Consult the testing tables farther down of this page to see other users' experience with your model Thinkpad.
NOTE!
Lenovo has changed the packaging format. Old bios can be extracted with cabextract, new ones with innoextract.

Older .exe installers from Lenovo mostly appear to be just a wrapper license program around Windows .cab files (see BIOS-Bootsplash). If you install the Linux program cabextract you can expand these .cab files directly. For example, if you downloaded 1iuj13us.exe from Lenovo:

$ cabextract 1iuj13us.exe
Extracting cabinet: 1iuj13us.exe
 extracting 1IUJ13US.IMG
 extracting BIOSUPTP.EXE
 extracting DOBOOT.EXE
 extracting DOSBOOT.COM
 extracting DOSBOOT.SYS
 extracting DOSBOOT.VXD
 extracting DOSBOOT2.COM
 extracting ECTLUPTP.EXE
 extracting EFLASHAS.SYS
 extracting HDFWUPTP.EXE
 extracting IBMTPI.XML
All done, no errors.

The file we want is FILENAME.IMG, with "FILENAME" being the .exe. you downloaded. E.g., 1IUJ13US.IMG.

If this does not work for the Non-diskette .exe, try it on the Diskette .exe. It's reported, for example, that the Non-diskette .exe for BIOS version 3.23 for the T41p was not extractable, but the Diskette .exe worked perfectly, with $ cabextract delivering a .IMG file.

If cabeextract/innoextract fails

Diskette .exe for some older models can't be extracted using cabextract. For example for the latest BIOS of 390E one gets

spsdilc9.exe: no valid cabinets found

There is a simple way to solve this, by stripping the header off from the Non-diskette version. To do this, first you need to find the index for the first occurance of MSCF in the downloaded executable. This can be done with the following

strings -a -t d NO-DISKETT.EXE | awk 'offset=index($2,"MSCF"), (offset != 0) {print $1+offset-1}' | head --lines 1
4196

The command adds the byte offset of the matching line plus the index for the start of the MSCF on that line, thus the byte offset of MSCF, this number is usually 4196 Now we need to cut these header bytes off, this is done by a standard dd cut, the following cuts away the first 4196 bytes.

dd if=NO-DISKETTE.EXE of=out.cab iflag=skip_bytes skip=4196

The newly created out.cab should now work with cabextract

cabextract out.cab

A second alternative is to use Windows XP (works in VirtualBox too) together with Virtual Floppy Drive. Rund vfdwin.exe, go to the Driver tab and hit Install and Start. Then go to the Drive0 tab, click on Change and select A:. Finally, click on Open/Create, and click Create. This should give you a virtual floppy drive the .exe file will extract files to.

A third solution is to use QEMU with a DOS diskette image to run the disk extractor.

Testing the Image

You can test that FILENAME.IMG is really a floppy image by running:

# mkdir /tmp/mntfloppy

# mount -o loop FILENAME.IMG /tmp/mntfloppy

If a ls command on the image returns what looks like a DOS floppy, and no read errors were displayed, you have a pretty good chance that the image is usable. For example:

# ls /tmp/mntfloppy

$0195000.FL1  069580.PAT  06d2.HSH     IBMDOS.COM    TPCHKS.EXE
0691.HSH      06D0.PAT    06d6.HSH     LOGO.BAT      UPDTFLSH.EXE
0691.PAT      06D1.PAT    06d8.HSH     LOGO.SCR      UPDTMN.EXE
0694.HSH      06D2.PAT    CHKBMP.EXE   PHLASH16.EXE  USERINT.EXE
0694.PAT      06D6.PAT    COMMAND.COM  PREPARE.EXE   UTILINFO.EXE
0695.HSH      06D8.PAT    CONFIG.SYS   PROD.dat      lcreflsh.bat
0695.PAT      06d0.HSH    FLASH2.EXE   QKFLASH.EXE
069580.HSH    06d1.HSH    IBMBIO.COM   README.TXT

Unmount the image after you are done testing:

# umount /tmp/mntfloppy

Booting from update image

Now that you have a bootable image for the correct update for you hardware, you need to do is boot from that image to install the update.

There are different ways to do that:

Booting from a CD

Hint:
If there is a Bootable CD image available, e.g., FILENAME.iso, just download that, instead of mucking around with image files.

If you are going to update the firmware by booting from a CD, you need to turn FILENAME.IMG that you extracted above into an .iso file.

The El Torito Bootable CD Specification is a wonderful thing. Thanks to it, a bootable CD can be made with a bootable floppy image in such as way that the CD believes that it is a 2.88 MB floppy drive. This allows you to replace a boot floppy by a boot CD in nearly all situations.

It is very easy to create such a bootable CD ISO image in Linux using the mkisofs tool1. Run a command as follows:

# genisoimage -b 1WUJ25US.IMG -c boot.catalog -o bootcd.iso 1WUJ25US.IMG #or older mkisofs

Where *.IMG is the name of the image file extracted above. This creates a CD with one file on it and marks that file as the boot image.

You can now burn the bootcd.iso to a CD in your favorite CD-burning program.

ATTENTION!
By following any of the instructions here you are accepting the very real risk of turning your ThinkPad into a big expensive paper weight, as a firmware update gone wrong can create unfix-able problems. Proceed at your own risk!

Boot from the CD to update your firmware. Remember to have both BIOS and ECP firmware boot-CDs ready, as needed, and use them in the proper order.

Help needed
Please, report your success/failure with flashing BIOS from the manually cooked CD (from .IMG file) here: BIOS_Upgrade_success_failure#Booting_from_CD

Booting using GRUB (Traditional)

ATTENTION!
Many have warned not to use the SYSLINUX image-loader memdisk to boot firmware update images.
Help needed
Who are these "many"? Link to a discussion?

Warning: These instructions are for 'Traditional' GRUB, not GRUB2. Traditional GRUB uses a configuration file at /boot/grub/menu.lst. GRUB2 uses /boot/grub/grub.cfg. See the next section for the GRUB2 instructions.

Once the bootable image, FILENAME.IMG, is extracted from the .exe, it can be booted directly through GRUB without the need of burning a CD, using the SYSLINUX image-loader memdisk.

Locate the memdisk file from the syslinux package. You can search for it with find:

# find /usr -name memdisk #or just use "dlocate memdisk" or "locate memdisk" if these programs are installed

If /usr/.../memdisk is not present, syslinux is not installed. You will need to install it to boot a .IMG from GRUB.

Copy both the FILENAME.IMG and memdisk files into /boot directory. For example:

# cp ./FILENAME.IMG /usr/share/syslinux/memdisk /boot/

Open /boot/grub/menu.lst in your favourite editor. Copy the active section into a new section, and edit the new section:

Parameter Instructions Example
title Pick a name for the new section. This will show up in the GRUB boot menu. title IBM ECP Update
root Do not change. This is the partition containing the /boot directory root (hd0,0)
kernel /boot/memdisk will allow you to boot an image file. kernel /boot/memdisk
initrd This is the name of the firmware-updater image file, e.g., 1IUJ13US.IMG initrd /boot/1IUJ13US.IMG

Do not modify the original section in /boot/grub/menu.lst, or you might not be able to boot back to the operating system.

If you have two firmware updates to do, you will need a section for each firmware's FILENAME.IMG in /boot/grub/menu.lst.

NOTE!
If both BIOS and ECP are to be updated, be sure to update them in the proper order.
ATTENTION!
By following any of the instructions here you are accepting the very real risk of turning your ThinkPad into a big expensive paper weight, as a firmware update gone wrong can create unfix-able problems. Proceed at your own risk!

Reboot your computer, entering the GRUB menu and selecting IBM BIOS Update, or whatever you named the new section in /boot/grub/menu.lst.

Booting image with GRUB2

GRUB2: booting floppy Image

With grub2, one would append the following to /boot/grub/grub.cfg :

menuentry "My BIOS Upgrade" {
set root=(hd0,0) #should match the others in your grub.cfg
linux16 /boot/memdisk
initrd16 /boot/1WUJ25US.IMG #or whatever yours is
}
Help needed
Please, report your success/failure with flashing BIOS from the manually cooked CD (from .IMG file) here: BIOS_Upgrade_success_failure#GRUB2:_Booting_floppy_Image
GRUB2: booting CD Image

You must first download the bootable iso file from the Lenovo Website.

On Debian and Ubuntu

Then, on Debian and Ubuntu, you can install the grub-imageboot package, then you just have to copy the iso file in /boot/images and run update-grub:

sudo apt-get install grub-imageboot
sudo mkdir -p /boot/images
sudo cp /home/youruser/Downloads/6uuj12uc.iso /boot/images
sudo update-grub
Manual method

Otherwise, copy the file 'memdisk' from the syslinux package to /boot. Also create a symlink, so you do not have to change the grub configuration for each bios upgrade:

sudo su -
cd /boot
cp /home/youruser/Downloads/6uuj12uc.iso .
cp /usr/share/syslinux/memdisk .
ln -s 6uuj12uc.iso biosupgrade.iso

Now create the boot entry:

cat >> /etc/grub.d/40_custom <<EOF
menuentry "Lenovo BIOS Upgrade" {
    set root=(hd0,1)  # <-- check for correct numbering
    linux16 /boot/memdisk iso
    initrd16 /boot/biosupgrade.iso
}
EOF
update-grub

Reboot an Select "Lenovo BIOS Upgrade".

For the next Bios Upgrade you'll just need to copy the new iso file to /boot and adjust the symlink.

Help needed
Please, report your success/failure with flashing BIOS from the manually cooked CD (from .IMG file) here: BIOS_Upgrade_success_failure#GRUB2:_Booting_CD_Image

Booting from a USB Flash drive

Updating the BIOS in MS-DOS mode

(This process works for most Thinkpad models that has Windows XP, Windows Vista or Windows 7 OS)

1. Using HP USB Boot Utility, create a bootable USB flash drive [http://www.bay-wolf.com/utility/usbkey/win98boot.zip DOS using Windows 98 Boot Disk Floppy Image.

2. Extract the (*.ima) from the ISO BIOS image (e.g. WinRAR will do this).

3. Using a tool that can open .IMA files (such as WinImage), extract all files to a temporary folder.

4. Run the HP tool, select the USB device, I used FAT32, create a DOS bootable disk and point at the win98boot folder - then "Start". Warning: this formats the USB flash drive and all data will be erased!

5. Once complete (you could test if it boots at this point), copy the extracted BIOS files from the temporary folder you created to the USB flash drive.

6. Boot from USB flash drive by pressing F11 within the BIOS boot logo. At the DOS command prompt, type "updflsh" and then follow the prompts by pressing "Y" or Enter. Make sure that you have a fully charged battery pack and the AC Adapter is firmly plugged before proceeding with the BIOS update. DO NOT Power off the laptop or unplug the USB flash drive while the update is in progress or else update will fail and your computer will be unable to boot and system board may need to be serviced.

This process takes around 1-2 minutes. A long beep followed by a short beep will notify you that the update is complete and the system will automatically power off.

7. Power on the laptop then enter the BIOS setup by pressing F1 and Load BIOS defaults.

Using grub4dos (also for Linux)

grub4dos is a GNU GRUB fork with interesting features. One of them is the ability to boot ISO images directly off USB flash drives. Contrary to the name, GRUB for DOS works fine on Linux. Follow these steps:

  • Download the latest grub4dos package at http://download.gna.org/grub4dos/ (I needed 0.4.4 for my USB2 drive - 0.4.3 did not work.)
  • Unpack
  • Insert your FAT-32 formatted pendrive
  • Run sudo ./bootlace.com /dev/sdX, where /dev/sdX is the device name assigned to your pendrive (use sudo fdisk -l to figure this out). Be very careful to get the device correct or else you could overwrite your hard drive! This creates grub4dos boot sector in MBR of the flash drive.
  • Copy the files grldr and menu.lst to the root directory of your pendrive.
  • Convert the ThinkPad .IMG file to a .ISO file using genisoimage -b 1yuj18us.img -c boot.catalog -o 1yuj18us.iso 1yuj18us.img
  • Copy the ISO image to the root directory of your pendrive (e.g. 1yuj18us.iso).
  • Edit menu.lst on the pendrive and include the following section (of course putting the appropriate ISO image name):
title thinkpad-bios
map (hd0,0)/1yuj18us.iso (hd32)
map --hook
chainloader (hd32)
boot
  • Reboot and press F12 to select booting from USB.
  • If all went well, you should be able to boot the Thinkpad's ISO image and flash the BIOS. I tested it successfully on T400.

Manually creating a USB Flash drive in Linux

Use "geteltorito" to extract the update image from ISO image, downloaded from Lenovo's drivers page. Write the extracted image to a USB Flash drive using dd. "geteltorito" is available in Ubuntu (at least in Trusty, 14.04) from package "genisoimage".

  • Install the genisoimage package: sudo apt-get install genisoimage
  • Extract the boot image from the ISO: geteltorito g6uj14us.iso > biosupdate.img
  • Install the boot image to USB Flash drive, make sure to install to the correct device! (device for me was /dev/sdb): sudo dd if=biosupdate.img of=/dev/<yourusbflashdevice> bs=512K
  • Reboot and press F12 to select booting from USB.
  • If all went well, you should be able to boot the Thinkpad's ISO image and flash the BIOS. Tested successfully on: X1 Carbon, X230.

Booting from a Floppy

ATTENTION!
Using a floppy disk is NOT recommended.

This is how IBM/Lenovo intended it. Use their .exe files to create a bootable floppy with the flash update on it. Boot from the floppy and there you go.

So, why is it not recommended?

  1. If something goes wrong, your ThinkPad may be permanently damaged
  2. Floppy disk drives are not reliable
  3. Floppy disks are not reliable
  4. It only works with /dev/fd0, meaning it won't work with a USB floppy

So, even though Lenovo is now offering "Linux diskette" updaters, that will create a bootable floppy under Linux, using a floppy is still not recommended. Besides, many people don't even have a floppy drive on their ThinkPad.

If you really want to do it with a floppy, some tips:

  • Use a clean (in the physical sense) floppy drive
  • Use new floppies
  • Test floppies for errors before starting update process
  • Have multiple copies of the update disks ready--if one should fail, replace it with a copy
  • Should DOS complain of a read error, only respond wth "Retry"
NOTE!
Should the system encounter a disk read error during the flash process, and you select "Abort", your system could be permanently damaged.

Using UNetbootin

Unetbootin 422 worked with the image files unpacked with cabextract on my x31.

Help needed
How exactly did you do this? It failed for me. Does it work only with .IMG files that are converted to .ISO files, or can .ISO files provided by Lenovo also work (how?)

Booting from a Network Boot Image

BIOS, ECP, CD/DVD and Harddisk firmware disks can be booted over the network with PXELINX as part of the SYSLINUX package. This requires that you have a DHCP and tftp server configured and setup properly on your network, and is probably not for the faint of heart.

Make sure the firmware bootdisk is in linux 'dd' format, as the self-extracting .exe disks from the IBM website cannot be booted directly as such.

This worked on the R31, X22, T21, T30 and T41p with various firmware updates. On the X22, it worked with ECP 1.30 but not with BIOS 1.32

After updating

Lenovo recommends reseting your BIOS settings to their factory defaults after a firmware update.

Also, please consider updating the List of DMI IDs after updating your BIOS.

Special Cases

  • In one case, see (APM setup on a type 2379 ThinkPad T40), it was not possible to upgrade the BIOS from Windows XP; a downgrade to Windows 98 was required to successfully run the BIOS upgrade app. The symptoms in this case were that, once the files had been extracted to the hard disk, and the machine was to reboot into the upgrade app, it would beep and hang just before reboot, requiring a power cycle. Once the power was cycled, it would simply reboot back into XP without performing any BIOS upgrade actions. So even if you have Windows, you may still need to use the info on this page.

Updating Thinkpad X Series

The special update instructions for X1, X1 Carbon, X1 Carbon G2, X1 Carbon G3, X1 Carbon G4, X1 Carbon G5, X1 Carbon G6, X1 Carbon G7, X1 Carbon G8, X1 Extreme, X1 Extreme G2, X1 Hybrid, X13, X20, X21, X22, X23, X24, X30, X31, X32, X40, X41, X41 Tablet, X60, X60s, X60 Tablet, X61, X61s, X61Ls, X61 Tablet, X100e, X120e, X121e, X130e, X131e, X140e, X200, X200s, X200 Tablet, X201, X201i, X201s, X201si, X201 Tablet, X201i Tablet, X220, X220i, X220 Tablet, X220i Tablet, X230, X230i, X230s, X230 Tablet, X230i Tablet, X240, X240s, X250, X260, X270, X280, X300, X301, X390, X395 Thinkpads are quite long. You can find them at the page BIOS_Upgrade/X_Series.

Updating without battery or with dead battery

This is a last-resort approach. Use this only if everything else fails.

The BIOS updater may refuse to update a BIOS without a battery, or if the battery charge is too low. In that case, extract the disk image with cabextract as per instructions above and dd it to an usb stick. (This will destroy the data on it, of course.) Acquire a pure DOS boot cd such as Windows 98 recovery CD and boot that.

Use F8 to abort the boot sequence of a windows 98 boot CD. If you need CD-ROM support, load CD-related things but say no to everything else. In particular, avoid loading himem.sys and doskey, as the presence of either program causes Phoenix bios flash tool phlash16.exe to abort.

Change to the volume where flash2.exe and other tools are installed, and execute "flash2.exe /u". This should bypass the battery check and perform the flashing. If that doesn't work, check if the update disk contains a tool called "phlash16.exe". This can be used directly to flash the image, and the invocation is typically "phlash16 /exit $01c80000.fl1".

Updating the ECP with a dead battery or no battery presents a similar problem. For example, on the IBM ThinkPad X31, the normal command-line command to update the ECP would be UPDTFLSH ("UPDTFLSH $018E000.FL2"). But this utility checks for an installed and charged battery and will not let you update the ECP firmware if the battery is missing or not charged. Instead, issue "QKFLASH $018E000.FL2". This will bypass the test for the battery and allow the ECP firmware to be updated. The same disclaimer applies here as for the BIOS: do this only as a last resort. If there is a power failure during the update, you will likely brick your laptop.

This method won't work for the Thinkpad 560X (and likely other older models). Since the 560X is a bit older, it won't be a big surprise if the battery is as dead as a dodo. Here's how to update the bios in this case: download the spsdi833 bios update and create the update floppy. If you have trouble creating this disk, download an archive with the files and put them on a floppy. Don't worry about making it bootable. Also, you will need a DOS bootdisk. A Windows 98 bootdisk will be fine. Boot the system with the W98 bootdisk, do not load CD-rom support. Remove the W98 bootdisk and put the disk with the BIOS update in the drive. If you would now run UPDTFLSH you would get the battery message, so don't do that. If you open UPDTFLSH.exe with a text editor, you would find some lines about UPDTROM. UPDTROM is the actual flash tool, but you can't simply run it just like that. Run the following:

  • updtrom /np /prep1
  • updtrom /np /prep2
  • updtrom /np /prep3
  • updtrom /np /romcmp /romflsh /prep4
  • updtrom /np /h8flsh /h8img /model

Yes, you need to run updtrom five times. Hold your breath and reboot the machine. It's done.

Perhaps not all these lines are necessary, but to be sure I ran them all, and this worked for me. So I suggest you do the same. This could probably be done from the harddisk as well, but I did not test that.

For the i Series 1400 follow instructions on this website. It works not only for 2611 but for 2621 types too.



FOOTNOTES [Δ]
  1. For lots of detail on making and burning .iso files, see The Linux Documentation Project (tldp.org): 3.1 Writing CD-ROMs (pure data).