Page 1 of 1
Plug into BIOS to do some pre OS tasks
Posted: Wed Jun 13, 2012 12:17 pm
by bbrar
Hi, does anyone have suggestions on how and whether it is possible to plug into an existing BIOS OR get the BIOS to launch some custom code ( that does /modifies bus enumerations , memory range etc)? This has to be done prior to the OS booting...
Re: Plug into BIOS to do some pre OS tasks
Posted: Wed Jun 13, 2012 12:27 pm
by Griwes
Re: Plug into BIOS to do some pre OS tasks
Posted: Thu Jun 14, 2012 4:00 pm
by Nessphoro
Bios hijacking (AKA running code before BIOS):
The Intel ICHx series South Bridge (since ICH2) supports a
“Top-Block Swap” mode that has the ICHx swap the top block in
the Firmware Hub (the Boot Block) with another location, which
allows for safe update of the Boot Block even when a power
failure occurs. When the “TOP_SWAP” Enable bit (BUC.TS) is set,
the ICHx will invert the 16th bit of address line A16 for
cycles targeting Firmware Hub space, in this way processor
accesses to 0xFFFF0000~0xFFFFFFFF will be directed to
0xFFFE0000~0xFFFEFFFF in the Firmware Hub, and vice versa, and
this bit can only be cleared by a RTCRST# (Real Time Clock
Reset Signal). Moreover ICHx also provides a BIOS Interface
Lock-Down bit (GCS.BILD) to prevent “TOP_SWAP” bit from being
altered, and a Top Swap Status bit (BIOS_CNTL.TSS) as well to
view the current status of Top Swap bit.
So,
1. Software copies the top block to the block immediately below the top.
2. Software checks that the copied block is correct. This could be done by
performing a checksum calculation.
3. Software sets the TOP_SWAP bit, enable the A16 address bit inversion.
4. Software erases the top block.
5. Software writes the new top block.
6. Software checks the new top block.
7. Software clears the TOP_SWAP bit.
8. Software sets the Top_Swap Lock-Down bit.