Difference between revisions of "BIOS Upgrade"

From ThinkWiki
Jump to: navigation, search
(X Series)
(T Series)
Line 544: Line 544:
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-63024 1.04]
 
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-63024 1.04]
 
|
 
|
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-63027 1.04]{{footnote|1}}
+
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-63027 1.04] (CD)
 
|
 
|
 
|
 
|
Line 602: Line 602:
 
|-
 
|-
 
| {{X60}}, {{X60s}}
 
| {{X60}}, {{X60s}}
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-63144 1.04]
 
 
|
 
|
| [http://www-307.ibm.com/pc/support/site.wss/document.do?lndocid=MIGR-63145 1.04] (CD)
+
|
 +
|
 
|
 
|
 
|
 
|

Revision as of 10:31, 15 April 2006

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.

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.

Before You Begin

Updating the BIOS in Linux (with few exceptions) is not officially supported by IBM. 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 unfixable problems.

Proceed at your own risk!

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. If you go through the readme's on the IBM site they'll clearly state that you must update the BIOS first, then immediately update the Control Program. Otherwise you risk turning your thinkpad into a very nice paper weight.

BIOS Upgrade Paths

For every firmware (either BIOS or Control Program) update on the IBM site there are two different firmware update programs provided.

The Diskette Updater

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 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.

The Non Diskette Updater

ATTENTION!
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 BIOS-Bootsplash). If you install the Linux program cabextract you can expand these files directly. Run the following:

$ cabextract FILENAME.exe

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:

# mkdir mntfloppy
# mount -o loop FILENAME.img mntfloppy
# ls -la mntfloppy

If the results of # 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.

Downloads

NOTE!
Firefox or Konqueror users should disable the Use IBM Download Director option when downloading files.


Models Non-Diskette Diskette
BIOS Embedded Controller Program BIOS Embedded Controller Program
Windows Linux

200 Series

240 1.18
240X 1.09

300 Series

365C, 365CD, 365CS, 365CSD, 365E, 365ED 2.0.14
365X, 365XD 1.10
380, 380D, 380E, 380ED, 385D, 385ED 1.14
380XD, 385XD 1.19
380Z 1.08
390 5.62
390E 1.55
390X 0.55

500 Series

560 1.20
560E 1.13
560X 1.15
560Z 1.07
570 1.16
570E 1.07 1.07

600 Series

600 1.22
600E (2645 selected models, 2646) 1.16
600E (2645: 55x, 56x, 57x, 58x, A5x, A6x, Bxx [except for BAU], JJ1, JJ2, RRA) 1.15
600X 1.11 1.11

700 Series

750, 750CS, 755C, 755CS 1.43
755CE, 755CSE, 755CD, 755CX, 755CV, 755CDV 1.44
760C, 760CD, 760L, 760LD 1.30
760E (XGA), 760ED (XGA), 760XD, 765D, 765L 2.13
760E (SVGA), 760ED (SVGA), 760EL, 760ELD, 760XL 2.13
770, 770E, 770ED 1.34
770X 1.10
770Z 1.05

A Series

A20m 1.13 1.13
A20p 1.11 1.11
A21e (2165) 1.07 1.07
A21e (2628) 1.13 1.13
A21m 1.09 1.09
A21p 1.11 1.11
A22e Celeron 1.07 1.07
A22e Pentium 1.05 1.05
A22m 1.09 1.09
A22m (2628-Sxx) 1.05 1.05
A22p 1.11 1.11
A30, A30p 1.18 1.08 1.18 1.08
A31, A31p (Bios 1G*) 1.12 1.05 1.12 1.05 1.05
A31, A31p (Bios 1N*) 1.09 1.05 1.09 1.02 1.05

G Series

G40 1.20 1.20
G41 1.11 1.11

R Series

R30 1.38 1.38
R31 3.11 3.11
R32 2.15 2.15
R40 (2681, 2682, 2683, 2896, 2898, 2899) 1.23 1.14 1.23 1.14
R40 (2722, 2723, 2724, 2897) 1.29 1.14 1.29 1.14
R40e 1.36 1.04 1.36 1.04
R50, R50p 3.20 3.04 3.20 3.04
R50e 2.06 1.04 2.06 1.04
R51 (1829, 1830, 1831, 1836) 3.20 3.04 3.20 3.04
R51 (2883, 2887, 2888, 2889, 2894, 2895) 1.25 1.04 1.25 1.04
R51e 1.47 1.00 2.06 1.00
R52 (1846, 1847, 1848, 1849, 1850, 1870) 1.22 1.04 1.22 1.04
R52 (1858, 1859, 1860, 1861, 1862, 1863) 1.22 1.03 1.22 1.03

T Series

T20 1.22 1.22
T21 1.16 1.16
T22 1.12 1.12
T23 1.18 1.06a 1.18 1.06a
T30 2.09 1.07 2.09 2.02 1.07
T40, T40p, T41, T41p, T42, T42p 3.20 3.04 3.20 3.04
T43 (1871, 1872, 1873, 1874, 1875, 1876) 1.23 1.03 1.23 1.03
T43 (2668, 2669, 2678, 2679, 2686, 2687), T43p 1.25 1.05 1.25 1.05
T60, T60p 1.04 1.04 (CD)

X Series

X20, X21 2.25 1.36 2.25 1.36
X22, X23, X24 1.32 1.30 1.32 1.30
X30 1.08 1.06 1.08 1.06
X31, X32 3.02 1.08 3.02 1.08
X40 2.06 1.61 2.03 1.60
X41 2.05 1.01 2.05 1.01
X41 Tablet 2.00 1.00 2.00 1.00
X60, X60s

Z Series

Z60m, Z60t 1.14 1.14 1.14 1.14

Other

TransNote 1.02 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.

Updating via CD/DVD Drive

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.

Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.

Be aware that IBM officially does not support this! The official statement to my support request was:

I'm afraid we only support the options listed on our web page and no you
can't burn a CD/DVD, however you can try to use an external USB FDD
(floppy) drive. The experts recommend a IBM USB FDD, however they have also
tested it with a Sony USB FDD drive.

In order to make sure the drive is recognised you can boot up the FDD with
a bootable dos diskette for w98

But it seems to be possible as Mathias Dalheimer describes this here.

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 other vendors to flash the BIOS from bootable CD-ROMs.

ATTENTION!
Do not use the SYSLINUX image-loader 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 here.

Creating a Floppy 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:

# dd bs=2x80x18b if=/dev/fd0 of=/tmp/floppy.img

You can also create a floppy image by using Ken Kato's 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).

You should verify this floppy.img as explained above.

Creating a Bootable CD from a Floppy Image

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.

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.

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:

# mkisofs -b bootfloppy.img -o bootcd.iso bootfloppy.img

Note: You don't strictly need the last 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 -b <boot image> is applied to the CD. For more info on this read $ man mkisofs.

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

To get an overview which models have been tested with this version, here is a list:

Does work:

Model Tested by
A20p (2629-6VU)
A21e (2628-JXU)
  • 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.
R31
R40
R50 (1836-3SU)
  • jlbartos <jlbartos at hotmail dot com>
R51 (1829)
  • Robert Uhl <rob dot uhl at gmx dot de>, Jellby <jellby at yahoo dot com>
R51 (1830-RM7)
  • Will Parker <stardotstar at sourcepoint dot com dot au> successfully flashed 3.20 using existing 3.04 ECP and retained custom boot splash.
R51 (2887)
  • Ingo van Lil <inguin at gmx dot de>
T20
  • Franz Hassels <fhassel at suse dot com>
T22
  • Daniel Maier <nusse teamidiot de>
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.
T40
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
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 >
T41p
  • Nils Newman, work great. (Version: Bios 3.14 / Embedded Controller 3.04)
T42
  • Dan (BIOS 3.20 / EC 3.04, cabextract/CD method) <tronic171 at evilphb.org>
T42p
  • Robert Schiele <rschiele@uni-mannheim.de>, Joern Heissler <joern@heissler.de>
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)
X20
  • Neil Caunt <retardis at gmail dot com>
X21
  • Patrick Leickner <ranma at web dot de>, (BIOS 2.21->2.25 / EC 1.31->1.36) via non-disk/cabextract/mkisofs/cdrecord
X22
  • David Emery <dave at skiddlydee dot com>, (EC 1.30, BIOS 1.32 using non-disk/cabextract/CD method)
X23
  • Nils Faerber <nils dot faerber at kernelconcepts dot de> (Embedded Controller 1.30, BIOS 1.32 with cabextract/CD method)
X30
  • Hella Breitkopf, www (Embedded Controller 1.04, BIOS 1.07 with cabextract/CD method)
X31
  • Grzegorz KuÅ›nierz <koniu at sheket dot org> (Embedded Controller 1.08, BIOS 3.01 with cabextract/CD method)
X40
  • Robbie Stone <robbie@serendipity.cx>

Does not work:

Model Tested by

Please note that testing this is at your own risk!!!

Updating via Grub and a Floppy Image

ATTENTION!
Many have warned not to use the SYSLINUX image-loader MEMDISK to boot the images! Some flash tools may crash in that situation! Proceed at your own risk!

Floppy images may be booted from Grub via a utility called MEMDISK, which may be compiled from the SYSLINUX source. Copy the compiled memdisk image and the floppy image to your boot directory and configure grub as follows:

title     Bios Flash
kernel    /boot/memdisk
initrd    /boot/FILENAME.img

Again, proceed at your own risk. This was tested on an R51 type 2888.

Updating with Network Boot Image

BIOS, Embedded Controller (EC), CD/DVD and Harddisk firmware disks can be booted over the network with PXELINUX 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.

Check List

The following is important to remember:

  1. 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)
  2. 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.
  3. 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.