<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://www.thinkwiki.org/w/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Ladoga</id>
	<title>ThinkWiki - User contributions [en]</title>
	<link rel="self" type="application/atom+xml" href="https://www.thinkwiki.org/w/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Ladoga"/>
	<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/wiki/Special:Contributions/Ladoga"/>
	<updated>2026-04-09T04:38:01Z</updated>
	<subtitle>User contributions</subtitle>
	<generator>MediaWiki 1.31.12</generator>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29376</id>
		<title>Talk:BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29376"/>
		<updated>2007-04-17T03:06:31Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* BIOS upgrade using USB flash drive */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Dead link == &lt;br /&gt;
&lt;br /&gt;
The link to the FreeDOS floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip), which is needed to upgrade the BIOS from a CD, is dead. Is the information still valid? And is there a different source for the floppy image? [[User:Jamesavery|Jamesavery]] 05:49, 18 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using WINE ==&lt;br /&gt;
&lt;br /&gt;
Does anyone think this would be possible? [[User:Mcalwell|Mcalwell]] 08:58, 28 January 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
: No this is not possible. [[User:Mcalwell|Mcalwell]] 16:01, 12 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade without battery ==&lt;br /&gt;
&lt;br /&gt;
Concerning the known problem with 600 series with batteries dead too soon, it is impossible to upgrade the bios without the battery because the original ibm update program doesn't allow this. I bought an old 600E without the battery. There was one workaround, but i think for the older releases of the bios, where you just extracted files and upgraded manualy, bypassing the ibm install program. The page that describes this (i lost the link) has a list of different files, that the ones found in current release so i never did figure out what to do? I would like to upgrade because i have really old bios, where ACPI doesn't cooperate so well with the operating system, either windows or linux.&lt;br /&gt;
&lt;br /&gt;
If somebody finds a workaround please help. Thanks&lt;br /&gt;
&lt;br /&gt;
//Edit&lt;br /&gt;
&lt;br /&gt;
I've found the page on Vim's bios upgrade forum.. I don't know if it exactly for my model, since the files differ.. '''Is it possible, to upgrade bios in linux without the battery?'''&lt;br /&gt;
&lt;br /&gt;
''I have found a working solution WOW on the other forum: &lt;br /&gt;
&lt;br /&gt;
*** This is NOT a safe way to update the bios (disclaimer) *** &lt;br /&gt;
&lt;br /&gt;
* First you need to make a BIOS update floppy disk (from the bios file from IBM - place disk in a: drive, run app and answer Y to the agreement) and then format another disk by right clicking on A: - format - make system bootdisk (assuming you have another machine spare) &lt;br /&gt;
&lt;br /&gt;
* Copy all the files from the IBM Boot disk - in my case &lt;br /&gt;
$0029000.fl1 &lt;br /&gt;
$0029000.fl2 &lt;br /&gt;
FLASH2.EXE &lt;br /&gt;
PROD.DAT &lt;br /&gt;
UPDTFLSH.EXE &lt;br /&gt;
updtrom.exe &lt;br /&gt;
USERINT.EXE &lt;br /&gt;
UTILINFO.EXE &lt;br /&gt;
to the other clean bootdisk. &lt;br /&gt;
&lt;br /&gt;
* Ensure that there is no config.sys and autoexec.bat so it just runs straight into DOS. &lt;br /&gt;
&lt;br /&gt;
* Place the disk into the Laptop, reboot and allow the machine to load via the floppy &lt;br /&gt;
&lt;br /&gt;
* At the command prompt, type &amp;quot;FLASH2.EXE /U&amp;quot; with no quotes then press enter. &lt;br /&gt;
&lt;br /&gt;
The program will automatically search for the files *.FL1 &amp;amp; *.FL2 and load the bios first then the platform file. &lt;br /&gt;
&lt;br /&gt;
The program will automatically update and perform erasing on the rom and then finish with &amp;quot;Update complete&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
* Now reboot. &lt;br /&gt;
&lt;br /&gt;
* Hold F1 down as you turn the laptop back on and go into Easy Setup under &amp;quot;Config&amp;quot; click on Initialize to ensure defaults and settings are error free. &lt;br /&gt;
&lt;br /&gt;
* Save and exit...''&lt;br /&gt;
&lt;br /&gt;
// EDIT&lt;br /&gt;
&lt;br /&gt;
This worked on my machine.. I make no guarantees it will work on others.&lt;br /&gt;
&lt;br /&gt;
The above procedure did not work on my T23 using the 1.20 bios; it kept returning error 14 (Low Battery). However, following those instructions and running &amp;quot;qkflash&amp;quot; rather than flash2 did work for the main bios, and later for the embedded controller.&lt;br /&gt;
&lt;br /&gt;
--grythumn&lt;br /&gt;
&lt;br /&gt;
== Bios upgrade &amp;amp; hidden partition ==&lt;br /&gt;
&lt;br /&gt;
I have disabled the hidden partition to make more space for linux (24G). I still have Windows on the 14G partition. Is it safe to upgrade the BIOS without the hidden partition? I want to get a newer BIOS to fix the annoying fan issue. Thanks&lt;br /&gt;
&lt;br /&gt;
- yes don't worry about it. bios upgrades have nothing to do with whats inside the harddrive.&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade over PXE ==&lt;br /&gt;
&lt;br /&gt;
Hi,&lt;br /&gt;
&lt;br /&gt;
I have a Thinkpad X20 with a very early BIOS and Embedded Controller Program which I'd like to update. Currently, the only feasible way of doing this is over the network using PXE. I already have a fully functional PXE server using SYSLINUX, and have so far been able to boot the BIOS diskette image using MEMDISK, although I have not attempted to flash anything yet due to the warnings given on the page. Is there any safe way I can update both the Controller Program and the BIOS in the same session over the network in this manner? If not, what other methods would be suitable? I have a USB CD-ROM drive and could probably get hold of a USB floppy drive.&lt;br /&gt;
&lt;br /&gt;
Thanks.&lt;br /&gt;
&lt;br /&gt;
Update: I ended up burning CDs as described and successfully updated everything. I'd still like to know if there is a way I could do it entirely over the network, though.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== RE: grub initrd ==&lt;br /&gt;
&lt;br /&gt;
&amp;quot;Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
0) Interesting suggestion. Might be better of in its own section.&lt;br /&gt;
&lt;br /&gt;
1) Could you please elaborate?&lt;br /&gt;
&lt;br /&gt;
2) My first guess (pending your elaboration) would be to &amp;quot;chainload&amp;quot; the first block of the diskimage using the grub commandline, like:&lt;br /&gt;
   blocklist (''path'')/''to''/''diskimage''&lt;br /&gt;
   chainloader ''blockvalue''+1&lt;br /&gt;
&lt;br /&gt;
But that's just a guess!&lt;br /&gt;
&lt;br /&gt;
[[user:Pebolle|Paul Bolle]] Fri Jul 15 12:20:47 CEST 2005&lt;br /&gt;
&lt;br /&gt;
== bios/controller update sequence ==&lt;br /&gt;
&lt;br /&gt;
The article says:&lt;br /&gt;
&amp;quot;If you go through the readme's on the IBM site they'll cleary state that you must update the Control Program first, then imediately update the BIOS&amp;quot;&lt;br /&gt;
&lt;br /&gt;
When I look at the IBM udpate instructions for the T23, it says:&lt;br /&gt;
&amp;quot;If you need to update the BIOS as well as the Embedded Controller Program, update the BIOS first.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comments?&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I would first contact IBM for clarification, but you should probably be following instructions specific to your model.&lt;br /&gt;
&lt;br /&gt;
&amp;gt;&amp;gt; I did it following IBM's instructions to upgrade the BIOS first. Everything worked out great!&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Intel minipci combo card ==&lt;br /&gt;
&lt;br /&gt;
I just purchased an [[Intel 10/100 Ethernet Mini-PCI Adapter with 56K Modem]] that has an ancient (2.0.6) firmware version.  I Downloaded the update file intlbtag.EXE but cabextract was unable to find any cabfiles inside it.  I tried running the program via wine and that didn't work either.&lt;br /&gt;
&lt;br /&gt;
Finally I ran the program on a windows machine and created a boot floppy.  Then I went through the the process of converting the floppy to a bootable cd via linux and that worked like a charm.  The cd successfully updated the minipc card's firmware.&lt;br /&gt;
&lt;br /&gt;
Everything worked but I ended up needing a windows box to do it.  Could this have been done without windows?&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Wireless LAN MiniPCI COMBO Card using prism2_srec ==&lt;br /&gt;
&lt;br /&gt;
The appropriate firmware installation program for the wlan card in my R32 can be extracted using cabextract as described in the article. It contains (besides some installation programs) a disk image (1awg06ww.IMG) that seems to be a simple dos boot disk. This image contains 3 .hex files (id010001.hex, pk010100.hex, sf010402.hex) that are recognized by prism2_srec to be &amp;quot;srec&amp;quot;-files. Trying to load them to RAM yields:&lt;br /&gt;
&lt;br /&gt;
    {{cmdroot|prism2_srec -v -r wlan0 sf010402.hex}}&lt;br /&gt;
    S3 CRC-16 generation record: start=0x007E1800 len=65642 prog=1&lt;br /&gt;
    Start address 0x00000000&lt;br /&gt;
    srec summary for sf010402.hex&lt;br /&gt;
    Component: 0x001f 1.4.2 (station firmware)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    role=Supplier variant=2 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    role=Actor    variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Wireless LAN card information:&lt;br /&gt;
    Components:&lt;br /&gt;
    NICID: 0x8013 v1.0.0&lt;br /&gt;
    PRIID: 0x0015 v1.0.7&lt;br /&gt;
    STAID: 0x001f v1.3.6&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    PRI role=Supplier variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    PRI role=Supplier variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    PRI role=Supplier variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    STA role=Supplier variant=1 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    PRI role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    This image is not meant to be downloaded to volatile memory.&lt;br /&gt;
    Incompatible update data.&lt;br /&gt;
&lt;br /&gt;
Has anyone tried to flash this device using prism2_srec yet?&lt;br /&gt;
What bothers me is, that the upgrade is for many different parts of the combo card. Does anyone have an opinion on whether this could work?&lt;br /&gt;
&lt;br /&gt;
OK, I took the risk and successfully upgraded my station firmware, BUT when I tried to upgrade the primary firmware the system froze!!! The thinkpad won't start up with the miniPCI card inserted and all efforts to reflash it using the original DOS boot image failed!!!&lt;br /&gt;
&lt;br /&gt;
I'm quite sure the system freeze was not caused directly by prism2_srec, because I have noticed rare system freezes since I have been using my PCMCIA wireless card.&lt;br /&gt;
Anyway, if anyone should own a TP R32, I'd be glad if he could tell me the base address of the Wlan card, or it's PCI address.&lt;br /&gt;
&lt;br /&gt;
Thinkpad r32 owner here. I want to upgrade the firmware as well. If you need any information just send an email to haftbar[a]gmail.com [[User:Quickie|Quickie]] 02:12, 1 February 2006 (CET)&lt;br /&gt;
&lt;br /&gt;
==Reorganization suggestion==&lt;br /&gt;
The Downloads section is rather long. Would it be an idea to put it on a separate, new page (say: BIOS_Downloads) and link to that new page from this page?&lt;br /&gt;
&lt;br /&gt;
[[User:Pebolle|Paul Bolle]] 21:27, 15 Oct 2005 (CEST)&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I agree with this suggestion.&lt;br /&gt;
&lt;br /&gt;
== Upgrading BIOS and Embedded Control Program from Win XP ==&lt;br /&gt;
&lt;br /&gt;
I'm trying to upgrade the BIOS and Embedded Controller Program from Windows XP following the instructions on the Lenovo website. The problem is the instructions are not very clear about this. The instructions basically state that I must upgrade them at the same time because the Control Program does not work with the older BIOS and the BIOS does not work with the older Control Program. They also state that I should upgrade the Control Program first. &lt;br /&gt;
&lt;br /&gt;
But that means I must boot into XP after having upgraded the Control Program but with the older BIOS in order to then update the BIOS. But if this works then they are actually compatible and there's a contradiction. Am I missing something? I just want to make sure I don't end up with a non-functioning unit.&lt;br /&gt;
&lt;br /&gt;
I have an X23 and want the latest BIOS (v 1.32) and Control Program (v 1.30). &lt;br /&gt;
&lt;br /&gt;
Maybe there should be a note about this in the article? Or maybe I'm the only one who is this stupid :)&lt;br /&gt;
&lt;br /&gt;
Update: I talked to Lenovo support. The situation apparently is that though the description says that the newer control program is not compatible with the older BIOS, they are not so incompatible as to cause the machine to stop working so it is actually possible to use incompatible versions of BIOS and control program. In fact according to the support person it makes no difference if the BIOS is upgraded before the control program or vice versa. So I upgraded the control program using the executable running in Windows XP, which rebooted the computer to perform the upgrade and then I booted Windows again to upgrade the BIOS in the same manner and it all worked fine. If anyone reading this finds it useful maybe you can put it in the article? Or if you find it superfluous just delete this section.&lt;br /&gt;
&lt;br /&gt;
--[[User:xphinx|xphinx]] 12 March 2007&lt;br /&gt;
&lt;br /&gt;
I have an X22 with BIOS version 1.21 and Embedded Controller version 1.17 and using the steps described by you, I succesfully updated my bios to the lastest versions from WindowsXP (BIOS v1.32 / EC v1.30)&lt;br /&gt;
Thanks!&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade for T21 with T20 BIOS ==&lt;br /&gt;
&lt;br /&gt;
Hi, I bought a used T21 recently (type 2647-8AU), and would like to update the BIOS to the latest version, but there's a problem: this T21 appears to have a T20 BIOS (IYET50WW, a/k/a T20 BIOS version 1.11).  When I try updating this BIOS using one of IBM's T21 updaters - I tried KZET34WW/v1.16 (the latest one) and KZET16WW/v1.01 (the earliest one) - I get the following message:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
''The diskette in the default drive will not run on this system. Your system is now locked. To restart your system, press Ctrl+Alt+Del.''&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
I suspect this message appears because the existing BIOS is a T20 BIOS.&lt;br /&gt;
&lt;br /&gt;
There would appear to be two options: either use the most recent T20 updater (IYET61WW, a/k/a T20 v1.22), or find a way to defeat the block in the KZET34WW/v1.16 T21 updater.  Obviously either option is risky in the absence of more information and/or detective work.  And I don't know enough about T2x-series hardware to hazard a guess (i.e., were early T21s just T20s with a speed bump, did some T21s get T20 BIOSes by mistake due to factory error, or are the T20 and T21 similar enough that it doesn't matter whether a T20 or T21 BIOS is used).&lt;br /&gt;
&lt;br /&gt;
Some relevant data gleaned from the stickers on the case bottom and the current BIOS:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
* '''Type:''' 2647-8AU (T21 with 800-MHz processor)&lt;br /&gt;
* '''S/N:''' 78-0GL1Z (zero-G-L-one-zed)&lt;br /&gt;
* '''Manufacture date:''' 03/2001&lt;br /&gt;
* '''BIOS version:''' IYET50WW (T20 BIOS v1.11)&lt;br /&gt;
* '''System unit S/N:''' (appears to be blank)&lt;br /&gt;
* '''System board S/N:''' J1HHS15CL5C&lt;br /&gt;
* '''System board P/N:''' 08K3747 (printed on motherboard)&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Thanks for any help anyone can provide.&lt;br /&gt;
&lt;br /&gt;
-Linux Spice&lt;br /&gt;
&lt;br /&gt;
P.S. At first I thought this might be a Frankenstein ThinkPad with a T21 case and a T20 logic board - I did buy it used, after all - but it does have an 800-MHz processor, which was never an option for the T20 (both the BIOS and Linux report it as such), and all the other equipment checks out (except for the hard drive, which was replaced with a 40-GB model).&lt;br /&gt;
&lt;br /&gt;
== BIOS format ==&lt;br /&gt;
&lt;br /&gt;
Not sure if this is the right place, but...&lt;br /&gt;
Does anybody know what the formats for the various files are in the bios package (or, even better, the bios.bak file that gets dumped on your disk before updating)? I'm getting progressivel lower and lower level in figuring out just what happens when the computer boots, and the BIOS is the last step... (BTW, I have an x60s)&lt;br /&gt;
&lt;br /&gt;
-- Unknown&lt;br /&gt;
&lt;br /&gt;
Yes.  It is a binary dump.  Sometimes, there is junk in the start of the file.  This should be data enough for you to figure out what you need.&lt;br /&gt;
&lt;br /&gt;
--[[User:Hmh|hmh]] 13:30, 26 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS update gone bad ==&lt;br /&gt;
&lt;br /&gt;
I tried to flash my [[:Category:600|ThinkPad 600]]'s bios with catastrophalic outcome; now the machine is unable to boot. I, being overly stupid and too self-confident, ignored all warnings about the media containing the bios image not being write-protected (I used one partition of the disk, in which I had installed FreeDOS). During the updating process, the machine started to write screens full of random characters in cyan coloured background. At that point I knew it was b0rked. I asked my friend about what to do now, he said I could open the machine up, locate the bios chip and use EPROM programmer/burner to write the bios image to the chip. He also said that because my machine is very old, there are probably not safeguards like dual bios or emergency bios update from floppy disk on boot. He continued by saying that the bios update file images from IBM/Lenovo website might not be actual , &amp;quot;pure&amp;quot; binaries which could be burned directly to the chip, instead they may contain some vendor-specific checksums which must be taken into account. In ThinkWiki there seems to be no page about bios flashing gone bad and restoring the machine to working condition. Or is there? I really need your help with this; I think I'm able to locate the bios, take it off and find a working EPROM burner, but where can I get a clean BIOS image without the vendor checksums? I'd be grateful for any references.&lt;br /&gt;
&lt;br /&gt;
--[[User:Usv|Usv]] 12:45, 31 March 2007 (CEST)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using USB flash drive ==&lt;br /&gt;
&lt;br /&gt;
I flashed my Thinkpad X41 succesfully with 2.09 BIOS using bootable USB flash drive with DOS 6.22 system files. (I guess Freedos would work aswell). I had such key laying around so I can't help you with making one (i used windows HP USB key format utility to make it long long time ago) &lt;br /&gt;
Everything is quite simple once you have USB key and are able to boot DOS from it.&lt;br /&gt;
&lt;br /&gt;
I downloaded the non-diskette ThinkPad BIOS update utility (74uj15us.exe) from lenovo support site and extracted the disk image from it using cabextract:&lt;br /&gt;
   {{cmduser|cabextract -F &amp;quot;*.IMG&amp;quot; 74uj15us.exe}}&lt;br /&gt;
&lt;br /&gt;
I mounted the image file (74UJ15US.IMG):&lt;br /&gt;
   {{cmdroot|mkdir /tmp/mnt}}&lt;br /&gt;
   {{cmdroot|mount -loop o 74UJ15US.IMG /tmp/mnt}}&lt;br /&gt;
&lt;br /&gt;
I mounted the usb key and made a directory for ibm flash utility files under it:&lt;br /&gt;
   {{cmdroot|mount /dev/sdb1 /mnt/usbflash}}&lt;br /&gt;
   {{cmdroot|mkdir /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
I copied the contents of /tmp/mnt to /mnt/usbflash/ibm:&lt;br /&gt;
   {{cmdroot|cp /tmp/mnt/*.* /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
Then I unmounted the USB stick and rebooted from it to DOS (F12 during boot -&amp;gt; USB HDD).&amp;lt;br&amp;gt; &lt;br /&gt;
In the DOS Prompt:&amp;lt;br&amp;gt;&lt;br /&gt;
   C:\cd ibm&lt;br /&gt;
   C:\IBM\flash2 /U&lt;br /&gt;
I waited for about 1 minute, then my thinkpad made two beeps to signal that the flashing was complete.&lt;br /&gt;
&lt;br /&gt;
PS. Because lacking reliable guide on how to make bootable DOS USB stick for ThinkPads I decided to leave this into discussion section. Please feel free to move/edit all the necessary stuff into the BIOS upgrade article if you know/figure out how to make bootable DOS USB stick in linux. I tried various tutorials including http://gentoo-wiki.com/HOWTO_Create_a_DOS_boot_USB_flash_drive, but didn't manage to boot into the Freedos prompt.&lt;br /&gt;
--[[User:ladoga|ladoga]] 04:56 17 Apr 2007&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29375</id>
		<title>Talk:BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29375"/>
		<updated>2007-04-17T02:49:43Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* BIOS upgrade using USB flash drive */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Dead link == &lt;br /&gt;
&lt;br /&gt;
The link to the FreeDOS floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip), which is needed to upgrade the BIOS from a CD, is dead. Is the information still valid? And is there a different source for the floppy image? [[User:Jamesavery|Jamesavery]] 05:49, 18 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using WINE ==&lt;br /&gt;
&lt;br /&gt;
Does anyone think this would be possible? [[User:Mcalwell|Mcalwell]] 08:58, 28 January 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
: No this is not possible. [[User:Mcalwell|Mcalwell]] 16:01, 12 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade without battery ==&lt;br /&gt;
&lt;br /&gt;
Concerning the known problem with 600 series with batteries dead too soon, it is impossible to upgrade the bios without the battery because the original ibm update program doesn't allow this. I bought an old 600E without the battery. There was one workaround, but i think for the older releases of the bios, where you just extracted files and upgraded manualy, bypassing the ibm install program. The page that describes this (i lost the link) has a list of different files, that the ones found in current release so i never did figure out what to do? I would like to upgrade because i have really old bios, where ACPI doesn't cooperate so well with the operating system, either windows or linux.&lt;br /&gt;
&lt;br /&gt;
If somebody finds a workaround please help. Thanks&lt;br /&gt;
&lt;br /&gt;
//Edit&lt;br /&gt;
&lt;br /&gt;
I've found the page on Vim's bios upgrade forum.. I don't know if it exactly for my model, since the files differ.. '''Is it possible, to upgrade bios in linux without the battery?'''&lt;br /&gt;
&lt;br /&gt;
''I have found a working solution WOW on the other forum: &lt;br /&gt;
&lt;br /&gt;
*** This is NOT a safe way to update the bios (disclaimer) *** &lt;br /&gt;
&lt;br /&gt;
* First you need to make a BIOS update floppy disk (from the bios file from IBM - place disk in a: drive, run app and answer Y to the agreement) and then format another disk by right clicking on A: - format - make system bootdisk (assuming you have another machine spare) &lt;br /&gt;
&lt;br /&gt;
* Copy all the files from the IBM Boot disk - in my case &lt;br /&gt;
$0029000.fl1 &lt;br /&gt;
$0029000.fl2 &lt;br /&gt;
FLASH2.EXE &lt;br /&gt;
PROD.DAT &lt;br /&gt;
UPDTFLSH.EXE &lt;br /&gt;
updtrom.exe &lt;br /&gt;
USERINT.EXE &lt;br /&gt;
UTILINFO.EXE &lt;br /&gt;
to the other clean bootdisk. &lt;br /&gt;
&lt;br /&gt;
* Ensure that there is no config.sys and autoexec.bat so it just runs straight into DOS. &lt;br /&gt;
&lt;br /&gt;
* Place the disk into the Laptop, reboot and allow the machine to load via the floppy &lt;br /&gt;
&lt;br /&gt;
* At the command prompt, type &amp;quot;FLASH2.EXE /U&amp;quot; with no quotes then press enter. &lt;br /&gt;
&lt;br /&gt;
The program will automatically search for the files *.FL1 &amp;amp; *.FL2 and load the bios first then the platform file. &lt;br /&gt;
&lt;br /&gt;
The program will automatically update and perform erasing on the rom and then finish with &amp;quot;Update complete&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
* Now reboot. &lt;br /&gt;
&lt;br /&gt;
* Hold F1 down as you turn the laptop back on and go into Easy Setup under &amp;quot;Config&amp;quot; click on Initialize to ensure defaults and settings are error free. &lt;br /&gt;
&lt;br /&gt;
* Save and exit...''&lt;br /&gt;
&lt;br /&gt;
// EDIT&lt;br /&gt;
&lt;br /&gt;
This worked on my machine.. I make no guarantees it will work on others.&lt;br /&gt;
&lt;br /&gt;
The above procedure did not work on my T23 using the 1.20 bios; it kept returning error 14 (Low Battery). However, following those instructions and running &amp;quot;qkflash&amp;quot; rather than flash2 did work for the main bios, and later for the embedded controller.&lt;br /&gt;
&lt;br /&gt;
--grythumn&lt;br /&gt;
&lt;br /&gt;
== Bios upgrade &amp;amp; hidden partition ==&lt;br /&gt;
&lt;br /&gt;
I have disabled the hidden partition to make more space for linux (24G). I still have Windows on the 14G partition. Is it safe to upgrade the BIOS without the hidden partition? I want to get a newer BIOS to fix the annoying fan issue. Thanks&lt;br /&gt;
&lt;br /&gt;
- yes don't worry about it. bios upgrades have nothing to do with whats inside the harddrive.&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade over PXE ==&lt;br /&gt;
&lt;br /&gt;
Hi,&lt;br /&gt;
&lt;br /&gt;
I have a Thinkpad X20 with a very early BIOS and Embedded Controller Program which I'd like to update. Currently, the only feasible way of doing this is over the network using PXE. I already have a fully functional PXE server using SYSLINUX, and have so far been able to boot the BIOS diskette image using MEMDISK, although I have not attempted to flash anything yet due to the warnings given on the page. Is there any safe way I can update both the Controller Program and the BIOS in the same session over the network in this manner? If not, what other methods would be suitable? I have a USB CD-ROM drive and could probably get hold of a USB floppy drive.&lt;br /&gt;
&lt;br /&gt;
Thanks.&lt;br /&gt;
&lt;br /&gt;
Update: I ended up burning CDs as described and successfully updated everything. I'd still like to know if there is a way I could do it entirely over the network, though.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== RE: grub initrd ==&lt;br /&gt;
&lt;br /&gt;
&amp;quot;Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
0) Interesting suggestion. Might be better of in its own section.&lt;br /&gt;
&lt;br /&gt;
1) Could you please elaborate?&lt;br /&gt;
&lt;br /&gt;
2) My first guess (pending your elaboration) would be to &amp;quot;chainload&amp;quot; the first block of the diskimage using the grub commandline, like:&lt;br /&gt;
   blocklist (''path'')/''to''/''diskimage''&lt;br /&gt;
   chainloader ''blockvalue''+1&lt;br /&gt;
&lt;br /&gt;
But that's just a guess!&lt;br /&gt;
&lt;br /&gt;
[[user:Pebolle|Paul Bolle]] Fri Jul 15 12:20:47 CEST 2005&lt;br /&gt;
&lt;br /&gt;
== bios/controller update sequence ==&lt;br /&gt;
&lt;br /&gt;
The article says:&lt;br /&gt;
&amp;quot;If you go through the readme's on the IBM site they'll cleary state that you must update the Control Program first, then imediately update the BIOS&amp;quot;&lt;br /&gt;
&lt;br /&gt;
When I look at the IBM udpate instructions for the T23, it says:&lt;br /&gt;
&amp;quot;If you need to update the BIOS as well as the Embedded Controller Program, update the BIOS first.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comments?&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I would first contact IBM for clarification, but you should probably be following instructions specific to your model.&lt;br /&gt;
&lt;br /&gt;
&amp;gt;&amp;gt; I did it following IBM's instructions to upgrade the BIOS first. Everything worked out great!&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Intel minipci combo card ==&lt;br /&gt;
&lt;br /&gt;
I just purchased an [[Intel 10/100 Ethernet Mini-PCI Adapter with 56K Modem]] that has an ancient (2.0.6) firmware version.  I Downloaded the update file intlbtag.EXE but cabextract was unable to find any cabfiles inside it.  I tried running the program via wine and that didn't work either.&lt;br /&gt;
&lt;br /&gt;
Finally I ran the program on a windows machine and created a boot floppy.  Then I went through the the process of converting the floppy to a bootable cd via linux and that worked like a charm.  The cd successfully updated the minipc card's firmware.&lt;br /&gt;
&lt;br /&gt;
Everything worked but I ended up needing a windows box to do it.  Could this have been done without windows?&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Wireless LAN MiniPCI COMBO Card using prism2_srec ==&lt;br /&gt;
&lt;br /&gt;
The appropriate firmware installation program for the wlan card in my R32 can be extracted using cabextract as described in the article. It contains (besides some installation programs) a disk image (1awg06ww.IMG) that seems to be a simple dos boot disk. This image contains 3 .hex files (id010001.hex, pk010100.hex, sf010402.hex) that are recognized by prism2_srec to be &amp;quot;srec&amp;quot;-files. Trying to load them to RAM yields:&lt;br /&gt;
&lt;br /&gt;
    {{cmdroot|prism2_srec -v -r wlan0 sf010402.hex}}&lt;br /&gt;
    S3 CRC-16 generation record: start=0x007E1800 len=65642 prog=1&lt;br /&gt;
    Start address 0x00000000&lt;br /&gt;
    srec summary for sf010402.hex&lt;br /&gt;
    Component: 0x001f 1.4.2 (station firmware)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    role=Supplier variant=2 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    role=Actor    variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Wireless LAN card information:&lt;br /&gt;
    Components:&lt;br /&gt;
    NICID: 0x8013 v1.0.0&lt;br /&gt;
    PRIID: 0x0015 v1.0.7&lt;br /&gt;
    STAID: 0x001f v1.3.6&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    PRI role=Supplier variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    PRI role=Supplier variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    PRI role=Supplier variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    STA role=Supplier variant=1 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    PRI role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    This image is not meant to be downloaded to volatile memory.&lt;br /&gt;
    Incompatible update data.&lt;br /&gt;
&lt;br /&gt;
Has anyone tried to flash this device using prism2_srec yet?&lt;br /&gt;
What bothers me is, that the upgrade is for many different parts of the combo card. Does anyone have an opinion on whether this could work?&lt;br /&gt;
&lt;br /&gt;
OK, I took the risk and successfully upgraded my station firmware, BUT when I tried to upgrade the primary firmware the system froze!!! The thinkpad won't start up with the miniPCI card inserted and all efforts to reflash it using the original DOS boot image failed!!!&lt;br /&gt;
&lt;br /&gt;
I'm quite sure the system freeze was not caused directly by prism2_srec, because I have noticed rare system freezes since I have been using my PCMCIA wireless card.&lt;br /&gt;
Anyway, if anyone should own a TP R32, I'd be glad if he could tell me the base address of the Wlan card, or it's PCI address.&lt;br /&gt;
&lt;br /&gt;
Thinkpad r32 owner here. I want to upgrade the firmware as well. If you need any information just send an email to haftbar[a]gmail.com [[User:Quickie|Quickie]] 02:12, 1 February 2006 (CET)&lt;br /&gt;
&lt;br /&gt;
==Reorganization suggestion==&lt;br /&gt;
The Downloads section is rather long. Would it be an idea to put it on a separate, new page (say: BIOS_Downloads) and link to that new page from this page?&lt;br /&gt;
&lt;br /&gt;
[[User:Pebolle|Paul Bolle]] 21:27, 15 Oct 2005 (CEST)&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I agree with this suggestion.&lt;br /&gt;
&lt;br /&gt;
== Upgrading BIOS and Embedded Control Program from Win XP ==&lt;br /&gt;
&lt;br /&gt;
I'm trying to upgrade the BIOS and Embedded Controller Program from Windows XP following the instructions on the Lenovo website. The problem is the instructions are not very clear about this. The instructions basically state that I must upgrade them at the same time because the Control Program does not work with the older BIOS and the BIOS does not work with the older Control Program. They also state that I should upgrade the Control Program first. &lt;br /&gt;
&lt;br /&gt;
But that means I must boot into XP after having upgraded the Control Program but with the older BIOS in order to then update the BIOS. But if this works then they are actually compatible and there's a contradiction. Am I missing something? I just want to make sure I don't end up with a non-functioning unit.&lt;br /&gt;
&lt;br /&gt;
I have an X23 and want the latest BIOS (v 1.32) and Control Program (v 1.30). &lt;br /&gt;
&lt;br /&gt;
Maybe there should be a note about this in the article? Or maybe I'm the only one who is this stupid :)&lt;br /&gt;
&lt;br /&gt;
Update: I talked to Lenovo support. The situation apparently is that though the description says that the newer control program is not compatible with the older BIOS, they are not so incompatible as to cause the machine to stop working so it is actually possible to use incompatible versions of BIOS and control program. In fact according to the support person it makes no difference if the BIOS is upgraded before the control program or vice versa. So I upgraded the control program using the executable running in Windows XP, which rebooted the computer to perform the upgrade and then I booted Windows again to upgrade the BIOS in the same manner and it all worked fine. If anyone reading this finds it useful maybe you can put it in the article? Or if you find it superfluous just delete this section.&lt;br /&gt;
&lt;br /&gt;
--[[User:xphinx|xphinx]] 12 March 2007&lt;br /&gt;
&lt;br /&gt;
I have an X22 with BIOS version 1.21 and Embedded Controller version 1.17 and using the steps described by you, I succesfully updated my bios to the lastest versions from WindowsXP (BIOS v1.32 / EC v1.30)&lt;br /&gt;
Thanks!&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade for T21 with T20 BIOS ==&lt;br /&gt;
&lt;br /&gt;
Hi, I bought a used T21 recently (type 2647-8AU), and would like to update the BIOS to the latest version, but there's a problem: this T21 appears to have a T20 BIOS (IYET50WW, a/k/a T20 BIOS version 1.11).  When I try updating this BIOS using one of IBM's T21 updaters - I tried KZET34WW/v1.16 (the latest one) and KZET16WW/v1.01 (the earliest one) - I get the following message:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
''The diskette in the default drive will not run on this system. Your system is now locked. To restart your system, press Ctrl+Alt+Del.''&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
I suspect this message appears because the existing BIOS is a T20 BIOS.&lt;br /&gt;
&lt;br /&gt;
There would appear to be two options: either use the most recent T20 updater (IYET61WW, a/k/a T20 v1.22), or find a way to defeat the block in the KZET34WW/v1.16 T21 updater.  Obviously either option is risky in the absence of more information and/or detective work.  And I don't know enough about T2x-series hardware to hazard a guess (i.e., were early T21s just T20s with a speed bump, did some T21s get T20 BIOSes by mistake due to factory error, or are the T20 and T21 similar enough that it doesn't matter whether a T20 or T21 BIOS is used).&lt;br /&gt;
&lt;br /&gt;
Some relevant data gleaned from the stickers on the case bottom and the current BIOS:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
* '''Type:''' 2647-8AU (T21 with 800-MHz processor)&lt;br /&gt;
* '''S/N:''' 78-0GL1Z (zero-G-L-one-zed)&lt;br /&gt;
* '''Manufacture date:''' 03/2001&lt;br /&gt;
* '''BIOS version:''' IYET50WW (T20 BIOS v1.11)&lt;br /&gt;
* '''System unit S/N:''' (appears to be blank)&lt;br /&gt;
* '''System board S/N:''' J1HHS15CL5C&lt;br /&gt;
* '''System board P/N:''' 08K3747 (printed on motherboard)&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Thanks for any help anyone can provide.&lt;br /&gt;
&lt;br /&gt;
-Linux Spice&lt;br /&gt;
&lt;br /&gt;
P.S. At first I thought this might be a Frankenstein ThinkPad with a T21 case and a T20 logic board - I did buy it used, after all - but it does have an 800-MHz processor, which was never an option for the T20 (both the BIOS and Linux report it as such), and all the other equipment checks out (except for the hard drive, which was replaced with a 40-GB model).&lt;br /&gt;
&lt;br /&gt;
== BIOS format ==&lt;br /&gt;
&lt;br /&gt;
Not sure if this is the right place, but...&lt;br /&gt;
Does anybody know what the formats for the various files are in the bios package (or, even better, the bios.bak file that gets dumped on your disk before updating)? I'm getting progressivel lower and lower level in figuring out just what happens when the computer boots, and the BIOS is the last step... (BTW, I have an x60s)&lt;br /&gt;
&lt;br /&gt;
-- Unknown&lt;br /&gt;
&lt;br /&gt;
Yes.  It is a binary dump.  Sometimes, there is junk in the start of the file.  This should be data enough for you to figure out what you need.&lt;br /&gt;
&lt;br /&gt;
--[[User:Hmh|hmh]] 13:30, 26 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS update gone bad ==&lt;br /&gt;
&lt;br /&gt;
I tried to flash my [[:Category:600|ThinkPad 600]]'s bios with catastrophalic outcome; now the machine is unable to boot. I, being overly stupid and too self-confident, ignored all warnings about the media containing the bios image not being write-protected (I used one partition of the disk, in which I had installed FreeDOS). During the updating process, the machine started to write screens full of random characters in cyan coloured background. At that point I knew it was b0rked. I asked my friend about what to do now, he said I could open the machine up, locate the bios chip and use EPROM programmer/burner to write the bios image to the chip. He also said that because my machine is very old, there are probably not safeguards like dual bios or emergency bios update from floppy disk on boot. He continued by saying that the bios update file images from IBM/Lenovo website might not be actual , &amp;quot;pure&amp;quot; binaries which could be burned directly to the chip, instead they may contain some vendor-specific checksums which must be taken into account. In ThinkWiki there seems to be no page about bios flashing gone bad and restoring the machine to working condition. Or is there? I really need your help with this; I think I'm able to locate the bios, take it off and find a working EPROM burner, but where can I get a clean BIOS image without the vendor checksums? I'd be grateful for any references.&lt;br /&gt;
&lt;br /&gt;
--[[User:Usv|Usv]] 12:45, 31 March 2007 (CEST)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using USB flash drive ==&lt;br /&gt;
&lt;br /&gt;
I flashed my Thinkpad X41 succesfully with 2.09 BIOS using bootable USB flash drive with DOS 6.22 system files. (I guess Freedos would work aswell). I had such key laying around so I can't help you with making one (i used windows HP USB key format utility to make it long long time ago) &lt;br /&gt;
Everything is quite simple once you have USB key and are able to boot DOS from it.&lt;br /&gt;
&lt;br /&gt;
I downloaded the non-diskette ThinkPad BIOS update utility (74uj15us.exe) from lenovo support site and extracted the disk image from it using cabextract:&lt;br /&gt;
   {{cmduser|cabextract -F &amp;quot;*.IMG&amp;quot; 74uj15us.exe}}&lt;br /&gt;
&lt;br /&gt;
I mounted the image file (74UJ15US.IMG):&lt;br /&gt;
   {{cmdroot|mkdir /tmp/mnt}}&lt;br /&gt;
   {{cmdroot|mount -loop o 74UJ15US.IMG /tmp/mnt}}&lt;br /&gt;
&lt;br /&gt;
I mounted the usb key and made a directory for ibm flash utility files under it:&lt;br /&gt;
   {{cmdroot|mount /dev/sdb1 /mnt/usbflash}}&lt;br /&gt;
   {{cmdroot|mkdir /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
I copied the contents of /tmp/mnt to /mnt/usbflash/ibm:&lt;br /&gt;
   {{cmdroot|cp /tmp/mnt/*.* /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
Then I unmounted the USB stick and rebooted from it to DOS (F12 during boot -&amp;gt; USB HDD).&amp;lt;br&amp;gt; &lt;br /&gt;
In the DOS Prompt:&amp;lt;br&amp;gt;&lt;br /&gt;
   C:\cd ibm&lt;br /&gt;
   C:\IBM\flash2 /U&lt;br /&gt;
I waited for about 1 minute, then my thinkpad made two beeps to signal that the flashing was complete.&lt;br /&gt;
&lt;br /&gt;
PS. Because lacking reliable guide on how to make bootable DOS USB stick for ThinkPads I decided to leave this into discussion section. Feel free to move all the necessary stuff into the BIOS upgrade article if you know/figure out how to make bootable DOS USB stick in linux.   &lt;br /&gt;
--[[User:ladoga|ladoga]] 04:56 17 Apr 2007&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29374</id>
		<title>Talk:BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29374"/>
		<updated>2007-04-17T02:48:34Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* Upgrading BIOS from USB flash drive */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Dead link == &lt;br /&gt;
&lt;br /&gt;
The link to the FreeDOS floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip), which is needed to upgrade the BIOS from a CD, is dead. Is the information still valid? And is there a different source for the floppy image? [[User:Jamesavery|Jamesavery]] 05:49, 18 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using WINE ==&lt;br /&gt;
&lt;br /&gt;
Does anyone think this would be possible? [[User:Mcalwell|Mcalwell]] 08:58, 28 January 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
: No this is not possible. [[User:Mcalwell|Mcalwell]] 16:01, 12 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade without battery ==&lt;br /&gt;
&lt;br /&gt;
Concerning the known problem with 600 series with batteries dead too soon, it is impossible to upgrade the bios without the battery because the original ibm update program doesn't allow this. I bought an old 600E without the battery. There was one workaround, but i think for the older releases of the bios, where you just extracted files and upgraded manualy, bypassing the ibm install program. The page that describes this (i lost the link) has a list of different files, that the ones found in current release so i never did figure out what to do? I would like to upgrade because i have really old bios, where ACPI doesn't cooperate so well with the operating system, either windows or linux.&lt;br /&gt;
&lt;br /&gt;
If somebody finds a workaround please help. Thanks&lt;br /&gt;
&lt;br /&gt;
//Edit&lt;br /&gt;
&lt;br /&gt;
I've found the page on Vim's bios upgrade forum.. I don't know if it exactly for my model, since the files differ.. '''Is it possible, to upgrade bios in linux without the battery?'''&lt;br /&gt;
&lt;br /&gt;
''I have found a working solution WOW on the other forum: &lt;br /&gt;
&lt;br /&gt;
*** This is NOT a safe way to update the bios (disclaimer) *** &lt;br /&gt;
&lt;br /&gt;
* First you need to make a BIOS update floppy disk (from the bios file from IBM - place disk in a: drive, run app and answer Y to the agreement) and then format another disk by right clicking on A: - format - make system bootdisk (assuming you have another machine spare) &lt;br /&gt;
&lt;br /&gt;
* Copy all the files from the IBM Boot disk - in my case &lt;br /&gt;
$0029000.fl1 &lt;br /&gt;
$0029000.fl2 &lt;br /&gt;
FLASH2.EXE &lt;br /&gt;
PROD.DAT &lt;br /&gt;
UPDTFLSH.EXE &lt;br /&gt;
updtrom.exe &lt;br /&gt;
USERINT.EXE &lt;br /&gt;
UTILINFO.EXE &lt;br /&gt;
to the other clean bootdisk. &lt;br /&gt;
&lt;br /&gt;
* Ensure that there is no config.sys and autoexec.bat so it just runs straight into DOS. &lt;br /&gt;
&lt;br /&gt;
* Place the disk into the Laptop, reboot and allow the machine to load via the floppy &lt;br /&gt;
&lt;br /&gt;
* At the command prompt, type &amp;quot;FLASH2.EXE /U&amp;quot; with no quotes then press enter. &lt;br /&gt;
&lt;br /&gt;
The program will automatically search for the files *.FL1 &amp;amp; *.FL2 and load the bios first then the platform file. &lt;br /&gt;
&lt;br /&gt;
The program will automatically update and perform erasing on the rom and then finish with &amp;quot;Update complete&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
* Now reboot. &lt;br /&gt;
&lt;br /&gt;
* Hold F1 down as you turn the laptop back on and go into Easy Setup under &amp;quot;Config&amp;quot; click on Initialize to ensure defaults and settings are error free. &lt;br /&gt;
&lt;br /&gt;
* Save and exit...''&lt;br /&gt;
&lt;br /&gt;
// EDIT&lt;br /&gt;
&lt;br /&gt;
This worked on my machine.. I make no guarantees it will work on others.&lt;br /&gt;
&lt;br /&gt;
The above procedure did not work on my T23 using the 1.20 bios; it kept returning error 14 (Low Battery). However, following those instructions and running &amp;quot;qkflash&amp;quot; rather than flash2 did work for the main bios, and later for the embedded controller.&lt;br /&gt;
&lt;br /&gt;
--grythumn&lt;br /&gt;
&lt;br /&gt;
== Bios upgrade &amp;amp; hidden partition ==&lt;br /&gt;
&lt;br /&gt;
I have disabled the hidden partition to make more space for linux (24G). I still have Windows on the 14G partition. Is it safe to upgrade the BIOS without the hidden partition? I want to get a newer BIOS to fix the annoying fan issue. Thanks&lt;br /&gt;
&lt;br /&gt;
- yes don't worry about it. bios upgrades have nothing to do with whats inside the harddrive.&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade over PXE ==&lt;br /&gt;
&lt;br /&gt;
Hi,&lt;br /&gt;
&lt;br /&gt;
I have a Thinkpad X20 with a very early BIOS and Embedded Controller Program which I'd like to update. Currently, the only feasible way of doing this is over the network using PXE. I already have a fully functional PXE server using SYSLINUX, and have so far been able to boot the BIOS diskette image using MEMDISK, although I have not attempted to flash anything yet due to the warnings given on the page. Is there any safe way I can update both the Controller Program and the BIOS in the same session over the network in this manner? If not, what other methods would be suitable? I have a USB CD-ROM drive and could probably get hold of a USB floppy drive.&lt;br /&gt;
&lt;br /&gt;
Thanks.&lt;br /&gt;
&lt;br /&gt;
Update: I ended up burning CDs as described and successfully updated everything. I'd still like to know if there is a way I could do it entirely over the network, though.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== RE: grub initrd ==&lt;br /&gt;
&lt;br /&gt;
&amp;quot;Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
0) Interesting suggestion. Might be better of in its own section.&lt;br /&gt;
&lt;br /&gt;
1) Could you please elaborate?&lt;br /&gt;
&lt;br /&gt;
2) My first guess (pending your elaboration) would be to &amp;quot;chainload&amp;quot; the first block of the diskimage using the grub commandline, like:&lt;br /&gt;
   blocklist (''path'')/''to''/''diskimage''&lt;br /&gt;
   chainloader ''blockvalue''+1&lt;br /&gt;
&lt;br /&gt;
But that's just a guess!&lt;br /&gt;
&lt;br /&gt;
[[user:Pebolle|Paul Bolle]] Fri Jul 15 12:20:47 CEST 2005&lt;br /&gt;
&lt;br /&gt;
== bios/controller update sequence ==&lt;br /&gt;
&lt;br /&gt;
The article says:&lt;br /&gt;
&amp;quot;If you go through the readme's on the IBM site they'll cleary state that you must update the Control Program first, then imediately update the BIOS&amp;quot;&lt;br /&gt;
&lt;br /&gt;
When I look at the IBM udpate instructions for the T23, it says:&lt;br /&gt;
&amp;quot;If you need to update the BIOS as well as the Embedded Controller Program, update the BIOS first.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comments?&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I would first contact IBM for clarification, but you should probably be following instructions specific to your model.&lt;br /&gt;
&lt;br /&gt;
&amp;gt;&amp;gt; I did it following IBM's instructions to upgrade the BIOS first. Everything worked out great!&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Intel minipci combo card ==&lt;br /&gt;
&lt;br /&gt;
I just purchased an [[Intel 10/100 Ethernet Mini-PCI Adapter with 56K Modem]] that has an ancient (2.0.6) firmware version.  I Downloaded the update file intlbtag.EXE but cabextract was unable to find any cabfiles inside it.  I tried running the program via wine and that didn't work either.&lt;br /&gt;
&lt;br /&gt;
Finally I ran the program on a windows machine and created a boot floppy.  Then I went through the the process of converting the floppy to a bootable cd via linux and that worked like a charm.  The cd successfully updated the minipc card's firmware.&lt;br /&gt;
&lt;br /&gt;
Everything worked but I ended up needing a windows box to do it.  Could this have been done without windows?&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Wireless LAN MiniPCI COMBO Card using prism2_srec ==&lt;br /&gt;
&lt;br /&gt;
The appropriate firmware installation program for the wlan card in my R32 can be extracted using cabextract as described in the article. It contains (besides some installation programs) a disk image (1awg06ww.IMG) that seems to be a simple dos boot disk. This image contains 3 .hex files (id010001.hex, pk010100.hex, sf010402.hex) that are recognized by prism2_srec to be &amp;quot;srec&amp;quot;-files. Trying to load them to RAM yields:&lt;br /&gt;
&lt;br /&gt;
    {{cmdroot|prism2_srec -v -r wlan0 sf010402.hex}}&lt;br /&gt;
    S3 CRC-16 generation record: start=0x007E1800 len=65642 prog=1&lt;br /&gt;
    Start address 0x00000000&lt;br /&gt;
    srec summary for sf010402.hex&lt;br /&gt;
    Component: 0x001f 1.4.2 (station firmware)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    role=Supplier variant=2 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    role=Actor    variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Wireless LAN card information:&lt;br /&gt;
    Components:&lt;br /&gt;
    NICID: 0x8013 v1.0.0&lt;br /&gt;
    PRIID: 0x0015 v1.0.7&lt;br /&gt;
    STAID: 0x001f v1.3.6&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    PRI role=Supplier variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    PRI role=Supplier variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    PRI role=Supplier variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    STA role=Supplier variant=1 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    PRI role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    This image is not meant to be downloaded to volatile memory.&lt;br /&gt;
    Incompatible update data.&lt;br /&gt;
&lt;br /&gt;
Has anyone tried to flash this device using prism2_srec yet?&lt;br /&gt;
What bothers me is, that the upgrade is for many different parts of the combo card. Does anyone have an opinion on whether this could work?&lt;br /&gt;
&lt;br /&gt;
OK, I took the risk and successfully upgraded my station firmware, BUT when I tried to upgrade the primary firmware the system froze!!! The thinkpad won't start up with the miniPCI card inserted and all efforts to reflash it using the original DOS boot image failed!!!&lt;br /&gt;
&lt;br /&gt;
I'm quite sure the system freeze was not caused directly by prism2_srec, because I have noticed rare system freezes since I have been using my PCMCIA wireless card.&lt;br /&gt;
Anyway, if anyone should own a TP R32, I'd be glad if he could tell me the base address of the Wlan card, or it's PCI address.&lt;br /&gt;
&lt;br /&gt;
Thinkpad r32 owner here. I want to upgrade the firmware as well. If you need any information just send an email to haftbar[a]gmail.com [[User:Quickie|Quickie]] 02:12, 1 February 2006 (CET)&lt;br /&gt;
&lt;br /&gt;
==Reorganization suggestion==&lt;br /&gt;
The Downloads section is rather long. Would it be an idea to put it on a separate, new page (say: BIOS_Downloads) and link to that new page from this page?&lt;br /&gt;
&lt;br /&gt;
[[User:Pebolle|Paul Bolle]] 21:27, 15 Oct 2005 (CEST)&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I agree with this suggestion.&lt;br /&gt;
&lt;br /&gt;
== Upgrading BIOS and Embedded Control Program from Win XP ==&lt;br /&gt;
&lt;br /&gt;
I'm trying to upgrade the BIOS and Embedded Controller Program from Windows XP following the instructions on the Lenovo website. The problem is the instructions are not very clear about this. The instructions basically state that I must upgrade them at the same time because the Control Program does not work with the older BIOS and the BIOS does not work with the older Control Program. They also state that I should upgrade the Control Program first. &lt;br /&gt;
&lt;br /&gt;
But that means I must boot into XP after having upgraded the Control Program but with the older BIOS in order to then update the BIOS. But if this works then they are actually compatible and there's a contradiction. Am I missing something? I just want to make sure I don't end up with a non-functioning unit.&lt;br /&gt;
&lt;br /&gt;
I have an X23 and want the latest BIOS (v 1.32) and Control Program (v 1.30). &lt;br /&gt;
&lt;br /&gt;
Maybe there should be a note about this in the article? Or maybe I'm the only one who is this stupid :)&lt;br /&gt;
&lt;br /&gt;
Update: I talked to Lenovo support. The situation apparently is that though the description says that the newer control program is not compatible with the older BIOS, they are not so incompatible as to cause the machine to stop working so it is actually possible to use incompatible versions of BIOS and control program. In fact according to the support person it makes no difference if the BIOS is upgraded before the control program or vice versa. So I upgraded the control program using the executable running in Windows XP, which rebooted the computer to perform the upgrade and then I booted Windows again to upgrade the BIOS in the same manner and it all worked fine. If anyone reading this finds it useful maybe you can put it in the article? Or if you find it superfluous just delete this section.&lt;br /&gt;
&lt;br /&gt;
--[[User:xphinx|xphinx]] 12 March 2007&lt;br /&gt;
&lt;br /&gt;
I have an X22 with BIOS version 1.21 and Embedded Controller version 1.17 and using the steps described by you, I succesfully updated my bios to the lastest versions from WindowsXP (BIOS v1.32 / EC v1.30)&lt;br /&gt;
Thanks!&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade for T21 with T20 BIOS ==&lt;br /&gt;
&lt;br /&gt;
Hi, I bought a used T21 recently (type 2647-8AU), and would like to update the BIOS to the latest version, but there's a problem: this T21 appears to have a T20 BIOS (IYET50WW, a/k/a T20 BIOS version 1.11).  When I try updating this BIOS using one of IBM's T21 updaters - I tried KZET34WW/v1.16 (the latest one) and KZET16WW/v1.01 (the earliest one) - I get the following message:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
''The diskette in the default drive will not run on this system. Your system is now locked. To restart your system, press Ctrl+Alt+Del.''&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
I suspect this message appears because the existing BIOS is a T20 BIOS.&lt;br /&gt;
&lt;br /&gt;
There would appear to be two options: either use the most recent T20 updater (IYET61WW, a/k/a T20 v1.22), or find a way to defeat the block in the KZET34WW/v1.16 T21 updater.  Obviously either option is risky in the absence of more information and/or detective work.  And I don't know enough about T2x-series hardware to hazard a guess (i.e., were early T21s just T20s with a speed bump, did some T21s get T20 BIOSes by mistake due to factory error, or are the T20 and T21 similar enough that it doesn't matter whether a T20 or T21 BIOS is used).&lt;br /&gt;
&lt;br /&gt;
Some relevant data gleaned from the stickers on the case bottom and the current BIOS:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
* '''Type:''' 2647-8AU (T21 with 800-MHz processor)&lt;br /&gt;
* '''S/N:''' 78-0GL1Z (zero-G-L-one-zed)&lt;br /&gt;
* '''Manufacture date:''' 03/2001&lt;br /&gt;
* '''BIOS version:''' IYET50WW (T20 BIOS v1.11)&lt;br /&gt;
* '''System unit S/N:''' (appears to be blank)&lt;br /&gt;
* '''System board S/N:''' J1HHS15CL5C&lt;br /&gt;
* '''System board P/N:''' 08K3747 (printed on motherboard)&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Thanks for any help anyone can provide.&lt;br /&gt;
&lt;br /&gt;
-Linux Spice&lt;br /&gt;
&lt;br /&gt;
P.S. At first I thought this might be a Frankenstein ThinkPad with a T21 case and a T20 logic board - I did buy it used, after all - but it does have an 800-MHz processor, which was never an option for the T20 (both the BIOS and Linux report it as such), and all the other equipment checks out (except for the hard drive, which was replaced with a 40-GB model).&lt;br /&gt;
&lt;br /&gt;
== BIOS format ==&lt;br /&gt;
&lt;br /&gt;
Not sure if this is the right place, but...&lt;br /&gt;
Does anybody know what the formats for the various files are in the bios package (or, even better, the bios.bak file that gets dumped on your disk before updating)? I'm getting progressivel lower and lower level in figuring out just what happens when the computer boots, and the BIOS is the last step... (BTW, I have an x60s)&lt;br /&gt;
&lt;br /&gt;
-- Unknown&lt;br /&gt;
&lt;br /&gt;
Yes.  It is a binary dump.  Sometimes, there is junk in the start of the file.  This should be data enough for you to figure out what you need.&lt;br /&gt;
&lt;br /&gt;
--[[User:Hmh|hmh]] 13:30, 26 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS update gone bad ==&lt;br /&gt;
&lt;br /&gt;
I tried to flash my [[:Category:600|ThinkPad 600]]'s bios with catastrophalic outcome; now the machine is unable to boot. I, being overly stupid and too self-confident, ignored all warnings about the media containing the bios image not being write-protected (I used one partition of the disk, in which I had installed FreeDOS). During the updating process, the machine started to write screens full of random characters in cyan coloured background. At that point I knew it was b0rked. I asked my friend about what to do now, he said I could open the machine up, locate the bios chip and use EPROM programmer/burner to write the bios image to the chip. He also said that because my machine is very old, there are probably not safeguards like dual bios or emergency bios update from floppy disk on boot. He continued by saying that the bios update file images from IBM/Lenovo website might not be actual , &amp;quot;pure&amp;quot; binaries which could be burned directly to the chip, instead they may contain some vendor-specific checksums which must be taken into account. In ThinkWiki there seems to be no page about bios flashing gone bad and restoring the machine to working condition. Or is there? I really need your help with this; I think I'm able to locate the bios, take it off and find a working EPROM burner, but where can I get a clean BIOS image without the vendor checksums? I'd be grateful for any references.&lt;br /&gt;
&lt;br /&gt;
--[[User:Usv|Usv]] 12:45, 31 March 2007 (CEST)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using USB flash drive ==&lt;br /&gt;
&lt;br /&gt;
I flashed my Thinkpad X41 succesfully with 2.09 BIOS using bootable USB flash drive with DOS 6.22 system files. (I guess Freedos would work aswell). I had such key laying around so I can't help you with making one (i used windows HP USB key format utility to make it long long time ago) &lt;br /&gt;
Everything is quite simple once you have USB key and are able to boot DOS from it.&lt;br /&gt;
&lt;br /&gt;
I downloaded the non-diskette ThinkPad BIOS update utility (74uj15us.exe) from lenovo support site and extrated disk image from it using cabextract:&lt;br /&gt;
   {{cmduser|cabextract -F &amp;quot;*.IMG&amp;quot; 74uj15us.exe}}&lt;br /&gt;
&lt;br /&gt;
I mounted the image file (74UJ15US.IMG):&lt;br /&gt;
   {{cmdroot|mkdir /tmp/mnt}}&lt;br /&gt;
   {{cmdroot|mount -loop o 74UJ15US.IMG /tmp/mnt}}&lt;br /&gt;
&lt;br /&gt;
I mounted the usb key and made a directory for ibm flash utility files under it:&lt;br /&gt;
   {{cmdroot|mount /dev/sdb1 /mnt/usbflash}}&lt;br /&gt;
   {{cmdroot|mkdir /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
I copied the contents of /tmp/mnt to /mnt/usbflash/ibm:&lt;br /&gt;
   {{cmdroot|cp /tmp/mnt/*.* /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
Then I unmounted the USB stick and rebooted from it to DOS (F12 during boot -&amp;gt; USB HDD).&amp;lt;br&amp;gt; &lt;br /&gt;
In the DOS Prompt:&amp;lt;br&amp;gt;&lt;br /&gt;
   C:\cd ibm&lt;br /&gt;
   C:\IBM\flash2 /U&lt;br /&gt;
I waited for about 1 minute, then my thinkpad made two beeps to signal that the flashing was complete.&lt;br /&gt;
&lt;br /&gt;
PS. Because lacking reliable guide on how to make bootable DOS USB stick for ThinkPads I decided to leave this into discussion section. Feel free to move all the necessary stuff into the BIOS upgrade article if you know/figure out how to make bootable DOS USB stick in linux.   &lt;br /&gt;
--[[User:ladoga|ladoga]] 04:56 17 Apr 2007&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29373</id>
		<title>Talk:BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29373"/>
		<updated>2007-04-17T02:47:23Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* BIOS upgrage using USB flash drive */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Dead link == &lt;br /&gt;
&lt;br /&gt;
The link to the FreeDOS floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip), which is needed to upgrade the BIOS from a CD, is dead. Is the information still valid? And is there a different source for the floppy image? [[User:Jamesavery|Jamesavery]] 05:49, 18 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using WINE ==&lt;br /&gt;
&lt;br /&gt;
Does anyone think this would be possible? [[User:Mcalwell|Mcalwell]] 08:58, 28 January 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
: No this is not possible. [[User:Mcalwell|Mcalwell]] 16:01, 12 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade without battery ==&lt;br /&gt;
&lt;br /&gt;
Concerning the known problem with 600 series with batteries dead too soon, it is impossible to upgrade the bios without the battery because the original ibm update program doesn't allow this. I bought an old 600E without the battery. There was one workaround, but i think for the older releases of the bios, where you just extracted files and upgraded manualy, bypassing the ibm install program. The page that describes this (i lost the link) has a list of different files, that the ones found in current release so i never did figure out what to do? I would like to upgrade because i have really old bios, where ACPI doesn't cooperate so well with the operating system, either windows or linux.&lt;br /&gt;
&lt;br /&gt;
If somebody finds a workaround please help. Thanks&lt;br /&gt;
&lt;br /&gt;
//Edit&lt;br /&gt;
&lt;br /&gt;
I've found the page on Vim's bios upgrade forum.. I don't know if it exactly for my model, since the files differ.. '''Is it possible, to upgrade bios in linux without the battery?'''&lt;br /&gt;
&lt;br /&gt;
''I have found a working solution WOW on the other forum: &lt;br /&gt;
&lt;br /&gt;
*** This is NOT a safe way to update the bios (disclaimer) *** &lt;br /&gt;
&lt;br /&gt;
* First you need to make a BIOS update floppy disk (from the bios file from IBM - place disk in a: drive, run app and answer Y to the agreement) and then format another disk by right clicking on A: - format - make system bootdisk (assuming you have another machine spare) &lt;br /&gt;
&lt;br /&gt;
* Copy all the files from the IBM Boot disk - in my case &lt;br /&gt;
$0029000.fl1 &lt;br /&gt;
$0029000.fl2 &lt;br /&gt;
FLASH2.EXE &lt;br /&gt;
PROD.DAT &lt;br /&gt;
UPDTFLSH.EXE &lt;br /&gt;
updtrom.exe &lt;br /&gt;
USERINT.EXE &lt;br /&gt;
UTILINFO.EXE &lt;br /&gt;
to the other clean bootdisk. &lt;br /&gt;
&lt;br /&gt;
* Ensure that there is no config.sys and autoexec.bat so it just runs straight into DOS. &lt;br /&gt;
&lt;br /&gt;
* Place the disk into the Laptop, reboot and allow the machine to load via the floppy &lt;br /&gt;
&lt;br /&gt;
* At the command prompt, type &amp;quot;FLASH2.EXE /U&amp;quot; with no quotes then press enter. &lt;br /&gt;
&lt;br /&gt;
The program will automatically search for the files *.FL1 &amp;amp; *.FL2 and load the bios first then the platform file. &lt;br /&gt;
&lt;br /&gt;
The program will automatically update and perform erasing on the rom and then finish with &amp;quot;Update complete&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
* Now reboot. &lt;br /&gt;
&lt;br /&gt;
* Hold F1 down as you turn the laptop back on and go into Easy Setup under &amp;quot;Config&amp;quot; click on Initialize to ensure defaults and settings are error free. &lt;br /&gt;
&lt;br /&gt;
* Save and exit...''&lt;br /&gt;
&lt;br /&gt;
// EDIT&lt;br /&gt;
&lt;br /&gt;
This worked on my machine.. I make no guarantees it will work on others.&lt;br /&gt;
&lt;br /&gt;
The above procedure did not work on my T23 using the 1.20 bios; it kept returning error 14 (Low Battery). However, following those instructions and running &amp;quot;qkflash&amp;quot; rather than flash2 did work for the main bios, and later for the embedded controller.&lt;br /&gt;
&lt;br /&gt;
--grythumn&lt;br /&gt;
&lt;br /&gt;
== Bios upgrade &amp;amp; hidden partition ==&lt;br /&gt;
&lt;br /&gt;
I have disabled the hidden partition to make more space for linux (24G). I still have Windows on the 14G partition. Is it safe to upgrade the BIOS without the hidden partition? I want to get a newer BIOS to fix the annoying fan issue. Thanks&lt;br /&gt;
&lt;br /&gt;
- yes don't worry about it. bios upgrades have nothing to do with whats inside the harddrive.&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade over PXE ==&lt;br /&gt;
&lt;br /&gt;
Hi,&lt;br /&gt;
&lt;br /&gt;
I have a Thinkpad X20 with a very early BIOS and Embedded Controller Program which I'd like to update. Currently, the only feasible way of doing this is over the network using PXE. I already have a fully functional PXE server using SYSLINUX, and have so far been able to boot the BIOS diskette image using MEMDISK, although I have not attempted to flash anything yet due to the warnings given on the page. Is there any safe way I can update both the Controller Program and the BIOS in the same session over the network in this manner? If not, what other methods would be suitable? I have a USB CD-ROM drive and could probably get hold of a USB floppy drive.&lt;br /&gt;
&lt;br /&gt;
Thanks.&lt;br /&gt;
&lt;br /&gt;
Update: I ended up burning CDs as described and successfully updated everything. I'd still like to know if there is a way I could do it entirely over the network, though.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== RE: grub initrd ==&lt;br /&gt;
&lt;br /&gt;
&amp;quot;Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
0) Interesting suggestion. Might be better of in its own section.&lt;br /&gt;
&lt;br /&gt;
1) Could you please elaborate?&lt;br /&gt;
&lt;br /&gt;
2) My first guess (pending your elaboration) would be to &amp;quot;chainload&amp;quot; the first block of the diskimage using the grub commandline, like:&lt;br /&gt;
   blocklist (''path'')/''to''/''diskimage''&lt;br /&gt;
   chainloader ''blockvalue''+1&lt;br /&gt;
&lt;br /&gt;
But that's just a guess!&lt;br /&gt;
&lt;br /&gt;
[[user:Pebolle|Paul Bolle]] Fri Jul 15 12:20:47 CEST 2005&lt;br /&gt;
&lt;br /&gt;
== bios/controller update sequence ==&lt;br /&gt;
&lt;br /&gt;
The article says:&lt;br /&gt;
&amp;quot;If you go through the readme's on the IBM site they'll cleary state that you must update the Control Program first, then imediately update the BIOS&amp;quot;&lt;br /&gt;
&lt;br /&gt;
When I look at the IBM udpate instructions for the T23, it says:&lt;br /&gt;
&amp;quot;If you need to update the BIOS as well as the Embedded Controller Program, update the BIOS first.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comments?&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I would first contact IBM for clarification, but you should probably be following instructions specific to your model.&lt;br /&gt;
&lt;br /&gt;
&amp;gt;&amp;gt; I did it following IBM's instructions to upgrade the BIOS first. Everything worked out great!&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Intel minipci combo card ==&lt;br /&gt;
&lt;br /&gt;
I just purchased an [[Intel 10/100 Ethernet Mini-PCI Adapter with 56K Modem]] that has an ancient (2.0.6) firmware version.  I Downloaded the update file intlbtag.EXE but cabextract was unable to find any cabfiles inside it.  I tried running the program via wine and that didn't work either.&lt;br /&gt;
&lt;br /&gt;
Finally I ran the program on a windows machine and created a boot floppy.  Then I went through the the process of converting the floppy to a bootable cd via linux and that worked like a charm.  The cd successfully updated the minipc card's firmware.&lt;br /&gt;
&lt;br /&gt;
Everything worked but I ended up needing a windows box to do it.  Could this have been done without windows?&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Wireless LAN MiniPCI COMBO Card using prism2_srec ==&lt;br /&gt;
&lt;br /&gt;
The appropriate firmware installation program for the wlan card in my R32 can be extracted using cabextract as described in the article. It contains (besides some installation programs) a disk image (1awg06ww.IMG) that seems to be a simple dos boot disk. This image contains 3 .hex files (id010001.hex, pk010100.hex, sf010402.hex) that are recognized by prism2_srec to be &amp;quot;srec&amp;quot;-files. Trying to load them to RAM yields:&lt;br /&gt;
&lt;br /&gt;
    {{cmdroot|prism2_srec -v -r wlan0 sf010402.hex}}&lt;br /&gt;
    S3 CRC-16 generation record: start=0x007E1800 len=65642 prog=1&lt;br /&gt;
    Start address 0x00000000&lt;br /&gt;
    srec summary for sf010402.hex&lt;br /&gt;
    Component: 0x001f 1.4.2 (station firmware)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    role=Supplier variant=2 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    role=Actor    variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Wireless LAN card information:&lt;br /&gt;
    Components:&lt;br /&gt;
    NICID: 0x8013 v1.0.0&lt;br /&gt;
    PRIID: 0x0015 v1.0.7&lt;br /&gt;
    STAID: 0x001f v1.3.6&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    PRI role=Supplier variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    PRI role=Supplier variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    PRI role=Supplier variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    STA role=Supplier variant=1 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    PRI role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    This image is not meant to be downloaded to volatile memory.&lt;br /&gt;
    Incompatible update data.&lt;br /&gt;
&lt;br /&gt;
Has anyone tried to flash this device using prism2_srec yet?&lt;br /&gt;
What bothers me is, that the upgrade is for many different parts of the combo card. Does anyone have an opinion on whether this could work?&lt;br /&gt;
&lt;br /&gt;
OK, I took the risk and successfully upgraded my station firmware, BUT when I tried to upgrade the primary firmware the system froze!!! The thinkpad won't start up with the miniPCI card inserted and all efforts to reflash it using the original DOS boot image failed!!!&lt;br /&gt;
&lt;br /&gt;
I'm quite sure the system freeze was not caused directly by prism2_srec, because I have noticed rare system freezes since I have been using my PCMCIA wireless card.&lt;br /&gt;
Anyway, if anyone should own a TP R32, I'd be glad if he could tell me the base address of the Wlan card, or it's PCI address.&lt;br /&gt;
&lt;br /&gt;
Thinkpad r32 owner here. I want to upgrade the firmware as well. If you need any information just send an email to haftbar[a]gmail.com [[User:Quickie|Quickie]] 02:12, 1 February 2006 (CET)&lt;br /&gt;
&lt;br /&gt;
==Reorganization suggestion==&lt;br /&gt;
The Downloads section is rather long. Would it be an idea to put it on a separate, new page (say: BIOS_Downloads) and link to that new page from this page?&lt;br /&gt;
&lt;br /&gt;
[[User:Pebolle|Paul Bolle]] 21:27, 15 Oct 2005 (CEST)&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I agree with this suggestion.&lt;br /&gt;
&lt;br /&gt;
== Upgrading BIOS and Embedded Control Program from Win XP ==&lt;br /&gt;
&lt;br /&gt;
I'm trying to upgrade the BIOS and Embedded Controller Program from Windows XP following the instructions on the Lenovo website. The problem is the instructions are not very clear about this. The instructions basically state that I must upgrade them at the same time because the Control Program does not work with the older BIOS and the BIOS does not work with the older Control Program. They also state that I should upgrade the Control Program first. &lt;br /&gt;
&lt;br /&gt;
But that means I must boot into XP after having upgraded the Control Program but with the older BIOS in order to then update the BIOS. But if this works then they are actually compatible and there's a contradiction. Am I missing something? I just want to make sure I don't end up with a non-functioning unit.&lt;br /&gt;
&lt;br /&gt;
I have an X23 and want the latest BIOS (v 1.32) and Control Program (v 1.30). &lt;br /&gt;
&lt;br /&gt;
Maybe there should be a note about this in the article? Or maybe I'm the only one who is this stupid :)&lt;br /&gt;
&lt;br /&gt;
Update: I talked to Lenovo support. The situation apparently is that though the description says that the newer control program is not compatible with the older BIOS, they are not so incompatible as to cause the machine to stop working so it is actually possible to use incompatible versions of BIOS and control program. In fact according to the support person it makes no difference if the BIOS is upgraded before the control program or vice versa. So I upgraded the control program using the executable running in Windows XP, which rebooted the computer to perform the upgrade and then I booted Windows again to upgrade the BIOS in the same manner and it all worked fine. If anyone reading this finds it useful maybe you can put it in the article? Or if you find it superfluous just delete this section.&lt;br /&gt;
&lt;br /&gt;
--[[User:xphinx|xphinx]] 12 March 2007&lt;br /&gt;
&lt;br /&gt;
I have an X22 with BIOS version 1.21 and Embedded Controller version 1.17 and using the steps described by you, I succesfully updated my bios to the lastest versions from WindowsXP (BIOS v1.32 / EC v1.30)&lt;br /&gt;
Thanks!&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade for T21 with T20 BIOS ==&lt;br /&gt;
&lt;br /&gt;
Hi, I bought a used T21 recently (type 2647-8AU), and would like to update the BIOS to the latest version, but there's a problem: this T21 appears to have a T20 BIOS (IYET50WW, a/k/a T20 BIOS version 1.11).  When I try updating this BIOS using one of IBM's T21 updaters - I tried KZET34WW/v1.16 (the latest one) and KZET16WW/v1.01 (the earliest one) - I get the following message:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
''The diskette in the default drive will not run on this system. Your system is now locked. To restart your system, press Ctrl+Alt+Del.''&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
I suspect this message appears because the existing BIOS is a T20 BIOS.&lt;br /&gt;
&lt;br /&gt;
There would appear to be two options: either use the most recent T20 updater (IYET61WW, a/k/a T20 v1.22), or find a way to defeat the block in the KZET34WW/v1.16 T21 updater.  Obviously either option is risky in the absence of more information and/or detective work.  And I don't know enough about T2x-series hardware to hazard a guess (i.e., were early T21s just T20s with a speed bump, did some T21s get T20 BIOSes by mistake due to factory error, or are the T20 and T21 similar enough that it doesn't matter whether a T20 or T21 BIOS is used).&lt;br /&gt;
&lt;br /&gt;
Some relevant data gleaned from the stickers on the case bottom and the current BIOS:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
* '''Type:''' 2647-8AU (T21 with 800-MHz processor)&lt;br /&gt;
* '''S/N:''' 78-0GL1Z (zero-G-L-one-zed)&lt;br /&gt;
* '''Manufacture date:''' 03/2001&lt;br /&gt;
* '''BIOS version:''' IYET50WW (T20 BIOS v1.11)&lt;br /&gt;
* '''System unit S/N:''' (appears to be blank)&lt;br /&gt;
* '''System board S/N:''' J1HHS15CL5C&lt;br /&gt;
* '''System board P/N:''' 08K3747 (printed on motherboard)&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Thanks for any help anyone can provide.&lt;br /&gt;
&lt;br /&gt;
-Linux Spice&lt;br /&gt;
&lt;br /&gt;
P.S. At first I thought this might be a Frankenstein ThinkPad with a T21 case and a T20 logic board - I did buy it used, after all - but it does have an 800-MHz processor, which was never an option for the T20 (both the BIOS and Linux report it as such), and all the other equipment checks out (except for the hard drive, which was replaced with a 40-GB model).&lt;br /&gt;
&lt;br /&gt;
== BIOS format ==&lt;br /&gt;
&lt;br /&gt;
Not sure if this is the right place, but...&lt;br /&gt;
Does anybody know what the formats for the various files are in the bios package (or, even better, the bios.bak file that gets dumped on your disk before updating)? I'm getting progressivel lower and lower level in figuring out just what happens when the computer boots, and the BIOS is the last step... (BTW, I have an x60s)&lt;br /&gt;
&lt;br /&gt;
-- Unknown&lt;br /&gt;
&lt;br /&gt;
Yes.  It is a binary dump.  Sometimes, there is junk in the start of the file.  This should be data enough for you to figure out what you need.&lt;br /&gt;
&lt;br /&gt;
--[[User:Hmh|hmh]] 13:30, 26 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS update gone bad ==&lt;br /&gt;
&lt;br /&gt;
I tried to flash my [[:Category:600|ThinkPad 600]]'s bios with catastrophalic outcome; now the machine is unable to boot. I, being overly stupid and too self-confident, ignored all warnings about the media containing the bios image not being write-protected (I used one partition of the disk, in which I had installed FreeDOS). During the updating process, the machine started to write screens full of random characters in cyan coloured background. At that point I knew it was b0rked. I asked my friend about what to do now, he said I could open the machine up, locate the bios chip and use EPROM programmer/burner to write the bios image to the chip. He also said that because my machine is very old, there are probably not safeguards like dual bios or emergency bios update from floppy disk on boot. He continued by saying that the bios update file images from IBM/Lenovo website might not be actual , &amp;quot;pure&amp;quot; binaries which could be burned directly to the chip, instead they may contain some vendor-specific checksums which must be taken into account. In ThinkWiki there seems to be no page about bios flashing gone bad and restoring the machine to working condition. Or is there? I really need your help with this; I think I'm able to locate the bios, take it off and find a working EPROM burner, but where can I get a clean BIOS image without the vendor checksums? I'd be grateful for any references.&lt;br /&gt;
&lt;br /&gt;
--[[User:Usv|Usv]] 12:45, 31 March 2007 (CEST)&lt;br /&gt;
&lt;br /&gt;
== Upgrading BIOS from USB flash drive ==&lt;br /&gt;
&lt;br /&gt;
I flashed my Thinkpad X41 succesfully with 2.09 BIOS using bootable USB flash drive with DOS 6.22 system files. (I guess Freedos would work aswell). I had such key laying around so I can't help you with making one (i used windows HP USB key format utility to make it long long time ago) &lt;br /&gt;
Everything is quite simple once you have USB key and are able to boot DOS from it.&lt;br /&gt;
&lt;br /&gt;
I downloaded the non-diskette ThinkPad BIOS update utility (74uj15us.exe) from lenovo support site and extrated disk image from it using cabextract:&lt;br /&gt;
   {{cmduser|cabextract -F &amp;quot;*.IMG&amp;quot; 74uj15us.exe}}&lt;br /&gt;
&lt;br /&gt;
I mounted the image file (74UJ15US.IMG):&lt;br /&gt;
   {{cmdroot|mkdir /tmp/mnt}}&lt;br /&gt;
   {{cmdroot|mount -loop o 74UJ15US.IMG /tmp/mnt}}&lt;br /&gt;
&lt;br /&gt;
I mounted the usb key and made a directory for ibm flash utility files under it:&lt;br /&gt;
   {{cmdroot|mount /dev/sdb1 /mnt/usbflash}}&lt;br /&gt;
   {{cmdroot|mkdir /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
I copied the contents of /tmp/mnt to /mnt/usbflash/ibm:&lt;br /&gt;
   {{cmdroot|cp /tmp/mnt/*.* /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
Then I unmounted the USB stick and rebooted from it to DOS (F12 during boot -&amp;gt; USB HDD).&amp;lt;br&amp;gt; &lt;br /&gt;
In the DOS Prompt:&amp;lt;br&amp;gt;&lt;br /&gt;
   C:\cd ibm&lt;br /&gt;
   C:\IBM\flash2 /U&lt;br /&gt;
I waited for about 1 minute, then my thinkpad made two beeps to signal that the flashing was complete.&lt;br /&gt;
&lt;br /&gt;
PS. Because lacking reliable guide on how to make bootable DOS USB stick for ThinkPads I decided to leave this into discussion section. Feel free to move all the necessary stuff into the BIOS upgrade article if you know/figure out how to make bootable DOS USB stick in linux.   &lt;br /&gt;
--[[User:ladoga|ladoga]] 04:56 17 Apr 2007&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29372</id>
		<title>Talk:BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29372"/>
		<updated>2007-04-17T02:46:25Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* Upgraded BIOS using USB flash drive */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Dead link == &lt;br /&gt;
&lt;br /&gt;
The link to the FreeDOS floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip), which is needed to upgrade the BIOS from a CD, is dead. Is the information still valid? And is there a different source for the floppy image? [[User:Jamesavery|Jamesavery]] 05:49, 18 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using WINE ==&lt;br /&gt;
&lt;br /&gt;
Does anyone think this would be possible? [[User:Mcalwell|Mcalwell]] 08:58, 28 January 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
: No this is not possible. [[User:Mcalwell|Mcalwell]] 16:01, 12 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade without battery ==&lt;br /&gt;
&lt;br /&gt;
Concerning the known problem with 600 series with batteries dead too soon, it is impossible to upgrade the bios without the battery because the original ibm update program doesn't allow this. I bought an old 600E without the battery. There was one workaround, but i think for the older releases of the bios, where you just extracted files and upgraded manualy, bypassing the ibm install program. The page that describes this (i lost the link) has a list of different files, that the ones found in current release so i never did figure out what to do? I would like to upgrade because i have really old bios, where ACPI doesn't cooperate so well with the operating system, either windows or linux.&lt;br /&gt;
&lt;br /&gt;
If somebody finds a workaround please help. Thanks&lt;br /&gt;
&lt;br /&gt;
//Edit&lt;br /&gt;
&lt;br /&gt;
I've found the page on Vim's bios upgrade forum.. I don't know if it exactly for my model, since the files differ.. '''Is it possible, to upgrade bios in linux without the battery?'''&lt;br /&gt;
&lt;br /&gt;
''I have found a working solution WOW on the other forum: &lt;br /&gt;
&lt;br /&gt;
*** This is NOT a safe way to update the bios (disclaimer) *** &lt;br /&gt;
&lt;br /&gt;
* First you need to make a BIOS update floppy disk (from the bios file from IBM - place disk in a: drive, run app and answer Y to the agreement) and then format another disk by right clicking on A: - format - make system bootdisk (assuming you have another machine spare) &lt;br /&gt;
&lt;br /&gt;
* Copy all the files from the IBM Boot disk - in my case &lt;br /&gt;
$0029000.fl1 &lt;br /&gt;
$0029000.fl2 &lt;br /&gt;
FLASH2.EXE &lt;br /&gt;
PROD.DAT &lt;br /&gt;
UPDTFLSH.EXE &lt;br /&gt;
updtrom.exe &lt;br /&gt;
USERINT.EXE &lt;br /&gt;
UTILINFO.EXE &lt;br /&gt;
to the other clean bootdisk. &lt;br /&gt;
&lt;br /&gt;
* Ensure that there is no config.sys and autoexec.bat so it just runs straight into DOS. &lt;br /&gt;
&lt;br /&gt;
* Place the disk into the Laptop, reboot and allow the machine to load via the floppy &lt;br /&gt;
&lt;br /&gt;
* At the command prompt, type &amp;quot;FLASH2.EXE /U&amp;quot; with no quotes then press enter. &lt;br /&gt;
&lt;br /&gt;
The program will automatically search for the files *.FL1 &amp;amp; *.FL2 and load the bios first then the platform file. &lt;br /&gt;
&lt;br /&gt;
The program will automatically update and perform erasing on the rom and then finish with &amp;quot;Update complete&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
* Now reboot. &lt;br /&gt;
&lt;br /&gt;
* Hold F1 down as you turn the laptop back on and go into Easy Setup under &amp;quot;Config&amp;quot; click on Initialize to ensure defaults and settings are error free. &lt;br /&gt;
&lt;br /&gt;
* Save and exit...''&lt;br /&gt;
&lt;br /&gt;
// EDIT&lt;br /&gt;
&lt;br /&gt;
This worked on my machine.. I make no guarantees it will work on others.&lt;br /&gt;
&lt;br /&gt;
The above procedure did not work on my T23 using the 1.20 bios; it kept returning error 14 (Low Battery). However, following those instructions and running &amp;quot;qkflash&amp;quot; rather than flash2 did work for the main bios, and later for the embedded controller.&lt;br /&gt;
&lt;br /&gt;
--grythumn&lt;br /&gt;
&lt;br /&gt;
== Bios upgrade &amp;amp; hidden partition ==&lt;br /&gt;
&lt;br /&gt;
I have disabled the hidden partition to make more space for linux (24G). I still have Windows on the 14G partition. Is it safe to upgrade the BIOS without the hidden partition? I want to get a newer BIOS to fix the annoying fan issue. Thanks&lt;br /&gt;
&lt;br /&gt;
- yes don't worry about it. bios upgrades have nothing to do with whats inside the harddrive.&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade over PXE ==&lt;br /&gt;
&lt;br /&gt;
Hi,&lt;br /&gt;
&lt;br /&gt;
I have a Thinkpad X20 with a very early BIOS and Embedded Controller Program which I'd like to update. Currently, the only feasible way of doing this is over the network using PXE. I already have a fully functional PXE server using SYSLINUX, and have so far been able to boot the BIOS diskette image using MEMDISK, although I have not attempted to flash anything yet due to the warnings given on the page. Is there any safe way I can update both the Controller Program and the BIOS in the same session over the network in this manner? If not, what other methods would be suitable? I have a USB CD-ROM drive and could probably get hold of a USB floppy drive.&lt;br /&gt;
&lt;br /&gt;
Thanks.&lt;br /&gt;
&lt;br /&gt;
Update: I ended up burning CDs as described and successfully updated everything. I'd still like to know if there is a way I could do it entirely over the network, though.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== RE: grub initrd ==&lt;br /&gt;
&lt;br /&gt;
&amp;quot;Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
0) Interesting suggestion. Might be better of in its own section.&lt;br /&gt;
&lt;br /&gt;
1) Could you please elaborate?&lt;br /&gt;
&lt;br /&gt;
2) My first guess (pending your elaboration) would be to &amp;quot;chainload&amp;quot; the first block of the diskimage using the grub commandline, like:&lt;br /&gt;
   blocklist (''path'')/''to''/''diskimage''&lt;br /&gt;
   chainloader ''blockvalue''+1&lt;br /&gt;
&lt;br /&gt;
But that's just a guess!&lt;br /&gt;
&lt;br /&gt;
[[user:Pebolle|Paul Bolle]] Fri Jul 15 12:20:47 CEST 2005&lt;br /&gt;
&lt;br /&gt;
== bios/controller update sequence ==&lt;br /&gt;
&lt;br /&gt;
The article says:&lt;br /&gt;
&amp;quot;If you go through the readme's on the IBM site they'll cleary state that you must update the Control Program first, then imediately update the BIOS&amp;quot;&lt;br /&gt;
&lt;br /&gt;
When I look at the IBM udpate instructions for the T23, it says:&lt;br /&gt;
&amp;quot;If you need to update the BIOS as well as the Embedded Controller Program, update the BIOS first.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comments?&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I would first contact IBM for clarification, but you should probably be following instructions specific to your model.&lt;br /&gt;
&lt;br /&gt;
&amp;gt;&amp;gt; I did it following IBM's instructions to upgrade the BIOS first. Everything worked out great!&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Intel minipci combo card ==&lt;br /&gt;
&lt;br /&gt;
I just purchased an [[Intel 10/100 Ethernet Mini-PCI Adapter with 56K Modem]] that has an ancient (2.0.6) firmware version.  I Downloaded the update file intlbtag.EXE but cabextract was unable to find any cabfiles inside it.  I tried running the program via wine and that didn't work either.&lt;br /&gt;
&lt;br /&gt;
Finally I ran the program on a windows machine and created a boot floppy.  Then I went through the the process of converting the floppy to a bootable cd via linux and that worked like a charm.  The cd successfully updated the minipc card's firmware.&lt;br /&gt;
&lt;br /&gt;
Everything worked but I ended up needing a windows box to do it.  Could this have been done without windows?&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Wireless LAN MiniPCI COMBO Card using prism2_srec ==&lt;br /&gt;
&lt;br /&gt;
The appropriate firmware installation program for the wlan card in my R32 can be extracted using cabextract as described in the article. It contains (besides some installation programs) a disk image (1awg06ww.IMG) that seems to be a simple dos boot disk. This image contains 3 .hex files (id010001.hex, pk010100.hex, sf010402.hex) that are recognized by prism2_srec to be &amp;quot;srec&amp;quot;-files. Trying to load them to RAM yields:&lt;br /&gt;
&lt;br /&gt;
    {{cmdroot|prism2_srec -v -r wlan0 sf010402.hex}}&lt;br /&gt;
    S3 CRC-16 generation record: start=0x007E1800 len=65642 prog=1&lt;br /&gt;
    Start address 0x00000000&lt;br /&gt;
    srec summary for sf010402.hex&lt;br /&gt;
    Component: 0x001f 1.4.2 (station firmware)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    role=Supplier variant=2 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    role=Actor    variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Wireless LAN card information:&lt;br /&gt;
    Components:&lt;br /&gt;
    NICID: 0x8013 v1.0.0&lt;br /&gt;
    PRIID: 0x0015 v1.0.7&lt;br /&gt;
    STAID: 0x001f v1.3.6&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    PRI role=Supplier variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    PRI role=Supplier variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    PRI role=Supplier variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    STA role=Supplier variant=1 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    PRI role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    This image is not meant to be downloaded to volatile memory.&lt;br /&gt;
    Incompatible update data.&lt;br /&gt;
&lt;br /&gt;
Has anyone tried to flash this device using prism2_srec yet?&lt;br /&gt;
What bothers me is, that the upgrade is for many different parts of the combo card. Does anyone have an opinion on whether this could work?&lt;br /&gt;
&lt;br /&gt;
OK, I took the risk and successfully upgraded my station firmware, BUT when I tried to upgrade the primary firmware the system froze!!! The thinkpad won't start up with the miniPCI card inserted and all efforts to reflash it using the original DOS boot image failed!!!&lt;br /&gt;
&lt;br /&gt;
I'm quite sure the system freeze was not caused directly by prism2_srec, because I have noticed rare system freezes since I have been using my PCMCIA wireless card.&lt;br /&gt;
Anyway, if anyone should own a TP R32, I'd be glad if he could tell me the base address of the Wlan card, or it's PCI address.&lt;br /&gt;
&lt;br /&gt;
Thinkpad r32 owner here. I want to upgrade the firmware as well. If you need any information just send an email to haftbar[a]gmail.com [[User:Quickie|Quickie]] 02:12, 1 February 2006 (CET)&lt;br /&gt;
&lt;br /&gt;
==Reorganization suggestion==&lt;br /&gt;
The Downloads section is rather long. Would it be an idea to put it on a separate, new page (say: BIOS_Downloads) and link to that new page from this page?&lt;br /&gt;
&lt;br /&gt;
[[User:Pebolle|Paul Bolle]] 21:27, 15 Oct 2005 (CEST)&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I agree with this suggestion.&lt;br /&gt;
&lt;br /&gt;
== Upgrading BIOS and Embedded Control Program from Win XP ==&lt;br /&gt;
&lt;br /&gt;
I'm trying to upgrade the BIOS and Embedded Controller Program from Windows XP following the instructions on the Lenovo website. The problem is the instructions are not very clear about this. The instructions basically state that I must upgrade them at the same time because the Control Program does not work with the older BIOS and the BIOS does not work with the older Control Program. They also state that I should upgrade the Control Program first. &lt;br /&gt;
&lt;br /&gt;
But that means I must boot into XP after having upgraded the Control Program but with the older BIOS in order to then update the BIOS. But if this works then they are actually compatible and there's a contradiction. Am I missing something? I just want to make sure I don't end up with a non-functioning unit.&lt;br /&gt;
&lt;br /&gt;
I have an X23 and want the latest BIOS (v 1.32) and Control Program (v 1.30). &lt;br /&gt;
&lt;br /&gt;
Maybe there should be a note about this in the article? Or maybe I'm the only one who is this stupid :)&lt;br /&gt;
&lt;br /&gt;
Update: I talked to Lenovo support. The situation apparently is that though the description says that the newer control program is not compatible with the older BIOS, they are not so incompatible as to cause the machine to stop working so it is actually possible to use incompatible versions of BIOS and control program. In fact according to the support person it makes no difference if the BIOS is upgraded before the control program or vice versa. So I upgraded the control program using the executable running in Windows XP, which rebooted the computer to perform the upgrade and then I booted Windows again to upgrade the BIOS in the same manner and it all worked fine. If anyone reading this finds it useful maybe you can put it in the article? Or if you find it superfluous just delete this section.&lt;br /&gt;
&lt;br /&gt;
--[[User:xphinx|xphinx]] 12 March 2007&lt;br /&gt;
&lt;br /&gt;
I have an X22 with BIOS version 1.21 and Embedded Controller version 1.17 and using the steps described by you, I succesfully updated my bios to the lastest versions from WindowsXP (BIOS v1.32 / EC v1.30)&lt;br /&gt;
Thanks!&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade for T21 with T20 BIOS ==&lt;br /&gt;
&lt;br /&gt;
Hi, I bought a used T21 recently (type 2647-8AU), and would like to update the BIOS to the latest version, but there's a problem: this T21 appears to have a T20 BIOS (IYET50WW, a/k/a T20 BIOS version 1.11).  When I try updating this BIOS using one of IBM's T21 updaters - I tried KZET34WW/v1.16 (the latest one) and KZET16WW/v1.01 (the earliest one) - I get the following message:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
''The diskette in the default drive will not run on this system. Your system is now locked. To restart your system, press Ctrl+Alt+Del.''&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
I suspect this message appears because the existing BIOS is a T20 BIOS.&lt;br /&gt;
&lt;br /&gt;
There would appear to be two options: either use the most recent T20 updater (IYET61WW, a/k/a T20 v1.22), or find a way to defeat the block in the KZET34WW/v1.16 T21 updater.  Obviously either option is risky in the absence of more information and/or detective work.  And I don't know enough about T2x-series hardware to hazard a guess (i.e., were early T21s just T20s with a speed bump, did some T21s get T20 BIOSes by mistake due to factory error, or are the T20 and T21 similar enough that it doesn't matter whether a T20 or T21 BIOS is used).&lt;br /&gt;
&lt;br /&gt;
Some relevant data gleaned from the stickers on the case bottom and the current BIOS:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
* '''Type:''' 2647-8AU (T21 with 800-MHz processor)&lt;br /&gt;
* '''S/N:''' 78-0GL1Z (zero-G-L-one-zed)&lt;br /&gt;
* '''Manufacture date:''' 03/2001&lt;br /&gt;
* '''BIOS version:''' IYET50WW (T20 BIOS v1.11)&lt;br /&gt;
* '''System unit S/N:''' (appears to be blank)&lt;br /&gt;
* '''System board S/N:''' J1HHS15CL5C&lt;br /&gt;
* '''System board P/N:''' 08K3747 (printed on motherboard)&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Thanks for any help anyone can provide.&lt;br /&gt;
&lt;br /&gt;
-Linux Spice&lt;br /&gt;
&lt;br /&gt;
P.S. At first I thought this might be a Frankenstein ThinkPad with a T21 case and a T20 logic board - I did buy it used, after all - but it does have an 800-MHz processor, which was never an option for the T20 (both the BIOS and Linux report it as such), and all the other equipment checks out (except for the hard drive, which was replaced with a 40-GB model).&lt;br /&gt;
&lt;br /&gt;
== BIOS format ==&lt;br /&gt;
&lt;br /&gt;
Not sure if this is the right place, but...&lt;br /&gt;
Does anybody know what the formats for the various files are in the bios package (or, even better, the bios.bak file that gets dumped on your disk before updating)? I'm getting progressivel lower and lower level in figuring out just what happens when the computer boots, and the BIOS is the last step... (BTW, I have an x60s)&lt;br /&gt;
&lt;br /&gt;
-- Unknown&lt;br /&gt;
&lt;br /&gt;
Yes.  It is a binary dump.  Sometimes, there is junk in the start of the file.  This should be data enough for you to figure out what you need.&lt;br /&gt;
&lt;br /&gt;
--[[User:Hmh|hmh]] 13:30, 26 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS update gone bad ==&lt;br /&gt;
&lt;br /&gt;
I tried to flash my [[:Category:600|ThinkPad 600]]'s bios with catastrophalic outcome; now the machine is unable to boot. I, being overly stupid and too self-confident, ignored all warnings about the media containing the bios image not being write-protected (I used one partition of the disk, in which I had installed FreeDOS). During the updating process, the machine started to write screens full of random characters in cyan coloured background. At that point I knew it was b0rked. I asked my friend about what to do now, he said I could open the machine up, locate the bios chip and use EPROM programmer/burner to write the bios image to the chip. He also said that because my machine is very old, there are probably not safeguards like dual bios or emergency bios update from floppy disk on boot. He continued by saying that the bios update file images from IBM/Lenovo website might not be actual , &amp;quot;pure&amp;quot; binaries which could be burned directly to the chip, instead they may contain some vendor-specific checksums which must be taken into account. In ThinkWiki there seems to be no page about bios flashing gone bad and restoring the machine to working condition. Or is there? I really need your help with this; I think I'm able to locate the bios, take it off and find a working EPROM burner, but where can I get a clean BIOS image without the vendor checksums? I'd be grateful for any references.&lt;br /&gt;
&lt;br /&gt;
--[[User:Usv|Usv]] 12:45, 31 March 2007 (CEST)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrage using USB flash drive ==&lt;br /&gt;
&lt;br /&gt;
I flashed my Thinkpad X41 succesfully with 2.09 BIOS using bootable USB flash drive with DOS 6.22 system files. (I guess Freedos would work aswell). I had such key laying around so I can't help you with making one (i used windows HP USB key format utility to make it long long time ago) &lt;br /&gt;
Everything is quite simple once you have USB key and are able to boot DOS from it.&lt;br /&gt;
&lt;br /&gt;
I downloaded the non-diskette ThinkPad BIOS update utility (74uj15us.exe) from lenovo support site and extrated disk image from it using cabextract:&lt;br /&gt;
   {{cmduser|cabextract -F &amp;quot;*.IMG&amp;quot; 74uj15us.exe}}&lt;br /&gt;
&lt;br /&gt;
I mounted the image file (74UJ15US.IMG):&lt;br /&gt;
   {{cmdroot|mkdir /tmp/mnt}}&lt;br /&gt;
   {{cmdroot|mount -loop o 74UJ15US.IMG /tmp/mnt}}&lt;br /&gt;
&lt;br /&gt;
I mounted the usb key and made a directory for ibm flash utility files under it:&lt;br /&gt;
   {{cmdroot|mount /dev/sdb1 /mnt/usbflash}}&lt;br /&gt;
   {{cmdroot|mkdir /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
I copied the contents of /tmp/mnt to /mnt/usbflash/ibm:&lt;br /&gt;
   {{cmdroot|cp /tmp/mnt/*.* /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
Then I unmounted the USB stick and rebooted from it to DOS (F12 during boot -&amp;gt; USB HDD).&amp;lt;br&amp;gt; &lt;br /&gt;
In the DOS Prompt:&amp;lt;br&amp;gt;&lt;br /&gt;
   C:\cd ibm&lt;br /&gt;
   C:\IBM\flash2 /U&lt;br /&gt;
I waited for about 1 minute, then my thinkpad made two beeps to signal that the flashing was complete.&lt;br /&gt;
&lt;br /&gt;
PS. Because lacking reliable guide on how to make bootable DOS USB stick for ThinkPads I decided to leave this into discussion section. Feel free to move all the necessary stuff into the BIOS upgrade article if you know/figure out how to make bootable DOS USB stick in linux.   &lt;br /&gt;
--[[User:ladoga|ladoga]] 04:56 17 Apr 2007&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29371</id>
		<title>Talk:BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29371"/>
		<updated>2007-04-17T02:43:35Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* Upgraded BIOS using USB flash drive */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Dead link == &lt;br /&gt;
&lt;br /&gt;
The link to the FreeDOS floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip), which is needed to upgrade the BIOS from a CD, is dead. Is the information still valid? And is there a different source for the floppy image? [[User:Jamesavery|Jamesavery]] 05:49, 18 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using WINE ==&lt;br /&gt;
&lt;br /&gt;
Does anyone think this would be possible? [[User:Mcalwell|Mcalwell]] 08:58, 28 January 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
: No this is not possible. [[User:Mcalwell|Mcalwell]] 16:01, 12 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade without battery ==&lt;br /&gt;
&lt;br /&gt;
Concerning the known problem with 600 series with batteries dead too soon, it is impossible to upgrade the bios without the battery because the original ibm update program doesn't allow this. I bought an old 600E without the battery. There was one workaround, but i think for the older releases of the bios, where you just extracted files and upgraded manualy, bypassing the ibm install program. The page that describes this (i lost the link) has a list of different files, that the ones found in current release so i never did figure out what to do? I would like to upgrade because i have really old bios, where ACPI doesn't cooperate so well with the operating system, either windows or linux.&lt;br /&gt;
&lt;br /&gt;
If somebody finds a workaround please help. Thanks&lt;br /&gt;
&lt;br /&gt;
//Edit&lt;br /&gt;
&lt;br /&gt;
I've found the page on Vim's bios upgrade forum.. I don't know if it exactly for my model, since the files differ.. '''Is it possible, to upgrade bios in linux without the battery?'''&lt;br /&gt;
&lt;br /&gt;
''I have found a working solution WOW on the other forum: &lt;br /&gt;
&lt;br /&gt;
*** This is NOT a safe way to update the bios (disclaimer) *** &lt;br /&gt;
&lt;br /&gt;
* First you need to make a BIOS update floppy disk (from the bios file from IBM - place disk in a: drive, run app and answer Y to the agreement) and then format another disk by right clicking on A: - format - make system bootdisk (assuming you have another machine spare) &lt;br /&gt;
&lt;br /&gt;
* Copy all the files from the IBM Boot disk - in my case &lt;br /&gt;
$0029000.fl1 &lt;br /&gt;
$0029000.fl2 &lt;br /&gt;
FLASH2.EXE &lt;br /&gt;
PROD.DAT &lt;br /&gt;
UPDTFLSH.EXE &lt;br /&gt;
updtrom.exe &lt;br /&gt;
USERINT.EXE &lt;br /&gt;
UTILINFO.EXE &lt;br /&gt;
to the other clean bootdisk. &lt;br /&gt;
&lt;br /&gt;
* Ensure that there is no config.sys and autoexec.bat so it just runs straight into DOS. &lt;br /&gt;
&lt;br /&gt;
* Place the disk into the Laptop, reboot and allow the machine to load via the floppy &lt;br /&gt;
&lt;br /&gt;
* At the command prompt, type &amp;quot;FLASH2.EXE /U&amp;quot; with no quotes then press enter. &lt;br /&gt;
&lt;br /&gt;
The program will automatically search for the files *.FL1 &amp;amp; *.FL2 and load the bios first then the platform file. &lt;br /&gt;
&lt;br /&gt;
The program will automatically update and perform erasing on the rom and then finish with &amp;quot;Update complete&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
* Now reboot. &lt;br /&gt;
&lt;br /&gt;
* Hold F1 down as you turn the laptop back on and go into Easy Setup under &amp;quot;Config&amp;quot; click on Initialize to ensure defaults and settings are error free. &lt;br /&gt;
&lt;br /&gt;
* Save and exit...''&lt;br /&gt;
&lt;br /&gt;
// EDIT&lt;br /&gt;
&lt;br /&gt;
This worked on my machine.. I make no guarantees it will work on others.&lt;br /&gt;
&lt;br /&gt;
The above procedure did not work on my T23 using the 1.20 bios; it kept returning error 14 (Low Battery). However, following those instructions and running &amp;quot;qkflash&amp;quot; rather than flash2 did work for the main bios, and later for the embedded controller.&lt;br /&gt;
&lt;br /&gt;
--grythumn&lt;br /&gt;
&lt;br /&gt;
== Bios upgrade &amp;amp; hidden partition ==&lt;br /&gt;
&lt;br /&gt;
I have disabled the hidden partition to make more space for linux (24G). I still have Windows on the 14G partition. Is it safe to upgrade the BIOS without the hidden partition? I want to get a newer BIOS to fix the annoying fan issue. Thanks&lt;br /&gt;
&lt;br /&gt;
- yes don't worry about it. bios upgrades have nothing to do with whats inside the harddrive.&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade over PXE ==&lt;br /&gt;
&lt;br /&gt;
Hi,&lt;br /&gt;
&lt;br /&gt;
I have a Thinkpad X20 with a very early BIOS and Embedded Controller Program which I'd like to update. Currently, the only feasible way of doing this is over the network using PXE. I already have a fully functional PXE server using SYSLINUX, and have so far been able to boot the BIOS diskette image using MEMDISK, although I have not attempted to flash anything yet due to the warnings given on the page. Is there any safe way I can update both the Controller Program and the BIOS in the same session over the network in this manner? If not, what other methods would be suitable? I have a USB CD-ROM drive and could probably get hold of a USB floppy drive.&lt;br /&gt;
&lt;br /&gt;
Thanks.&lt;br /&gt;
&lt;br /&gt;
Update: I ended up burning CDs as described and successfully updated everything. I'd still like to know if there is a way I could do it entirely over the network, though.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== RE: grub initrd ==&lt;br /&gt;
&lt;br /&gt;
&amp;quot;Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
0) Interesting suggestion. Might be better of in its own section.&lt;br /&gt;
&lt;br /&gt;
1) Could you please elaborate?&lt;br /&gt;
&lt;br /&gt;
2) My first guess (pending your elaboration) would be to &amp;quot;chainload&amp;quot; the first block of the diskimage using the grub commandline, like:&lt;br /&gt;
   blocklist (''path'')/''to''/''diskimage''&lt;br /&gt;
   chainloader ''blockvalue''+1&lt;br /&gt;
&lt;br /&gt;
But that's just a guess!&lt;br /&gt;
&lt;br /&gt;
[[user:Pebolle|Paul Bolle]] Fri Jul 15 12:20:47 CEST 2005&lt;br /&gt;
&lt;br /&gt;
== bios/controller update sequence ==&lt;br /&gt;
&lt;br /&gt;
The article says:&lt;br /&gt;
&amp;quot;If you go through the readme's on the IBM site they'll cleary state that you must update the Control Program first, then imediately update the BIOS&amp;quot;&lt;br /&gt;
&lt;br /&gt;
When I look at the IBM udpate instructions for the T23, it says:&lt;br /&gt;
&amp;quot;If you need to update the BIOS as well as the Embedded Controller Program, update the BIOS first.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comments?&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I would first contact IBM for clarification, but you should probably be following instructions specific to your model.&lt;br /&gt;
&lt;br /&gt;
&amp;gt;&amp;gt; I did it following IBM's instructions to upgrade the BIOS first. Everything worked out great!&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Intel minipci combo card ==&lt;br /&gt;
&lt;br /&gt;
I just purchased an [[Intel 10/100 Ethernet Mini-PCI Adapter with 56K Modem]] that has an ancient (2.0.6) firmware version.  I Downloaded the update file intlbtag.EXE but cabextract was unable to find any cabfiles inside it.  I tried running the program via wine and that didn't work either.&lt;br /&gt;
&lt;br /&gt;
Finally I ran the program on a windows machine and created a boot floppy.  Then I went through the the process of converting the floppy to a bootable cd via linux and that worked like a charm.  The cd successfully updated the minipc card's firmware.&lt;br /&gt;
&lt;br /&gt;
Everything worked but I ended up needing a windows box to do it.  Could this have been done without windows?&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Wireless LAN MiniPCI COMBO Card using prism2_srec ==&lt;br /&gt;
&lt;br /&gt;
The appropriate firmware installation program for the wlan card in my R32 can be extracted using cabextract as described in the article. It contains (besides some installation programs) a disk image (1awg06ww.IMG) that seems to be a simple dos boot disk. This image contains 3 .hex files (id010001.hex, pk010100.hex, sf010402.hex) that are recognized by prism2_srec to be &amp;quot;srec&amp;quot;-files. Trying to load them to RAM yields:&lt;br /&gt;
&lt;br /&gt;
    {{cmdroot|prism2_srec -v -r wlan0 sf010402.hex}}&lt;br /&gt;
    S3 CRC-16 generation record: start=0x007E1800 len=65642 prog=1&lt;br /&gt;
    Start address 0x00000000&lt;br /&gt;
    srec summary for sf010402.hex&lt;br /&gt;
    Component: 0x001f 1.4.2 (station firmware)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    role=Supplier variant=2 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    role=Actor    variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Wireless LAN card information:&lt;br /&gt;
    Components:&lt;br /&gt;
    NICID: 0x8013 v1.0.0&lt;br /&gt;
    PRIID: 0x0015 v1.0.7&lt;br /&gt;
    STAID: 0x001f v1.3.6&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    PRI role=Supplier variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    PRI role=Supplier variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    PRI role=Supplier variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    STA role=Supplier variant=1 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    PRI role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    This image is not meant to be downloaded to volatile memory.&lt;br /&gt;
    Incompatible update data.&lt;br /&gt;
&lt;br /&gt;
Has anyone tried to flash this device using prism2_srec yet?&lt;br /&gt;
What bothers me is, that the upgrade is for many different parts of the combo card. Does anyone have an opinion on whether this could work?&lt;br /&gt;
&lt;br /&gt;
OK, I took the risk and successfully upgraded my station firmware, BUT when I tried to upgrade the primary firmware the system froze!!! The thinkpad won't start up with the miniPCI card inserted and all efforts to reflash it using the original DOS boot image failed!!!&lt;br /&gt;
&lt;br /&gt;
I'm quite sure the system freeze was not caused directly by prism2_srec, because I have noticed rare system freezes since I have been using my PCMCIA wireless card.&lt;br /&gt;
Anyway, if anyone should own a TP R32, I'd be glad if he could tell me the base address of the Wlan card, or it's PCI address.&lt;br /&gt;
&lt;br /&gt;
Thinkpad r32 owner here. I want to upgrade the firmware as well. If you need any information just send an email to haftbar[a]gmail.com [[User:Quickie|Quickie]] 02:12, 1 February 2006 (CET)&lt;br /&gt;
&lt;br /&gt;
==Reorganization suggestion==&lt;br /&gt;
The Downloads section is rather long. Would it be an idea to put it on a separate, new page (say: BIOS_Downloads) and link to that new page from this page?&lt;br /&gt;
&lt;br /&gt;
[[User:Pebolle|Paul Bolle]] 21:27, 15 Oct 2005 (CEST)&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I agree with this suggestion.&lt;br /&gt;
&lt;br /&gt;
== Upgrading BIOS and Embedded Control Program from Win XP ==&lt;br /&gt;
&lt;br /&gt;
I'm trying to upgrade the BIOS and Embedded Controller Program from Windows XP following the instructions on the Lenovo website. The problem is the instructions are not very clear about this. The instructions basically state that I must upgrade them at the same time because the Control Program does not work with the older BIOS and the BIOS does not work with the older Control Program. They also state that I should upgrade the Control Program first. &lt;br /&gt;
&lt;br /&gt;
But that means I must boot into XP after having upgraded the Control Program but with the older BIOS in order to then update the BIOS. But if this works then they are actually compatible and there's a contradiction. Am I missing something? I just want to make sure I don't end up with a non-functioning unit.&lt;br /&gt;
&lt;br /&gt;
I have an X23 and want the latest BIOS (v 1.32) and Control Program (v 1.30). &lt;br /&gt;
&lt;br /&gt;
Maybe there should be a note about this in the article? Or maybe I'm the only one who is this stupid :)&lt;br /&gt;
&lt;br /&gt;
Update: I talked to Lenovo support. The situation apparently is that though the description says that the newer control program is not compatible with the older BIOS, they are not so incompatible as to cause the machine to stop working so it is actually possible to use incompatible versions of BIOS and control program. In fact according to the support person it makes no difference if the BIOS is upgraded before the control program or vice versa. So I upgraded the control program using the executable running in Windows XP, which rebooted the computer to perform the upgrade and then I booted Windows again to upgrade the BIOS in the same manner and it all worked fine. If anyone reading this finds it useful maybe you can put it in the article? Or if you find it superfluous just delete this section.&lt;br /&gt;
&lt;br /&gt;
--[[User:xphinx|xphinx]] 12 March 2007&lt;br /&gt;
&lt;br /&gt;
I have an X22 with BIOS version 1.21 and Embedded Controller version 1.17 and using the steps described by you, I succesfully updated my bios to the lastest versions from WindowsXP (BIOS v1.32 / EC v1.30)&lt;br /&gt;
Thanks!&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade for T21 with T20 BIOS ==&lt;br /&gt;
&lt;br /&gt;
Hi, I bought a used T21 recently (type 2647-8AU), and would like to update the BIOS to the latest version, but there's a problem: this T21 appears to have a T20 BIOS (IYET50WW, a/k/a T20 BIOS version 1.11).  When I try updating this BIOS using one of IBM's T21 updaters - I tried KZET34WW/v1.16 (the latest one) and KZET16WW/v1.01 (the earliest one) - I get the following message:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
''The diskette in the default drive will not run on this system. Your system is now locked. To restart your system, press Ctrl+Alt+Del.''&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
I suspect this message appears because the existing BIOS is a T20 BIOS.&lt;br /&gt;
&lt;br /&gt;
There would appear to be two options: either use the most recent T20 updater (IYET61WW, a/k/a T20 v1.22), or find a way to defeat the block in the KZET34WW/v1.16 T21 updater.  Obviously either option is risky in the absence of more information and/or detective work.  And I don't know enough about T2x-series hardware to hazard a guess (i.e., were early T21s just T20s with a speed bump, did some T21s get T20 BIOSes by mistake due to factory error, or are the T20 and T21 similar enough that it doesn't matter whether a T20 or T21 BIOS is used).&lt;br /&gt;
&lt;br /&gt;
Some relevant data gleaned from the stickers on the case bottom and the current BIOS:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
* '''Type:''' 2647-8AU (T21 with 800-MHz processor)&lt;br /&gt;
* '''S/N:''' 78-0GL1Z (zero-G-L-one-zed)&lt;br /&gt;
* '''Manufacture date:''' 03/2001&lt;br /&gt;
* '''BIOS version:''' IYET50WW (T20 BIOS v1.11)&lt;br /&gt;
* '''System unit S/N:''' (appears to be blank)&lt;br /&gt;
* '''System board S/N:''' J1HHS15CL5C&lt;br /&gt;
* '''System board P/N:''' 08K3747 (printed on motherboard)&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Thanks for any help anyone can provide.&lt;br /&gt;
&lt;br /&gt;
-Linux Spice&lt;br /&gt;
&lt;br /&gt;
P.S. At first I thought this might be a Frankenstein ThinkPad with a T21 case and a T20 logic board - I did buy it used, after all - but it does have an 800-MHz processor, which was never an option for the T20 (both the BIOS and Linux report it as such), and all the other equipment checks out (except for the hard drive, which was replaced with a 40-GB model).&lt;br /&gt;
&lt;br /&gt;
== BIOS format ==&lt;br /&gt;
&lt;br /&gt;
Not sure if this is the right place, but...&lt;br /&gt;
Does anybody know what the formats for the various files are in the bios package (or, even better, the bios.bak file that gets dumped on your disk before updating)? I'm getting progressivel lower and lower level in figuring out just what happens when the computer boots, and the BIOS is the last step... (BTW, I have an x60s)&lt;br /&gt;
&lt;br /&gt;
-- Unknown&lt;br /&gt;
&lt;br /&gt;
Yes.  It is a binary dump.  Sometimes, there is junk in the start of the file.  This should be data enough for you to figure out what you need.&lt;br /&gt;
&lt;br /&gt;
--[[User:Hmh|hmh]] 13:30, 26 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS update gone bad ==&lt;br /&gt;
&lt;br /&gt;
I tried to flash my [[:Category:600|ThinkPad 600]]'s bios with catastrophalic outcome; now the machine is unable to boot. I, being overly stupid and too self-confident, ignored all warnings about the media containing the bios image not being write-protected (I used one partition of the disk, in which I had installed FreeDOS). During the updating process, the machine started to write screens full of random characters in cyan coloured background. At that point I knew it was b0rked. I asked my friend about what to do now, he said I could open the machine up, locate the bios chip and use EPROM programmer/burner to write the bios image to the chip. He also said that because my machine is very old, there are probably not safeguards like dual bios or emergency bios update from floppy disk on boot. He continued by saying that the bios update file images from IBM/Lenovo website might not be actual , &amp;quot;pure&amp;quot; binaries which could be burned directly to the chip, instead they may contain some vendor-specific checksums which must be taken into account. In ThinkWiki there seems to be no page about bios flashing gone bad and restoring the machine to working condition. Or is there? I really need your help with this; I think I'm able to locate the bios, take it off and find a working EPROM burner, but where can I get a clean BIOS image without the vendor checksums? I'd be grateful for any references.&lt;br /&gt;
&lt;br /&gt;
--[[User:Usv|Usv]] 12:45, 31 March 2007 (CEST)&lt;br /&gt;
&lt;br /&gt;
== Upgraded BIOS using USB flash drive ==&lt;br /&gt;
&lt;br /&gt;
I flashed my Thinkpad X41 succesfully with 2.09 BIOS using bootable USB flash drive with DOS 6.22 system files. (I guess Freedos would work aswell). I had such key laying around so I can't help you with making one (i used windows HP USB key format utility to make it long long time ago) &lt;br /&gt;
Everything is quite simple once you have USB key and are able to boot DOS from it.&lt;br /&gt;
&lt;br /&gt;
I downloaded the non-diskette ThinkPad BIOS update utility (74uj15us.exe) from lenovo support site and extrated disk image from it using cabextract:&lt;br /&gt;
   {{cmduser|cabextract -F &amp;quot;*.IMG&amp;quot; 74uj15us.exe}}&lt;br /&gt;
&lt;br /&gt;
I mounted the image file (74UJ15US.IMG):&lt;br /&gt;
   {{cmdroot|mkdir /tmp/mnt}}&lt;br /&gt;
   {{cmdroot|mount -loop o 74UJ15US.IMG /tmp/mnt}}&lt;br /&gt;
&lt;br /&gt;
I mounted the usb key and made a directory for ibm flash utility files under it:&lt;br /&gt;
   {{cmdroot|mount /dev/sdb1 /mnt/usbflash}}&lt;br /&gt;
   {{cmdroot|mkdir /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
I copied the contents of /tmp/mnt to /mnt/usbflash/ibm:&lt;br /&gt;
   {{cmdroot|cp /tmp/mnt/*.* /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
Then I unmounted the USB stick and rebooted from it to DOS (F12 during boot -&amp;gt; USB HDD).&amp;lt;br&amp;gt; &lt;br /&gt;
In the DOS Prompt:&amp;lt;br&amp;gt;&lt;br /&gt;
   C:\cd ibm&lt;br /&gt;
   C:\IBM\flash2 /U&lt;br /&gt;
I waited for about 1 minute, then my thinkpad made two beeps to signal that the flashing was complete.&lt;br /&gt;
&lt;br /&gt;
PS. Because lacking reliable guide on how to make bootable DOS USB stick for ThinkPads I decided to leave this into discussion section. Feel free to move all the necessary stuff into the BIOS upgrade article if you know/figure out how to make bootable DOS USB stick in linux.   &lt;br /&gt;
--[[User:ladoga|ladoga]] 04:56 17 Apr 2007&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=User:Ladoga&amp;diff=29370</id>
		<title>User:Ladoga</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=User:Ladoga&amp;diff=29370"/>
		<updated>2007-04-17T02:24:53Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Who is ladoga? ==&lt;br /&gt;
Lauri Koponen&amp;lt;br&amp;gt;&lt;br /&gt;
Seen idling at irc.debian.org #debian and IRCnet&lt;br /&gt;
&lt;br /&gt;
== My Thinkpad ==&lt;br /&gt;
Thinkpad X41 type 2525-F8G. This very solid and portable machine is one of the best purchases I ever made. It's been running Debian testing since early 2006. Everything works and I haven't even put much effort into it. (thanks to ThinkWiki)&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29369</id>
		<title>Talk:BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29369"/>
		<updated>2007-04-17T02:08:28Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* Upgraded BIOS using USB flash drive */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Dead link == &lt;br /&gt;
&lt;br /&gt;
The link to the FreeDOS floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip), which is needed to upgrade the BIOS from a CD, is dead. Is the information still valid? And is there a different source for the floppy image? [[User:Jamesavery|Jamesavery]] 05:49, 18 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using WINE ==&lt;br /&gt;
&lt;br /&gt;
Does anyone think this would be possible? [[User:Mcalwell|Mcalwell]] 08:58, 28 January 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
: No this is not possible. [[User:Mcalwell|Mcalwell]] 16:01, 12 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade without battery ==&lt;br /&gt;
&lt;br /&gt;
Concerning the known problem with 600 series with batteries dead too soon, it is impossible to upgrade the bios without the battery because the original ibm update program doesn't allow this. I bought an old 600E without the battery. There was one workaround, but i think for the older releases of the bios, where you just extracted files and upgraded manualy, bypassing the ibm install program. The page that describes this (i lost the link) has a list of different files, that the ones found in current release so i never did figure out what to do? I would like to upgrade because i have really old bios, where ACPI doesn't cooperate so well with the operating system, either windows or linux.&lt;br /&gt;
&lt;br /&gt;
If somebody finds a workaround please help. Thanks&lt;br /&gt;
&lt;br /&gt;
//Edit&lt;br /&gt;
&lt;br /&gt;
I've found the page on Vim's bios upgrade forum.. I don't know if it exactly for my model, since the files differ.. '''Is it possible, to upgrade bios in linux without the battery?'''&lt;br /&gt;
&lt;br /&gt;
''I have found a working solution WOW on the other forum: &lt;br /&gt;
&lt;br /&gt;
*** This is NOT a safe way to update the bios (disclaimer) *** &lt;br /&gt;
&lt;br /&gt;
* First you need to make a BIOS update floppy disk (from the bios file from IBM - place disk in a: drive, run app and answer Y to the agreement) and then format another disk by right clicking on A: - format - make system bootdisk (assuming you have another machine spare) &lt;br /&gt;
&lt;br /&gt;
* Copy all the files from the IBM Boot disk - in my case &lt;br /&gt;
$0029000.fl1 &lt;br /&gt;
$0029000.fl2 &lt;br /&gt;
FLASH2.EXE &lt;br /&gt;
PROD.DAT &lt;br /&gt;
UPDTFLSH.EXE &lt;br /&gt;
updtrom.exe &lt;br /&gt;
USERINT.EXE &lt;br /&gt;
UTILINFO.EXE &lt;br /&gt;
to the other clean bootdisk. &lt;br /&gt;
&lt;br /&gt;
* Ensure that there is no config.sys and autoexec.bat so it just runs straight into DOS. &lt;br /&gt;
&lt;br /&gt;
* Place the disk into the Laptop, reboot and allow the machine to load via the floppy &lt;br /&gt;
&lt;br /&gt;
* At the command prompt, type &amp;quot;FLASH2.EXE /U&amp;quot; with no quotes then press enter. &lt;br /&gt;
&lt;br /&gt;
The program will automatically search for the files *.FL1 &amp;amp; *.FL2 and load the bios first then the platform file. &lt;br /&gt;
&lt;br /&gt;
The program will automatically update and perform erasing on the rom and then finish with &amp;quot;Update complete&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
* Now reboot. &lt;br /&gt;
&lt;br /&gt;
* Hold F1 down as you turn the laptop back on and go into Easy Setup under &amp;quot;Config&amp;quot; click on Initialize to ensure defaults and settings are error free. &lt;br /&gt;
&lt;br /&gt;
* Save and exit...''&lt;br /&gt;
&lt;br /&gt;
// EDIT&lt;br /&gt;
&lt;br /&gt;
This worked on my machine.. I make no guarantees it will work on others.&lt;br /&gt;
&lt;br /&gt;
The above procedure did not work on my T23 using the 1.20 bios; it kept returning error 14 (Low Battery). However, following those instructions and running &amp;quot;qkflash&amp;quot; rather than flash2 did work for the main bios, and later for the embedded controller.&lt;br /&gt;
&lt;br /&gt;
--grythumn&lt;br /&gt;
&lt;br /&gt;
== Bios upgrade &amp;amp; hidden partition ==&lt;br /&gt;
&lt;br /&gt;
I have disabled the hidden partition to make more space for linux (24G). I still have Windows on the 14G partition. Is it safe to upgrade the BIOS without the hidden partition? I want to get a newer BIOS to fix the annoying fan issue. Thanks&lt;br /&gt;
&lt;br /&gt;
- yes don't worry about it. bios upgrades have nothing to do with whats inside the harddrive.&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade over PXE ==&lt;br /&gt;
&lt;br /&gt;
Hi,&lt;br /&gt;
&lt;br /&gt;
I have a Thinkpad X20 with a very early BIOS and Embedded Controller Program which I'd like to update. Currently, the only feasible way of doing this is over the network using PXE. I already have a fully functional PXE server using SYSLINUX, and have so far been able to boot the BIOS diskette image using MEMDISK, although I have not attempted to flash anything yet due to the warnings given on the page. Is there any safe way I can update both the Controller Program and the BIOS in the same session over the network in this manner? If not, what other methods would be suitable? I have a USB CD-ROM drive and could probably get hold of a USB floppy drive.&lt;br /&gt;
&lt;br /&gt;
Thanks.&lt;br /&gt;
&lt;br /&gt;
Update: I ended up burning CDs as described and successfully updated everything. I'd still like to know if there is a way I could do it entirely over the network, though.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== RE: grub initrd ==&lt;br /&gt;
&lt;br /&gt;
&amp;quot;Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
0) Interesting suggestion. Might be better of in its own section.&lt;br /&gt;
&lt;br /&gt;
1) Could you please elaborate?&lt;br /&gt;
&lt;br /&gt;
2) My first guess (pending your elaboration) would be to &amp;quot;chainload&amp;quot; the first block of the diskimage using the grub commandline, like:&lt;br /&gt;
   blocklist (''path'')/''to''/''diskimage''&lt;br /&gt;
   chainloader ''blockvalue''+1&lt;br /&gt;
&lt;br /&gt;
But that's just a guess!&lt;br /&gt;
&lt;br /&gt;
[[user:Pebolle|Paul Bolle]] Fri Jul 15 12:20:47 CEST 2005&lt;br /&gt;
&lt;br /&gt;
== bios/controller update sequence ==&lt;br /&gt;
&lt;br /&gt;
The article says:&lt;br /&gt;
&amp;quot;If you go through the readme's on the IBM site they'll cleary state that you must update the Control Program first, then imediately update the BIOS&amp;quot;&lt;br /&gt;
&lt;br /&gt;
When I look at the IBM udpate instructions for the T23, it says:&lt;br /&gt;
&amp;quot;If you need to update the BIOS as well as the Embedded Controller Program, update the BIOS first.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comments?&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I would first contact IBM for clarification, but you should probably be following instructions specific to your model.&lt;br /&gt;
&lt;br /&gt;
&amp;gt;&amp;gt; I did it following IBM's instructions to upgrade the BIOS first. Everything worked out great!&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Intel minipci combo card ==&lt;br /&gt;
&lt;br /&gt;
I just purchased an [[Intel 10/100 Ethernet Mini-PCI Adapter with 56K Modem]] that has an ancient (2.0.6) firmware version.  I Downloaded the update file intlbtag.EXE but cabextract was unable to find any cabfiles inside it.  I tried running the program via wine and that didn't work either.&lt;br /&gt;
&lt;br /&gt;
Finally I ran the program on a windows machine and created a boot floppy.  Then I went through the the process of converting the floppy to a bootable cd via linux and that worked like a charm.  The cd successfully updated the minipc card's firmware.&lt;br /&gt;
&lt;br /&gt;
Everything worked but I ended up needing a windows box to do it.  Could this have been done without windows?&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Wireless LAN MiniPCI COMBO Card using prism2_srec ==&lt;br /&gt;
&lt;br /&gt;
The appropriate firmware installation program for the wlan card in my R32 can be extracted using cabextract as described in the article. It contains (besides some installation programs) a disk image (1awg06ww.IMG) that seems to be a simple dos boot disk. This image contains 3 .hex files (id010001.hex, pk010100.hex, sf010402.hex) that are recognized by prism2_srec to be &amp;quot;srec&amp;quot;-files. Trying to load them to RAM yields:&lt;br /&gt;
&lt;br /&gt;
    {{cmdroot|prism2_srec -v -r wlan0 sf010402.hex}}&lt;br /&gt;
    S3 CRC-16 generation record: start=0x007E1800 len=65642 prog=1&lt;br /&gt;
    Start address 0x00000000&lt;br /&gt;
    srec summary for sf010402.hex&lt;br /&gt;
    Component: 0x001f 1.4.2 (station firmware)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    role=Supplier variant=2 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    role=Actor    variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Wireless LAN card information:&lt;br /&gt;
    Components:&lt;br /&gt;
    NICID: 0x8013 v1.0.0&lt;br /&gt;
    PRIID: 0x0015 v1.0.7&lt;br /&gt;
    STAID: 0x001f v1.3.6&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    PRI role=Supplier variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    PRI role=Supplier variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    PRI role=Supplier variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    STA role=Supplier variant=1 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    PRI role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    This image is not meant to be downloaded to volatile memory.&lt;br /&gt;
    Incompatible update data.&lt;br /&gt;
&lt;br /&gt;
Has anyone tried to flash this device using prism2_srec yet?&lt;br /&gt;
What bothers me is, that the upgrade is for many different parts of the combo card. Does anyone have an opinion on whether this could work?&lt;br /&gt;
&lt;br /&gt;
OK, I took the risk and successfully upgraded my station firmware, BUT when I tried to upgrade the primary firmware the system froze!!! The thinkpad won't start up with the miniPCI card inserted and all efforts to reflash it using the original DOS boot image failed!!!&lt;br /&gt;
&lt;br /&gt;
I'm quite sure the system freeze was not caused directly by prism2_srec, because I have noticed rare system freezes since I have been using my PCMCIA wireless card.&lt;br /&gt;
Anyway, if anyone should own a TP R32, I'd be glad if he could tell me the base address of the Wlan card, or it's PCI address.&lt;br /&gt;
&lt;br /&gt;
Thinkpad r32 owner here. I want to upgrade the firmware as well. If you need any information just send an email to haftbar[a]gmail.com [[User:Quickie|Quickie]] 02:12, 1 February 2006 (CET)&lt;br /&gt;
&lt;br /&gt;
==Reorganization suggestion==&lt;br /&gt;
The Downloads section is rather long. Would it be an idea to put it on a separate, new page (say: BIOS_Downloads) and link to that new page from this page?&lt;br /&gt;
&lt;br /&gt;
[[User:Pebolle|Paul Bolle]] 21:27, 15 Oct 2005 (CEST)&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I agree with this suggestion.&lt;br /&gt;
&lt;br /&gt;
== Upgrading BIOS and Embedded Control Program from Win XP ==&lt;br /&gt;
&lt;br /&gt;
I'm trying to upgrade the BIOS and Embedded Controller Program from Windows XP following the instructions on the Lenovo website. The problem is the instructions are not very clear about this. The instructions basically state that I must upgrade them at the same time because the Control Program does not work with the older BIOS and the BIOS does not work with the older Control Program. They also state that I should upgrade the Control Program first. &lt;br /&gt;
&lt;br /&gt;
But that means I must boot into XP after having upgraded the Control Program but with the older BIOS in order to then update the BIOS. But if this works then they are actually compatible and there's a contradiction. Am I missing something? I just want to make sure I don't end up with a non-functioning unit.&lt;br /&gt;
&lt;br /&gt;
I have an X23 and want the latest BIOS (v 1.32) and Control Program (v 1.30). &lt;br /&gt;
&lt;br /&gt;
Maybe there should be a note about this in the article? Or maybe I'm the only one who is this stupid :)&lt;br /&gt;
&lt;br /&gt;
Update: I talked to Lenovo support. The situation apparently is that though the description says that the newer control program is not compatible with the older BIOS, they are not so incompatible as to cause the machine to stop working so it is actually possible to use incompatible versions of BIOS and control program. In fact according to the support person it makes no difference if the BIOS is upgraded before the control program or vice versa. So I upgraded the control program using the executable running in Windows XP, which rebooted the computer to perform the upgrade and then I booted Windows again to upgrade the BIOS in the same manner and it all worked fine. If anyone reading this finds it useful maybe you can put it in the article? Or if you find it superfluous just delete this section.&lt;br /&gt;
&lt;br /&gt;
--[[User:xphinx|xphinx]] 12 March 2007&lt;br /&gt;
&lt;br /&gt;
I have an X22 with BIOS version 1.21 and Embedded Controller version 1.17 and using the steps described by you, I succesfully updated my bios to the lastest versions from WindowsXP (BIOS v1.32 / EC v1.30)&lt;br /&gt;
Thanks!&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade for T21 with T20 BIOS ==&lt;br /&gt;
&lt;br /&gt;
Hi, I bought a used T21 recently (type 2647-8AU), and would like to update the BIOS to the latest version, but there's a problem: this T21 appears to have a T20 BIOS (IYET50WW, a/k/a T20 BIOS version 1.11).  When I try updating this BIOS using one of IBM's T21 updaters - I tried KZET34WW/v1.16 (the latest one) and KZET16WW/v1.01 (the earliest one) - I get the following message:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
''The diskette in the default drive will not run on this system. Your system is now locked. To restart your system, press Ctrl+Alt+Del.''&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
I suspect this message appears because the existing BIOS is a T20 BIOS.&lt;br /&gt;
&lt;br /&gt;
There would appear to be two options: either use the most recent T20 updater (IYET61WW, a/k/a T20 v1.22), or find a way to defeat the block in the KZET34WW/v1.16 T21 updater.  Obviously either option is risky in the absence of more information and/or detective work.  And I don't know enough about T2x-series hardware to hazard a guess (i.e., were early T21s just T20s with a speed bump, did some T21s get T20 BIOSes by mistake due to factory error, or are the T20 and T21 similar enough that it doesn't matter whether a T20 or T21 BIOS is used).&lt;br /&gt;
&lt;br /&gt;
Some relevant data gleaned from the stickers on the case bottom and the current BIOS:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
* '''Type:''' 2647-8AU (T21 with 800-MHz processor)&lt;br /&gt;
* '''S/N:''' 78-0GL1Z (zero-G-L-one-zed)&lt;br /&gt;
* '''Manufacture date:''' 03/2001&lt;br /&gt;
* '''BIOS version:''' IYET50WW (T20 BIOS v1.11)&lt;br /&gt;
* '''System unit S/N:''' (appears to be blank)&lt;br /&gt;
* '''System board S/N:''' J1HHS15CL5C&lt;br /&gt;
* '''System board P/N:''' 08K3747 (printed on motherboard)&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Thanks for any help anyone can provide.&lt;br /&gt;
&lt;br /&gt;
-Linux Spice&lt;br /&gt;
&lt;br /&gt;
P.S. At first I thought this might be a Frankenstein ThinkPad with a T21 case and a T20 logic board - I did buy it used, after all - but it does have an 800-MHz processor, which was never an option for the T20 (both the BIOS and Linux report it as such), and all the other equipment checks out (except for the hard drive, which was replaced with a 40-GB model).&lt;br /&gt;
&lt;br /&gt;
== BIOS format ==&lt;br /&gt;
&lt;br /&gt;
Not sure if this is the right place, but...&lt;br /&gt;
Does anybody know what the formats for the various files are in the bios package (or, even better, the bios.bak file that gets dumped on your disk before updating)? I'm getting progressivel lower and lower level in figuring out just what happens when the computer boots, and the BIOS is the last step... (BTW, I have an x60s)&lt;br /&gt;
&lt;br /&gt;
-- Unknown&lt;br /&gt;
&lt;br /&gt;
Yes.  It is a binary dump.  Sometimes, there is junk in the start of the file.  This should be data enough for you to figure out what you need.&lt;br /&gt;
&lt;br /&gt;
--[[User:Hmh|hmh]] 13:30, 26 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS update gone bad ==&lt;br /&gt;
&lt;br /&gt;
I tried to flash my [[:Category:600|ThinkPad 600]]'s bios with catastrophalic outcome; now the machine is unable to boot. I, being overly stupid and too self-confident, ignored all warnings about the media containing the bios image not being write-protected (I used one partition of the disk, in which I had installed FreeDOS). During the updating process, the machine started to write screens full of random characters in cyan coloured background. At that point I knew it was b0rked. I asked my friend about what to do now, he said I could open the machine up, locate the bios chip and use EPROM programmer/burner to write the bios image to the chip. He also said that because my machine is very old, there are probably not safeguards like dual bios or emergency bios update from floppy disk on boot. He continued by saying that the bios update file images from IBM/Lenovo website might not be actual , &amp;quot;pure&amp;quot; binaries which could be burned directly to the chip, instead they may contain some vendor-specific checksums which must be taken into account. In ThinkWiki there seems to be no page about bios flashing gone bad and restoring the machine to working condition. Or is there? I really need your help with this; I think I'm able to locate the bios, take it off and find a working EPROM burner, but where can I get a clean BIOS image without the vendor checksums? I'd be grateful for any references.&lt;br /&gt;
&lt;br /&gt;
--[[User:Usv|Usv]] 12:45, 31 March 2007 (CEST)&lt;br /&gt;
&lt;br /&gt;
== Upgraded BIOS using USB flash drive ==&lt;br /&gt;
&lt;br /&gt;
I flashed my Thinkpad X41 succesfully with 2.09 BIOS using bootable USB flash drive with DOS 6.22 system files. (I guess Freedos would work aswell). I had such key laying around so I can't help you with making one (i used windows HP USB key format utility to make it long long time ago) &lt;br /&gt;
Everything is quite simple once you have USB key and are able to boot DOS from it.&lt;br /&gt;
&lt;br /&gt;
I downloaded the non-diskette ThinkPad BIOS update utility (74uj15us.exe) from lenovo support site and extrated disk image from it using cabextract:&lt;br /&gt;
   {{cmduser|cabextract -F &amp;quot;*.IMG&amp;quot; 74uj15us.exe}}&lt;br /&gt;
&lt;br /&gt;
I mounted the image file (74UJ15US.IMG):&lt;br /&gt;
   {{cmdroot|mkdir /tmp/mnt}}&lt;br /&gt;
   {{cmdroot|mount -loop o 74UJ15US.IMG /tmp/mnt}}&lt;br /&gt;
&lt;br /&gt;
I mounted the usb key and made a directory for ibm flash utility files under it:&lt;br /&gt;
   {{cmdroot|mount /dev/sdb1 /mnt/usbflash}}&lt;br /&gt;
   {{cmdroot|mkdir /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
I copied the contents of /tmp/mnt to /mnt/usbflash/ibm:&lt;br /&gt;
   {{cmdroot|cp /tmp/mnt/*.* /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
Then I unmounted the USB stick and rebooted from it to DOS (F12 during boot -&amp;gt; USB HDD).&amp;lt;br&amp;gt; &lt;br /&gt;
In the DOS Prompt:&amp;lt;br&amp;gt;&lt;br /&gt;
   C:\cd ibm&lt;br /&gt;
   C:\IBM\flash2 /U&lt;br /&gt;
I waited for about 1 minute, then my thinkpad made two beeps to signal that the flashing was complete.&lt;br /&gt;
--[[User:ladoga|ladoga]] 04:56 17 Apr 2007&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29368</id>
		<title>Talk:BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29368"/>
		<updated>2007-04-17T02:07:21Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* Upgraded BIOS using USB flash drive */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Dead link == &lt;br /&gt;
&lt;br /&gt;
The link to the FreeDOS floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip), which is needed to upgrade the BIOS from a CD, is dead. Is the information still valid? And is there a different source for the floppy image? [[User:Jamesavery|Jamesavery]] 05:49, 18 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using WINE ==&lt;br /&gt;
&lt;br /&gt;
Does anyone think this would be possible? [[User:Mcalwell|Mcalwell]] 08:58, 28 January 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
: No this is not possible. [[User:Mcalwell|Mcalwell]] 16:01, 12 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade without battery ==&lt;br /&gt;
&lt;br /&gt;
Concerning the known problem with 600 series with batteries dead too soon, it is impossible to upgrade the bios without the battery because the original ibm update program doesn't allow this. I bought an old 600E without the battery. There was one workaround, but i think for the older releases of the bios, where you just extracted files and upgraded manualy, bypassing the ibm install program. The page that describes this (i lost the link) has a list of different files, that the ones found in current release so i never did figure out what to do? I would like to upgrade because i have really old bios, where ACPI doesn't cooperate so well with the operating system, either windows or linux.&lt;br /&gt;
&lt;br /&gt;
If somebody finds a workaround please help. Thanks&lt;br /&gt;
&lt;br /&gt;
//Edit&lt;br /&gt;
&lt;br /&gt;
I've found the page on Vim's bios upgrade forum.. I don't know if it exactly for my model, since the files differ.. '''Is it possible, to upgrade bios in linux without the battery?'''&lt;br /&gt;
&lt;br /&gt;
''I have found a working solution WOW on the other forum: &lt;br /&gt;
&lt;br /&gt;
*** This is NOT a safe way to update the bios (disclaimer) *** &lt;br /&gt;
&lt;br /&gt;
* First you need to make a BIOS update floppy disk (from the bios file from IBM - place disk in a: drive, run app and answer Y to the agreement) and then format another disk by right clicking on A: - format - make system bootdisk (assuming you have another machine spare) &lt;br /&gt;
&lt;br /&gt;
* Copy all the files from the IBM Boot disk - in my case &lt;br /&gt;
$0029000.fl1 &lt;br /&gt;
$0029000.fl2 &lt;br /&gt;
FLASH2.EXE &lt;br /&gt;
PROD.DAT &lt;br /&gt;
UPDTFLSH.EXE &lt;br /&gt;
updtrom.exe &lt;br /&gt;
USERINT.EXE &lt;br /&gt;
UTILINFO.EXE &lt;br /&gt;
to the other clean bootdisk. &lt;br /&gt;
&lt;br /&gt;
* Ensure that there is no config.sys and autoexec.bat so it just runs straight into DOS. &lt;br /&gt;
&lt;br /&gt;
* Place the disk into the Laptop, reboot and allow the machine to load via the floppy &lt;br /&gt;
&lt;br /&gt;
* At the command prompt, type &amp;quot;FLASH2.EXE /U&amp;quot; with no quotes then press enter. &lt;br /&gt;
&lt;br /&gt;
The program will automatically search for the files *.FL1 &amp;amp; *.FL2 and load the bios first then the platform file. &lt;br /&gt;
&lt;br /&gt;
The program will automatically update and perform erasing on the rom and then finish with &amp;quot;Update complete&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
* Now reboot. &lt;br /&gt;
&lt;br /&gt;
* Hold F1 down as you turn the laptop back on and go into Easy Setup under &amp;quot;Config&amp;quot; click on Initialize to ensure defaults and settings are error free. &lt;br /&gt;
&lt;br /&gt;
* Save and exit...''&lt;br /&gt;
&lt;br /&gt;
// EDIT&lt;br /&gt;
&lt;br /&gt;
This worked on my machine.. I make no guarantees it will work on others.&lt;br /&gt;
&lt;br /&gt;
The above procedure did not work on my T23 using the 1.20 bios; it kept returning error 14 (Low Battery). However, following those instructions and running &amp;quot;qkflash&amp;quot; rather than flash2 did work for the main bios, and later for the embedded controller.&lt;br /&gt;
&lt;br /&gt;
--grythumn&lt;br /&gt;
&lt;br /&gt;
== Bios upgrade &amp;amp; hidden partition ==&lt;br /&gt;
&lt;br /&gt;
I have disabled the hidden partition to make more space for linux (24G). I still have Windows on the 14G partition. Is it safe to upgrade the BIOS without the hidden partition? I want to get a newer BIOS to fix the annoying fan issue. Thanks&lt;br /&gt;
&lt;br /&gt;
- yes don't worry about it. bios upgrades have nothing to do with whats inside the harddrive.&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade over PXE ==&lt;br /&gt;
&lt;br /&gt;
Hi,&lt;br /&gt;
&lt;br /&gt;
I have a Thinkpad X20 with a very early BIOS and Embedded Controller Program which I'd like to update. Currently, the only feasible way of doing this is over the network using PXE. I already have a fully functional PXE server using SYSLINUX, and have so far been able to boot the BIOS diskette image using MEMDISK, although I have not attempted to flash anything yet due to the warnings given on the page. Is there any safe way I can update both the Controller Program and the BIOS in the same session over the network in this manner? If not, what other methods would be suitable? I have a USB CD-ROM drive and could probably get hold of a USB floppy drive.&lt;br /&gt;
&lt;br /&gt;
Thanks.&lt;br /&gt;
&lt;br /&gt;
Update: I ended up burning CDs as described and successfully updated everything. I'd still like to know if there is a way I could do it entirely over the network, though.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== RE: grub initrd ==&lt;br /&gt;
&lt;br /&gt;
&amp;quot;Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
0) Interesting suggestion. Might be better of in its own section.&lt;br /&gt;
&lt;br /&gt;
1) Could you please elaborate?&lt;br /&gt;
&lt;br /&gt;
2) My first guess (pending your elaboration) would be to &amp;quot;chainload&amp;quot; the first block of the diskimage using the grub commandline, like:&lt;br /&gt;
   blocklist (''path'')/''to''/''diskimage''&lt;br /&gt;
   chainloader ''blockvalue''+1&lt;br /&gt;
&lt;br /&gt;
But that's just a guess!&lt;br /&gt;
&lt;br /&gt;
[[user:Pebolle|Paul Bolle]] Fri Jul 15 12:20:47 CEST 2005&lt;br /&gt;
&lt;br /&gt;
== bios/controller update sequence ==&lt;br /&gt;
&lt;br /&gt;
The article says:&lt;br /&gt;
&amp;quot;If you go through the readme's on the IBM site they'll cleary state that you must update the Control Program first, then imediately update the BIOS&amp;quot;&lt;br /&gt;
&lt;br /&gt;
When I look at the IBM udpate instructions for the T23, it says:&lt;br /&gt;
&amp;quot;If you need to update the BIOS as well as the Embedded Controller Program, update the BIOS first.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comments?&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I would first contact IBM for clarification, but you should probably be following instructions specific to your model.&lt;br /&gt;
&lt;br /&gt;
&amp;gt;&amp;gt; I did it following IBM's instructions to upgrade the BIOS first. Everything worked out great!&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Intel minipci combo card ==&lt;br /&gt;
&lt;br /&gt;
I just purchased an [[Intel 10/100 Ethernet Mini-PCI Adapter with 56K Modem]] that has an ancient (2.0.6) firmware version.  I Downloaded the update file intlbtag.EXE but cabextract was unable to find any cabfiles inside it.  I tried running the program via wine and that didn't work either.&lt;br /&gt;
&lt;br /&gt;
Finally I ran the program on a windows machine and created a boot floppy.  Then I went through the the process of converting the floppy to a bootable cd via linux and that worked like a charm.  The cd successfully updated the minipc card's firmware.&lt;br /&gt;
&lt;br /&gt;
Everything worked but I ended up needing a windows box to do it.  Could this have been done without windows?&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Wireless LAN MiniPCI COMBO Card using prism2_srec ==&lt;br /&gt;
&lt;br /&gt;
The appropriate firmware installation program for the wlan card in my R32 can be extracted using cabextract as described in the article. It contains (besides some installation programs) a disk image (1awg06ww.IMG) that seems to be a simple dos boot disk. This image contains 3 .hex files (id010001.hex, pk010100.hex, sf010402.hex) that are recognized by prism2_srec to be &amp;quot;srec&amp;quot;-files. Trying to load them to RAM yields:&lt;br /&gt;
&lt;br /&gt;
    {{cmdroot|prism2_srec -v -r wlan0 sf010402.hex}}&lt;br /&gt;
    S3 CRC-16 generation record: start=0x007E1800 len=65642 prog=1&lt;br /&gt;
    Start address 0x00000000&lt;br /&gt;
    srec summary for sf010402.hex&lt;br /&gt;
    Component: 0x001f 1.4.2 (station firmware)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    role=Supplier variant=2 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    role=Actor    variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Wireless LAN card information:&lt;br /&gt;
    Components:&lt;br /&gt;
    NICID: 0x8013 v1.0.0&lt;br /&gt;
    PRIID: 0x0015 v1.0.7&lt;br /&gt;
    STAID: 0x001f v1.3.6&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    PRI role=Supplier variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    PRI role=Supplier variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    PRI role=Supplier variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    STA role=Supplier variant=1 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    PRI role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    This image is not meant to be downloaded to volatile memory.&lt;br /&gt;
    Incompatible update data.&lt;br /&gt;
&lt;br /&gt;
Has anyone tried to flash this device using prism2_srec yet?&lt;br /&gt;
What bothers me is, that the upgrade is for many different parts of the combo card. Does anyone have an opinion on whether this could work?&lt;br /&gt;
&lt;br /&gt;
OK, I took the risk and successfully upgraded my station firmware, BUT when I tried to upgrade the primary firmware the system froze!!! The thinkpad won't start up with the miniPCI card inserted and all efforts to reflash it using the original DOS boot image failed!!!&lt;br /&gt;
&lt;br /&gt;
I'm quite sure the system freeze was not caused directly by prism2_srec, because I have noticed rare system freezes since I have been using my PCMCIA wireless card.&lt;br /&gt;
Anyway, if anyone should own a TP R32, I'd be glad if he could tell me the base address of the Wlan card, or it's PCI address.&lt;br /&gt;
&lt;br /&gt;
Thinkpad r32 owner here. I want to upgrade the firmware as well. If you need any information just send an email to haftbar[a]gmail.com [[User:Quickie|Quickie]] 02:12, 1 February 2006 (CET)&lt;br /&gt;
&lt;br /&gt;
==Reorganization suggestion==&lt;br /&gt;
The Downloads section is rather long. Would it be an idea to put it on a separate, new page (say: BIOS_Downloads) and link to that new page from this page?&lt;br /&gt;
&lt;br /&gt;
[[User:Pebolle|Paul Bolle]] 21:27, 15 Oct 2005 (CEST)&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I agree with this suggestion.&lt;br /&gt;
&lt;br /&gt;
== Upgrading BIOS and Embedded Control Program from Win XP ==&lt;br /&gt;
&lt;br /&gt;
I'm trying to upgrade the BIOS and Embedded Controller Program from Windows XP following the instructions on the Lenovo website. The problem is the instructions are not very clear about this. The instructions basically state that I must upgrade them at the same time because the Control Program does not work with the older BIOS and the BIOS does not work with the older Control Program. They also state that I should upgrade the Control Program first. &lt;br /&gt;
&lt;br /&gt;
But that means I must boot into XP after having upgraded the Control Program but with the older BIOS in order to then update the BIOS. But if this works then they are actually compatible and there's a contradiction. Am I missing something? I just want to make sure I don't end up with a non-functioning unit.&lt;br /&gt;
&lt;br /&gt;
I have an X23 and want the latest BIOS (v 1.32) and Control Program (v 1.30). &lt;br /&gt;
&lt;br /&gt;
Maybe there should be a note about this in the article? Or maybe I'm the only one who is this stupid :)&lt;br /&gt;
&lt;br /&gt;
Update: I talked to Lenovo support. The situation apparently is that though the description says that the newer control program is not compatible with the older BIOS, they are not so incompatible as to cause the machine to stop working so it is actually possible to use incompatible versions of BIOS and control program. In fact according to the support person it makes no difference if the BIOS is upgraded before the control program or vice versa. So I upgraded the control program using the executable running in Windows XP, which rebooted the computer to perform the upgrade and then I booted Windows again to upgrade the BIOS in the same manner and it all worked fine. If anyone reading this finds it useful maybe you can put it in the article? Or if you find it superfluous just delete this section.&lt;br /&gt;
&lt;br /&gt;
--[[User:xphinx|xphinx]] 12 March 2007&lt;br /&gt;
&lt;br /&gt;
I have an X22 with BIOS version 1.21 and Embedded Controller version 1.17 and using the steps described by you, I succesfully updated my bios to the lastest versions from WindowsXP (BIOS v1.32 / EC v1.30)&lt;br /&gt;
Thanks!&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade for T21 with T20 BIOS ==&lt;br /&gt;
&lt;br /&gt;
Hi, I bought a used T21 recently (type 2647-8AU), and would like to update the BIOS to the latest version, but there's a problem: this T21 appears to have a T20 BIOS (IYET50WW, a/k/a T20 BIOS version 1.11).  When I try updating this BIOS using one of IBM's T21 updaters - I tried KZET34WW/v1.16 (the latest one) and KZET16WW/v1.01 (the earliest one) - I get the following message:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
''The diskette in the default drive will not run on this system. Your system is now locked. To restart your system, press Ctrl+Alt+Del.''&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
I suspect this message appears because the existing BIOS is a T20 BIOS.&lt;br /&gt;
&lt;br /&gt;
There would appear to be two options: either use the most recent T20 updater (IYET61WW, a/k/a T20 v1.22), or find a way to defeat the block in the KZET34WW/v1.16 T21 updater.  Obviously either option is risky in the absence of more information and/or detective work.  And I don't know enough about T2x-series hardware to hazard a guess (i.e., were early T21s just T20s with a speed bump, did some T21s get T20 BIOSes by mistake due to factory error, or are the T20 and T21 similar enough that it doesn't matter whether a T20 or T21 BIOS is used).&lt;br /&gt;
&lt;br /&gt;
Some relevant data gleaned from the stickers on the case bottom and the current BIOS:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
* '''Type:''' 2647-8AU (T21 with 800-MHz processor)&lt;br /&gt;
* '''S/N:''' 78-0GL1Z (zero-G-L-one-zed)&lt;br /&gt;
* '''Manufacture date:''' 03/2001&lt;br /&gt;
* '''BIOS version:''' IYET50WW (T20 BIOS v1.11)&lt;br /&gt;
* '''System unit S/N:''' (appears to be blank)&lt;br /&gt;
* '''System board S/N:''' J1HHS15CL5C&lt;br /&gt;
* '''System board P/N:''' 08K3747 (printed on motherboard)&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Thanks for any help anyone can provide.&lt;br /&gt;
&lt;br /&gt;
-Linux Spice&lt;br /&gt;
&lt;br /&gt;
P.S. At first I thought this might be a Frankenstein ThinkPad with a T21 case and a T20 logic board - I did buy it used, after all - but it does have an 800-MHz processor, which was never an option for the T20 (both the BIOS and Linux report it as such), and all the other equipment checks out (except for the hard drive, which was replaced with a 40-GB model).&lt;br /&gt;
&lt;br /&gt;
== BIOS format ==&lt;br /&gt;
&lt;br /&gt;
Not sure if this is the right place, but...&lt;br /&gt;
Does anybody know what the formats for the various files are in the bios package (or, even better, the bios.bak file that gets dumped on your disk before updating)? I'm getting progressivel lower and lower level in figuring out just what happens when the computer boots, and the BIOS is the last step... (BTW, I have an x60s)&lt;br /&gt;
&lt;br /&gt;
-- Unknown&lt;br /&gt;
&lt;br /&gt;
Yes.  It is a binary dump.  Sometimes, there is junk in the start of the file.  This should be data enough for you to figure out what you need.&lt;br /&gt;
&lt;br /&gt;
--[[User:Hmh|hmh]] 13:30, 26 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS update gone bad ==&lt;br /&gt;
&lt;br /&gt;
I tried to flash my [[:Category:600|ThinkPad 600]]'s bios with catastrophalic outcome; now the machine is unable to boot. I, being overly stupid and too self-confident, ignored all warnings about the media containing the bios image not being write-protected (I used one partition of the disk, in which I had installed FreeDOS). During the updating process, the machine started to write screens full of random characters in cyan coloured background. At that point I knew it was b0rked. I asked my friend about what to do now, he said I could open the machine up, locate the bios chip and use EPROM programmer/burner to write the bios image to the chip. He also said that because my machine is very old, there are probably not safeguards like dual bios or emergency bios update from floppy disk on boot. He continued by saying that the bios update file images from IBM/Lenovo website might not be actual , &amp;quot;pure&amp;quot; binaries which could be burned directly to the chip, instead they may contain some vendor-specific checksums which must be taken into account. In ThinkWiki there seems to be no page about bios flashing gone bad and restoring the machine to working condition. Or is there? I really need your help with this; I think I'm able to locate the bios, take it off and find a working EPROM burner, but where can I get a clean BIOS image without the vendor checksums? I'd be grateful for any references.&lt;br /&gt;
&lt;br /&gt;
--[[User:Usv|Usv]] 12:45, 31 March 2007 (CEST)&lt;br /&gt;
&lt;br /&gt;
== Upgraded BIOS using USB flash drive ==&lt;br /&gt;
&lt;br /&gt;
I flashed my Thinkpad X41 succesfully with 2.09 BIOS using bootable USB flash drive with DOS 6.22 system files. (I guess Freedos would work aswell). I had such key laying around so I can't help you with making one (i used windows HP USB key format utility to make it long long time ago) &lt;br /&gt;
Everything is quite simple once you have USB key and are able to boot DOS from it.&lt;br /&gt;
&lt;br /&gt;
I downloaded the non-diskette ThinkPad BIOS update utility (74uj15us.exe) from lenovo support site and extrated disk image from it using cabextract:&lt;br /&gt;
   :{{cmduser|cabextract -F &amp;quot;*.IMG&amp;quot; 74uj15us.exe}}&lt;br /&gt;
&lt;br /&gt;
I mounted the image file (74UJ15US.IMG):&lt;br /&gt;
   :{{cmdroot|mkdir /tmp/mnt}}&lt;br /&gt;
   :{{cmdroot|mount -loop o 74UJ15US.IMG /tmp/mnt}}&lt;br /&gt;
&lt;br /&gt;
I mounted the usb key and made a directory for ibm flash utility files under it:&lt;br /&gt;
   :{{cmdroot|mount /dev/sdb1 /mnt/usbflash}}&lt;br /&gt;
   :{{cmdroot|mkdir /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
I copied the contents of /tmp/mnt to /mnt/usbflash/ibm:&lt;br /&gt;
   :{{cmdroot|cp /tmp/mnt/*.* /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
Then I unmounted the USB stick and rebooted from it to DOS (F12 during boot -&amp;gt; USB HDD).&amp;lt;br&amp;gt; &lt;br /&gt;
In the DOS Prompt:&amp;lt;br&amp;gt;&lt;br /&gt;
   C:\cd ibm&lt;br /&gt;
   C:\IBM\flash2 /U&lt;br /&gt;
I waited for about 1 minute, then my thinkpad made two beeps to signal that the flashing was complete.&lt;br /&gt;
--[[User:ladoga|ladoga]] 04:56 17 Apr 2007&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29367</id>
		<title>Talk:BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:BIOS_Upgrade&amp;diff=29367"/>
		<updated>2007-04-17T02:05:16Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Dead link == &lt;br /&gt;
&lt;br /&gt;
The link to the FreeDOS floppy (http://www.ankreuzen.de/freedos/files/fd9sr1/fdos1440.zip), which is needed to upgrade the BIOS from a CD, is dead. Is the information still valid? And is there a different source for the floppy image? [[User:Jamesavery|Jamesavery]] 05:49, 18 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade using WINE ==&lt;br /&gt;
&lt;br /&gt;
Does anyone think this would be possible? [[User:Mcalwell|Mcalwell]] 08:58, 28 January 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
: No this is not possible. [[User:Mcalwell|Mcalwell]] 16:01, 12 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade without battery ==&lt;br /&gt;
&lt;br /&gt;
Concerning the known problem with 600 series with batteries dead too soon, it is impossible to upgrade the bios without the battery because the original ibm update program doesn't allow this. I bought an old 600E without the battery. There was one workaround, but i think for the older releases of the bios, where you just extracted files and upgraded manualy, bypassing the ibm install program. The page that describes this (i lost the link) has a list of different files, that the ones found in current release so i never did figure out what to do? I would like to upgrade because i have really old bios, where ACPI doesn't cooperate so well with the operating system, either windows or linux.&lt;br /&gt;
&lt;br /&gt;
If somebody finds a workaround please help. Thanks&lt;br /&gt;
&lt;br /&gt;
//Edit&lt;br /&gt;
&lt;br /&gt;
I've found the page on Vim's bios upgrade forum.. I don't know if it exactly for my model, since the files differ.. '''Is it possible, to upgrade bios in linux without the battery?'''&lt;br /&gt;
&lt;br /&gt;
''I have found a working solution WOW on the other forum: &lt;br /&gt;
&lt;br /&gt;
*** This is NOT a safe way to update the bios (disclaimer) *** &lt;br /&gt;
&lt;br /&gt;
* First you need to make a BIOS update floppy disk (from the bios file from IBM - place disk in a: drive, run app and answer Y to the agreement) and then format another disk by right clicking on A: - format - make system bootdisk (assuming you have another machine spare) &lt;br /&gt;
&lt;br /&gt;
* Copy all the files from the IBM Boot disk - in my case &lt;br /&gt;
$0029000.fl1 &lt;br /&gt;
$0029000.fl2 &lt;br /&gt;
FLASH2.EXE &lt;br /&gt;
PROD.DAT &lt;br /&gt;
UPDTFLSH.EXE &lt;br /&gt;
updtrom.exe &lt;br /&gt;
USERINT.EXE &lt;br /&gt;
UTILINFO.EXE &lt;br /&gt;
to the other clean bootdisk. &lt;br /&gt;
&lt;br /&gt;
* Ensure that there is no config.sys and autoexec.bat so it just runs straight into DOS. &lt;br /&gt;
&lt;br /&gt;
* Place the disk into the Laptop, reboot and allow the machine to load via the floppy &lt;br /&gt;
&lt;br /&gt;
* At the command prompt, type &amp;quot;FLASH2.EXE /U&amp;quot; with no quotes then press enter. &lt;br /&gt;
&lt;br /&gt;
The program will automatically search for the files *.FL1 &amp;amp; *.FL2 and load the bios first then the platform file. &lt;br /&gt;
&lt;br /&gt;
The program will automatically update and perform erasing on the rom and then finish with &amp;quot;Update complete&amp;quot;. &lt;br /&gt;
&lt;br /&gt;
* Now reboot. &lt;br /&gt;
&lt;br /&gt;
* Hold F1 down as you turn the laptop back on and go into Easy Setup under &amp;quot;Config&amp;quot; click on Initialize to ensure defaults and settings are error free. &lt;br /&gt;
&lt;br /&gt;
* Save and exit...''&lt;br /&gt;
&lt;br /&gt;
// EDIT&lt;br /&gt;
&lt;br /&gt;
This worked on my machine.. I make no guarantees it will work on others.&lt;br /&gt;
&lt;br /&gt;
The above procedure did not work on my T23 using the 1.20 bios; it kept returning error 14 (Low Battery). However, following those instructions and running &amp;quot;qkflash&amp;quot; rather than flash2 did work for the main bios, and later for the embedded controller.&lt;br /&gt;
&lt;br /&gt;
--grythumn&lt;br /&gt;
&lt;br /&gt;
== Bios upgrade &amp;amp; hidden partition ==&lt;br /&gt;
&lt;br /&gt;
I have disabled the hidden partition to make more space for linux (24G). I still have Windows on the 14G partition. Is it safe to upgrade the BIOS without the hidden partition? I want to get a newer BIOS to fix the annoying fan issue. Thanks&lt;br /&gt;
&lt;br /&gt;
- yes don't worry about it. bios upgrades have nothing to do with whats inside the harddrive.&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade over PXE ==&lt;br /&gt;
&lt;br /&gt;
Hi,&lt;br /&gt;
&lt;br /&gt;
I have a Thinkpad X20 with a very early BIOS and Embedded Controller Program which I'd like to update. Currently, the only feasible way of doing this is over the network using PXE. I already have a fully functional PXE server using SYSLINUX, and have so far been able to boot the BIOS diskette image using MEMDISK, although I have not attempted to flash anything yet due to the warnings given on the page. Is there any safe way I can update both the Controller Program and the BIOS in the same session over the network in this manner? If not, what other methods would be suitable? I have a USB CD-ROM drive and could probably get hold of a USB floppy drive.&lt;br /&gt;
&lt;br /&gt;
Thanks.&lt;br /&gt;
&lt;br /&gt;
Update: I ended up burning CDs as described and successfully updated everything. I'd still like to know if there is a way I could do it entirely over the network, though.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== RE: grub initrd ==&lt;br /&gt;
&lt;br /&gt;
&amp;quot;Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
0) Interesting suggestion. Might be better of in its own section.&lt;br /&gt;
&lt;br /&gt;
1) Could you please elaborate?&lt;br /&gt;
&lt;br /&gt;
2) My first guess (pending your elaboration) would be to &amp;quot;chainload&amp;quot; the first block of the diskimage using the grub commandline, like:&lt;br /&gt;
   blocklist (''path'')/''to''/''diskimage''&lt;br /&gt;
   chainloader ''blockvalue''+1&lt;br /&gt;
&lt;br /&gt;
But that's just a guess!&lt;br /&gt;
&lt;br /&gt;
[[user:Pebolle|Paul Bolle]] Fri Jul 15 12:20:47 CEST 2005&lt;br /&gt;
&lt;br /&gt;
== bios/controller update sequence ==&lt;br /&gt;
&lt;br /&gt;
The article says:&lt;br /&gt;
&amp;quot;If you go through the readme's on the IBM site they'll cleary state that you must update the Control Program first, then imediately update the BIOS&amp;quot;&lt;br /&gt;
&lt;br /&gt;
When I look at the IBM udpate instructions for the T23, it says:&lt;br /&gt;
&amp;quot;If you need to update the BIOS as well as the Embedded Controller Program, update the BIOS first.&amp;quot;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comments?&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I would first contact IBM for clarification, but you should probably be following instructions specific to your model.&lt;br /&gt;
&lt;br /&gt;
&amp;gt;&amp;gt; I did it following IBM's instructions to upgrade the BIOS first. Everything worked out great!&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Intel minipci combo card ==&lt;br /&gt;
&lt;br /&gt;
I just purchased an [[Intel 10/100 Ethernet Mini-PCI Adapter with 56K Modem]] that has an ancient (2.0.6) firmware version.  I Downloaded the update file intlbtag.EXE but cabextract was unable to find any cabfiles inside it.  I tried running the program via wine and that didn't work either.&lt;br /&gt;
&lt;br /&gt;
Finally I ran the program on a windows machine and created a boot floppy.  Then I went through the the process of converting the floppy to a bootable cd via linux and that worked like a charm.  The cd successfully updated the minipc card's firmware.&lt;br /&gt;
&lt;br /&gt;
Everything worked but I ended up needing a windows box to do it.  Could this have been done without windows?&lt;br /&gt;
&lt;br /&gt;
== Firmware upgrade for Wireless LAN MiniPCI COMBO Card using prism2_srec ==&lt;br /&gt;
&lt;br /&gt;
The appropriate firmware installation program for the wlan card in my R32 can be extracted using cabextract as described in the article. It contains (besides some installation programs) a disk image (1awg06ww.IMG) that seems to be a simple dos boot disk. This image contains 3 .hex files (id010001.hex, pk010100.hex, sf010402.hex) that are recognized by prism2_srec to be &amp;quot;srec&amp;quot;-files. Trying to load them to RAM yields:&lt;br /&gt;
&lt;br /&gt;
    {{cmdroot|prism2_srec -v -r wlan0 sf010402.hex}}&lt;br /&gt;
    S3 CRC-16 generation record: start=0x007E1800 len=65642 prog=1&lt;br /&gt;
    Start address 0x00000000&lt;br /&gt;
    srec summary for sf010402.hex&lt;br /&gt;
    Component: 0x001f 1.4.2 (station firmware)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    role=Supplier variant=2 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    role=Actor    variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    Wireless LAN card information:&lt;br /&gt;
    Components:&lt;br /&gt;
    NICID: 0x8013 v1.0.0&lt;br /&gt;
    PRIID: 0x0015 v1.0.7&lt;br /&gt;
    STAID: 0x001f v1.3.6&lt;br /&gt;
    Interface compatibility information:&lt;br /&gt;
    PRI role=Supplier variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    PRI role=Supplier variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    PRI role=Supplier variant=1 range=4-4 iface=Primary Firmware-Driver (3)&lt;br /&gt;
    STA role=Supplier variant=1 range=1-9 iface=Station Firmware-Driver (4)&lt;br /&gt;
    PRI role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=2 range=1-1 iface=Controller-Firmware (2)&lt;br /&gt;
    STA role=Actor    variant=1 range=1-1 iface=Modem-Firmware (1)&lt;br /&gt;
    &amp;lt;snip&amp;gt;&lt;br /&gt;
    This image is not meant to be downloaded to volatile memory.&lt;br /&gt;
    Incompatible update data.&lt;br /&gt;
&lt;br /&gt;
Has anyone tried to flash this device using prism2_srec yet?&lt;br /&gt;
What bothers me is, that the upgrade is for many different parts of the combo card. Does anyone have an opinion on whether this could work?&lt;br /&gt;
&lt;br /&gt;
OK, I took the risk and successfully upgraded my station firmware, BUT when I tried to upgrade the primary firmware the system froze!!! The thinkpad won't start up with the miniPCI card inserted and all efforts to reflash it using the original DOS boot image failed!!!&lt;br /&gt;
&lt;br /&gt;
I'm quite sure the system freeze was not caused directly by prism2_srec, because I have noticed rare system freezes since I have been using my PCMCIA wireless card.&lt;br /&gt;
Anyway, if anyone should own a TP R32, I'd be glad if he could tell me the base address of the Wlan card, or it's PCI address.&lt;br /&gt;
&lt;br /&gt;
Thinkpad r32 owner here. I want to upgrade the firmware as well. If you need any information just send an email to haftbar[a]gmail.com [[User:Quickie|Quickie]] 02:12, 1 February 2006 (CET)&lt;br /&gt;
&lt;br /&gt;
==Reorganization suggestion==&lt;br /&gt;
The Downloads section is rather long. Would it be an idea to put it on a separate, new page (say: BIOS_Downloads) and link to that new page from this page?&lt;br /&gt;
&lt;br /&gt;
[[User:Pebolle|Paul Bolle]] 21:27, 15 Oct 2005 (CEST)&lt;br /&gt;
&lt;br /&gt;
&amp;gt; I agree with this suggestion.&lt;br /&gt;
&lt;br /&gt;
== Upgrading BIOS and Embedded Control Program from Win XP ==&lt;br /&gt;
&lt;br /&gt;
I'm trying to upgrade the BIOS and Embedded Controller Program from Windows XP following the instructions on the Lenovo website. The problem is the instructions are not very clear about this. The instructions basically state that I must upgrade them at the same time because the Control Program does not work with the older BIOS and the BIOS does not work with the older Control Program. They also state that I should upgrade the Control Program first. &lt;br /&gt;
&lt;br /&gt;
But that means I must boot into XP after having upgraded the Control Program but with the older BIOS in order to then update the BIOS. But if this works then they are actually compatible and there's a contradiction. Am I missing something? I just want to make sure I don't end up with a non-functioning unit.&lt;br /&gt;
&lt;br /&gt;
I have an X23 and want the latest BIOS (v 1.32) and Control Program (v 1.30). &lt;br /&gt;
&lt;br /&gt;
Maybe there should be a note about this in the article? Or maybe I'm the only one who is this stupid :)&lt;br /&gt;
&lt;br /&gt;
Update: I talked to Lenovo support. The situation apparently is that though the description says that the newer control program is not compatible with the older BIOS, they are not so incompatible as to cause the machine to stop working so it is actually possible to use incompatible versions of BIOS and control program. In fact according to the support person it makes no difference if the BIOS is upgraded before the control program or vice versa. So I upgraded the control program using the executable running in Windows XP, which rebooted the computer to perform the upgrade and then I booted Windows again to upgrade the BIOS in the same manner and it all worked fine. If anyone reading this finds it useful maybe you can put it in the article? Or if you find it superfluous just delete this section.&lt;br /&gt;
&lt;br /&gt;
--[[User:xphinx|xphinx]] 12 March 2007&lt;br /&gt;
&lt;br /&gt;
I have an X22 with BIOS version 1.21 and Embedded Controller version 1.17 and using the steps described by you, I succesfully updated my bios to the lastest versions from WindowsXP (BIOS v1.32 / EC v1.30)&lt;br /&gt;
Thanks!&lt;br /&gt;
&lt;br /&gt;
== BIOS upgrade for T21 with T20 BIOS ==&lt;br /&gt;
&lt;br /&gt;
Hi, I bought a used T21 recently (type 2647-8AU), and would like to update the BIOS to the latest version, but there's a problem: this T21 appears to have a T20 BIOS (IYET50WW, a/k/a T20 BIOS version 1.11).  When I try updating this BIOS using one of IBM's T21 updaters - I tried KZET34WW/v1.16 (the latest one) and KZET16WW/v1.01 (the earliest one) - I get the following message:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
''The diskette in the default drive will not run on this system. Your system is now locked. To restart your system, press Ctrl+Alt+Del.''&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
I suspect this message appears because the existing BIOS is a T20 BIOS.&lt;br /&gt;
&lt;br /&gt;
There would appear to be two options: either use the most recent T20 updater (IYET61WW, a/k/a T20 v1.22), or find a way to defeat the block in the KZET34WW/v1.16 T21 updater.  Obviously either option is risky in the absence of more information and/or detective work.  And I don't know enough about T2x-series hardware to hazard a guess (i.e., were early T21s just T20s with a speed bump, did some T21s get T20 BIOSes by mistake due to factory error, or are the T20 and T21 similar enough that it doesn't matter whether a T20 or T21 BIOS is used).&lt;br /&gt;
&lt;br /&gt;
Some relevant data gleaned from the stickers on the case bottom and the current BIOS:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote&amp;gt;&lt;br /&gt;
* '''Type:''' 2647-8AU (T21 with 800-MHz processor)&lt;br /&gt;
* '''S/N:''' 78-0GL1Z (zero-G-L-one-zed)&lt;br /&gt;
* '''Manufacture date:''' 03/2001&lt;br /&gt;
* '''BIOS version:''' IYET50WW (T20 BIOS v1.11)&lt;br /&gt;
* '''System unit S/N:''' (appears to be blank)&lt;br /&gt;
* '''System board S/N:''' J1HHS15CL5C&lt;br /&gt;
* '''System board P/N:''' 08K3747 (printed on motherboard)&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Thanks for any help anyone can provide.&lt;br /&gt;
&lt;br /&gt;
-Linux Spice&lt;br /&gt;
&lt;br /&gt;
P.S. At first I thought this might be a Frankenstein ThinkPad with a T21 case and a T20 logic board - I did buy it used, after all - but it does have an 800-MHz processor, which was never an option for the T20 (both the BIOS and Linux report it as such), and all the other equipment checks out (except for the hard drive, which was replaced with a 40-GB model).&lt;br /&gt;
&lt;br /&gt;
== BIOS format ==&lt;br /&gt;
&lt;br /&gt;
Not sure if this is the right place, but...&lt;br /&gt;
Does anybody know what the formats for the various files are in the bios package (or, even better, the bios.bak file that gets dumped on your disk before updating)? I'm getting progressivel lower and lower level in figuring out just what happens when the computer boots, and the BIOS is the last step... (BTW, I have an x60s)&lt;br /&gt;
&lt;br /&gt;
-- Unknown&lt;br /&gt;
&lt;br /&gt;
Yes.  It is a binary dump.  Sometimes, there is junk in the start of the file.  This should be data enough for you to figure out what you need.&lt;br /&gt;
&lt;br /&gt;
--[[User:Hmh|hmh]] 13:30, 26 February 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
== BIOS update gone bad ==&lt;br /&gt;
&lt;br /&gt;
I tried to flash my [[:Category:600|ThinkPad 600]]'s bios with catastrophalic outcome; now the machine is unable to boot. I, being overly stupid and too self-confident, ignored all warnings about the media containing the bios image not being write-protected (I used one partition of the disk, in which I had installed FreeDOS). During the updating process, the machine started to write screens full of random characters in cyan coloured background. At that point I knew it was b0rked. I asked my friend about what to do now, he said I could open the machine up, locate the bios chip and use EPROM programmer/burner to write the bios image to the chip. He also said that because my machine is very old, there are probably not safeguards like dual bios or emergency bios update from floppy disk on boot. He continued by saying that the bios update file images from IBM/Lenovo website might not be actual , &amp;quot;pure&amp;quot; binaries which could be burned directly to the chip, instead they may contain some vendor-specific checksums which must be taken into account. In ThinkWiki there seems to be no page about bios flashing gone bad and restoring the machine to working condition. Or is there? I really need your help with this; I think I'm able to locate the bios, take it off and find a working EPROM burner, but where can I get a clean BIOS image without the vendor checksums? I'd be grateful for any references.&lt;br /&gt;
&lt;br /&gt;
--[[User:Usv|Usv]] 12:45, 31 March 2007 (CEST)&lt;br /&gt;
&lt;br /&gt;
== Upgraded BIOS using USB flash drive ==&lt;br /&gt;
&lt;br /&gt;
I flashed my Thinkpad X41 succesfully with 2.09 BIOS using bootable USB flash drive with DOS 6.22 system files. (I guess Freedos would work aswell). I had such key laying around so I can't help you with making one (i used windows HP USB key format utility to make it long long time ago) &lt;br /&gt;
Everything is quite simple once you have USB key and are able to boot DOS from it.&lt;br /&gt;
&lt;br /&gt;
I downloaded the non-diskette ThinkPad BIOS update utility (74uj15us.exe) from lenovo support site and extrated disk image from it using cabextract:&lt;br /&gt;
   :{{cmduser|cabextract -F &amp;quot;*.IMG&amp;quot; 74uj15us.exe}}&lt;br /&gt;
&lt;br /&gt;
I mounted the image file (74UJ15US.IMG):&lt;br /&gt;
   :{{cmdroot|mkdir /tmp/mnt}}&lt;br /&gt;
   :{{cmdroot|mount -loop o 74UJ15US.IMG /tmp/mnt}}&lt;br /&gt;
&lt;br /&gt;
I mounted the usb key and made a directory for ibm flash utility files under it:&lt;br /&gt;
   :{{cmdroot|mount /dev/sdb1 /mnt/usbflash}}&lt;br /&gt;
   :{{cmdroot|mkdir /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
I copied the contents of /tmp/mnt to /mnt/usbflash/ibm:&lt;br /&gt;
   :{{cmdroot|cp /tmp/mnt/*.* /mnt/usbflash/ibm}}&lt;br /&gt;
&lt;br /&gt;
Then I unmounted the USB stick and rebooted from it to DOS (F12 during boot -&amp;gt; USB HDD).&amp;lt;br&amp;gt; &lt;br /&gt;
In the DOS Prompt:&amp;lt;br&amp;gt;&lt;br /&gt;
   C:\cd ibm&lt;br /&gt;
   C:\IBM\flash2 /U&lt;br /&gt;
I waited for about 1 minute, then my thinkpad made two beeps to signal that the flashing was complete.&lt;br /&gt;
--[[User:ladoga|ladoga]] 12:45, 31 March 2007 (CEST)&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=BIOS_Upgrade&amp;diff=29347</id>
		<title>BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=BIOS_Upgrade&amp;diff=29347"/>
		<updated>2007-04-16T09:34:19Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* Updating via Grub and a Floppy Image */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;__TOC__&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
{{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.}}&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
==Before You Begin==&lt;br /&gt;
Updating the BIOS in Linux (with few exceptions) '''is not officially supported''' by IBM.  However there are work arounds.&lt;br /&gt;
&lt;br /&gt;
{{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.&lt;br /&gt;
&lt;br /&gt;
'''Proceed at your own risk!'''&lt;br /&gt;
&lt;br /&gt;
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 risk turning your thinkpad into a very nice paper weight.}}&lt;br /&gt;
&lt;br /&gt;
==BIOS Upgrade Paths==&lt;br /&gt;
&lt;br /&gt;
For every firmware (either BIOS or Control Program) update on the IBM site there are two different firmware update programs provided.  A list of links to firmware downloads can be found at [[BIOS Upgrade Downloads]] for nearly all Thinkpad Models.&lt;br /&gt;
&lt;br /&gt;
===The Diskette Updater===&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
===The Non Diskette Updater===&lt;br /&gt;
{{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.}}&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmduser|cabextract FILENAME.exe}}&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmdroot|mkdir mntfloppy}}&lt;br /&gt;
:{{cmdroot|mount -o loop FILENAME.img mntfloppy}}&lt;br /&gt;
:{{cmdroot|ls -la mntfloppy}}&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
== Updating Thinkpad X Series ==&lt;br /&gt;
&lt;br /&gt;
X Series Thinkpads do not have an internal drive. If there is no Windows installed, the BIOS must be updated by booting from an USB drive or a drive that is integrated in the docking station. Since a while Lenovo provides BIOS updates in form of bootable CD images. Unfortunately, these images are intended to be used with the docking station's CD drive. If you do not own such a drive, things get complicated.&lt;br /&gt;
&lt;br /&gt;
The problem is that current BIOS updates are quite large, about 3 MB in size. Booting from CDs typically works like booting from a 1.44 MB or 2.88 MB floppy disk. The floppy image is stored on the CD and is referenced in the CD's boot record. Because the BIOS update file are that large, they do not fit on such a floppy image. Thus, they must be stored on the CD outside the virtual floppy image. To access these files a driver for the CD drive has to be loaded. Since Lenovo's CD images are intended to be used with a docking station's CD drive, it is not possible to use them for BIOS updates by booting from an USB CD drive.&lt;br /&gt;
&lt;br /&gt;
But there is hope. The CD images provided by Lenovo can be modified such that they contain drivers for USB CD drives. I tested the following with a Thinkpad X60s.&lt;br /&gt;
&lt;br /&gt;
The idea is to take Lenovo's ISO CD image and modify it such that a USB CD drive can be used instead the CD drive in the docking station. Unfortunately, simply replacing the drivers is not enough. While doing the BIOS update, the USB ports seem to get disabled or something. Therefore, before starting the update process the CD contents have to be copied to a RAM disk. I will describe the procedure step by step.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ol&amp;gt;&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Download the ISO image style BIOS update from Lenovo's website. This file will be refered to as &amp;lt;tt&amp;gt;/tmp/bios-lenovo.iso&amp;lt;/tt&amp;gt;.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Extract the floppy image from this ISO image. You can use the following shell script for this task. Simply save this code into the file &amp;lt;tt&amp;gt;/tmp/extractbootimage.sh&amp;lt;/tt&amp;gt;, set the x-flag (&amp;lt;tt&amp;gt;chmod +x /tmp/extractbootimage.sh&amp;lt;/tt&amp;gt;) and call it using the command &amp;lt;tt&amp;gt;/tmp/extractbootimage.sh /tmp/bios-lenovo.iso /tmp/bios-lenovo.img&amp;lt;/tt&amp;gt;. The floppy image contained in the ISO image will then be saved to &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img&amp;lt;/tt&amp;gt;. Here is the code of the shell script:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
#!/bin/bash&lt;br /&gt;
&lt;br /&gt;
# This script extracts the floopy boot image from bootable ISO images&lt;br /&gt;
#&lt;br /&gt;
# Written by Joachim Selke (mail@joachim-selke.de), 2007-04-07&lt;br /&gt;
&lt;br /&gt;
ISOFILE=$1&lt;br /&gt;
IMAGEFILE=$2&lt;br /&gt;
&lt;br /&gt;
if [ ! -r $ISOFILE ]; then&lt;br /&gt;
        echo $ISOFILE: file does not exist or is not readable&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
if [ -z $IMAGEFILE ]; then&lt;br /&gt;
        echo Error: no image file specified&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
ISOFILESIZE=`stat -c %s $ISOFILE`&lt;br /&gt;
&lt;br /&gt;
# collect El Torito data&lt;br /&gt;
# see http://www.phoenix.com/NR/rdonlyres/98D3219C-9CC9-4DF5-B496-A286D893E36A/0/specscdrom.pdf for reference&lt;br /&gt;
&lt;br /&gt;
BOOTCATALOGPOINTERBYTE=$((17 * 0x800 + 0x47))&lt;br /&gt;
&lt;br /&gt;
if [ $ISOFILESIZE -lt $(($BOOTCATALOGPOINTERBYTE + 4)) ]; then&lt;br /&gt;
        echo ISO file is too short, possibly damaged&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
# absolute pointer to first sector of boot catalog:&lt;br /&gt;
BOOTCATALOG=`od -A n -t x4 -N 4 -j $BOOTCATALOGPOINTERBYTE $ISOFILE | tr -d [:blank:]`&lt;br /&gt;
&lt;br /&gt;
BOOTCATALOGBYTE=$((0x$BOOTCATALOG * 0x800))&lt;br /&gt;
&lt;br /&gt;
echo Boot catalog starts at byte $BOOTCATALOGBYTE&lt;br /&gt;
&lt;br /&gt;
if [ $ISOFILESIZE -lt $(($BOOTCATALOGBYTE + 32 + 2)) ]; then&lt;br /&gt;
        echo ISO file is too short, possibly damaged&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
# media type of boot image&lt;br /&gt;
# only floppy disk images are supported by this script&lt;br /&gt;
BOOTMEDIATYPE=`od -A n -t x1 -N 1 -j $(($BOOTCATALOGBYTE + 32 + 1)) $ISOFILE | tr -d [:blank:]`&lt;br /&gt;
&lt;br /&gt;
if [ $BOOTMEDIATYPE -eq 1 ]; then&lt;br /&gt;
        echo Boot media type is 1.2M floppy disk&lt;br /&gt;
        IMAGEBLOCKS=$((1200 / 2))&lt;br /&gt;
elif [ $BOOTMEDIATYPE -eq 2 ]; then&lt;br /&gt;
        echo Boot media type is 1.44M floppy disk&lt;br /&gt;
        IMAGEBLOCKS=$((1440 / 2))&lt;br /&gt;
elif [ $BOOTMEDIATYPE -eq 3 ]; then&lt;br /&gt;
        echo Boot media type is 2.88M floppy disk&lt;br /&gt;
        IMAGEBLOCKS=$((2880 / 2))&lt;br /&gt;
else&lt;br /&gt;
        echo Boot media type is $((0x$BOOTMEDIATYPE)). This type is not supported yet.&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
# absolute pointer to start of boot image&lt;br /&gt;
BOOTIMAGE=`od -A n -t x4 -N 4 -j $(($BOOTCATALOGBYTE + 32 + 8)) $ISOFILE | tr -d [:blank:]`&lt;br /&gt;
&lt;br /&gt;
BOOTIMAGEBYTE=$((0x$BOOTIMAGE * 0x800))&lt;br /&gt;
&lt;br /&gt;
echo Boot image starts at byte $BOOTIMAGEBYTE&lt;br /&gt;
&lt;br /&gt;
if [ $ISOFILESIZE -lt $((0x$BOOTIMAGE * 0x800 + $IMAGEBLOCKS * 0x800)) ]; then&lt;br /&gt;
        echo ISO file is too short, possibly damaged&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
echo Extracting boot image ...&lt;br /&gt;
&lt;br /&gt;
dd if=$ISOFILE of=$IMAGEFILE bs=2K count=$IMAGEBLOCKS skip=$((0x$BOOTIMAGE))&lt;br /&gt;
&lt;br /&gt;
echo Finished&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Mount the floppy image '''as root''' using the loop device:&lt;br /&gt;
:{{cmdroot|mkdir /tmp/bios-lenovo.img-mnt}}&lt;br /&gt;
:{{cmdroot|mount -o loop /tmp/bios-lenovo.img /tmp/bios-lenovo.img-mnt}}&lt;br /&gt;
The image is now mounted as &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img-mnt&amp;lt;/tt&amp;gt;.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Download needed drivers. First download some [http://panasonic.co.jp/pcc/products/drive/other/driver/f2h_usb.exe USB drivers] from Panasonic Japan. Save the file to &amp;lt;tt&amp;gt;/tmp/f2h_usb.exe&amp;lt;/tt&amp;gt; This file is a self-extracting EXE file, that can be executed under Linux using [http://www.winehq.com/ Wine]:&lt;br /&gt;
:{{cmduser|wine /tmp/f2h_usb.exe}}&lt;br /&gt;
You will be asked where to save the extracted files. Choose &amp;lt;tt&amp;gt;/tmp&amp;lt;/tt&amp;gt;. A new directory &amp;lt;tt&amp;gt;/tmp/F2h&amp;lt;/tt&amp;gt; containing the needed drivers will be created.&lt;br /&gt;
&lt;br /&gt;
Additionally, you will need drivers for the RAM disk mentioned. Download them from the [http://sourceforge.net/projects/srdisk ReSizeable RAMDisk project]. Unzip them to &amp;lt;tt&amp;gt;/tmp/srdisk&amp;lt;/tt&amp;gt;.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Let's modify the floppy image:&lt;br /&gt;
:{{cmduser|cp /tmp/F2h/Usbaspi.sys /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/F2h/USBCD.SYS /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/F2h/RAMFD.SYS /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/srdisk/srdxms.sys /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/srdisk/srdisk.exe /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
Now add the following lines to &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img-mnt/config.sys&amp;lt;/tt&amp;gt; replacing the line &amp;lt;tt&amp;gt;DEVICE = A:\IBMTPCD.SYS /R /C&amp;lt;/tt&amp;gt;:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
DEVICE = A:\SRDXMS.SYS&lt;br /&gt;
DEVICE = A:\RAMFD.SYS&lt;br /&gt;
DEVICE = A:\USBASPI.SYS /V&lt;br /&gt;
DEVICE = A:\USBCD.SYS /D:TPCD001&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Finally, edit the file &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img-mnt/autoexec.bat&amp;lt;/tt&amp;gt; replacing the last line (saying &amp;lt;tt&amp;gt;COMMAND.COM&amp;lt;/tt&amp;gt;) by the following:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
A:\SRDISK 10000&lt;br /&gt;
COPY *.* D:&lt;br /&gt;
D:&lt;br /&gt;
COMMAND.COM&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Unmount the floppy image (as root):&lt;br /&gt;
:{{cmdroot|umount /tmp/bios-lenovo.img-mnt}}&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Copy the content of the original CD image to a new directory and create a new ISO file:&lt;br /&gt;
:{{cmdroot|mkdir /tmp/bios-lenovo.iso-mnt}}&lt;br /&gt;
:{{cmdroot|mount -o loop /tmp/bios-lenovo.iso /tmp/bios-lenovo.iso-mnt}}&lt;br /&gt;
:{{cmduser|mkdir /tmp/bios-new.iso-mnt}}&lt;br /&gt;
:{{cmduser|cp /tmp/bios-lenovo.iso-mnt/* /tmp/bios-new.iso-mnt}}&lt;br /&gt;
:{{cmduser|cp /tmp/bios-lenovo.img /tmp/bios-new.iso-mnt/boot.img}}&lt;br /&gt;
:{{cmdroot|umount /tmp/bios-lenovo.iso-mnt}}&lt;br /&gt;
:{{cmduser|mkisofs -b boot.img -o /tmp/bios-new.iso /tmp/bios-new.iso-mnt/}}&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
The file &amp;lt;tt&amp;gt;/tmp/bios-new.iso&amp;lt;/tt&amp;gt; is the modified ISO file. Just burn it to CD and use this CD for updating your BIOS (boot from it using your USB drive). Please give some comments here if it worked for you.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/ol&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Updating via CD/DVD Drive==&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&lt;br /&gt;
&lt;br /&gt;
Be aware that IBM officially does '''not''' support this! The official statement to my support request was:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
I'm afraid we only support the options listed on our web page and no you&lt;br /&gt;
can't burn a CD/DVD, however you can try to use an external USB FDD&lt;br /&gt;
(floppy) drive. The experts recommend a IBM USB FDD, however they have also&lt;br /&gt;
tested it with a Sony USB FDD drive.&lt;br /&gt;
&lt;br /&gt;
In order to make sure the drive is recognised you can boot up the FDD with&lt;br /&gt;
a bootable dos diskette for w98&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
But it seems to be possible as Mathias Dalheimer describes this [http://mailman.linux-thinkpad.org/pipermail/linux-thinkpad/1998-January/009743.html here].&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
{{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!}}&lt;br /&gt;
&lt;br /&gt;
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].&lt;br /&gt;
&lt;br /&gt;
===Creating a Floppy Image===&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmdroot|1=dd bs=2x80x18b if=/dev/fd0 of=/tmp/floppy.img}}&lt;br /&gt;
&lt;br /&gt;
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).&lt;br /&gt;
&lt;br /&gt;
You should verify this {{path|floppy.img}} as explained above.&lt;br /&gt;
&lt;br /&gt;
===Creating a Bootable CD from a Floppy Image===&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmdroot|mkisofs -b bootfloppy.img -o bootcd.iso bootfloppy.img}}&lt;br /&gt;
&lt;br /&gt;
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 &amp;lt;tt&amp;gt;-b &amp;lt;boot image&amp;gt;&amp;lt;/tt&amp;gt; is applied to the CD.  For more info on this read {{cmduser|man mkisofs}}.&lt;br /&gt;
&lt;br /&gt;
You can now burn the {{path|bootcd.iso}} in your favorite CD burning program.&lt;br /&gt;
&lt;br /&gt;
To get an overview which models have been tested with this version, here is a list:&lt;br /&gt;
&lt;br /&gt;
===Does work:===&lt;br /&gt;
{| border=&amp;quot;1&amp;quot; cellspacing=&amp;quot;0&amp;quot; cellpadding=&amp;quot;2&amp;quot;&lt;br /&gt;
| '''Model''' || '''Tested by'''&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{600X}} (2645) ||&lt;br /&gt;
*Jonathan Byrne &amp;lt;jonathan@RemoveThisToMailMe.yamame.org&amp;gt;. BIOS 1.11 from spsuit55.exe worked perfectly using cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A20p}} (2629-6VU) ||&lt;br /&gt;
*Chris Pickett http://www.sable.mcgill.ca/~cpicke/. BIOS 1.11 flashed fine with cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A21e}} (2628-JXU) ||&lt;br /&gt;
*Amit Gurdasani &amp;lt;gurdasani at yahoo dot com&amp;gt;. 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 &amp;quot;do not shut down the laptop&amp;quot; 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.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A31p}} (2653) ||&lt;br /&gt;
*Matthias Meinke largeeddy@gmx.at, BIOS 1.09 1NET15WW flashed fine with cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A31}} (2652) ||&lt;br /&gt;
*[[User:Wnoise|Aaron Denney]], BIOS 1.13 flashed fine with cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{R31}} ||&lt;br /&gt;
*[http://mailman.linux-thinkpad.org/pipermail/linux-thinkpad/1998-January/009743.html Mathias Dalheimer]&lt;br /&gt;
*Sebastian Sauer (with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R40}} ||&lt;br /&gt;
*Matthew Lambie, http://lambie.org&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R50}} (1836-3SU) ||&lt;br /&gt;
*jlbartos &amp;lt;jlbartos at hotmail dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R50e}} (1834-PTG) ||&lt;br /&gt;
*item &amp;lt;item at freemail dot hu&amp;gt; : successfully finished with cabextract/CD method for &amp;quot;1wuj25us.exe&amp;quot; (BIOS version 1WET90WW (2.10), Release Date: 2006/12/22)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R51}} (1829) ||&lt;br /&gt;
*Robert Uhl &amp;lt;rob dot uhl at gmx dot de&amp;gt;, Jellby &amp;lt;jellby at yahoo dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R51}} (1830-RM7) ||&lt;br /&gt;
*Will Parker &amp;lt;stardotstar at sourcepoint dot com dot au&amp;gt; successfully flashed 3.20 using existing 3.04 ECP and retained custom boot splash.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R51}} (2887) ||&lt;br /&gt;
*Ingo van Lil &amp;lt;inguin at gmx dot de&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R52}} (1858) ||&lt;br /&gt;
*Stuart McCord &amp;lt;stuart dot mccord at gmail dot com&amp;gt;  flashed both BIOS and ECP using cabextract, BIOS flashed first as on IBM website&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T20}} ||&lt;br /&gt;
*Franz Hassels &amp;lt;fhassel at suse dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T22}} ||&lt;br /&gt;
*Daniel Maier &amp;lt;nusse teamidiot de&amp;gt;&lt;br /&gt;
*Mathias Behrle (with cabextract/CD method, Version 1.07 =&amp;gt; 1.12) --[[User:Mathiasb|Mathiasb]] 11:58, 14 December 2006 (CET)&lt;br /&gt;
*Bob Skaroff (cabextract/CD), 1.06 =&amp;gt; 1.12&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T23}} ||&lt;br /&gt;
*Bart Snapp &amp;lt;snapp at uiuc dot edu&amp;gt; Note: I followed IBM's instructions to flash the BIOS *first* and the Embedded Controller *second*.&lt;br /&gt;
*Moy Easwaran: BIOS 1.18 / EC 1.06a via cabextract and CD-boot.  The BIOS-update exe generated errors in Windows 2000.&lt;br /&gt;
*Joe Renes: BIOS 1.18 / EC 1.06a on 2006-03-20 via cabextract and CD-boot. Piece of cake.&lt;br /&gt;
*Raphael Errani: BIOS 1.20 / EC 1.06a on 2006-11-06 via cabextract and CD-boot (using mkisofs). Worked without errors. 1st Bios, 2nd EC&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T30}} ||&lt;br /&gt;
*Martin GÃ¼hring &amp;lt;guehring at gmail.com&amp;gt; BIOS 2.10 via cabextract the Non-Diskette BIOS -&amp;gt; mkisofs '''in the directory the exe was extracted''' to generate the iso -&amp;gt; burn the iso -&amp;gt; boot the CD&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{T40}} ||&lt;br /&gt;
*Sean Dague, http://dague.net&lt;br /&gt;
*Justin Mason, http://jmason.org&lt;br /&gt;
*Ivanhoe (Bios 3.19)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T40p}} ||&lt;br /&gt;
*Lukas KrÃ¤henbÃ¼hl, ismo at pop dot agri dot ch&lt;br /&gt;
*Thomas Achtemichuk, tom at tomchuk dot com. BIOS 3.15 flashed fine with cabextract/CD method&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{T41}} ||&lt;br /&gt;
*Lev Givon (Bios 3.15 / EC 3.04) &amp;lt;lev at columbia dot edu&amp;gt;&lt;br /&gt;
*Ernesto HernÃ¡ndez-Novich (Bios 3.19 / CP 3.04) &amp;lt; emhn at usb dot ve &amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T41p}} ||&lt;br /&gt;
*Nils Newman, work great. (Version: Bios 3.14 / Embedded Controller 3.04)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T42}} ||&lt;br /&gt;
*Dan (BIOS 3.20 / EC 3.04, cabextract/CD method) &amp;lt;tronic171 at evilphb.org&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T42p}} ||&lt;br /&gt;
*Robert Schiele &amp;lt;rschiele@uni-mannheim.de&amp;gt;, Joern Heissler &amp;lt;joern@heissler.de&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T43}}  ||&lt;br /&gt;
*Conrad Rentsch &amp;lt;Conrad dot Rentsch at t-online dot de&amp;gt; (Version: Bios 1.29 / Embedded Controller 1.06)&lt;br /&gt;
*Tom Heady &amp;lt;tom-thinkwiki.org@punch.net&amp;gt;&lt;br /&gt;
*Florian Boucault &amp;lt;florian at boucault dot ath dot cx&amp;gt; (Model : 1871-W34 &amp;amp; Version: Bios 1.23 / Embedded Controller 1.03)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X20}}  ||&lt;br /&gt;
*Neil Caunt &amp;lt;retardis at gmail dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X21}}  ||&lt;br /&gt;
*Patrick Leickner &amp;lt;ranma at web dot de&amp;gt;, (BIOS 2.21-&amp;gt;2.25 / EC 1.31-&amp;gt;1.36) via non-disk/cabextract/mkisofs/cdrecord&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X22}}  ||&lt;br /&gt;
*David Emery &amp;lt;dave at skiddlydee dot com&amp;gt;,  (EC 1.30, BIOS 1.32 using non-disk/cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X23}}  ||&lt;br /&gt;
*Nils Faerber &amp;lt;nils dot faerber at kernelconcepts dot de&amp;gt; (Embedded Controller 1.30, BIOS 1.32 with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X30}}  ||&lt;br /&gt;
*Hella Breitkopf, [http://www.unixwitch.de/ www]  (Embedded Controller 1.04, BIOS 1.07 with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X31}}  ||&lt;br /&gt;
*Grzegorz KuÅ›nierz &amp;lt;koniu at sheket dot org&amp;gt;  (Embedded Controller 1.08, BIOS 3.01 with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X40}}  ||&lt;br /&gt;
*Robbie Stone &amp;lt;robbie@serendipity.cx&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{Z60m}}  ||&lt;br /&gt;
*[[User:Morle|Morle]] 13:09, 20 May 2006 (CEST),  (Embedded Controller 1.14 with cabextract/CD method)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Does not work:===&lt;br /&gt;
{|&lt;br /&gt;
| '''Model''' || '''Tested by'''&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Please note that testing this is '''at your own risk'''!!!&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Updating via Grub and a Floppy Image==&lt;br /&gt;
&lt;br /&gt;
{{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!}}&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
title     Bios Flash&lt;br /&gt;
kernel    /boot/memdisk&lt;br /&gt;
initrd    /boot/FILENAME.img&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Again, proceed at your own risk.  This was tested on an R51 type 2888.&lt;br /&gt;
&lt;br /&gt;
This also worked for me on a T41p type 2373. -- [[User:MrStaticVoid|James Lee]] 20:55, 8 May 2006 (CEST)&lt;br /&gt;
&lt;br /&gt;
And it worked for me on a X31 type 2673-CBU. -- [[User:JanTopinski|Jan Topinski]], 18 September 2006 &lt;br /&gt;
&lt;br /&gt;
And it worked for me too on a X31 type 2672-CXU, very useful. -- [[User:TheAnarcat|TheAnarcat]] 16:21, 7 March 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
And it worked for me on two X40 type 2371 -- [[User:Antialize|Jakob Truelsen]], 19 Jan 2007 -- BIOS: 2.07 1uuj21us.exe -- ECP: 1.62 1uhj10us.exe&lt;br /&gt;
&lt;br /&gt;
Not working for me on T43 type 2668-F7G -- [[User:Maus3273|Maus3273]] 20:48, 30 January 2007 (CET) -- BIOS: 1.29 1YUJ18US.IMG -- I got into the bios program, but the machine never restarts after initiating the upgrade.&lt;br /&gt;
&lt;br /&gt;
X41 type 2525-F8G -- [[User:ladoga|Lauri Koponen]], 11:08 16 Apr 2007&amp;lt;br&amp;gt; &lt;br /&gt;
BIOS: 2.09 (74UJ15US.IMG), is no go. (hangs while initialising the actual flashing process) I tried with 2.07 (74UJ13US.IMG) and 2.06 (74UJ12US.IMG) aswell and they all failed in the very same fashion.&amp;lt;br&amp;gt;&lt;br /&gt;
ECP: 1.02 74HJ03US.IMG, works.&lt;br /&gt;
&lt;br /&gt;
==Updating with Network Boot Image==&lt;br /&gt;
&lt;br /&gt;
BIOS, Embedded Controller (EC), CD/DVD and Harddisk firmware disks can be booted&lt;br /&gt;
over the network with [http://syslinux.zytor.com/pxe.php PXELINUX] as part of the [http://syslinux.zytor.com/ SYSLINUX] package.&lt;br /&gt;
&lt;br /&gt;
This requires that you have a DHCP and tftp server configured and setup properly on&lt;br /&gt;
your network, and is probably not for the faint of heart.&lt;br /&gt;
&lt;br /&gt;
Make sure the firmware bootdisk is in linux 'dd' format, as the self-extracting .exe disks&lt;br /&gt;
from the IBM website cannot be booted directly as such.&lt;br /&gt;
&lt;br /&gt;
This worked on the {{R31}}, {{X22}}, {{T21}}, {{T30}} and {{T41p}} with various firmware updates.&lt;br /&gt;
&lt;br /&gt;
==Updating via &amp;quot;IBM Predesktop area&amp;quot;, suitable for model X (not have CDROM and floppy)==&lt;br /&gt;
It's so difficult to update BIOS and ECP without cdrom, floppy disk.&lt;br /&gt;
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: 	&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
Primary: ext3, ext3, ntfs&lt;br /&gt;
Extended: Ntsf, fat32&lt;br /&gt;
Bootloader: GRUB&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
No problem, you can use this way to do it:&lt;br /&gt;
* First, config in BIOS&lt;br /&gt;
In Security part:&lt;br /&gt;
# Remove all password of Subpervisor and Power on password&lt;br /&gt;
# Set Access IBM Predesktop Area to Normal&lt;br /&gt;
# Choose Enable &amp;quot;Flash BIOS updating by End User&amp;quot; in BIOS update Option.&lt;br /&gt;
&lt;br /&gt;
In Config part:&lt;br /&gt;
# Choose Enable for Network flash over Lan&lt;br /&gt;
&lt;br /&gt;
* Second, download the newest version of BIOS update and ECP update &lt;br /&gt;
Running: The program extract all files to the folder. There is a .img file (1QUJ19US.IMG, 1QUJ08US.IMG) in each folder.&lt;br /&gt;
Copy the imformation content in that img file and paste it to one FAT partition(using winimage or TotalCmd to extract) &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
as seen All files in 1QUJ19US.IMG is extracted to D:\BIOS&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
695,764  $018E000.FL1&lt;br /&gt;
163      0691.HSH&lt;br /&gt;
2,049    0691.PAT&lt;br /&gt;
163      0694.HSH&lt;br /&gt;
2,049    0694.PAT&lt;br /&gt;
163      0695.HSH&lt;br /&gt;
2,049    0695.PAT&lt;br /&gt;
2,049    06D0.PAT&lt;br /&gt;
163      06D1.HSH&lt;br /&gt;
2,049    06D1.PAT&lt;br /&gt;
163      06D2.HSH&lt;br /&gt;
2,049    06D2.PAT&lt;br /&gt;
163      06D6.HSH&lt;br /&gt;
2,049    06D6.PAT&lt;br /&gt;
2,049    06D8.PAT&lt;br /&gt;
697      CHKBMP.EXE&lt;br /&gt;
8,128    COMMAND.COM&lt;br /&gt;
26       CONFIG.SYS&lt;br /&gt;
24,860   FLASH2.EXE&lt;br /&gt;
26       LCREFLSH.BAT&lt;br /&gt;
170      LOGO.BAT&lt;br /&gt;
330      LOGO.SCR&lt;br /&gt;
111,925  PHLASH16.EXE&lt;br /&gt;
91,648   PREPARE.EXE&lt;br /&gt;
45       PROD.DAT&lt;br /&gt;
22,252   QKFLASH.EXE&lt;br /&gt;
9,923    README.TXT&lt;br /&gt;
4,260    TPCHKS.EXE&lt;br /&gt;
39,666   UPDTFLSH.EXE&lt;br /&gt;
6,958    UPDTMN.EXE&lt;br /&gt;
12,501   USERINT.EXE&lt;br /&gt;
15,254   UTILINFO.EXE&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
And all files in 1QUJ08US.IMG are: D:\ECP&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
315,404 $018E000.FL2&lt;br /&gt;
8,000   COMMAND.COM&lt;br /&gt;
36      CONFIG.SYS&lt;br /&gt;
16,910  ECFLASH2.EXE&lt;br /&gt;
45      PROD.DAT&lt;br /&gt;
17,812  QKFLASH.EXE&lt;br /&gt;
990     README.TXT&lt;br /&gt;
4,260   TPCHKS.EXE&lt;br /&gt;
89,738  UPDTEC.EXE&lt;br /&gt;
31,134  UPDTFLSH.EXE&lt;br /&gt;
12,501  USERINT.EXE&lt;br /&gt;
15,226  UTILINFO.EXE&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
* Okie, now plug AC Adapter, charge full battery to your laptop and continue third step:&lt;br /&gt;
&lt;br /&gt;
** '''Flash BIOS first,'''&lt;br /&gt;
1. Power On, press blue button on keyboard: '''Access IBM'''&lt;br /&gt;
&lt;br /&gt;
2. On &amp;quot;Utilities&amp;quot;, double click &amp;quot; Diagnostic disk&amp;quot;&lt;br /&gt;
&lt;br /&gt;
3. Your laptop will start PC-DOS, wait when this message appear:&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
Please insert the first floppy diskette and&lt;br /&gt;
Press any key to continue&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
4. Press Ctrl + Break, you will see :&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;Terminate batch job (Y/N) ?&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
5. Okie, press Y, you will get DOS prompt like D:\&lt;br /&gt;
{{NOTE|D:\ is my RAMDISK, C:\ is my disk format as FAT.!}}&lt;br /&gt;
&lt;br /&gt;
6. Enter to c:\BIOS&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
c:&lt;br /&gt;
cd c:\BIOS&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
7. Run FLASH2.EXE /u $018E000.FL1&lt;br /&gt;
&lt;br /&gt;
8. Wait flash progress compelete and reboot.&lt;br /&gt;
** '''Flash ECP'''&lt;br /&gt;
Follow above instruction from step 1 to 5&lt;br /&gt;
&lt;br /&gt;
6. Enter to c:\ECP&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
c:&lt;br /&gt;
cd c:\ECP&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
7. run UPDTFLSH.EXE $018E000.FL2&lt;br /&gt;
&lt;br /&gt;
8. Follow UPDTFLSH's instructions&lt;br /&gt;
&lt;br /&gt;
9. Wait flash complete and auto turn off computer.&lt;br /&gt;
&lt;br /&gt;
I done it on my IBM Thinkpad X31.&lt;br /&gt;
&lt;br /&gt;
Enjoy,&lt;br /&gt;
&lt;br /&gt;
Tested by nm.&lt;br /&gt;
&lt;br /&gt;
==Check List==&lt;br /&gt;
&lt;br /&gt;
The following is important to remember:&lt;br /&gt;
# 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)&lt;br /&gt;
# 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.&lt;br /&gt;
# You must update the Control Program '''before''' you update the BIOS&lt;br /&gt;
&lt;br /&gt;
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.&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=BIOS_Upgrade&amp;diff=29346</id>
		<title>BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=BIOS_Upgrade&amp;diff=29346"/>
		<updated>2007-04-16T09:31:41Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* Updating via Grub and a Floppy Image */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;__TOC__&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
{{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.}}&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
==Before You Begin==&lt;br /&gt;
Updating the BIOS in Linux (with few exceptions) '''is not officially supported''' by IBM.  However there are work arounds.&lt;br /&gt;
&lt;br /&gt;
{{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.&lt;br /&gt;
&lt;br /&gt;
'''Proceed at your own risk!'''&lt;br /&gt;
&lt;br /&gt;
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 risk turning your thinkpad into a very nice paper weight.}}&lt;br /&gt;
&lt;br /&gt;
==BIOS Upgrade Paths==&lt;br /&gt;
&lt;br /&gt;
For every firmware (either BIOS or Control Program) update on the IBM site there are two different firmware update programs provided.  A list of links to firmware downloads can be found at [[BIOS Upgrade Downloads]] for nearly all Thinkpad Models.&lt;br /&gt;
&lt;br /&gt;
===The Diskette Updater===&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
===The Non Diskette Updater===&lt;br /&gt;
{{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.}}&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmduser|cabextract FILENAME.exe}}&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmdroot|mkdir mntfloppy}}&lt;br /&gt;
:{{cmdroot|mount -o loop FILENAME.img mntfloppy}}&lt;br /&gt;
:{{cmdroot|ls -la mntfloppy}}&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
== Updating Thinkpad X Series ==&lt;br /&gt;
&lt;br /&gt;
X Series Thinkpads do not have an internal drive. If there is no Windows installed, the BIOS must be updated by booting from an USB drive or a drive that is integrated in the docking station. Since a while Lenovo provides BIOS updates in form of bootable CD images. Unfortunately, these images are intended to be used with the docking station's CD drive. If you do not own such a drive, things get complicated.&lt;br /&gt;
&lt;br /&gt;
The problem is that current BIOS updates are quite large, about 3 MB in size. Booting from CDs typically works like booting from a 1.44 MB or 2.88 MB floppy disk. The floppy image is stored on the CD and is referenced in the CD's boot record. Because the BIOS update file are that large, they do not fit on such a floppy image. Thus, they must be stored on the CD outside the virtual floppy image. To access these files a driver for the CD drive has to be loaded. Since Lenovo's CD images are intended to be used with a docking station's CD drive, it is not possible to use them for BIOS updates by booting from an USB CD drive.&lt;br /&gt;
&lt;br /&gt;
But there is hope. The CD images provided by Lenovo can be modified such that they contain drivers for USB CD drives. I tested the following with a Thinkpad X60s.&lt;br /&gt;
&lt;br /&gt;
The idea is to take Lenovo's ISO CD image and modify it such that a USB CD drive can be used instead the CD drive in the docking station. Unfortunately, simply replacing the drivers is not enough. While doing the BIOS update, the USB ports seem to get disabled or something. Therefore, before starting the update process the CD contents have to be copied to a RAM disk. I will describe the procedure step by step.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ol&amp;gt;&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Download the ISO image style BIOS update from Lenovo's website. This file will be refered to as &amp;lt;tt&amp;gt;/tmp/bios-lenovo.iso&amp;lt;/tt&amp;gt;.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Extract the floppy image from this ISO image. You can use the following shell script for this task. Simply save this code into the file &amp;lt;tt&amp;gt;/tmp/extractbootimage.sh&amp;lt;/tt&amp;gt;, set the x-flag (&amp;lt;tt&amp;gt;chmod +x /tmp/extractbootimage.sh&amp;lt;/tt&amp;gt;) and call it using the command &amp;lt;tt&amp;gt;/tmp/extractbootimage.sh /tmp/bios-lenovo.iso /tmp/bios-lenovo.img&amp;lt;/tt&amp;gt;. The floppy image contained in the ISO image will then be saved to &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img&amp;lt;/tt&amp;gt;. Here is the code of the shell script:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
#!/bin/bash&lt;br /&gt;
&lt;br /&gt;
# This script extracts the floopy boot image from bootable ISO images&lt;br /&gt;
#&lt;br /&gt;
# Written by Joachim Selke (mail@joachim-selke.de), 2007-04-07&lt;br /&gt;
&lt;br /&gt;
ISOFILE=$1&lt;br /&gt;
IMAGEFILE=$2&lt;br /&gt;
&lt;br /&gt;
if [ ! -r $ISOFILE ]; then&lt;br /&gt;
        echo $ISOFILE: file does not exist or is not readable&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
if [ -z $IMAGEFILE ]; then&lt;br /&gt;
        echo Error: no image file specified&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
ISOFILESIZE=`stat -c %s $ISOFILE`&lt;br /&gt;
&lt;br /&gt;
# collect El Torito data&lt;br /&gt;
# see http://www.phoenix.com/NR/rdonlyres/98D3219C-9CC9-4DF5-B496-A286D893E36A/0/specscdrom.pdf for reference&lt;br /&gt;
&lt;br /&gt;
BOOTCATALOGPOINTERBYTE=$((17 * 0x800 + 0x47))&lt;br /&gt;
&lt;br /&gt;
if [ $ISOFILESIZE -lt $(($BOOTCATALOGPOINTERBYTE + 4)) ]; then&lt;br /&gt;
        echo ISO file is too short, possibly damaged&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
# absolute pointer to first sector of boot catalog:&lt;br /&gt;
BOOTCATALOG=`od -A n -t x4 -N 4 -j $BOOTCATALOGPOINTERBYTE $ISOFILE | tr -d [:blank:]`&lt;br /&gt;
&lt;br /&gt;
BOOTCATALOGBYTE=$((0x$BOOTCATALOG * 0x800))&lt;br /&gt;
&lt;br /&gt;
echo Boot catalog starts at byte $BOOTCATALOGBYTE&lt;br /&gt;
&lt;br /&gt;
if [ $ISOFILESIZE -lt $(($BOOTCATALOGBYTE + 32 + 2)) ]; then&lt;br /&gt;
        echo ISO file is too short, possibly damaged&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
# media type of boot image&lt;br /&gt;
# only floppy disk images are supported by this script&lt;br /&gt;
BOOTMEDIATYPE=`od -A n -t x1 -N 1 -j $(($BOOTCATALOGBYTE + 32 + 1)) $ISOFILE | tr -d [:blank:]`&lt;br /&gt;
&lt;br /&gt;
if [ $BOOTMEDIATYPE -eq 1 ]; then&lt;br /&gt;
        echo Boot media type is 1.2M floppy disk&lt;br /&gt;
        IMAGEBLOCKS=$((1200 / 2))&lt;br /&gt;
elif [ $BOOTMEDIATYPE -eq 2 ]; then&lt;br /&gt;
        echo Boot media type is 1.44M floppy disk&lt;br /&gt;
        IMAGEBLOCKS=$((1440 / 2))&lt;br /&gt;
elif [ $BOOTMEDIATYPE -eq 3 ]; then&lt;br /&gt;
        echo Boot media type is 2.88M floppy disk&lt;br /&gt;
        IMAGEBLOCKS=$((2880 / 2))&lt;br /&gt;
else&lt;br /&gt;
        echo Boot media type is $((0x$BOOTMEDIATYPE)). This type is not supported yet.&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
# absolute pointer to start of boot image&lt;br /&gt;
BOOTIMAGE=`od -A n -t x4 -N 4 -j $(($BOOTCATALOGBYTE + 32 + 8)) $ISOFILE | tr -d [:blank:]`&lt;br /&gt;
&lt;br /&gt;
BOOTIMAGEBYTE=$((0x$BOOTIMAGE * 0x800))&lt;br /&gt;
&lt;br /&gt;
echo Boot image starts at byte $BOOTIMAGEBYTE&lt;br /&gt;
&lt;br /&gt;
if [ $ISOFILESIZE -lt $((0x$BOOTIMAGE * 0x800 + $IMAGEBLOCKS * 0x800)) ]; then&lt;br /&gt;
        echo ISO file is too short, possibly damaged&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
echo Extracting boot image ...&lt;br /&gt;
&lt;br /&gt;
dd if=$ISOFILE of=$IMAGEFILE bs=2K count=$IMAGEBLOCKS skip=$((0x$BOOTIMAGE))&lt;br /&gt;
&lt;br /&gt;
echo Finished&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Mount the floppy image '''as root''' using the loop device:&lt;br /&gt;
:{{cmdroot|mkdir /tmp/bios-lenovo.img-mnt}}&lt;br /&gt;
:{{cmdroot|mount -o loop /tmp/bios-lenovo.img /tmp/bios-lenovo.img-mnt}}&lt;br /&gt;
The image is now mounted as &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img-mnt&amp;lt;/tt&amp;gt;.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Download needed drivers. First download some [http://panasonic.co.jp/pcc/products/drive/other/driver/f2h_usb.exe USB drivers] from Panasonic Japan. Save the file to &amp;lt;tt&amp;gt;/tmp/f2h_usb.exe&amp;lt;/tt&amp;gt; This file is a self-extracting EXE file, that can be executed under Linux using [http://www.winehq.com/ Wine]:&lt;br /&gt;
:{{cmduser|wine /tmp/f2h_usb.exe}}&lt;br /&gt;
You will be asked where to save the extracted files. Choose &amp;lt;tt&amp;gt;/tmp&amp;lt;/tt&amp;gt;. A new directory &amp;lt;tt&amp;gt;/tmp/F2h&amp;lt;/tt&amp;gt; containing the needed drivers will be created.&lt;br /&gt;
&lt;br /&gt;
Additionally, you will need drivers for the RAM disk mentioned. Download them from the [http://sourceforge.net/projects/srdisk ReSizeable RAMDisk project]. Unzip them to &amp;lt;tt&amp;gt;/tmp/srdisk&amp;lt;/tt&amp;gt;.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Let's modify the floppy image:&lt;br /&gt;
:{{cmduser|cp /tmp/F2h/Usbaspi.sys /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/F2h/USBCD.SYS /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/F2h/RAMFD.SYS /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/srdisk/srdxms.sys /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/srdisk/srdisk.exe /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
Now add the following lines to &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img-mnt/config.sys&amp;lt;/tt&amp;gt; replacing the line &amp;lt;tt&amp;gt;DEVICE = A:\IBMTPCD.SYS /R /C&amp;lt;/tt&amp;gt;:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
DEVICE = A:\SRDXMS.SYS&lt;br /&gt;
DEVICE = A:\RAMFD.SYS&lt;br /&gt;
DEVICE = A:\USBASPI.SYS /V&lt;br /&gt;
DEVICE = A:\USBCD.SYS /D:TPCD001&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Finally, edit the file &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img-mnt/autoexec.bat&amp;lt;/tt&amp;gt; replacing the last line (saying &amp;lt;tt&amp;gt;COMMAND.COM&amp;lt;/tt&amp;gt;) by the following:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
A:\SRDISK 10000&lt;br /&gt;
COPY *.* D:&lt;br /&gt;
D:&lt;br /&gt;
COMMAND.COM&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Unmount the floppy image (as root):&lt;br /&gt;
:{{cmdroot|umount /tmp/bios-lenovo.img-mnt}}&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Copy the content of the original CD image to a new directory and create a new ISO file:&lt;br /&gt;
:{{cmdroot|mkdir /tmp/bios-lenovo.iso-mnt}}&lt;br /&gt;
:{{cmdroot|mount -o loop /tmp/bios-lenovo.iso /tmp/bios-lenovo.iso-mnt}}&lt;br /&gt;
:{{cmduser|mkdir /tmp/bios-new.iso-mnt}}&lt;br /&gt;
:{{cmduser|cp /tmp/bios-lenovo.iso-mnt/* /tmp/bios-new.iso-mnt}}&lt;br /&gt;
:{{cmduser|cp /tmp/bios-lenovo.img /tmp/bios-new.iso-mnt/boot.img}}&lt;br /&gt;
:{{cmdroot|umount /tmp/bios-lenovo.iso-mnt}}&lt;br /&gt;
:{{cmduser|mkisofs -b boot.img -o /tmp/bios-new.iso /tmp/bios-new.iso-mnt/}}&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
The file &amp;lt;tt&amp;gt;/tmp/bios-new.iso&amp;lt;/tt&amp;gt; is the modified ISO file. Just burn it to CD and use this CD for updating your BIOS (boot from it using your USB drive). Please give some comments here if it worked for you.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/ol&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Updating via CD/DVD Drive==&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&lt;br /&gt;
&lt;br /&gt;
Be aware that IBM officially does '''not''' support this! The official statement to my support request was:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
I'm afraid we only support the options listed on our web page and no you&lt;br /&gt;
can't burn a CD/DVD, however you can try to use an external USB FDD&lt;br /&gt;
(floppy) drive. The experts recommend a IBM USB FDD, however they have also&lt;br /&gt;
tested it with a Sony USB FDD drive.&lt;br /&gt;
&lt;br /&gt;
In order to make sure the drive is recognised you can boot up the FDD with&lt;br /&gt;
a bootable dos diskette for w98&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
But it seems to be possible as Mathias Dalheimer describes this [http://mailman.linux-thinkpad.org/pipermail/linux-thinkpad/1998-January/009743.html here].&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
{{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!}}&lt;br /&gt;
&lt;br /&gt;
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].&lt;br /&gt;
&lt;br /&gt;
===Creating a Floppy Image===&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmdroot|1=dd bs=2x80x18b if=/dev/fd0 of=/tmp/floppy.img}}&lt;br /&gt;
&lt;br /&gt;
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).&lt;br /&gt;
&lt;br /&gt;
You should verify this {{path|floppy.img}} as explained above.&lt;br /&gt;
&lt;br /&gt;
===Creating a Bootable CD from a Floppy Image===&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmdroot|mkisofs -b bootfloppy.img -o bootcd.iso bootfloppy.img}}&lt;br /&gt;
&lt;br /&gt;
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 &amp;lt;tt&amp;gt;-b &amp;lt;boot image&amp;gt;&amp;lt;/tt&amp;gt; is applied to the CD.  For more info on this read {{cmduser|man mkisofs}}.&lt;br /&gt;
&lt;br /&gt;
You can now burn the {{path|bootcd.iso}} in your favorite CD burning program.&lt;br /&gt;
&lt;br /&gt;
To get an overview which models have been tested with this version, here is a list:&lt;br /&gt;
&lt;br /&gt;
===Does work:===&lt;br /&gt;
{| border=&amp;quot;1&amp;quot; cellspacing=&amp;quot;0&amp;quot; cellpadding=&amp;quot;2&amp;quot;&lt;br /&gt;
| '''Model''' || '''Tested by'''&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{600X}} (2645) ||&lt;br /&gt;
*Jonathan Byrne &amp;lt;jonathan@RemoveThisToMailMe.yamame.org&amp;gt;. BIOS 1.11 from spsuit55.exe worked perfectly using cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A20p}} (2629-6VU) ||&lt;br /&gt;
*Chris Pickett http://www.sable.mcgill.ca/~cpicke/. BIOS 1.11 flashed fine with cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A21e}} (2628-JXU) ||&lt;br /&gt;
*Amit Gurdasani &amp;lt;gurdasani at yahoo dot com&amp;gt;. 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 &amp;quot;do not shut down the laptop&amp;quot; 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.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A31p}} (2653) ||&lt;br /&gt;
*Matthias Meinke largeeddy@gmx.at, BIOS 1.09 1NET15WW flashed fine with cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A31}} (2652) ||&lt;br /&gt;
*[[User:Wnoise|Aaron Denney]], BIOS 1.13 flashed fine with cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{R31}} ||&lt;br /&gt;
*[http://mailman.linux-thinkpad.org/pipermail/linux-thinkpad/1998-January/009743.html Mathias Dalheimer]&lt;br /&gt;
*Sebastian Sauer (with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R40}} ||&lt;br /&gt;
*Matthew Lambie, http://lambie.org&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R50}} (1836-3SU) ||&lt;br /&gt;
*jlbartos &amp;lt;jlbartos at hotmail dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R50e}} (1834-PTG) ||&lt;br /&gt;
*item &amp;lt;item at freemail dot hu&amp;gt; : successfully finished with cabextract/CD method for &amp;quot;1wuj25us.exe&amp;quot; (BIOS version 1WET90WW (2.10), Release Date: 2006/12/22)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R51}} (1829) ||&lt;br /&gt;
*Robert Uhl &amp;lt;rob dot uhl at gmx dot de&amp;gt;, Jellby &amp;lt;jellby at yahoo dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R51}} (1830-RM7) ||&lt;br /&gt;
*Will Parker &amp;lt;stardotstar at sourcepoint dot com dot au&amp;gt; successfully flashed 3.20 using existing 3.04 ECP and retained custom boot splash.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R51}} (2887) ||&lt;br /&gt;
*Ingo van Lil &amp;lt;inguin at gmx dot de&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R52}} (1858) ||&lt;br /&gt;
*Stuart McCord &amp;lt;stuart dot mccord at gmail dot com&amp;gt;  flashed both BIOS and ECP using cabextract, BIOS flashed first as on IBM website&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T20}} ||&lt;br /&gt;
*Franz Hassels &amp;lt;fhassel at suse dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T22}} ||&lt;br /&gt;
*Daniel Maier &amp;lt;nusse teamidiot de&amp;gt;&lt;br /&gt;
*Mathias Behrle (with cabextract/CD method, Version 1.07 =&amp;gt; 1.12) --[[User:Mathiasb|Mathiasb]] 11:58, 14 December 2006 (CET)&lt;br /&gt;
*Bob Skaroff (cabextract/CD), 1.06 =&amp;gt; 1.12&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T23}} ||&lt;br /&gt;
*Bart Snapp &amp;lt;snapp at uiuc dot edu&amp;gt; Note: I followed IBM's instructions to flash the BIOS *first* and the Embedded Controller *second*.&lt;br /&gt;
*Moy Easwaran: BIOS 1.18 / EC 1.06a via cabextract and CD-boot.  The BIOS-update exe generated errors in Windows 2000.&lt;br /&gt;
*Joe Renes: BIOS 1.18 / EC 1.06a on 2006-03-20 via cabextract and CD-boot. Piece of cake.&lt;br /&gt;
*Raphael Errani: BIOS 1.20 / EC 1.06a on 2006-11-06 via cabextract and CD-boot (using mkisofs). Worked without errors. 1st Bios, 2nd EC&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T30}} ||&lt;br /&gt;
*Martin GÃ¼hring &amp;lt;guehring at gmail.com&amp;gt; BIOS 2.10 via cabextract the Non-Diskette BIOS -&amp;gt; mkisofs '''in the directory the exe was extracted''' to generate the iso -&amp;gt; burn the iso -&amp;gt; boot the CD&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{T40}} ||&lt;br /&gt;
*Sean Dague, http://dague.net&lt;br /&gt;
*Justin Mason, http://jmason.org&lt;br /&gt;
*Ivanhoe (Bios 3.19)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T40p}} ||&lt;br /&gt;
*Lukas KrÃ¤henbÃ¼hl, ismo at pop dot agri dot ch&lt;br /&gt;
*Thomas Achtemichuk, tom at tomchuk dot com. BIOS 3.15 flashed fine with cabextract/CD method&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{T41}} ||&lt;br /&gt;
*Lev Givon (Bios 3.15 / EC 3.04) &amp;lt;lev at columbia dot edu&amp;gt;&lt;br /&gt;
*Ernesto HernÃ¡ndez-Novich (Bios 3.19 / CP 3.04) &amp;lt; emhn at usb dot ve &amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T41p}} ||&lt;br /&gt;
*Nils Newman, work great. (Version: Bios 3.14 / Embedded Controller 3.04)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T42}} ||&lt;br /&gt;
*Dan (BIOS 3.20 / EC 3.04, cabextract/CD method) &amp;lt;tronic171 at evilphb.org&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T42p}} ||&lt;br /&gt;
*Robert Schiele &amp;lt;rschiele@uni-mannheim.de&amp;gt;, Joern Heissler &amp;lt;joern@heissler.de&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T43}}  ||&lt;br /&gt;
*Conrad Rentsch &amp;lt;Conrad dot Rentsch at t-online dot de&amp;gt; (Version: Bios 1.29 / Embedded Controller 1.06)&lt;br /&gt;
*Tom Heady &amp;lt;tom-thinkwiki.org@punch.net&amp;gt;&lt;br /&gt;
*Florian Boucault &amp;lt;florian at boucault dot ath dot cx&amp;gt; (Model : 1871-W34 &amp;amp; Version: Bios 1.23 / Embedded Controller 1.03)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X20}}  ||&lt;br /&gt;
*Neil Caunt &amp;lt;retardis at gmail dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X21}}  ||&lt;br /&gt;
*Patrick Leickner &amp;lt;ranma at web dot de&amp;gt;, (BIOS 2.21-&amp;gt;2.25 / EC 1.31-&amp;gt;1.36) via non-disk/cabextract/mkisofs/cdrecord&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X22}}  ||&lt;br /&gt;
*David Emery &amp;lt;dave at skiddlydee dot com&amp;gt;,  (EC 1.30, BIOS 1.32 using non-disk/cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X23}}  ||&lt;br /&gt;
*Nils Faerber &amp;lt;nils dot faerber at kernelconcepts dot de&amp;gt; (Embedded Controller 1.30, BIOS 1.32 with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X30}}  ||&lt;br /&gt;
*Hella Breitkopf, [http://www.unixwitch.de/ www]  (Embedded Controller 1.04, BIOS 1.07 with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X31}}  ||&lt;br /&gt;
*Grzegorz KuÅ›nierz &amp;lt;koniu at sheket dot org&amp;gt;  (Embedded Controller 1.08, BIOS 3.01 with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X40}}  ||&lt;br /&gt;
*Robbie Stone &amp;lt;robbie@serendipity.cx&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{Z60m}}  ||&lt;br /&gt;
*[[User:Morle|Morle]] 13:09, 20 May 2006 (CEST),  (Embedded Controller 1.14 with cabextract/CD method)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Does not work:===&lt;br /&gt;
{|&lt;br /&gt;
| '''Model''' || '''Tested by'''&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Please note that testing this is '''at your own risk'''!!!&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Updating via Grub and a Floppy Image==&lt;br /&gt;
&lt;br /&gt;
{{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!}}&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
title     Bios Flash&lt;br /&gt;
kernel    /boot/memdisk&lt;br /&gt;
initrd    /boot/FILENAME.img&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Again, proceed at your own risk.  This was tested on an R51 type 2888.&lt;br /&gt;
&lt;br /&gt;
This also worked for me on a T41p type 2373. -- [[User:MrStaticVoid|James Lee]] 20:55, 8 May 2006 (CEST)&lt;br /&gt;
&lt;br /&gt;
And it worked for me on a X31 type 2673-CBU. -- [[User:JanTopinski|Jan Topinski]], 18 September 2006 &lt;br /&gt;
&lt;br /&gt;
And it worked for me too on a X31 type 2672-CXU, very useful. -- [[User:TheAnarcat|TheAnarcat]] 16:21, 7 March 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
And it worked for me on two X40 type 2371 -- [[User:Antialize|Jakob Truelsen]], 19 Jan 2007 -- BIOS: 2.07 1uuj21us.exe -- ECP: 1.62 1uhj10us.exe&lt;br /&gt;
&lt;br /&gt;
Not working for me on T43 type 2668-F7G -- [[User:Maus3273|Maus3273]] 20:48, 30 January 2007 (CET) -- BIOS: 1.29 1YUJ18US.IMG -- I got into the bios program, but the machine never restarts after initiating the upgrade.&lt;br /&gt;
&lt;br /&gt;
X41 type 2525-F8G -- [[User:ladoga|Lauri Koponen]], 11:08 16 Apr 2007&amp;lt;br&amp;gt; &lt;br /&gt;
BIOS: 2.09 (74UJ15US.IMG), is no go. (hangs while initialising the actual flash process) I tried with 2.07 (74UJ13US.IMG) and 2.06 (74UJ12US.IMG) aswell and they all failed in the very same fashion.&amp;lt;br&amp;gt;&lt;br /&gt;
ECP: 1.02 74HJ03US.IMG, works.&lt;br /&gt;
&lt;br /&gt;
==Updating with Network Boot Image==&lt;br /&gt;
&lt;br /&gt;
BIOS, Embedded Controller (EC), CD/DVD and Harddisk firmware disks can be booted&lt;br /&gt;
over the network with [http://syslinux.zytor.com/pxe.php PXELINUX] as part of the [http://syslinux.zytor.com/ SYSLINUX] package.&lt;br /&gt;
&lt;br /&gt;
This requires that you have a DHCP and tftp server configured and setup properly on&lt;br /&gt;
your network, and is probably not for the faint of heart.&lt;br /&gt;
&lt;br /&gt;
Make sure the firmware bootdisk is in linux 'dd' format, as the self-extracting .exe disks&lt;br /&gt;
from the IBM website cannot be booted directly as such.&lt;br /&gt;
&lt;br /&gt;
This worked on the {{R31}}, {{X22}}, {{T21}}, {{T30}} and {{T41p}} with various firmware updates.&lt;br /&gt;
&lt;br /&gt;
==Updating via &amp;quot;IBM Predesktop area&amp;quot;, suitable for model X (not have CDROM and floppy)==&lt;br /&gt;
It's so difficult to update BIOS and ECP without cdrom, floppy disk.&lt;br /&gt;
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: 	&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
Primary: ext3, ext3, ntfs&lt;br /&gt;
Extended: Ntsf, fat32&lt;br /&gt;
Bootloader: GRUB&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
No problem, you can use this way to do it:&lt;br /&gt;
* First, config in BIOS&lt;br /&gt;
In Security part:&lt;br /&gt;
# Remove all password of Subpervisor and Power on password&lt;br /&gt;
# Set Access IBM Predesktop Area to Normal&lt;br /&gt;
# Choose Enable &amp;quot;Flash BIOS updating by End User&amp;quot; in BIOS update Option.&lt;br /&gt;
&lt;br /&gt;
In Config part:&lt;br /&gt;
# Choose Enable for Network flash over Lan&lt;br /&gt;
&lt;br /&gt;
* Second, download the newest version of BIOS update and ECP update &lt;br /&gt;
Running: The program extract all files to the folder. There is a .img file (1QUJ19US.IMG, 1QUJ08US.IMG) in each folder.&lt;br /&gt;
Copy the imformation content in that img file and paste it to one FAT partition(using winimage or TotalCmd to extract) &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
as seen All files in 1QUJ19US.IMG is extracted to D:\BIOS&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
695,764  $018E000.FL1&lt;br /&gt;
163      0691.HSH&lt;br /&gt;
2,049    0691.PAT&lt;br /&gt;
163      0694.HSH&lt;br /&gt;
2,049    0694.PAT&lt;br /&gt;
163      0695.HSH&lt;br /&gt;
2,049    0695.PAT&lt;br /&gt;
2,049    06D0.PAT&lt;br /&gt;
163      06D1.HSH&lt;br /&gt;
2,049    06D1.PAT&lt;br /&gt;
163      06D2.HSH&lt;br /&gt;
2,049    06D2.PAT&lt;br /&gt;
163      06D6.HSH&lt;br /&gt;
2,049    06D6.PAT&lt;br /&gt;
2,049    06D8.PAT&lt;br /&gt;
697      CHKBMP.EXE&lt;br /&gt;
8,128    COMMAND.COM&lt;br /&gt;
26       CONFIG.SYS&lt;br /&gt;
24,860   FLASH2.EXE&lt;br /&gt;
26       LCREFLSH.BAT&lt;br /&gt;
170      LOGO.BAT&lt;br /&gt;
330      LOGO.SCR&lt;br /&gt;
111,925  PHLASH16.EXE&lt;br /&gt;
91,648   PREPARE.EXE&lt;br /&gt;
45       PROD.DAT&lt;br /&gt;
22,252   QKFLASH.EXE&lt;br /&gt;
9,923    README.TXT&lt;br /&gt;
4,260    TPCHKS.EXE&lt;br /&gt;
39,666   UPDTFLSH.EXE&lt;br /&gt;
6,958    UPDTMN.EXE&lt;br /&gt;
12,501   USERINT.EXE&lt;br /&gt;
15,254   UTILINFO.EXE&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
And all files in 1QUJ08US.IMG are: D:\ECP&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
315,404 $018E000.FL2&lt;br /&gt;
8,000   COMMAND.COM&lt;br /&gt;
36      CONFIG.SYS&lt;br /&gt;
16,910  ECFLASH2.EXE&lt;br /&gt;
45      PROD.DAT&lt;br /&gt;
17,812  QKFLASH.EXE&lt;br /&gt;
990     README.TXT&lt;br /&gt;
4,260   TPCHKS.EXE&lt;br /&gt;
89,738  UPDTEC.EXE&lt;br /&gt;
31,134  UPDTFLSH.EXE&lt;br /&gt;
12,501  USERINT.EXE&lt;br /&gt;
15,226  UTILINFO.EXE&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
* Okie, now plug AC Adapter, charge full battery to your laptop and continue third step:&lt;br /&gt;
&lt;br /&gt;
** '''Flash BIOS first,'''&lt;br /&gt;
1. Power On, press blue button on keyboard: '''Access IBM'''&lt;br /&gt;
&lt;br /&gt;
2. On &amp;quot;Utilities&amp;quot;, double click &amp;quot; Diagnostic disk&amp;quot;&lt;br /&gt;
&lt;br /&gt;
3. Your laptop will start PC-DOS, wait when this message appear:&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
Please insert the first floppy diskette and&lt;br /&gt;
Press any key to continue&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
4. Press Ctrl + Break, you will see :&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;Terminate batch job (Y/N) ?&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
5. Okie, press Y, you will get DOS prompt like D:\&lt;br /&gt;
{{NOTE|D:\ is my RAMDISK, C:\ is my disk format as FAT.!}}&lt;br /&gt;
&lt;br /&gt;
6. Enter to c:\BIOS&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
c:&lt;br /&gt;
cd c:\BIOS&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
7. Run FLASH2.EXE /u $018E000.FL1&lt;br /&gt;
&lt;br /&gt;
8. Wait flash progress compelete and reboot.&lt;br /&gt;
** '''Flash ECP'''&lt;br /&gt;
Follow above instruction from step 1 to 5&lt;br /&gt;
&lt;br /&gt;
6. Enter to c:\ECP&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
c:&lt;br /&gt;
cd c:\ECP&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
7. run UPDTFLSH.EXE $018E000.FL2&lt;br /&gt;
&lt;br /&gt;
8. Follow UPDTFLSH's instructions&lt;br /&gt;
&lt;br /&gt;
9. Wait flash complete and auto turn off computer.&lt;br /&gt;
&lt;br /&gt;
I done it on my IBM Thinkpad X31.&lt;br /&gt;
&lt;br /&gt;
Enjoy,&lt;br /&gt;
&lt;br /&gt;
Tested by nm.&lt;br /&gt;
&lt;br /&gt;
==Check List==&lt;br /&gt;
&lt;br /&gt;
The following is important to remember:&lt;br /&gt;
# 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)&lt;br /&gt;
# 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.&lt;br /&gt;
# You must update the Control Program '''before''' you update the BIOS&lt;br /&gt;
&lt;br /&gt;
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.&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=BIOS_Upgrade&amp;diff=29345</id>
		<title>BIOS Upgrade</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=BIOS_Upgrade&amp;diff=29345"/>
		<updated>2007-04-16T08:28:18Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* Updating via Grub and a Floppy Image */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;__TOC__&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
{{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.}}&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
==Before You Begin==&lt;br /&gt;
Updating the BIOS in Linux (with few exceptions) '''is not officially supported''' by IBM.  However there are work arounds.&lt;br /&gt;
&lt;br /&gt;
{{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.&lt;br /&gt;
&lt;br /&gt;
'''Proceed at your own risk!'''&lt;br /&gt;
&lt;br /&gt;
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 risk turning your thinkpad into a very nice paper weight.}}&lt;br /&gt;
&lt;br /&gt;
==BIOS Upgrade Paths==&lt;br /&gt;
&lt;br /&gt;
For every firmware (either BIOS or Control Program) update on the IBM site there are two different firmware update programs provided.  A list of links to firmware downloads can be found at [[BIOS Upgrade Downloads]] for nearly all Thinkpad Models.&lt;br /&gt;
&lt;br /&gt;
===The Diskette Updater===&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
===The Non Diskette Updater===&lt;br /&gt;
{{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.}}&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmduser|cabextract FILENAME.exe}}&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmdroot|mkdir mntfloppy}}&lt;br /&gt;
:{{cmdroot|mount -o loop FILENAME.img mntfloppy}}&lt;br /&gt;
:{{cmdroot|ls -la mntfloppy}}&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
== Updating Thinkpad X Series ==&lt;br /&gt;
&lt;br /&gt;
X Series Thinkpads do not have an internal drive. If there is no Windows installed, the BIOS must be updated by booting from an USB drive or a drive that is integrated in the docking station. Since a while Lenovo provides BIOS updates in form of bootable CD images. Unfortunately, these images are intended to be used with the docking station's CD drive. If you do not own such a drive, things get complicated.&lt;br /&gt;
&lt;br /&gt;
The problem is that current BIOS updates are quite large, about 3 MB in size. Booting from CDs typically works like booting from a 1.44 MB or 2.88 MB floppy disk. The floppy image is stored on the CD and is referenced in the CD's boot record. Because the BIOS update file are that large, they do not fit on such a floppy image. Thus, they must be stored on the CD outside the virtual floppy image. To access these files a driver for the CD drive has to be loaded. Since Lenovo's CD images are intended to be used with a docking station's CD drive, it is not possible to use them for BIOS updates by booting from an USB CD drive.&lt;br /&gt;
&lt;br /&gt;
But there is hope. The CD images provided by Lenovo can be modified such that they contain drivers for USB CD drives. I tested the following with a Thinkpad X60s.&lt;br /&gt;
&lt;br /&gt;
The idea is to take Lenovo's ISO CD image and modify it such that a USB CD drive can be used instead the CD drive in the docking station. Unfortunately, simply replacing the drivers is not enough. While doing the BIOS update, the USB ports seem to get disabled or something. Therefore, before starting the update process the CD contents have to be copied to a RAM disk. I will describe the procedure step by step.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;ol&amp;gt;&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Download the ISO image style BIOS update from Lenovo's website. This file will be refered to as &amp;lt;tt&amp;gt;/tmp/bios-lenovo.iso&amp;lt;/tt&amp;gt;.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Extract the floppy image from this ISO image. You can use the following shell script for this task. Simply save this code into the file &amp;lt;tt&amp;gt;/tmp/extractbootimage.sh&amp;lt;/tt&amp;gt;, set the x-flag (&amp;lt;tt&amp;gt;chmod +x /tmp/extractbootimage.sh&amp;lt;/tt&amp;gt;) and call it using the command &amp;lt;tt&amp;gt;/tmp/extractbootimage.sh /tmp/bios-lenovo.iso /tmp/bios-lenovo.img&amp;lt;/tt&amp;gt;. The floppy image contained in the ISO image will then be saved to &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img&amp;lt;/tt&amp;gt;. Here is the code of the shell script:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
#!/bin/bash&lt;br /&gt;
&lt;br /&gt;
# This script extracts the floopy boot image from bootable ISO images&lt;br /&gt;
#&lt;br /&gt;
# Written by Joachim Selke (mail@joachim-selke.de), 2007-04-07&lt;br /&gt;
&lt;br /&gt;
ISOFILE=$1&lt;br /&gt;
IMAGEFILE=$2&lt;br /&gt;
&lt;br /&gt;
if [ ! -r $ISOFILE ]; then&lt;br /&gt;
        echo $ISOFILE: file does not exist or is not readable&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
if [ -z $IMAGEFILE ]; then&lt;br /&gt;
        echo Error: no image file specified&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
ISOFILESIZE=`stat -c %s $ISOFILE`&lt;br /&gt;
&lt;br /&gt;
# collect El Torito data&lt;br /&gt;
# see http://www.phoenix.com/NR/rdonlyres/98D3219C-9CC9-4DF5-B496-A286D893E36A/0/specscdrom.pdf for reference&lt;br /&gt;
&lt;br /&gt;
BOOTCATALOGPOINTERBYTE=$((17 * 0x800 + 0x47))&lt;br /&gt;
&lt;br /&gt;
if [ $ISOFILESIZE -lt $(($BOOTCATALOGPOINTERBYTE + 4)) ]; then&lt;br /&gt;
        echo ISO file is too short, possibly damaged&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
# absolute pointer to first sector of boot catalog:&lt;br /&gt;
BOOTCATALOG=`od -A n -t x4 -N 4 -j $BOOTCATALOGPOINTERBYTE $ISOFILE | tr -d [:blank:]`&lt;br /&gt;
&lt;br /&gt;
BOOTCATALOGBYTE=$((0x$BOOTCATALOG * 0x800))&lt;br /&gt;
&lt;br /&gt;
echo Boot catalog starts at byte $BOOTCATALOGBYTE&lt;br /&gt;
&lt;br /&gt;
if [ $ISOFILESIZE -lt $(($BOOTCATALOGBYTE + 32 + 2)) ]; then&lt;br /&gt;
        echo ISO file is too short, possibly damaged&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
# media type of boot image&lt;br /&gt;
# only floppy disk images are supported by this script&lt;br /&gt;
BOOTMEDIATYPE=`od -A n -t x1 -N 1 -j $(($BOOTCATALOGBYTE + 32 + 1)) $ISOFILE | tr -d [:blank:]`&lt;br /&gt;
&lt;br /&gt;
if [ $BOOTMEDIATYPE -eq 1 ]; then&lt;br /&gt;
        echo Boot media type is 1.2M floppy disk&lt;br /&gt;
        IMAGEBLOCKS=$((1200 / 2))&lt;br /&gt;
elif [ $BOOTMEDIATYPE -eq 2 ]; then&lt;br /&gt;
        echo Boot media type is 1.44M floppy disk&lt;br /&gt;
        IMAGEBLOCKS=$((1440 / 2))&lt;br /&gt;
elif [ $BOOTMEDIATYPE -eq 3 ]; then&lt;br /&gt;
        echo Boot media type is 2.88M floppy disk&lt;br /&gt;
        IMAGEBLOCKS=$((2880 / 2))&lt;br /&gt;
else&lt;br /&gt;
        echo Boot media type is $((0x$BOOTMEDIATYPE)). This type is not supported yet.&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
# absolute pointer to start of boot image&lt;br /&gt;
BOOTIMAGE=`od -A n -t x4 -N 4 -j $(($BOOTCATALOGBYTE + 32 + 8)) $ISOFILE | tr -d [:blank:]`&lt;br /&gt;
&lt;br /&gt;
BOOTIMAGEBYTE=$((0x$BOOTIMAGE * 0x800))&lt;br /&gt;
&lt;br /&gt;
echo Boot image starts at byte $BOOTIMAGEBYTE&lt;br /&gt;
&lt;br /&gt;
if [ $ISOFILESIZE -lt $((0x$BOOTIMAGE * 0x800 + $IMAGEBLOCKS * 0x800)) ]; then&lt;br /&gt;
        echo ISO file is too short, possibly damaged&lt;br /&gt;
        exit 1&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
echo Extracting boot image ...&lt;br /&gt;
&lt;br /&gt;
dd if=$ISOFILE of=$IMAGEFILE bs=2K count=$IMAGEBLOCKS skip=$((0x$BOOTIMAGE))&lt;br /&gt;
&lt;br /&gt;
echo Finished&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Mount the floppy image '''as root''' using the loop device:&lt;br /&gt;
:{{cmdroot|mkdir /tmp/bios-lenovo.img-mnt}}&lt;br /&gt;
:{{cmdroot|mount -o loop /tmp/bios-lenovo.img /tmp/bios-lenovo.img-mnt}}&lt;br /&gt;
The image is now mounted as &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img-mnt&amp;lt;/tt&amp;gt;.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Download needed drivers. First download some [http://panasonic.co.jp/pcc/products/drive/other/driver/f2h_usb.exe USB drivers] from Panasonic Japan. Save the file to &amp;lt;tt&amp;gt;/tmp/f2h_usb.exe&amp;lt;/tt&amp;gt; This file is a self-extracting EXE file, that can be executed under Linux using [http://www.winehq.com/ Wine]:&lt;br /&gt;
:{{cmduser|wine /tmp/f2h_usb.exe}}&lt;br /&gt;
You will be asked where to save the extracted files. Choose &amp;lt;tt&amp;gt;/tmp&amp;lt;/tt&amp;gt;. A new directory &amp;lt;tt&amp;gt;/tmp/F2h&amp;lt;/tt&amp;gt; containing the needed drivers will be created.&lt;br /&gt;
&lt;br /&gt;
Additionally, you will need drivers for the RAM disk mentioned. Download them from the [http://sourceforge.net/projects/srdisk ReSizeable RAMDisk project]. Unzip them to &amp;lt;tt&amp;gt;/tmp/srdisk&amp;lt;/tt&amp;gt;.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Let's modify the floppy image:&lt;br /&gt;
:{{cmduser|cp /tmp/F2h/Usbaspi.sys /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/F2h/USBCD.SYS /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/F2h/RAMFD.SYS /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/srdisk/srdxms.sys /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
:{{cmduser|cp /tmp/srdisk/srdisk.exe /tmp/bios-lenovo.img-mnt/}}&lt;br /&gt;
Now add the following lines to &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img-mnt/config.sys&amp;lt;/tt&amp;gt; replacing the line &amp;lt;tt&amp;gt;DEVICE = A:\IBMTPCD.SYS /R /C&amp;lt;/tt&amp;gt;:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
DEVICE = A:\SRDXMS.SYS&lt;br /&gt;
DEVICE = A:\RAMFD.SYS&lt;br /&gt;
DEVICE = A:\USBASPI.SYS /V&lt;br /&gt;
DEVICE = A:\USBCD.SYS /D:TPCD001&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
Finally, edit the file &amp;lt;tt&amp;gt;/tmp/bios-lenovo.img-mnt/autoexec.bat&amp;lt;/tt&amp;gt; replacing the last line (saying &amp;lt;tt&amp;gt;COMMAND.COM&amp;lt;/tt&amp;gt;) by the following:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
A:\SRDISK 10000&lt;br /&gt;
COPY *.* D:&lt;br /&gt;
D:&lt;br /&gt;
COMMAND.COM&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Unmount the floppy image (as root):&lt;br /&gt;
:{{cmdroot|umount /tmp/bios-lenovo.img-mnt}}&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
Copy the content of the original CD image to a new directory and create a new ISO file:&lt;br /&gt;
:{{cmdroot|mkdir /tmp/bios-lenovo.iso-mnt}}&lt;br /&gt;
:{{cmdroot|mount -o loop /tmp/bios-lenovo.iso /tmp/bios-lenovo.iso-mnt}}&lt;br /&gt;
:{{cmduser|mkdir /tmp/bios-new.iso-mnt}}&lt;br /&gt;
:{{cmduser|cp /tmp/bios-lenovo.iso-mnt/* /tmp/bios-new.iso-mnt}}&lt;br /&gt;
:{{cmduser|cp /tmp/bios-lenovo.img /tmp/bios-new.iso-mnt/boot.img}}&lt;br /&gt;
:{{cmdroot|umount /tmp/bios-lenovo.iso-mnt}}&lt;br /&gt;
:{{cmduser|mkisofs -b boot.img -o /tmp/bios-new.iso /tmp/bios-new.iso-mnt/}}&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;li&amp;gt;&lt;br /&gt;
The file &amp;lt;tt&amp;gt;/tmp/bios-new.iso&amp;lt;/tt&amp;gt; is the modified ISO file. Just burn it to CD and use this CD for updating your BIOS (boot from it using your USB drive). Please give some comments here if it worked for you.&lt;br /&gt;
&amp;lt;/li&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/ol&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Updating via CD/DVD Drive==&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
Another possibility which works even without a CD-drive or network is to boot the disk image via the grub initrd mechanism.&lt;br /&gt;
&lt;br /&gt;
Be aware that IBM officially does '''not''' support this! The official statement to my support request was:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
I'm afraid we only support the options listed on our web page and no you&lt;br /&gt;
can't burn a CD/DVD, however you can try to use an external USB FDD&lt;br /&gt;
(floppy) drive. The experts recommend a IBM USB FDD, however they have also&lt;br /&gt;
tested it with a Sony USB FDD drive.&lt;br /&gt;
&lt;br /&gt;
In order to make sure the drive is recognised you can boot up the FDD with&lt;br /&gt;
a bootable dos diskette for w98&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&lt;br /&gt;
&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
But it seems to be possible as Mathias Dalheimer describes this [http://mailman.linux-thinkpad.org/pipermail/linux-thinkpad/1998-January/009743.html here].&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
{{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!}}&lt;br /&gt;
&lt;br /&gt;
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].&lt;br /&gt;
&lt;br /&gt;
===Creating a Floppy Image===&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmdroot|1=dd bs=2x80x18b if=/dev/fd0 of=/tmp/floppy.img}}&lt;br /&gt;
&lt;br /&gt;
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).&lt;br /&gt;
&lt;br /&gt;
You should verify this {{path|floppy.img}} as explained above.&lt;br /&gt;
&lt;br /&gt;
===Creating a Bootable CD from a Floppy Image===&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
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.&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
:{{cmdroot|mkisofs -b bootfloppy.img -o bootcd.iso bootfloppy.img}}&lt;br /&gt;
&lt;br /&gt;
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 &amp;lt;tt&amp;gt;-b &amp;lt;boot image&amp;gt;&amp;lt;/tt&amp;gt; is applied to the CD.  For more info on this read {{cmduser|man mkisofs}}.&lt;br /&gt;
&lt;br /&gt;
You can now burn the {{path|bootcd.iso}} in your favorite CD burning program.&lt;br /&gt;
&lt;br /&gt;
To get an overview which models have been tested with this version, here is a list:&lt;br /&gt;
&lt;br /&gt;
===Does work:===&lt;br /&gt;
{| border=&amp;quot;1&amp;quot; cellspacing=&amp;quot;0&amp;quot; cellpadding=&amp;quot;2&amp;quot;&lt;br /&gt;
| '''Model''' || '''Tested by'''&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{600X}} (2645) ||&lt;br /&gt;
*Jonathan Byrne &amp;lt;jonathan@RemoveThisToMailMe.yamame.org&amp;gt;. BIOS 1.11 from spsuit55.exe worked perfectly using cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A20p}} (2629-6VU) ||&lt;br /&gt;
*Chris Pickett http://www.sable.mcgill.ca/~cpicke/. BIOS 1.11 flashed fine with cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A21e}} (2628-JXU) ||&lt;br /&gt;
*Amit Gurdasani &amp;lt;gurdasani at yahoo dot com&amp;gt;. 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 &amp;quot;do not shut down the laptop&amp;quot; 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.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A31p}} (2653) ||&lt;br /&gt;
*Matthias Meinke largeeddy@gmx.at, BIOS 1.09 1NET15WW flashed fine with cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{A31}} (2652) ||&lt;br /&gt;
*[[User:Wnoise|Aaron Denney]], BIOS 1.13 flashed fine with cabextract/CD method.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{R31}} ||&lt;br /&gt;
*[http://mailman.linux-thinkpad.org/pipermail/linux-thinkpad/1998-January/009743.html Mathias Dalheimer]&lt;br /&gt;
*Sebastian Sauer (with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R40}} ||&lt;br /&gt;
*Matthew Lambie, http://lambie.org&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R50}} (1836-3SU) ||&lt;br /&gt;
*jlbartos &amp;lt;jlbartos at hotmail dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R50e}} (1834-PTG) ||&lt;br /&gt;
*item &amp;lt;item at freemail dot hu&amp;gt; : successfully finished with cabextract/CD method for &amp;quot;1wuj25us.exe&amp;quot; (BIOS version 1WET90WW (2.10), Release Date: 2006/12/22)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R51}} (1829) ||&lt;br /&gt;
*Robert Uhl &amp;lt;rob dot uhl at gmx dot de&amp;gt;, Jellby &amp;lt;jellby at yahoo dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R51}} (1830-RM7) ||&lt;br /&gt;
*Will Parker &amp;lt;stardotstar at sourcepoint dot com dot au&amp;gt; successfully flashed 3.20 using existing 3.04 ECP and retained custom boot splash.&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R51}} (2887) ||&lt;br /&gt;
*Ingo van Lil &amp;lt;inguin at gmx dot de&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{R52}} (1858) ||&lt;br /&gt;
*Stuart McCord &amp;lt;stuart dot mccord at gmail dot com&amp;gt;  flashed both BIOS and ECP using cabextract, BIOS flashed first as on IBM website&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T20}} ||&lt;br /&gt;
*Franz Hassels &amp;lt;fhassel at suse dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T22}} ||&lt;br /&gt;
*Daniel Maier &amp;lt;nusse teamidiot de&amp;gt;&lt;br /&gt;
*Mathias Behrle (with cabextract/CD method, Version 1.07 =&amp;gt; 1.12) --[[User:Mathiasb|Mathiasb]] 11:58, 14 December 2006 (CET)&lt;br /&gt;
*Bob Skaroff (cabextract/CD), 1.06 =&amp;gt; 1.12&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T23}} ||&lt;br /&gt;
*Bart Snapp &amp;lt;snapp at uiuc dot edu&amp;gt; Note: I followed IBM's instructions to flash the BIOS *first* and the Embedded Controller *second*.&lt;br /&gt;
*Moy Easwaran: BIOS 1.18 / EC 1.06a via cabextract and CD-boot.  The BIOS-update exe generated errors in Windows 2000.&lt;br /&gt;
*Joe Renes: BIOS 1.18 / EC 1.06a on 2006-03-20 via cabextract and CD-boot. Piece of cake.&lt;br /&gt;
*Raphael Errani: BIOS 1.20 / EC 1.06a on 2006-11-06 via cabextract and CD-boot (using mkisofs). Worked without errors. 1st Bios, 2nd EC&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T30}} ||&lt;br /&gt;
*Martin GÃ¼hring &amp;lt;guehring at gmail.com&amp;gt; BIOS 2.10 via cabextract the Non-Diskette BIOS -&amp;gt; mkisofs '''in the directory the exe was extracted''' to generate the iso -&amp;gt; burn the iso -&amp;gt; boot the CD&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{T40}} ||&lt;br /&gt;
*Sean Dague, http://dague.net&lt;br /&gt;
*Justin Mason, http://jmason.org&lt;br /&gt;
*Ivanhoe (Bios 3.19)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T40p}} ||&lt;br /&gt;
*Lukas KrÃ¤henbÃ¼hl, ismo at pop dot agri dot ch&lt;br /&gt;
*Thomas Achtemichuk, tom at tomchuk dot com. BIOS 3.15 flashed fine with cabextract/CD method&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; | {{T41}} ||&lt;br /&gt;
*Lev Givon (Bios 3.15 / EC 3.04) &amp;lt;lev at columbia dot edu&amp;gt;&lt;br /&gt;
*Ernesto HernÃ¡ndez-Novich (Bios 3.19 / CP 3.04) &amp;lt; emhn at usb dot ve &amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T41p}} ||&lt;br /&gt;
*Nils Newman, work great. (Version: Bios 3.14 / Embedded Controller 3.04)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T42}} ||&lt;br /&gt;
*Dan (BIOS 3.20 / EC 3.04, cabextract/CD method) &amp;lt;tronic171 at evilphb.org&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T42p}} ||&lt;br /&gt;
*Robert Schiele &amp;lt;rschiele@uni-mannheim.de&amp;gt;, Joern Heissler &amp;lt;joern@heissler.de&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{T43}}  ||&lt;br /&gt;
*Conrad Rentsch &amp;lt;Conrad dot Rentsch at t-online dot de&amp;gt; (Version: Bios 1.29 / Embedded Controller 1.06)&lt;br /&gt;
*Tom Heady &amp;lt;tom-thinkwiki.org@punch.net&amp;gt;&lt;br /&gt;
*Florian Boucault &amp;lt;florian at boucault dot ath dot cx&amp;gt; (Model : 1871-W34 &amp;amp; Version: Bios 1.23 / Embedded Controller 1.03)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X20}}  ||&lt;br /&gt;
*Neil Caunt &amp;lt;retardis at gmail dot com&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X21}}  ||&lt;br /&gt;
*Patrick Leickner &amp;lt;ranma at web dot de&amp;gt;, (BIOS 2.21-&amp;gt;2.25 / EC 1.31-&amp;gt;1.36) via non-disk/cabextract/mkisofs/cdrecord&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X22}}  ||&lt;br /&gt;
*David Emery &amp;lt;dave at skiddlydee dot com&amp;gt;,  (EC 1.30, BIOS 1.32 using non-disk/cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X23}}  ||&lt;br /&gt;
*Nils Faerber &amp;lt;nils dot faerber at kernelconcepts dot de&amp;gt; (Embedded Controller 1.30, BIOS 1.32 with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X30}}  ||&lt;br /&gt;
*Hella Breitkopf, [http://www.unixwitch.de/ www]  (Embedded Controller 1.04, BIOS 1.07 with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X31}}  ||&lt;br /&gt;
*Grzegorz KuÅ›nierz &amp;lt;koniu at sheket dot org&amp;gt;  (Embedded Controller 1.08, BIOS 3.01 with cabextract/CD method)&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{X40}}  ||&lt;br /&gt;
*Robbie Stone &amp;lt;robbie@serendipity.cx&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| style=&amp;quot;vertical-align:top;&amp;quot; |  {{Z60m}}  ||&lt;br /&gt;
*[[User:Morle|Morle]] 13:09, 20 May 2006 (CEST),  (Embedded Controller 1.14 with cabextract/CD method)&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
===Does not work:===&lt;br /&gt;
{|&lt;br /&gt;
| '''Model''' || '''Tested by'''&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Please note that testing this is '''at your own risk'''!!!&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Updating via Grub and a Floppy Image==&lt;br /&gt;
&lt;br /&gt;
{{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!}}&lt;br /&gt;
&lt;br /&gt;
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:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
title     Bios Flash&lt;br /&gt;
kernel    /boot/memdisk&lt;br /&gt;
initrd    /boot/FILENAME.img&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Again, proceed at your own risk.  This was tested on an R51 type 2888.&lt;br /&gt;
&lt;br /&gt;
This also worked for me on a T41p type 2373. -- [[User:MrStaticVoid|James Lee]] 20:55, 8 May 2006 (CEST)&lt;br /&gt;
&lt;br /&gt;
And it worked for me on a X31 type 2673-CBU. -- [[User:JanTopinski|Jan Topinski]], 18 September 2006 &lt;br /&gt;
&lt;br /&gt;
And it worked for me too on a X31 type 2672-CXU, very useful. -- [[User:TheAnarcat|TheAnarcat]] 16:21, 7 March 2007 (CET)&lt;br /&gt;
&lt;br /&gt;
And it worked for me on two X40 type 2371 -- [[User:Antialize|Jakob Truelsen]], 19 Jan 2007 -- BIOS: 2.07 1uuj21us.exe -- ECP: 1.62 1uhj10us.exe&lt;br /&gt;
&lt;br /&gt;
Not working for me on T43 type 2668-F7G -- [[User:Maus3273|Maus3273]] 20:48, 30 January 2007 (CET) -- BIOS: 1.29 1YUJ18US.IMG -- I got into the bios program, but the machine never restarts after initiating the upgrade.&lt;br /&gt;
&lt;br /&gt;
X41 type 2525-F8G -- [[User:ladoga|Lauri Koponen]], 11:08 16 Apr 2007&amp;lt;br&amp;gt; &lt;br /&gt;
BIOS: 2.09 74UJ15US.IMG, no go. (hangs at the beginning of the flash process)&amp;lt;br&amp;gt;&lt;br /&gt;
ECP: 1.02 74HJ03US.IMG, works.&lt;br /&gt;
&lt;br /&gt;
==Updating with Network Boot Image==&lt;br /&gt;
&lt;br /&gt;
BIOS, Embedded Controller (EC), CD/DVD and Harddisk firmware disks can be booted&lt;br /&gt;
over the network with [http://syslinux.zytor.com/pxe.php PXELINUX] as part of the [http://syslinux.zytor.com/ SYSLINUX] package.&lt;br /&gt;
&lt;br /&gt;
This requires that you have a DHCP and tftp server configured and setup properly on&lt;br /&gt;
your network, and is probably not for the faint of heart.&lt;br /&gt;
&lt;br /&gt;
Make sure the firmware bootdisk is in linux 'dd' format, as the self-extracting .exe disks&lt;br /&gt;
from the IBM website cannot be booted directly as such.&lt;br /&gt;
&lt;br /&gt;
This worked on the {{R31}}, {{X22}}, {{T21}}, {{T30}} and {{T41p}} with various firmware updates.&lt;br /&gt;
&lt;br /&gt;
==Updating via &amp;quot;IBM Predesktop area&amp;quot;, suitable for model X (not have CDROM and floppy)==&lt;br /&gt;
It's so difficult to update BIOS and ECP without cdrom, floppy disk.&lt;br /&gt;
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: 	&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
Primary: ext3, ext3, ntfs&lt;br /&gt;
Extended: Ntsf, fat32&lt;br /&gt;
Bootloader: GRUB&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
No problem, you can use this way to do it:&lt;br /&gt;
* First, config in BIOS&lt;br /&gt;
In Security part:&lt;br /&gt;
# Remove all password of Subpervisor and Power on password&lt;br /&gt;
# Set Access IBM Predesktop Area to Normal&lt;br /&gt;
# Choose Enable &amp;quot;Flash BIOS updating by End User&amp;quot; in BIOS update Option.&lt;br /&gt;
&lt;br /&gt;
In Config part:&lt;br /&gt;
# Choose Enable for Network flash over Lan&lt;br /&gt;
&lt;br /&gt;
* Second, download the newest version of BIOS update and ECP update &lt;br /&gt;
Running: The program extract all files to the folder. There is a .img file (1QUJ19US.IMG, 1QUJ08US.IMG) in each folder.&lt;br /&gt;
Copy the imformation content in that img file and paste it to one FAT partition(using winimage or TotalCmd to extract) &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
as seen All files in 1QUJ19US.IMG is extracted to D:\BIOS&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
695,764  $018E000.FL1&lt;br /&gt;
163      0691.HSH&lt;br /&gt;
2,049    0691.PAT&lt;br /&gt;
163      0694.HSH&lt;br /&gt;
2,049    0694.PAT&lt;br /&gt;
163      0695.HSH&lt;br /&gt;
2,049    0695.PAT&lt;br /&gt;
2,049    06D0.PAT&lt;br /&gt;
163      06D1.HSH&lt;br /&gt;
2,049    06D1.PAT&lt;br /&gt;
163      06D2.HSH&lt;br /&gt;
2,049    06D2.PAT&lt;br /&gt;
163      06D6.HSH&lt;br /&gt;
2,049    06D6.PAT&lt;br /&gt;
2,049    06D8.PAT&lt;br /&gt;
697      CHKBMP.EXE&lt;br /&gt;
8,128    COMMAND.COM&lt;br /&gt;
26       CONFIG.SYS&lt;br /&gt;
24,860   FLASH2.EXE&lt;br /&gt;
26       LCREFLSH.BAT&lt;br /&gt;
170      LOGO.BAT&lt;br /&gt;
330      LOGO.SCR&lt;br /&gt;
111,925  PHLASH16.EXE&lt;br /&gt;
91,648   PREPARE.EXE&lt;br /&gt;
45       PROD.DAT&lt;br /&gt;
22,252   QKFLASH.EXE&lt;br /&gt;
9,923    README.TXT&lt;br /&gt;
4,260    TPCHKS.EXE&lt;br /&gt;
39,666   UPDTFLSH.EXE&lt;br /&gt;
6,958    UPDTMN.EXE&lt;br /&gt;
12,501   USERINT.EXE&lt;br /&gt;
15,254   UTILINFO.EXE&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
And all files in 1QUJ08US.IMG are: D:\ECP&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
315,404 $018E000.FL2&lt;br /&gt;
8,000   COMMAND.COM&lt;br /&gt;
36      CONFIG.SYS&lt;br /&gt;
16,910  ECFLASH2.EXE&lt;br /&gt;
45      PROD.DAT&lt;br /&gt;
17,812  QKFLASH.EXE&lt;br /&gt;
990     README.TXT&lt;br /&gt;
4,260   TPCHKS.EXE&lt;br /&gt;
89,738  UPDTEC.EXE&lt;br /&gt;
31,134  UPDTFLSH.EXE&lt;br /&gt;
12,501  USERINT.EXE&lt;br /&gt;
15,226  UTILINFO.EXE&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
* Okie, now plug AC Adapter, charge full battery to your laptop and continue third step:&lt;br /&gt;
&lt;br /&gt;
** '''Flash BIOS first,'''&lt;br /&gt;
1. Power On, press blue button on keyboard: '''Access IBM'''&lt;br /&gt;
&lt;br /&gt;
2. On &amp;quot;Utilities&amp;quot;, double click &amp;quot; Diagnostic disk&amp;quot;&lt;br /&gt;
&lt;br /&gt;
3. Your laptop will start PC-DOS, wait when this message appear:&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
Please insert the first floppy diskette and&lt;br /&gt;
Press any key to continue&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
4. Press Ctrl + Break, you will see :&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;Terminate batch job (Y/N) ?&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
5. Okie, press Y, you will get DOS prompt like D:\&lt;br /&gt;
{{NOTE|D:\ is my RAMDISK, C:\ is my disk format as FAT.!}}&lt;br /&gt;
&lt;br /&gt;
6. Enter to c:\BIOS&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
c:&lt;br /&gt;
cd c:\BIOS&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
7. Run FLASH2.EXE /u $018E000.FL1&lt;br /&gt;
&lt;br /&gt;
8. Wait flash progress compelete and reboot.&lt;br /&gt;
** '''Flash ECP'''&lt;br /&gt;
Follow above instruction from step 1 to 5&lt;br /&gt;
&lt;br /&gt;
6. Enter to c:\ECP&lt;br /&gt;
&amp;lt;blockquote style=&amp;quot;background: white; border: 1px solid black; padding: 1em;&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;pre&amp;gt;&amp;lt;nowiki&amp;gt;&lt;br /&gt;
c:&lt;br /&gt;
cd c:\ECP&lt;br /&gt;
&amp;lt;/nowiki&amp;gt;&amp;lt;/pre&amp;gt;&amp;lt;/blockquote&amp;gt;&lt;br /&gt;
&lt;br /&gt;
7. run UPDTFLSH.EXE $018E000.FL2&lt;br /&gt;
&lt;br /&gt;
8. Follow UPDTFLSH's instructions&lt;br /&gt;
&lt;br /&gt;
9. Wait flash complete and auto turn off computer.&lt;br /&gt;
&lt;br /&gt;
I done it on my IBM Thinkpad X31.&lt;br /&gt;
&lt;br /&gt;
Enjoy,&lt;br /&gt;
&lt;br /&gt;
Tested by nm.&lt;br /&gt;
&lt;br /&gt;
==Check List==&lt;br /&gt;
&lt;br /&gt;
The following is important to remember:&lt;br /&gt;
# 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)&lt;br /&gt;
# 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.&lt;br /&gt;
# You must update the Control Program '''before''' you update the BIOS&lt;br /&gt;
&lt;br /&gt;
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.&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Problems_with_ACPI_suspend-to-ram&amp;diff=24136</id>
		<title>Problems with ACPI suspend-to-ram</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Problems_with_ACPI_suspend-to-ram&amp;diff=24136"/>
		<updated>2006-08-15T16:28:04Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: /* Troubles on resume */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;The following glitches may or may not occur in relation to suspending to RAM:&lt;br /&gt;
&lt;br /&gt;
==Troubles on suspend==&lt;br /&gt;
;Permissions:If your suspend is failing, and a {{cmdroot|tail /var/log/acpid}} shows &amp;quot;Permission denied&amp;quot; errors, be sure that your new ACPI event and action scripts have the appropriate permissions.&lt;br /&gt;
&lt;br /&gt;
;Broken sysfs interface:You may experience problems when using {{cmdroot|echo standby &amp;gt; /sys/power/state}} or {{cmdroot|echo mem &amp;gt; /sys/power/state}} (machine goes to sleep and wakes up immediately). This can be avoided by using {{cmdroot|echo -n 3 &amp;gt;/proc/acpi/sleep}} to get it to sleep. This can be also happen if hotplug daemon is still running.&lt;br /&gt;
&lt;br /&gt;
;Hangs on &amp;quot;switching to UP code&amp;quot;:You may be using a [[How to make use of Dynamic Frequency Scaling|frequency scaling governor]] such as &amp;quot;conservative&amp;quot; or &amp;quot;ondemand&amp;quot;, which sometimes have problems with suspending. Switching to a governor such as &amp;quot;powersave&amp;quot; or &amp;quot;performance&amp;quot; before suspending may solve this problem.&lt;br /&gt;
&lt;br /&gt;
;MySQL daemon running:If you're running MySQL, sleep may also not work, so stop MySQL first, then sleep. Remember to restart MySQL when you wakeup.&lt;br /&gt;
&lt;br /&gt;
;LCD backlight remains on during sleep:When your system is equiped with a Radeon Mobility graphic controller your [[Problem with LCD backlight remaining on during ACPI sleep|LCD backlight may not turn off automatically]]. Use [[radeontool]] to switch off your backlight prior suspend in your sleep action script.&lt;br /&gt;
&lt;br /&gt;
;High power drain during sleep:Also, you might want to take note of the [[Problem with high power drain in ACPI sleep]].&lt;br /&gt;
&lt;br /&gt;
==Troubles on resume==&lt;br /&gt;
;Blank display on resume:When resuming from a suspend-to-ram the display might remain black or might only show the pre-suspend output (the system is still rebootable via {{key|ctrl}}{{key|alt}}{{key|del}}). See [[Problem with display remaining black after resume]] for solutions.&lt;br /&gt;
;Garbage on text consoles on resume:When resuming from suspend-to-ram the text console displays may show garbage instead of actual text. The machine is otherwise still responsive and X displays fine. If all of this is true, then adding the kernel option '''acpi_sleep=s3_bios,s3_mode''' in your menu.lst or lilo.conf may solve the problem.&lt;br /&gt;
;Broken hardware support after resume:&lt;br /&gt;
:*The '''serial port''' of the port replicator might not work after resume.&lt;br /&gt;
:*The '''parallel port''' might not work after resume. A possible fix is to unload and reload the parallel port drivers: {{cmdroot|rmmod lp parport_pc parport; modprobe lp}}.&lt;br /&gt;
:*Problems with the '''CD-RW/DVD drive''' after wake up from ram have been experienced.&lt;br /&gt;
:*There is a known Problem regarding '''battery info''' after suspend to RAM. A [http://www.ussg.iu.edu/hypermail/linux/kernel/0511.0/2429.html small patch] exists for kernels 2.6.14/2.6.15.&lt;br /&gt;
:*On {{X20}} and {{X21}} (and possibly other) models, the '''sleep LED''' is not reset properly on resume and will keep blinking. If you have the [[ibm-acpi]] kernel module loaded with the &amp;lt;tt&amp;gt;experimental=1&amp;lt;/tt&amp;gt; option, you can switch it off on resume by appending the following line to your suspend script:&lt;br /&gt;
 echo 7 off &amp;gt; /proc/acpi/ibm/led&lt;br /&gt;
&lt;br /&gt;
;Crash on resume:&lt;br /&gt;
:*When using '''older ATI proprietary drivers''' a crash on resume can be solved by using [http://freshmeat.net/projects/vbetool/ vbetool]. See the example suspend script [[Problem with display remaining black after resume#Solution for ThinkPads with Intel I830 Chipset]]. This is no longer necessary with recent revisions of the ATI proprietary driver.&lt;br /&gt;
:*A crash could also be caused by having '''apic support''' enabled in the kernel config. Try disabling it (in the &amp;quot;Processor type and features&amp;quot; section).&lt;br /&gt;
:*On machines with Savage chipsets, the '''savagefb framebuffer driver''' might crash the machine on resume. Make sure it is disabled in your kernel config and use the standard vesafb driver instead.&lt;br /&gt;
:*Sonoma chipset based laptops ({{R52}}, {{T43}}, {{T43p}}, {{X41}}, {{X41T}}) utilize the '''SATA layer for disk access''' and SATA does not have power-management support yet. Suspend to RAM crashes these machines on resume. See the [[Problems with SATA and Linux#Hang on resume from suspend to RAM|relevant section]] on the [[Problems with SATA and Linux]] page.&lt;br /&gt;
:*When system resumes it hangs right after restarting tasks. This may be fixed by passing ec_intr=0 on kernel cmdline.&lt;br /&gt;
;Shutdown on resume:&lt;br /&gt;
:If your system immediately begins to shut down right after resume, make sure you don't have acpid running with the power button tied to shutdown. The system is simply sensing the power button event and shutting down.  This issue has been reported as a bug against the kernel ACPI subsystem, refer to [http://bugzilla.kernel.org/show_bug.cgi?id=6612 kernel.org bugzilla bug #6612].&lt;br /&gt;
&lt;br /&gt;
;Immediate suspend on resume:&lt;br /&gt;
:When running GNOME, sometimes gnome-power-manager will put the system back into suspend immediately after resuming.  This is caused by a known bug in HAL that causes some ACPI events to be reported incorrectly after a suspend-to-ram.  A simple workaround can be found [http://live.gnome.org/GnomePowerManager/Faq#head-b8b1280115b0a51c2cc27b13a57121130ebf36cb here].&lt;br /&gt;
:Note that suspend being triggered by unrelated ACPI events such as disconnecting the AC adapter may also be fixed by the above method.&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:Problems_with_ACPI_suspend-to-ram&amp;diff=23990</id>
		<title>Talk:Problems with ACPI suspend-to-ram</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:Problems_with_ACPI_suspend-to-ram&amp;diff=23990"/>
		<updated>2006-08-05T05:02:05Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;After a few resumes with my T43, I get &amp;quot;big green boxes&amp;quot; on my consoles tty1 and tty2.&lt;br /&gt;
tyy3 to tty6 stays completly black (there should be login prompt).&lt;br /&gt;
But X still working fine.&lt;br /&gt;
&lt;br /&gt;
This is a minor issue, but anyone with the same problem and a fix/workaround?&lt;br /&gt;
&lt;br /&gt;
--[[User:Defiant|Defiant]] 13:40, 02 Jun 2006 (CEST)&lt;br /&gt;
----&lt;br /&gt;
I have a similar issue on my T60. It seems like the problem is with the framebuffer; that the card is attempting to use the lowest resolution possible when I have the framebuffer set much higher, but that's just my intuition. I'm using hibernate with both &amp;lt;code&amp;gt;EnableVbetool&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;VbetoolPost&amp;lt;/code&amp;gt; set to &amp;lt;code&amp;gt;yes&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
An interesting thing is that if I manually call hibernate from an xterm inside X, I get no negative effects. It even fixes the console &amp;quot;big green boxes&amp;quot; if I previously suspended not in X. Also, on resume I see the following messages on the xterm (all previous output is cleared):&lt;br /&gt;
&lt;br /&gt;
  Allocated buffer at 0x11010 (base is 0x0)&lt;br /&gt;
  ES: 0x1101 EBX: 0x0000&lt;br /&gt;
  Calling INT 0x15 (F000: 5E79)&lt;br /&gt;
   EAX is 0x1005F08&lt;br /&gt;
  Calling INT 0x15 (F000: 5E79)&lt;br /&gt;
   EAX is 0x1005F08&lt;br /&gt;
  Calling INT 0x15 (F000: 5E79)&lt;br /&gt;
   EAX is 0x5F08&lt;br /&gt;
  Calling INT 0x15 (F000: 5E79)&lt;br /&gt;
   EAX is 0x5F08&lt;br /&gt;
  Calling INT 0x15 (F000: 5E79)&lt;br /&gt;
   EAX is 0x45F08&lt;br /&gt;
  Function not supported&lt;br /&gt;
&lt;br /&gt;
Any ideas?&lt;br /&gt;
&lt;br /&gt;
-- [[User:Deason|Deason]] 05:39, 14 July 2006 (CEST)&lt;br /&gt;
----&lt;br /&gt;
Just to update/confirm: suspend to RAM only works if I have X running, and I switch to the console running X after resuming. Editing the ACPI sleep script to switch to vt 7 before switching back to the original console seems to work fine, though. It just means that I can't suspend to RAM if I'm not running X. (Putting a check for that in the ACPI sleep script would also be a good idea.) I've tried using &amp;lt;code&amp;gt;EnableVbetool&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;VbetoolPost&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;RestoreVCSAData&amp;lt;/code&amp;gt;, and &amp;lt;code&amp;gt;RestoreVbeStateFrom&amp;lt;/code&amp;gt; from hiberante, but none seem to solve this without switching to X.&lt;br /&gt;
&lt;br /&gt;
-- [[User:Deason|Deason]] 21:48, 16 July 2006 (CEST)&lt;br /&gt;
----&lt;br /&gt;
Yes it's the vga framebuffer freaking out at you. Try adding '''acpi_sleep=s3_bios,s3_mode''' kernel option to /boot/grub/menu.lst&lt;br /&gt;
&lt;br /&gt;
The s3_mode part fixed the green boxes for me. (debian testing, kernel 2.6.16, TP x41)&lt;br /&gt;
&lt;br /&gt;
--[[User:Ladoga|Ladoga]] 06:46, 5 August 2006 (CEST)&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
	<entry>
		<id>https://www.thinkwiki.org/w/index.php?title=Talk:Problems_with_ACPI_suspend-to-ram&amp;diff=23989</id>
		<title>Talk:Problems with ACPI suspend-to-ram</title>
		<link rel="alternate" type="text/html" href="https://www.thinkwiki.org/w/index.php?title=Talk:Problems_with_ACPI_suspend-to-ram&amp;diff=23989"/>
		<updated>2006-08-05T04:46:25Z</updated>

		<summary type="html">&lt;p&gt;Ladoga: Fix for garbled framebuffer console.&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;After a few resumes with my T43, I get &amp;quot;big green boxes&amp;quot; on my consoles tty1 and tty2.&lt;br /&gt;
tyy3 to tty6 stays completly black (there should be login prompt).&lt;br /&gt;
But X still working fine.&lt;br /&gt;
&lt;br /&gt;
This is a minor issue, but anyone with the same problem and a fix/workaround?&lt;br /&gt;
&lt;br /&gt;
--[[User:Defiant|Defiant]] 13:40, 02 Jun 2006 (CEST)&lt;br /&gt;
----&lt;br /&gt;
I have a similar issue on my T60. It seems like the problem is with the framebuffer; that the card is attempting to use the lowest resolution possible when I have the framebuffer set much higher, but that's just my intuition. I'm using hibernate with both &amp;lt;code&amp;gt;EnableVbetool&amp;lt;/code&amp;gt; and &amp;lt;code&amp;gt;VbetoolPost&amp;lt;/code&amp;gt; set to &amp;lt;code&amp;gt;yes&amp;lt;/code&amp;gt;.&lt;br /&gt;
&lt;br /&gt;
An interesting thing is that if I manually call hibernate from an xterm inside X, I get no negative effects. It even fixes the console &amp;quot;big green boxes&amp;quot; if I previously suspended not in X. Also, on resume I see the following messages on the xterm (all previous output is cleared):&lt;br /&gt;
&lt;br /&gt;
  Allocated buffer at 0x11010 (base is 0x0)&lt;br /&gt;
  ES: 0x1101 EBX: 0x0000&lt;br /&gt;
  Calling INT 0x15 (F000: 5E79)&lt;br /&gt;
   EAX is 0x1005F08&lt;br /&gt;
  Calling INT 0x15 (F000: 5E79)&lt;br /&gt;
   EAX is 0x1005F08&lt;br /&gt;
  Calling INT 0x15 (F000: 5E79)&lt;br /&gt;
   EAX is 0x5F08&lt;br /&gt;
  Calling INT 0x15 (F000: 5E79)&lt;br /&gt;
   EAX is 0x5F08&lt;br /&gt;
  Calling INT 0x15 (F000: 5E79)&lt;br /&gt;
   EAX is 0x45F08&lt;br /&gt;
  Function not supported&lt;br /&gt;
&lt;br /&gt;
Any ideas?&lt;br /&gt;
&lt;br /&gt;
-- [[User:Deason|Deason]] 05:39, 14 July 2006 (CEST)&lt;br /&gt;
----&lt;br /&gt;
Just to update/confirm: suspend to RAM only works if I have X running, and I switch to the console running X after resuming. Editing the ACPI sleep script to switch to vt 7 before switching back to the original console seems to work fine, though. It just means that I can't suspend to RAM if I'm not running X. (Putting a check for that in the ACPI sleep script would also be a good idea.) I've tried using &amp;lt;code&amp;gt;EnableVbetool&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;VbetoolPost&amp;lt;/code&amp;gt;, &amp;lt;code&amp;gt;RestoreVCSAData&amp;lt;/code&amp;gt;, and &amp;lt;code&amp;gt;RestoreVbeStateFrom&amp;lt;/code&amp;gt; from hiberante, but none seem to solve this without switching to X.&lt;br /&gt;
&lt;br /&gt;
-- [[User:Deason|Deason]] 21:48, 16 July 2006 (CEST)&lt;br /&gt;
&lt;br /&gt;
== Fix for garbled framebuffer console. ==&lt;br /&gt;
&lt;br /&gt;
try to add following kernel option to /boot/grub/menu.lst&lt;br /&gt;
&lt;br /&gt;
'''acpi_sleep=s3_bios,s3_mode'''&lt;br /&gt;
&lt;br /&gt;
i think the s3_mode fixed the green boxes for me. (kernel 2.6.16)&lt;br /&gt;
--[[User:Ladoga|Ladoga]] 06:46, 5 August 2006 (CEST)&lt;/div&gt;</summary>
		<author><name>Ladoga</name></author>
		
	</entry>
</feed>